MPM-Geomechanics
Material Point Method for simulating geo-materials under large deformation conditions
Loading...
Searching...
No Matches
Particle.h
Go to the documentation of this file.
1/*
2 * Particle.h
3 *
4 * Created on: 13 de abr de 2021
5 * Author: Fabricio Fernandez <fabricio.hmf@gmail.com>
6 */
7
8#ifndef PARTICLE_H_
9#define PARTICLE_H_
10
11#include "Eigen/Core"
12using Eigen::Matrix3d;
13using Eigen::Vector3d;
14
15#include "Contribution.h"
16#include "Mesh/Mesh.h"
17#include "Model.h"
18#include "Shape/Shape.h"
19#include "Materials/Material.h"
20
21#include <vector>
22
23class Mesh;
24
29class Particle {
30
31public:
32
37 Particle(const Vector3d& position, Material* material, const Vector3d& size);
38
40 virtual ~Particle();
41
45
48 inline void updateStress() { material->updateStress(this); }
49
52 virtual inline void updatePressure(double dt) { return; }
53
57
60 virtual inline void updatePorosity() { return; }
61
64 inline bool getActive() const { return this->active; }
65
68 inline int getId() const { return this->id; }
69
72 inline int getMaterialId() const { return this->material!=0?this->material->getId():-1; }
73
76 inline int getBodyId() const { return this->bodyId; }
77
80 inline double getMass() const { return this->mass; }
81
84 virtual inline double getMassFluid() const { return 0.0; }
85
88 inline double getDensity() const { return this->density; }
89
92 virtual inline double getDensityFluid() const { return 0.0; }
93
96 virtual inline double getCurrentVolume() const { return this->mass/this->density; }
97
100 inline double getInitialVolume() const { return this->size.x()*this->size.y()*this->size.z(); }
101
104 inline const Vector3d& getPosition() const { return this->position; }
105
108 inline const Vector3d& getInitialPosition() const { return this->initialPosition; }
109
112 inline const Vector3d& getExternalForce() const { return this->externalForce; }
113
116 virtual inline const Vector3d* getExternalForceFluid() const { return NULL; }
117
120 inline const Vector3d& getVelocity() const { return this->velocity; }
121
124 virtual inline const Vector3d* getVelocityFluid() const { return NULL; }
125
128 inline const Matrix3d& getStress() const { return this->stress; }
129
132 inline const Matrix3d& getStrainIncrement() const { return this->strainIncrement; }
133
136 virtual inline const Matrix3d* getStrainIncrementFluid() const { return NULL; }
137
140 inline const Matrix3d& getStrain() const { return this->strain; }
141
144 inline const Matrix3d& getVorticityIncrement() const { return this->vorticityIncrement; }
145
148 inline vector<Contribution>* getContributionNodes() { return &(this->contributionNodes); }
149
152 inline void setActive(bool particle_active) { this->active=particle_active; }
153
156 inline void setId(int particle_id) { this->id=particle_id; }
157
160 inline void setBodyId(int body_id) { this->bodyId=body_id; }
161
164 inline void setMass(double particle_mass) { this->mass=particle_mass; }
165
168 inline void setDensity(double particle_density) { this->density=particle_density; }
169
172 inline void setPosition(const Vector3d& particle_position) { this->position=particle_position; }
173
176 inline void setInitialPosition(const Vector3d& particle_initial_position) { this->initialPosition=particle_initial_position; }
177
180 inline void setSize(const Vector3d& particle_size) { this->size=particle_size; }
181
184 inline const Vector3d& getSize( ) { return this->size; }
185
188 inline void setVelocity(const Vector3d& particle_velocity) { this->velocity = particle_velocity; }
189
192 virtual inline void setVelocityFluid(const Vector3d& particle_velocity_fluid) { return; }
193
196 inline void setStrainIncrement(const Matrix3d& strain_increment) { this->strainIncrement=strain_increment; this->strain+=strain_increment; }
197
200 virtual inline void setStrainIncrementFluid(const Matrix3d& strain_increment) { return; }
201
204 inline void setVorticityIncrement(const Matrix3d& vorticity_increment) { this->vorticityIncrement=vorticity_increment; }
205
208 inline void setStress(const Matrix3d& particle_stress) { this->stress=particle_stress; }
209
213
216 inline void setShape(Shape* shape) { this->shape=shape; }
217
220 inline void addExternalForce(const Vector3d& delta_external_force) { this->externalForce+=delta_external_force; }
221
224 virtual inline void addExternalForceFluid(const Vector3d& delta_external_fluid_force) { return; }
225
228 static int getTotalParticles();
229
232 inline void addPlasticStrain(double deltaPlasticStrain) { this->plasticStrain+=deltaPlasticStrain; }
233
236 inline double getPlasticStrain() const { return this->plasticStrain; }
237
240 virtual inline double getPressureFluid() const { return 0.0; }
241
244 virtual inline void setPressureFluid(double pressure) { return; }
245
248 virtual inline double getPorosity() const { return 0.0; }
249
252 virtual inline double getSaturation() const { return 0.0; }
253
256 virtual inline Vector3d getDragForceFluid() const { return Vector3d::Zero(); }
257
260 inline void setDeformationGradient(const Matrix3d& deformation_gradient) { this->deformationGradient=deformation_gradient; }
261
264 inline const Matrix3d& getDeformationGradient() const { return this->deformationGradient; }
265
266protected:
267
268 bool active;
269 int id;
270 int bodyId;
271
272 double mass;
273 double density;
275
276 Vector3d position;
278 Vector3d velocity;
279 Vector3d externalForce;
280 Vector3d size;
281
282 Matrix3d stress;
283 Matrix3d strain;
287
288 vector<Contribution> contributionNodes;
291
292 static int totalParticles;
293};
294
296
298}
299
301
302 return totalParticles;
303}
304
305#endif /* PARTICLE_H_ */
Represents a material.
Definition Material.h:18
int getId() const
Return the identification.
Definition Material.h:36
virtual void updateStress(Particle *particle) const =0
Update the stress tensor.
Class representing a rectangular grid mesh.
Definition Mesh.h:29
Represents a Lagrangian material point This class contain all Lagrangian variables that represents th...
Definition Particle.h:29
const Matrix3d & getStress() const
Returns the current particle stress tensor.
Definition Particle.h:128
void updateStress()
Update the particle stress.
Definition Particle.h:48
Matrix3d strainIncrement
current particle strain increment:
Definition Particle.h:284
Matrix3d stress
current particle stress:
Definition Particle.h:282
double plasticStrain
current effective plastic strain:
Definition Particle.h:274
void setVorticityIncrement(const Matrix3d &vorticity_increment)
Configures the vorticity increment.
Definition Particle.h:204
Vector3d externalForce
particle external force:
Definition Particle.h:279
Matrix3d deformationGradient
particle deformation gradient:
Definition Particle.h:286
const Matrix3d & getStrain() const
Returns the strain.
Definition Particle.h:140
int getBodyId() const
Returns the particle's body Id.
Definition Particle.h:76
virtual void setPressureFluid(double pressure)
Configure the pressure of fluid.
Definition Particle.h:244
void setActive(bool particle_active)
Configures the particle active status.
Definition Particle.h:152
void setMass(double particle_mass)
Configures particle mass.
Definition Particle.h:164
Material * material
particle material (see class Material)
Definition Particle.h:290
double getDensity() const
Returns the current solid density.
Definition Particle.h:88
void setBodyId(int body_id)
Configures the set particle's body Id.
Definition Particle.h:160
int getMaterialId() const
Returns the particle's material.
Definition Particle.h:72
virtual double getPorosity() const
Returns current porosity.
Definition Particle.h:248
virtual Vector3d getDragForceFluid() const
Returns the drag force of fluid in particle.
Definition Particle.h:256
void setVelocity(const Vector3d &particle_velocity)
Configures particle velocity.
Definition Particle.h:188
const Matrix3d & getStrainIncrement() const
Returns the strain increment.
Definition Particle.h:132
int getId() const
Returns the particle identification.
Definition Particle.h:68
void addPlasticStrain(double deltaPlasticStrain)
Add a plastic strain increment.
Definition Particle.h:232
virtual void setStrainIncrementFluid(const Matrix3d &strain_increment)
Configures the strain increment of fluid phase.
Definition Particle.h:200
void setStrainIncrement(const Matrix3d &strain_increment)
Configures the strain increment.
Definition Particle.h:196
int id
particle id
Definition Particle.h:269
void setStress(const Matrix3d &particle_stress)
Configures the current particle stress tensor.
Definition Particle.h:208
const Vector3d & getVelocity() const
Returns particle velocity.
Definition Particle.h:120
Vector3d position
current particle position:
Definition Particle.h:276
void setInitialPosition(const Vector3d &particle_initial_position)
Configures the initial particle position.
Definition Particle.h:176
void setDensity(double particle_density)
Configures particle density.
Definition Particle.h:168
virtual double getCurrentVolume() const
Returns current particle volume.
Definition Particle.h:96
virtual void updatePorosity()
Update the particle porosity.
Definition Particle.h:60
void updateDensity()
Update the particle density.
Matrix3d vorticityIncrement
particle vorticity increment:
Definition Particle.h:285
bool active
is particle active
Definition Particle.h:268
int bodyId
body id
Definition Particle.h:270
virtual double getSaturation() const
Returns Saturation of fluid in void in mixture.
Definition Particle.h:252
virtual const Vector3d * getExternalForceFluid() const
Returns the external force of fluid in particle.
Definition Particle.h:116
const Matrix3d & getDeformationGradient() const
Returns deformation gradient.
Definition Particle.h:264
virtual double getMassFluid() const
Returns fluid mass in mixture.
Definition Particle.h:84
double density
current particle density:
Definition Particle.h:273
Vector3d initialPosition
particle initial position:
Definition Particle.h:277
double getInitialVolume() const
Returns initial particle volume.
Definition Particle.h:100
Shape * shape
shape functions values (see class Shape)
Definition Particle.h:289
bool getActive() const
Returns the particle active status.
Definition Particle.h:64
void setShape(Shape *shape)
Configures the shape function in the particle.
Definition Particle.h:216
void setId(int particle_id)
Configures the particle id.
Definition Particle.h:156
virtual void setVelocityFluid(const Vector3d &particle_velocity_fluid)
Configures particle velocity of fluid phase.
Definition Particle.h:192
const Matrix3d & getVorticityIncrement() const
Returns the vorticity increment.
Definition Particle.h:144
vector< Contribution > contributionNodes
id of nodes that the particle contributes
Definition Particle.h:288
virtual void addExternalForceFluid(const Vector3d &delta_external_fluid_force)
Adds a external fluid force increment.
Definition Particle.h:224
virtual void updatePressure(double dt)
Update the particle pressure.
Definition Particle.h:52
virtual const Vector3d * getVelocityFluid() const
Returns velocity of fluid.
Definition Particle.h:124
virtual double getPressureFluid() const
Returns pressure of fluid.
Definition Particle.h:240
const Vector3d & getSize()
Return particle size in each direction.
Definition Particle.h:184
virtual const Matrix3d * getStrainIncrementFluid() const
Returns the strain increment of fluid.
Definition Particle.h:136
void updateContributionNodes(Mesh *mesh)
Update the list of nodes that the particle contributes.
void setDeformationGradient(const Matrix3d &deformation_gradient)
Configures deformation gradient.
Definition Particle.h:260
Vector3d size
current size in each direction:
Definition Particle.h:280
Particle(const Vector3d &position, Material *material, const Vector3d &size)
Create a particle.
virtual ~Particle()
Default destructor.
Definition Particle.h:295
double getMass() const
Returns solid mass.
Definition Particle.h:80
Vector3d velocity
current particle velocity:
Definition Particle.h:278
const Vector3d & getExternalForce() const
Returns the external force in particle.
Definition Particle.h:112
virtual void setMaterial(Material *material)
Configures the material in the particle.
const Vector3d & getInitialPosition() const
Returns the initial particle position.
Definition Particle.h:108
void addExternalForce(const Vector3d &delta_external_force)
Adds a external force increment.
Definition Particle.h:220
vector< Contribution > * getContributionNodes()
Returns the contribution list.
Definition Particle.h:148
double mass
particle mass:
Definition Particle.h:272
void setSize(const Vector3d &particle_size)
Configures particle size in each direction.
Definition Particle.h:180
void setPosition(const Vector3d &particle_position)
Configures the current particle position.
Definition Particle.h:172
const Vector3d & getPosition() const
Returns the current particle position.
Definition Particle.h:104
Matrix3d strain
current particle strain:
Definition Particle.h:283
double getPlasticStrain() const
Get effective plastic strain.
Definition Particle.h:236
static int getTotalParticles()
Returns o number of particles created.
Definition Particle.h:300
static int totalParticles
total particle in the model
Definition Particle.h:292
virtual double getDensityFluid() const
Returns the current density of fluid.
Definition Particle.h:92
Represents the shape functions used in the interpolation process.
Definition Shape.h:16