![]() |
PeriDyno 1.0.0
|
#include <SemiAnalyticalParticleShifting.h>
Public Types | |
typedef TDataType::Real | Real |
typedef TDataType::Coord | Coord |
typedef TopologyModule::Triangle | Triangle |
![]() | |
typedef TDataType::Real | Real |
![]() | |
typedef std::vector< FBase * > | FieldVector |
typedef std::map< FieldID, FBase * > | FieldMap |
Public Member Functions | |
SemiAnalyticalParticleShifting () | |
~SemiAnalyticalParticleShifting () override | |
DEF_VAR (uint, InterationNumber, 10, "") | |
DEF_VAR (Real, Inertia, Real(0.1), "inertia") | |
DEF_VAR (Real, Bulk, Real(0.5), "bulk") | |
DEF_VAR (Real, SurfaceTension, Real(0.03), "surface tension") | |
DEF_VAR (Real, AdhesionIntensity, Real(30.0), "adhesion") | |
DEF_VAR (Real, RestDensity, Real(1000.0), "Rest Density") | |
DEF_VAR_IN (Real, TimeStep, "Time step size") | |
DEF_ARRAY_IN (Coord, Position, DeviceType::GPU, "Particle position") | |
DEF_ARRAY_IN (Coord, Velocity, DeviceType::GPU, "Particle velocity") | |
DEF_ARRAYLIST_IN (int, NeighborIds, DeviceType::GPU, "") | |
DEF_ARRAYLIST_IN (int, NeighborTriIds, DeviceType::GPU, "triangle neighbors") | |
DEF_INSTANCE_IN (TriangleSet< TDataType >, TriangleSet, "") | |
![]() | |
ParticleApproximation () | |
virtual | ~ParticleApproximation () |
DECLARE_ENUM (EKernelType, KT_Smooth=0, KT_Spiky=1) | |
DEF_VAR_IN (Real, SmoothingLength, "Smoothing Length") | |
DEF_VAR_IN (Real, SamplingDistance, "Particle sampling distance") | |
DEF_ENUM (EKernelType, KernelType, EKernelType::KT_Spiky, "Rendering mode") | |
![]() | |
ComputeModule () | |
~ComputeModule () override | |
std::string | getModuleType () override |
![]() | |
Module (std::string name="default") | |
~Module (void) override | |
bool | initialize () |
void | update () |
void | setName (std::string name) |
std::string | getName () override |
virtual void | setParentNode (Node *node) |
Set the parent node. | |
Node * | getParentNode () |
SceneGraph * | getSceneGraph () |
bool | isInitialized () |
bool | attachField (FBase *field, std::string name, std::string desc, bool autoDestroy=true) override |
Attach a field to Base. | |
bool | isInputComplete () |
Check the completeness of input fields. | |
bool | isOutputCompete () |
DEF_VAR (bool, ForceUpdate, false, "") | |
void | setUpdateAlways (bool b) |
Set the update strategy for the module. | |
![]() | |
OBase () | |
~OBase () override | |
virtual std::string | caption () |
Return the caption. | |
virtual bool | captionVisible () |
Whether to hide the caption in the GUI. | |
virtual std::string | description () |
Return a description for the node or module, override this function to support user-defined description. | |
bool | addField (FBase *data) |
Add a field to Base FieldID will be set to the name of Field by default. | |
bool | addField (FieldID name, FBase *data) |
Add a field to Base. | |
bool | addFieldAlias (FieldID name, FBase *data) |
bool | addFieldAlias (FieldID name, FBase *data, FieldMap &fieldAlias) |
bool | findField (FBase *data) |
Find a field by its pointer. | |
bool | findFieldAlias (const FieldID name) |
Find a field by its name. | |
bool | findFieldAlias (const FieldID name, FieldMap &fieldAlias) |
Find a field in fieldAlias by its name This function is typically called by other functions. | |
bool | removeField (FBase *data) |
Remove a field by its pointer. | |
bool | removeFieldAlias (const FieldID name) |
Remove a field by its name. | |
bool | removeFieldAlias (const FieldID name, FieldMap &fieldAlias) |
FBase * | getField (const FieldID name) |
Return a field by its name. | |
std::vector< FBase * > & | getAllFields () |
template<typename T> | |
T * | getField (FieldID name) |
bool | isAllFieldsReady () |
Check the completeness of all required fields. | |
std::vector< FieldID > | getFieldAlias (FBase *data) |
int | getFieldAliasCount (FBase *data) |
void | setBlockCoord (float x, float y) |
float | bx () |
float | by () |
bool | findInputField (FBase *field) |
bool | addInputField (FBase *field) |
bool | removeInputField (FBase *field) |
std::vector< FBase * > & | getInputFields () |
bool | findOutputField (FBase *field) |
bool | addOutputField (FBase *field) |
bool | addToOutput (FBase *field) |
bool | removeOutputField (FBase *field) |
bool | removeFromOutput (FBase *field) |
std::vector< FBase * > & | getOutputFields () |
bool | findParameter (FBase *field) |
bool | addParameter (FBase *field) |
bool | removeParameter (FBase *field) |
std::vector< FBase * > & | getParameters () |
![]() | |
Object () | |
virtual | ~Object () |
ObjectId | objectId () |
Protected Member Functions | |
void | compute () override |
![]() | |
virtual bool | initializeImpl () |
virtual void | preprocess () |
virtual void | postprocess () |
virtual bool | validateInputs () |
virtual bool | validateOutputs () |
virtual bool | requireUpdate () |
virtual void | updateStarted () |
Two functions called at the beginning and end of update() used for debug. | |
virtual void | updateEnded () |
Private Attributes | |
DArray< Real > | mLambda |
DArray< Real > | mTotalW |
DArray< Coord > | mBoundaryDir |
DArray< Real > | mBoundaryDis |
DArray< Coord > | mDeltaPos |
DArray< Coord > | mPosBuf |
DArray< Coord > | mAdhesionEP |
std::shared_ptr< SemiAnalyticalSummationDensity< TDataType > > | mCalculateDensity |
Additional Inherited Members | |
![]() | |
static bool | registerClass (ClassInfo *ci) |
static Object * | createObject (std::string name) |
static std::map< std::string, ClassInfo * > * | getClassMap () |
static ObjectId | baseId () |
Base Id. | |
![]() | |
Real | mScalingFactor = Real(1) |
![]() | |
std::vector< FBase * > | fields_input |
std::vector< FBase * > | fields_output |
std::vector< FBase * > | fields_param |
Definition at line 33 of file SemiAnalyticalParticleShifting.h.
typedef TDataType::Coord dyno::SemiAnalyticalParticleShifting< TDataType >::Coord |
Definition at line 38 of file SemiAnalyticalParticleShifting.h.
typedef TDataType::Real dyno::SemiAnalyticalParticleShifting< TDataType >::Real |
Definition at line 37 of file SemiAnalyticalParticleShifting.h.
typedef TopologyModule::Triangle dyno::SemiAnalyticalParticleShifting< TDataType >::Triangle |
Definition at line 39 of file SemiAnalyticalParticleShifting.h.
dyno::SemiAnalyticalParticleShifting< TDataType >::SemiAnalyticalParticleShifting | ( | ) |
|
override |
|
overrideprotectedvirtual |
Reimplemented from dyno::ParticleApproximation< TDataType >.
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_ARRAY_IN | ( | Coord | , |
Position | , | ||
DeviceType::GPU | , | ||
"Particle position" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_ARRAY_IN | ( | Coord | , |
Velocity | , | ||
DeviceType::GPU | , | ||
"Particle velocity" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_ARRAYLIST_IN | ( | int | , |
NeighborIds | , | ||
DeviceType::GPU | , | ||
"" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_ARRAYLIST_IN | ( | int | , |
NeighborTriIds | , | ||
DeviceType::GPU | , | ||
"triangle neighbors" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_INSTANCE_IN | ( | TriangleSet< TDataType > | , |
TriangleSet | , | ||
"" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_VAR | ( | Real | , |
AdhesionIntensity | , | ||
Real(30.0) | , | ||
"adhesion" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_VAR | ( | Real | , |
Bulk | , | ||
Real(0.5) | , | ||
"bulk" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_VAR | ( | Real | , |
Inertia | , | ||
Real(0.1) | , | ||
"inertia" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_VAR | ( | Real | , |
RestDensity | , | ||
Real(1000.0) | , | ||
"Rest Density" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_VAR | ( | Real | , |
SurfaceTension | , | ||
Real(0.03) | , | ||
"surface tension" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_VAR | ( | uint | , |
InterationNumber | , | ||
10 | , | ||
"" | ) |
dyno::SemiAnalyticalParticleShifting< TDataType >::DEF_VAR_IN | ( | Real | , |
TimeStep | , | ||
"Time step size" | ) |
|
private |
Definition at line 80 of file SemiAnalyticalParticleShifting.h.
|
private |
Definition at line 76 of file SemiAnalyticalParticleShifting.h.
|
private |
Definition at line 77 of file SemiAnalyticalParticleShifting.h.
|
private |
Definition at line 81 of file SemiAnalyticalParticleShifting.h.
|
private |
Definition at line 78 of file SemiAnalyticalParticleShifting.h.
|
private |
Definition at line 74 of file SemiAnalyticalParticleShifting.h.
|
private |
Definition at line 79 of file SemiAnalyticalParticleShifting.h.
|
private |
Definition at line 75 of file SemiAnalyticalParticleShifting.h.