-
Notifications
You must be signed in to change notification settings - Fork 247
Kratos input files and IO
In the first tutorial you have successfully used Kratos to solve a few simple problems. The GiD preprocessor was used to create the input files for Kratos. There are three different types of files that compose a Kratos case:
-
.py
: A python script to run Kratos -
.json
: Contains settings for Kratos -
.mdpa
: Contains the model part information
These files where created by the GUI and used to directly start the simulation. In this tutorial we will have a closer look at the input files and their content. Also we will use Kratos without GUI but directly from the command line. This is a first step in order to customize the input files for Kratos to special use cases as it will be done in the following tutorials and the more flexible usage of Kratos beyond the GUI.
If you did not follow the first tutorial, you can download the input files for a simple structural mechanics case here.
The main file of a Kratos simulation is a python script. It is responsible to load the required Kratos applications and to call the main Kratos functionalities as desired by the user.
The main python script for Kratos is commonly named MainKratos.py
. Let's look at the content of this file for our structural analysis example:
import KratosMultiphysics
from KratosMultiphysics.StructuralMechanicsApplication.structural_mechanics_analysis import StructuralMechanicsAnalysis
if __name__ == "__main__":
with open("ProjectParameters.json", 'r') as parameter_file:
parameters = KratosMultiphysics.Parameters(parameter_file.read())
model = KratosMultiphysics.Model()
simulation = StructuralMechanicsAnalysis(model, parameters)
simulation.Run()
In the first lines, Kratos and the structural analysis are imported. Then the settings are read from the .json
file and used to create an object of the structural analysis. In the last line, the structural simulation executed.
Use the Kratos command prompt from your Kratos installation, navigate to the folder where your script is located and execute:
kratos MainKratos.py
Pro Tip: If you built Kratos yourself and set the paths properly as explained in the Building Kratos section of the Wiki, you can directly use python to execute your script.
The output of this analysis is written in two formats. The GiD post file ends with .post.bin
and can be drag and droppen into GiD. Additionally VTK files are written to the VTK_Output folder.
In order to show that the python script for Kratos indeed is just a simple python script, create a file named e.g. my_python_script.py
. Import the Kratos core module and additionaly write some simple python commands.
import KratosMultiphysics
# Custom python code
import math
a = 3
b = 4
c = math.sqrt(3**2 + 4**2)
print("-- Custom Code: c=", c, " --")
If you execute this script as described above you should see the following output in the terminal:
| / |
' / __| _` | __| _ \ __|
. \ | ( | | ( |\__ \
_|\_\_| \__,_|\__|\___/ ____/
Multi-Physics 7.0.0
-- Custom Code: c= 5.0 --
KRATOS TERMINATED CORRECTLY
The python script is a powerful tool to customize a Kratos simulation, as you will see in the next tutorials.
The settings for a Kratos simulation are stored in a .json
file. JSON is an open-standard format that uses human-readable text to transmit data objects consisting of attribute–value pairs. Kratos uses a thin wrapper arround this syntax, the Parameters
object. This section is a short version of a more detailed description about the JSON syntax and a tutorial on how to read and use it.
The project parameters file for Kratos is commonly named ProjectParameters.json
. Let's look at the content of this file for our structural analysis example. It contains four main blocks:
-
problem_data
: General settings for the Kratos run -
solver_settings
: Settings for the solvers, like analysis type, linear solver, etc. -
processes
: Processes to e.g. apply boundary conditions. -
output_processes
: Settings for the output
Try to change the end time of the structural case from to 5.0
seconds and run the analysis again.
Extend your custom python script by parsing the .json
file into a Parameters
object:
with open("ProjectParameters.json",'r') as parameter_file:
parameters = KratosMultiphysics.Parameters(parameter_file.read())
Extracting fields from the Parameters
object works similar to a python dictionary. To get and set the value of a field, you have to use specific functions for the data type. In order to get the file name (a string) of the .mdpa
file you need to type:
model_part_file_name = parameters["solver_settings"]["model_import_settings"]["input_filename"].GetString()
The .mdpa
(ModelPart) file contains the model information in Kratos specific syntax. It contains blocks for properties, nodes, elements and conditions and initial values. In addition the mesh entities can be grouped into sub model parts. A detailed description of the syntax is given here.
The following exercise is a short version of a more detailed tutorial.
A ModelPart
has to be created via a Model
object, which can contain several ModelParts
. Right after creating the empty ModelPart
, the variables needed for the following calculations have to be added. The empty ModelPart
is then filled using the ModelPartIO
that reads the information from an .mdpa file. In general, the analysis object takes care of these steps, especially because it knows which variables to add.
Here you will do it directly in your python script.
If the .mdpa file contains application dependent elements, the corresponding Kratos application has to be imported. In our structural example, the elements are from the StructuralMechanicsApplication
.
Extend the small python script from the first part of the exercise with the following lines:
import KratosMultiphysics.StructuralMechanicsApplication
this_model = KratosMultiphysics.Model()
this_model_part = this_model.CreateModelPart("MyModelPart")
# Adding variables BEFORE reading the .mdpa
this_model_part.AddNodalSolutionStepVariable(KratosMultiphysics.DISPLACEMENT)
model_part_io = KratosMultiphysics.ModelPartIO("KratosWorkshop2019_high_rise_building_CSM") #path to file without ".mdpa"
model_part_io.ReadModelPart(this_model_part)
You could also use the filename that you extracted from the ProjectParameters.json previously.
Hint: You can >>> print(this_model_part)
to see its content.
An extensive example on writing GiD output can be found here. In this part of the tutorial you will create a minimal configuration of a VTK output process.
The vtk_output
block in the ProjectParameters.json gives you an impression on the potential settings for the output. Here you will create just a minimal version of it.
from vtk_output_process import VtkOutputProcess
vtk_output_configuration = KratosMultiphysics.Parameters("""{
"model_part_name" : \""""+this_model_part.Name+"""\",
"output_sub_model_parts" : false,
"nodal_solution_step_data_variables" : ["DISPLACEMENT"]
}""")
vtk_output = VtkOutputProcess(this_model, vtk_output_configuration)
The output process is usually called at defined places inside the analysis. In order to use it, several functions need to be called in the right order.
vtk_output.ExecuteInitialize()
vtk_output.ExecuteBeforeSolutionLoop()
vtk_output.ExecuteInitializeSolutionStep()
vtk_output.PrintOutput()
vtk_output.ExecuteFinalizeSolutionStep()
vtk_output.ExecuteFinalize()
- Getting Kratos (Last compiled Release)
- Compiling Kratos
- Running an example from GiD
- Kratos input files and I/O
- Data management
- Solving strategies
- Manipulating solution values
- Multiphysics
- Video tutorials
- Style Guide
- Authorship of Kratos files
- Configure .gitignore
- How to configure clang-format
- How to use smart pointer in Kratos
- How to define adjoint elements and response functions
- Visibility and Exposure
- Namespaces and Static Classes
Kratos structure
Conventions
Solvers
Debugging, profiling and testing
- Compiling Kratos in debug mode
- Debugging Kratos using GDB
- Cross-debugging Kratos under Windows
- Debugging Kratos C++ under Windows
- Checking memory usage with Valgind
- Profiling Kratos with MAQAO
- Creating unitary tests
- Using ThreadSanitizer to detect OMP data race bugs
- Debugging Memory with ASAN
HOW TOs
- How to create applications
- Python Tutorials
- Kratos For Dummies (I)
- List of classes and variables accessible via python
- How to use Logger
- How to Create a New Application using cmake
- How to write a JSON configuration file
- How to Access DataBase
- How to use quaternions in Kratos
- How to do Mapping between nonmatching meshes
- How to use Clang-Tidy to automatically correct code
- How to use the Constitutive Law class
- How to use Serialization
- How to use GlobalPointerCommunicator
- How to use PointerMapCommunicator
- How to use the Geometry
- How to use processes for BCs
- How to use Parallel Utilities in futureproofing the code
- Porting to Pybind11 (LEGACY CODE)
- Porting to AMatrix
- How to use Cotire
- Applications: Python-modules
- How to run multiple cases using PyCOMPSs
- How to apply a function to a list of variables
- How to use Kratos Native sparse linear algebra
Utilities
Kratos API
Kratos Structural Mechanics API