-
Notifications
You must be signed in to change notification settings - Fork 67
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add tubes for rendering streamlines (#1239)
* add tubes for rendering streamlines * add seed population options
- Loading branch information
1 parent
6e6a70b
commit e3e4732
Showing
33 changed files
with
2,207 additions
and
128 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -14,9 +14,12 @@ and this project aspires to adhere to [Semantic Versioning](https://semver.org/s | |
- Added parameters to control HDF5 compression options to the Relay Extract. | ||
- Added check to make sure all domain IDs are unique | ||
- Added a `vtk` extract that saves each mesh domain to a legacy vtk file grouped, with all domain data grouped by a `.visit` file. | ||
- Added WarpX Streamline filter that uses charged particles. | ||
- Added seed population options for particle advection: point, point list, line, and box | ||
|
||
### Changed | ||
- Changed the Data Binning filter to accept a `reduction_field` parameter (instead of `var`), and similarly the axis parameters to take `field` (instead of `var`). The `var` style parameters are still accepted, but deprecated and will be removed in a future release. | ||
- Changed the Streamline and WarpXStreamline filters to apply the VTK-m Tube filter to their outputs, allowing for the results to be rendered. | ||
|
||
## [0.9.2] - Released 2023-06-30 | ||
### Preferred dependency versions for [email protected] | ||
|
156 changes: 156 additions & 0 deletions
156
install/examples/ascent/tutorial/ascent_intro/cpp/ascent_tutorial_cpp_utils.hpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,156 @@ | ||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~// | ||
// Copyright (c) Lawrence Livermore National Security, LLC and other Ascent | ||
// Project developers. See top-level LICENSE AND COPYRIGHT files for dates and | ||
// other details. No copyright assignment is required to contribute to Ascent. | ||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~// | ||
|
||
//----------------------------------------------------------------------------- | ||
/// | ||
/// file: ascent_tutorial_cpp_utils.hpp | ||
/// | ||
//----------------------------------------------------------------------------- | ||
|
||
#ifndef ASCENT_TUTORIAL_CPP_UTILS_H | ||
#define ASCENT_TUTORIAL_CPP_UTILS_H | ||
|
||
#include <iostream> | ||
#include "conduit_blueprint.hpp" | ||
|
||
#include <math.h> | ||
|
||
using namespace conduit; | ||
|
||
const float64 PI_VALUE = 3.14159265359; | ||
|
||
// --------------------------------------------------------------------------// | ||
void | ||
tutorial_tets_example(Node &mesh) | ||
{ | ||
mesh.reset(); | ||
|
||
// | ||
// (create example tet mesh from blueprint example 2) | ||
// | ||
// Create a 3D mesh defined on an explicit set of points, | ||
// composed of two tets, with two element associated fields | ||
// (`var1` and `var2`) | ||
// | ||
|
||
// create an explicit coordinate set | ||
double X[5] = { -1.0, 0.0, 0.0, 0.0, 1.0 }; | ||
double Y[5] = { 0.0, -1.0, 0.0, 1.0, 0.0 }; | ||
double Z[5] = { 0.0, 0.0, 1.0, 0.0, 0.0 }; | ||
mesh["coordsets/coords/type"] = "explicit"; | ||
mesh["coordsets/coords/values/x"].set(X, 5); | ||
mesh["coordsets/coords/values/y"].set(Y, 5); | ||
mesh["coordsets/coords/values/z"].set(Z, 5); | ||
|
||
|
||
// add an unstructured topology | ||
mesh["topologies/mesh/type"] = "unstructured"; | ||
// reference the coordinate set by name | ||
mesh["topologies/mesh/coordset"] = "coords"; | ||
// set topology shape type | ||
mesh["topologies/mesh/elements/shape"] = "tet"; | ||
// add a connectivity array for the tets | ||
int64 connectivity[8] = { 0, 1, 3, 2, 4, 3, 1, 2 }; | ||
mesh["topologies/mesh/elements/connectivity"].set(connectivity, 8); | ||
|
||
const int num_elements = 2; | ||
float var1_vals[num_elements] = { 0, 1 }; | ||
float var2_vals[num_elements] = { 1, 0 }; | ||
|
||
// create a field named var1 | ||
mesh["fields/var1/association"] = "element"; | ||
mesh["fields/var1/topology"] = "mesh"; | ||
mesh["fields/var1/values"].set(var1_vals, 2); | ||
|
||
// create a field named var2 | ||
mesh["fields/var2/association"] = "element"; | ||
mesh["fields/var2/topology"] = "mesh"; | ||
mesh["fields/var2/values"].set(var2_vals, 2); | ||
|
||
// make sure the mesh we created conforms to the blueprint | ||
Node verify_info; | ||
if(!blueprint::mesh::verify(mesh, verify_info)) | ||
{ | ||
std::cout << "Mesh Verify failed!" << std::endl; | ||
std::cout << verify_info.to_yaml() << std::endl; | ||
} | ||
} | ||
|
||
// --------------------------------------------------------------------------// | ||
void | ||
tutorial_gyre_example(float64 time_value, Node &mesh) | ||
{ | ||
mesh.reset(); | ||
int xy_dims = 40; | ||
int z_dims = 2; | ||
|
||
conduit::blueprint::mesh::examples::braid("hexs", | ||
xy_dims, | ||
xy_dims, | ||
z_dims, | ||
mesh); | ||
|
||
mesh["state/time"] = time_value; | ||
Node &field = mesh["fields/gyre"]; | ||
field["association"] = "vertex"; | ||
field["topology"] = "mesh"; | ||
field["values"].set(DataType::float64(xy_dims*xy_dims*z_dims)); | ||
|
||
Node &vec_field = mesh["fields/gyre_vel"]; | ||
vec_field["association"] = "vertex"; | ||
vec_field["topology"] = "mesh"; | ||
vec_field["values/u"].set(DataType::float64(xy_dims*xy_dims*z_dims)); | ||
vec_field["values/v"].set(DataType::float64(xy_dims*xy_dims*z_dims)); | ||
vec_field["values/w"].set(DataType::float64(xy_dims*xy_dims*z_dims)); | ||
|
||
float64 *values_ptr = field["values"].value(); | ||
float64 *u_values_ptr = vec_field["values/u"].value(); | ||
float64 *v_values_ptr = vec_field["values/v"].value(); | ||
float64 *w_values_ptr = vec_field["values/w"].value(); | ||
|
||
float64 e = 0.25; | ||
float64 A = 0.1; | ||
float64 w = (2.0 * PI_VALUE) / 10.0; | ||
float64 a_t = e * sin(w * time_value); | ||
float64 b_t = 1.0 - 2 * e * sin(w * time_value); | ||
// print("e: " + str(e) + " A " + str(A) + " w " + str(w) + " a_t " + str(a_t) + " b_t " + str(b_t)) | ||
// print(b_t) | ||
// print(w) | ||
int idx = 0; | ||
for (int z=0; z < z_dims; z++) | ||
{ | ||
for (int y=0; y < xy_dims; y++) | ||
{ | ||
// scale y to 0-1 | ||
float64 y_n = float64(y)/float64(xy_dims); | ||
float64 y_t = sin(PI_VALUE * y_n); | ||
for (int x=0; x < xy_dims; x++) | ||
{ | ||
// scale x to 0-1 | ||
float64 x_f = float(x)/ (float(xy_dims) * .5); | ||
float64 f_t = a_t * x_f * x_f + b_t * x_f; | ||
// print(f_t) | ||
float64 value = A * sin(PI_VALUE * f_t) * y_t; | ||
float64 u = -PI_VALUE * A * sin(PI_VALUE * f_t) * cos(PI_VALUE * y_n); | ||
float64 df_dx = 2.0 * a_t + b_t; | ||
// print("df_dx " + str(df_dx)) | ||
float64 v = PI_VALUE * A * cos(PI_VALUE * f_t) * sin(PI_VALUE * y_n) * df_dx; | ||
values_ptr[idx] = sqrt(u * u + v * v); | ||
u_values_ptr[idx] = u; | ||
v_values_ptr[idx] = v; | ||
w_values_ptr[idx] = 0; | ||
// values[idx] = u * u + v * v | ||
// values[idx] = value | ||
// print("u " + str(u) + " v " + str(v) + " mag " + str(math.sqrt(u * u + v * v))) | ||
idx++; | ||
} | ||
} | ||
} | ||
|
||
//print(values) | ||
} | ||
|
||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.