Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[MPM] Change application name #12011

Merged
merged 56 commits into from
Mar 13, 2024
Merged
Show file tree
Hide file tree
Changes from 43 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
cdff96a
rename files in main folder
ncrescenzio Jan 22, 2024
5b852c8
updated files using new application name
ncrescenzio Jan 22, 2024
d294b49
Renamed files in `custom_io`
ncrescenzio Jan 22, 2024
abde946
Updated files in `custom_io`
ncrescenzio Jan 22, 2024
ac7054a
Renamed file in `custom_processes`
ncrescenzio Jan 22, 2024
3d2f4c9
Updated file in `custom_processes`
ncrescenzio Jan 22, 2024
bc3acd8
Updated files in `custom_elements`
ncrescenzio Jan 22, 2024
1f48ef1
Updated files in `custom_conditions/grid_based_conditions`
ncrescenzio Jan 22, 2024
a7b6d56
Updated files in `custom_conditions/particle_based_conditions'
ncrescenzio Jan 22, 2024
1887246
Renamed files in `custom_utilities`
ncrescenzio Jan 22, 2024
7af6680
Updated files in `custom_utilities`
ncrescenzio Jan 22, 2024
86a4b3d
Renamed file in `custom_python`
ncrescenzio Jan 22, 2024
3eb84b2
Updated files in `custom_python`
ncrescenzio Jan 22, 2024
9aba25c
Updated files in `custom_strategies`
ncrescenzio Jan 22, 2024
23be12e
Renamed files in `custom_constitutive`
ncrescenzio Jan 22, 2024
0ed0176
Updated files in `custom_constitutive`
ncrescenzio Jan 22, 2024
8d73628
Renamed files in `python_scripts`
ncrescenzio Jan 23, 2024
dd993b7
Updated files in `python_scripts`
ncrescenzio Jan 23, 2024
1fa75af
Updated wheels
ncrescenzio Jan 23, 2024
746f6fa
Updated `KratosMultiphysics-all.json`
ncrescenzio Jan 23, 2024
269be38
Updated `CODEOWNERS`
ncrescenzio Jan 23, 2024
92696df
Updated `.github/workflows`
ncrescenzio Jan 23, 2024
7df0d8c
Changee `PARTICLES_PER_ELEMENT` with `MATERIAL_POINTS_PER_ELEMENT` an…
ncrescenzio Jan 23, 2024
1f08346
fix include files
ncrescenzio Jan 23, 2024
ee54a84
Renamed files in `tests`
ncrescenzio Jan 23, 2024
38c17ba
Updated cpp tests
ncrescenzio Jan 23, 2024
da6b1af
Updated files in `tests`
ncrescenzio Jan 23, 2024
b3e8b61
Renamed folder `ParticleMechanicsApplication` in `MPMApplication`
ncrescenzio Jan 23, 2024
cafea57
tests fixed
ncrescenzio Jan 23, 2024
80238b0
Renamed solver wrappers in `CoSimulationApplication`
ncrescenzio Jan 24, 2024
418c3a3
Updated solver wrappers in `CoSimulationApplication`
ncrescenzio Jan 24, 2024
dfc726e
Updated files in `CoSimulationApplication/tests`
ncrescenzio Jan 24, 2024
4d2ed98
Renamed files in `CoSimulationApplication/tests`
ncrescenzio Jan 24, 2024
8684d1d
Updated `README.md` and `FAQs.md`
ncrescenzio Jan 30, 2024
ee6e965
Changed name docs folder
ncrescenzio Jan 31, 2024
eebc0ed
Update docs `MPM_Application`
ncrescenzio Jan 31, 2024
2f8851b
Update docs in `CoSimulation_Application`
ncrescenzio Jan 31, 2024
24d5642
Change files name in `CoSimulation_Application` docs
ncrescenzio Jan 31, 2024
4e0ee43
Update JSON results
ncrescenzio Jan 31, 2024
9ef092f
Merge branch 'master' into mpm/change-application-name
ncrescenzio Feb 5, 2024
abc7ba8
Wrong application name in `custom_constitutive` (`KRATOS_API`)
ncrescenzio Feb 5, 2024
082bfc9
Update `CoSimulationApplication` tests
ncrescenzio Feb 5, 2024
4ad2aa2
Add wrappers with old name in `CoSimulationApplication`
ncrescenzio Feb 5, 2024
bde84aa
Revert "Renamed files in `CoSimulationApplication/tests`"
ncrescenzio Mar 5, 2024
15de64e
Revert "Updated files in `CoSimulationApplication/tests`"
ncrescenzio Mar 5, 2024
04aa3f8
Revert "Updated files in `tests`"
ncrescenzio Mar 7, 2024
fd081eb
Added deprecation warning: parameter `particles_per_condition` replac…
ncrescenzio Mar 8, 2024
cdccfe7
added wrappers for old python processes
ncrescenzio Mar 8, 2024
de1cbe1
added wrapper for old analysis stage class
ncrescenzio Mar 8, 2024
eaf8b6d
Added deprecation warning: parameter `PARTICLES_PER_ELEMENT` replaced…
ncrescenzio Mar 8, 2024
9667212
removed useless import
ncrescenzio Mar 8, 2024
2b7bf96
updated name test dependencies
ncrescenzio Mar 8, 2024
9f799fc
updated application name in tests projectparameters
ncrescenzio Mar 8, 2024
4033126
minor changes to prove backward compatibility
ncrescenzio Mar 8, 2024
f6019b7
update python tests
ncrescenzio Mar 8, 2024
855f989
Merge branch 'master' into mpm/change-application-name
ncrescenzio Mar 8, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
4 changes: 2 additions & 2 deletions .github/CODEOWNERS
Validating CODEOWNERS rules …
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,6 @@
/applications/IgaApplication/ @KratosMultiphysics/nurbs-breps
/applications/HDF5Application/ @KratosMultiphysics/hdf5-application
/applications/MultilevelMonteCarloApplication/ @KratosMultiphysics/uncertainty-quantification
/applications/ParticleMechanicsApplication/ @KratosMultiphysics/mpm
/applications/MPMApplication/ @KratosMultiphysics/mpm
/applications/RomApplication/ @KratosMultiphysics/rom
/applications/GeoMechanicsApplication/.................@KratosMultiphysics/geomechanics
/applications/GeoMechanicsApplication/.................@KratosMultiphysics/geomechanics
2 changes: 1 addition & 1 deletion .github/workflows/ci_apps_linux.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
"HDF5Application",
"ContactStructuralMechanicsApplication",
"IgaApplication",
"ParticleMechanicsApplication",
"MPMApplication",
"ChimeraApplication",
"StatisticsApplication",
"SwimmingDEMApplication",
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/ci_apps_windows.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
"DEMApplication",
"ChimeraApplication",
"IgaApplication",
"ParticleMechanicsApplication",
"MPMApplication",
"MappingApplication",
"CoSimulationApplication",
"StatisticsApplication",
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/configure.cmd
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\StructuralMechanic
set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\DEMApplication;
set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\ChimeraApplication;
set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\IgaApplication;
set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\ParticleMechanicsApplication;
set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\MPMApplication;
set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\MappingApplication;
set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\CoSimulationApplication;
set KRATOS_APPLICATIONS=%KRATOS_APPLICATIONS%%KRATOS_APP_DIR%\StatisticsApplication;
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/configure.sh
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ add_app ${KRATOS_APP_DIR}/CompressiblePotentialFlowApplication;
add_app ${KRATOS_APP_DIR}/HDF5Application;
add_app ${KRATOS_APP_DIR}/ContactStructuralMechanicsApplication;
add_app ${KRATOS_APP_DIR}/IgaApplication;
add_app ${KRATOS_APP_DIR}/ParticleMechanicsApplication;
add_app ${KRATOS_APP_DIR}/MPMApplication;
add_app ${KRATOS_APP_DIR}/ChimeraApplication;
add_app ${KRATOS_APP_DIR}/StatisticsApplication;
add_app ${KRATOS_APP_DIR}/SwimmingDEMApplication;
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/intel_configure.sh
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ export KRATOS_INSTALL_PYTHON_USING_LINKS=ON
# add_app ${KRATOS_APP_DIR}/HDF5Application;
# add_app ${KRATOS_APP_DIR}/ContactStructuralMechanicsApplication;
# add_app ${KRATOS_APP_DIR}/IgaApplication;
# add_app ${KRATOS_APP_DIR}/ParticleMechanicsApplication;
# add_app ${KRATOS_APP_DIR}/MPMApplication;
# add_app ${KRATOS_APP_DIR}/ChimeraApplication;
# add_app ${KRATOS_APP_DIR}/MultilevelMonteCarloApplication;
# add_app ${KRATOS_APP_DIR}/StatisticsApplication;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
# Importing the Kratos Library
import KratosMultiphysics as KM
from KratosMultiphysics.kratos_utilities import CheckIfApplicationsAvailable

# Importing the base class
from KratosMultiphysics.CoSimulationApplication.solver_wrappers.kratos import kratos_base_wrapper

# Importing MPM
if not CheckIfApplicationsAvailable("MPMApplication"):
raise ImportError("The MPMApplication is not available!")
import KratosMultiphysics.MPMApplication as KPM
from KratosMultiphysics.MPMApplication.mpm_analysis import MPMAnalysis

# Other imports
import math

def Create(settings, model, solver_name):
return MPMDirichletWrapper(settings, model, solver_name)

class MPMDirichletWrapper(kratos_base_wrapper.KratosBaseWrapper):
"""This class is the interface to the MPMApplication of Kratos."""
"""It is designed for the Dirichlet Interface in the MPMApplication"""

def _CreateAnalysisStage(self):
return MPMAnalysis(self.model, self.project_parameters)

def SolveSolutionStep(self):
coupling_model_part = self.model.GetModelPart("MPM_Coupling_Dirichlet_Interface")
model_part_name = self.settings["solver_wrapper_settings"]["interface_model_part_name"].GetString()
model_part = self.model.GetModelPart(model_part_name)

## Transfer information from coupling_mp to mp
for coupling_node in coupling_model_part.Nodes:
coupling_id = coupling_node.Id

## IMPOSED DISPLACEMENT
total_displacement = coupling_node.GetSolutionStepValue(KM.DISPLACEMENT,0)
old_displacement = model_part.GetCondition(coupling_id).CalculateOnIntegrationPoints(KPM.MPC_DISPLACEMENT, model_part.ProcessInfo)[0]
incremental_displacement = total_displacement - old_displacement
model_part.GetCondition(coupling_id).SetValuesOnIntegrationPoints(KPM.MPC_IMPOSED_DISPLACEMENT, [incremental_displacement], model_part.ProcessInfo)

## ADD VELOCITY
current_velocity = coupling_node.GetSolutionStepValue(KM.VELOCITY,0)
model_part.GetCondition(coupling_id).SetValuesOnIntegrationPoints(KPM.MPC_VELOCITY, [current_velocity], model_part.ProcessInfo)

## ADD NORMAL
normal = coupling_node.GetSolutionStepValue(KM.NORMAL,0)
# Check and see whether the normal is not zero
norm_normal = math.sqrt(normal[0]*normal[0] + normal[1]*normal[1] + normal[2]*normal[2])
if norm_normal > 1.e-10:
model_part.GetCondition(coupling_id).SetValuesOnIntegrationPoints(KPM.MPC_NORMAL, [normal], model_part.ProcessInfo)

super().SolveSolutionStep()

### Get contact force from mp to coupling_mp
for mpc in model_part.Conditions:
if (mpc.Is(KM.INTERFACE)):
coupling_id = mpc.Id
contact_force = mpc.CalculateOnIntegrationPoints(KPM.MPC_CONTACT_FORCE, model_part.ProcessInfo)[0]
coupling_model_part.GetNode(coupling_id).SetSolutionStepValue(KM.CONTACT_FORCE,0,contact_force)
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
# Importing the Kratos Library
import KratosMultiphysics as KM
from KratosMultiphysics.kratos_utilities import CheckIfApplicationsAvailable

# Importing the base class
from KratosMultiphysics.CoSimulationApplication.solver_wrappers.kratos import kratos_base_wrapper

# Importing MPM
if not CheckIfApplicationsAvailable("MPMApplication"):
raise ImportError("The MPMApplication is not available!")
import KratosMultiphysics.MPMApplication as KPM
from KratosMultiphysics.MPMApplication.mpm_analysis import MPMAnalysis

def Create(settings, model, solver_name):
return MPMNeumannWrapper(settings, model, solver_name)

class MPMNeumannWrapper(kratos_base_wrapper.KratosBaseWrapper):
"""This class is the interface to the MPMApplication of Kratos"""
"""It is designed for the Neumann Interface in the MPMApplication"""

def _CreateAnalysisStage(self):
return MPMAnalysis(self.model, self.project_parameters)

def SolveSolutionStep(self):
coupling_model_part = self.model.GetModelPart("MPM_Coupling_Neumann_Interface")
model_part_name = self.settings["solver_wrapper_settings"]["interface_model_part_name"].GetString()
model_part = self.model.GetModelPart(model_part_name)

## Transfer information from coupling_mp to mp
for coupling_node in coupling_model_part.Nodes:
coupling_id = coupling_node.Id

## IMPOSED Point load
point_load = coupling_node.GetSolutionStepValue(KM.CONTACT_FORCE)
model_part.GetCondition(coupling_id).SetValuesOnIntegrationPoints(KPM.POINT_LOAD, [point_load], model_part.ProcessInfo)

super().SolveSolutionStep()

### Save displacement of mpc in coupling node
for mpc in model_part.Conditions:
if (mpc.Is(KM.INTERFACE)):
coupling_id = mpc.Id

# Update displacement
delta_x = mpc.CalculateOnIntegrationPoints(KPM.MPC_DELTA_DISPLACEMENT, model_part.ProcessInfo)[0]
displacement = coupling_model_part.GetNode(coupling_id).GetSolutionStepValue(KM.DISPLACEMENT)
displacement += delta_x
coupling_model_part.GetNode(coupling_id).SetSolutionStepValue(KM.DISPLACEMENT,0,displacement)

# Update velocity
velocity = mpc.CalculateOnIntegrationPoints(KPM.MPC_VELOCITY, model_part.ProcessInfo)[0]
coupling_model_part.GetNode(coupling_id).SetSolutionStepValue(KM.VELOCITY,0,velocity)
philbucher marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -1,60 +1,16 @@
# Importing the Kratos Library
import KratosMultiphysics as KM
import KratosMultiphysics
from KratosMultiphysics.kratos_utilities import CheckIfApplicationsAvailable
from KratosMultiphysics.kratos_utilities import IssueDeprecationWarning

# Importing the base class
from KratosMultiphysics.CoSimulationApplication.solver_wrappers.kratos import kratos_base_wrapper
from KratosMultiphysics.CoSimulationApplication.solver_wrappers.kratos.mpm_dirichlet_wrapper import MPMDirichletWrapper

# Importing ParticleMechanics
if not CheckIfApplicationsAvailable("ParticleMechanicsApplication"):
raise ImportError("The ParticleMechanicsApplication is not available!")
import KratosMultiphysics.ParticleMechanicsApplication as KPM
from KratosMultiphysics.ParticleMechanicsApplication.particle_mechanics_analysis import ParticleMechanicsAnalysis

# Other imports
import math
# Importing MPM
if not CheckIfApplicationsAvailable("MPMApplication"):
raise ImportError("The MPMApplication is not available!")
import KratosMultiphysics.MPMApplication as KPM
from KratosMultiphysics.MPMApplication.mpm_analysis import MPMAnalysis

def Create(settings, model, solver_name):
return ParticleMechanicsDirichletWrapper(settings, model, solver_name)

class ParticleMechanicsDirichletWrapper(kratos_base_wrapper.KratosBaseWrapper):
"""This class is the interface to the ParticleMechanicsApplication of Kratos."""
"""It is designed for the Dirichlet Interface in the ParticleMechanicsApplication"""

def _CreateAnalysisStage(self):
return ParticleMechanicsAnalysis(self.model, self.project_parameters)

def SolveSolutionStep(self):
coupling_model_part = self.model.GetModelPart("MPM_Coupling_Dirichlet_Interface")
model_part_name = self.settings["solver_wrapper_settings"]["interface_model_part_name"].GetString()
model_part = self.model.GetModelPart(model_part_name)

## Transfer information from coupling_mp to mp
for coupling_node in coupling_model_part.Nodes:
coupling_id = coupling_node.Id

## IMPOSED DISPLACEMENT
total_displacement = coupling_node.GetSolutionStepValue(KM.DISPLACEMENT,0)
old_displacement = model_part.GetCondition(coupling_id).CalculateOnIntegrationPoints(KPM.MPC_DISPLACEMENT, model_part.ProcessInfo)[0]
incremental_displacement = total_displacement - old_displacement
model_part.GetCondition(coupling_id).SetValuesOnIntegrationPoints(KPM.MPC_IMPOSED_DISPLACEMENT, [incremental_displacement], model_part.ProcessInfo)

## ADD VELOCITY
current_velocity = coupling_node.GetSolutionStepValue(KM.VELOCITY,0)
model_part.GetCondition(coupling_id).SetValuesOnIntegrationPoints(KPM.MPC_VELOCITY, [current_velocity], model_part.ProcessInfo)

## ADD NORMAL
normal = coupling_node.GetSolutionStepValue(KM.NORMAL,0)
# Check and see whether the normal is not zero
norm_normal = math.sqrt(normal[0]*normal[0] + normal[1]*normal[1] + normal[2]*normal[2])
if norm_normal > 1.e-10:
model_part.GetCondition(coupling_id).SetValuesOnIntegrationPoints(KPM.MPC_NORMAL, [normal], model_part.ProcessInfo)

super().SolveSolutionStep()

### Get contact force from mp to coupling_mp
for mpc in model_part.Conditions:
if (mpc.Is(KM.INTERFACE)):
coupling_id = mpc.Id
contact_force = mpc.CalculateOnIntegrationPoints(KPM.MPC_CONTACT_FORCE, model_part.ProcessInfo)[0]
coupling_model_part.GetNode(coupling_id).SetSolutionStepValue(KM.CONTACT_FORCE,0,contact_force)
IssueDeprecationWarning('CoSimulationApplication:','"ParticleMechanicsDirichletWrapper" is deprecated and replaced by "MPMDirichletWrapper"')
return MPMDirichletWrapper(settings, model, solver_name)
Original file line number Diff line number Diff line change
@@ -1,52 +1,16 @@
# Importing the Kratos Library
import KratosMultiphysics as KM
import KratosMultiphysics
from KratosMultiphysics.kratos_utilities import CheckIfApplicationsAvailable
from KratosMultiphysics.kratos_utilities import IssueDeprecationWarning

# Importing the base class
from KratosMultiphysics.CoSimulationApplication.solver_wrappers.kratos import kratos_base_wrapper
from KratosMultiphysics.CoSimulationApplication.solver_wrappers.kratos.mpm_neumann_wrapper import MPMNeumannWrapper

# Importing ParticleMechanics
if not CheckIfApplicationsAvailable("ParticleMechanicsApplication"):
raise ImportError("The ParticleMechanicsApplication is not available!")
import KratosMultiphysics.ParticleMechanicsApplication as KPM
from KratosMultiphysics.ParticleMechanicsApplication.particle_mechanics_analysis import ParticleMechanicsAnalysis
# Importing MPM
if not CheckIfApplicationsAvailable("MPMApplication"):
raise ImportError("The MPMApplication is not available!")
import KratosMultiphysics.MPMApplication as KPM
from KratosMultiphysics.MPMApplication.mpm_analysis import MPMAnalysis

def Create(settings, model, solver_name):
return ParticleMechanicsNeumannWrapper(settings, model, solver_name)

class ParticleMechanicsNeumannWrapper(kratos_base_wrapper.KratosBaseWrapper):
"""This class is the interface to the ParticleMechanicsApplication of Kratos"""
"""It is designed for the Neumann Interface in the ParticleMechanicsApplication"""

def _CreateAnalysisStage(self):
return ParticleMechanicsAnalysis(self.model, self.project_parameters)

def SolveSolutionStep(self):
coupling_model_part = self.model.GetModelPart("MPM_Coupling_Neumann_Interface")
model_part_name = self.settings["solver_wrapper_settings"]["interface_model_part_name"].GetString()
model_part = self.model.GetModelPart(model_part_name)

## Transfer information from coupling_mp to mp
for coupling_node in coupling_model_part.Nodes:
coupling_id = coupling_node.Id

## IMPOSED Point load
point_load = coupling_node.GetSolutionStepValue(KM.CONTACT_FORCE)
model_part.GetCondition(coupling_id).SetValuesOnIntegrationPoints(KPM.POINT_LOAD, [point_load], model_part.ProcessInfo)

super().SolveSolutionStep()

### Save displacement of mpc in coupling node
for mpc in model_part.Conditions:
if (mpc.Is(KM.INTERFACE)):
coupling_id = mpc.Id

# Update displacement
delta_x = mpc.CalculateOnIntegrationPoints(KPM.MPC_DELTA_DISPLACEMENT, model_part.ProcessInfo)[0]
displacement = coupling_model_part.GetNode(coupling_id).GetSolutionStepValue(KM.DISPLACEMENT)
displacement += delta_x
coupling_model_part.GetNode(coupling_id).SetSolutionStepValue(KM.DISPLACEMENT,0,displacement)

# Update velocity
velocity = mpc.CalculateOnIntegrationPoints(KPM.MPC_VELOCITY, model_part.ProcessInfo)[0]
coupling_model_part.GetNode(coupling_id).SetSolutionStepValue(KM.VELOCITY,0,velocity)
IssueDeprecationWarning('CoSimulationApplication:','"ParticleMechanicsNeumannWrapper" is deprecated and replaced by "MPMNeumannWrapper"')
return MPMNeumannWrapper(settings, model, solver_name)
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,9 @@

have_fsi_dependencies = kratos_utils.CheckIfApplicationsAvailable("FluidDynamicsApplication", "StructuralMechanicsApplication", "MappingApplication", "MeshMovingApplication", "LinearSolversApplication")
have_potential_fsi_dependencies = kratos_utils.CheckIfApplicationsAvailable("CompressiblePotentialFlowApplication", "StructuralMechanicsApplication", "MappingApplication", "MeshMovingApplication", "LinearSolversApplication")
have_mpm_fem_dependencies = kratos_utils.CheckIfApplicationsAvailable("ParticleMechanicsApplication", "StructuralMechanicsApplication", "MappingApplication", "LinearSolversApplication", "ConstitutiveLawsApplication")
have_mpm_fem_dependencies = kratos_utils.CheckIfApplicationsAvailable("MPMApplication", "StructuralMechanicsApplication", "MappingApplication", "LinearSolversApplication", "ConstitutiveLawsApplication")
have_dem_fem_dependencies = kratos_utils.CheckIfApplicationsAvailable("DEMApplication", "StructuralMechanicsApplication", "MappingApplication", "LinearSolversApplication")
have_mpm_dem_dependencies = kratos_utils.CheckIfApplicationsAvailable("DEMApplication", "ParticleMechanicsApplication", "MappingApplication", "LinearSolversApplication")
have_mpm_dem_dependencies = kratos_utils.CheckIfApplicationsAvailable("DEMApplication", "MPMApplication", "MappingApplication", "LinearSolversApplication")
have_fem_fem_dependencies = kratos_utils.CheckIfApplicationsAvailable("StructuralMechanicsApplication", "MappingApplication")
have_pfem_fem_dependencies = kratos_utils.CheckIfApplicationsAvailable("PfemFluidDynamicsApplication", "StructuralMechanicsApplication", "MappingApplication", "LinearSolversApplication", "ConstitutiveLawsApplication")

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,11 @@
"name" : "LinearElasticIsotropicPlaneStrain2DLaw"
},
"Variables" : {
"THICKNESS" : 1.0,
"PARTICLES_PER_ELEMENT" : 3,
"DENSITY" : 1000.0,
"YOUNG_MODULUS" : 90000000.0,
"POISSON_RATIO" : 0.0
"THICKNESS" : 1.0,
"MATERIAL_POINTS_PER_ELEMENT" : 3,
philbucher marked this conversation as resolved.
Show resolved Hide resolved
"DENSITY" : 1000.0,
"YOUNG_MODULUS" : 90000000.0,
"POISSON_RATIO" : 0.0
},
"Tables" : {}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
"input_filename": "mpm_dem/beam_Body"
},
"material_import_settings": {
"materials_filename": "mpm_dem/ParticleMaterials.json"
"materials_filename": "mpm_dem/MaterialPointMaterials.json"
},
"time_stepping": {
"time_step": 2e-3
Expand Down Expand Up @@ -58,19 +58,19 @@
"loads_process_list": [
{
"python_module": "apply_mpm_coupling_interface_neumann_condition_process",
"kratos_module": "KratosMultiphysics.ParticleMechanicsApplication",
"kratos_module": "KratosMultiphysics.MPMApplication",
"Parameters": {
"model_part_name": "Background_Grid.INTERFACE_coupling_to_dem",
"particles_per_condition": 1
"material_points_per_condition": 1
}
}
],
"list_other_processes": [
{
"python_module": "particle_from_json_check_result_process",
"kratos_module": "KratosMultiphysics.ParticleMechanicsApplication",
"python_module": "mpm_from_json_check_result_process",
"kratos_module": "KratosMultiphysics.MPMApplication",
"help": "",
"process_name": "ParticleFromJsonCheckResultProcess",
"process_name": "MPMFromJsonCheckResultProcess",
"Parameters": {
"check_variables": [ "MP_DISPLACEMENT" ],
"input_file_name": "mpm_dem/cosim_mpm_dem_results.json",
Expand All @@ -83,10 +83,10 @@
},
"print_output_process": [
{
"python_module": "particle_json_output_process",
"kratos_module": "KratosMultiphysics.ParticleMechanicsApplication",
"python_module": "mpm_json_output_process",
"kratos_module": "KratosMultiphysics.MPMApplication",
"help": "",
"process_name": "ParticleJsonOutputProcess",
"process_name": "MPMJsonOutputProcess",
"Parameters": {
"gauss_points_output_variables": [ "MP_DISPLACEMENT" ],
"output_file_name": "mpm_dem/cosim_mpm_dem_results.json",
Expand Down
Loading
Loading