.. _tutorials: ############################## Getting Started ############################## PlatRock has two user interfaces, namely the "*script / CLI*" and the "*graphic / WebUI*". Both interfaces can be ran locally (on local ressources) as well as remotely (on a distant server ressources). The technical means used to achive that are summarized below: +------------------+----------------------+-------------------------------+ | |Script interface (CLI)|Graphical interface | +------------------+----------------------+-------------------------------+ |Local | Shell |PlatRock-WebUI on localhost | +------------------+----------------------+-------------------------------+ |Remote | SSH |PlatRock-WebUI on remote server| +------------------+----------------------+-------------------------------+ Note that unlike PlatRock which is licensed under GPLv3, PlatRock-WebUI is closed-source and its usage is restricted to authorized users only. *************************************** INSTALLATIONS *************************************** .. mdinclude:: Installation_auto-generated.md Optional modules ----------------------------------------- Realtime 3D viewer for testing 3D models: :: pip3 install pyqt5 vtk Siconos for models with rocks shape integration: See ``_ *************************************** Documentation creation *************************************** Dependencies : :: pip3 install sphinx sphinx-rtd-theme Compilation : :: make html .. note:: Pdf creation will require a latex distribution and the pre-conversion of all svg source images to pdf format. First install dependencies: :: sudo apt install texlive texlive-latex-extra dvipng latexmk inkscape Then the compilation in three steps: #. Automatic images conversion: :code:`find -type f -name '*.svg' -exec sh -c 'f=$(basename $1 .svg);d=$(dirname $1);inkscape {} --export-pdf="$d/$f.pdf"' sh {} \;` #. Creation of tex file: :code:`sphinx-build -b latex path_to_doc_source_dir path_to_doc_build_dir` #. Pdf creation: :code:`cd path_to_doc_build_dir && pdflatex PlatRock.tex` *************************************** PlatRock CLI *************************************** Usage : :: platrock script_name.py or, for a more verbose (but slower) mode: :: platrock -ll=info script_name.py .. _tutorial_2D: TwoD Model ---------------------------------------------------------- .. literalinclude:: ../../examples/2D.py TwoDShape (Siconos) Model ---------------------------------------------------------- .. literalinclude:: ../../examples/2DShape.py .. _tutorial_3D: ThreeD Model (spherical rocks, PlatRock engine) ---------------------------------------------------------- .. literalinclude:: ../../examples/3D.py ThreeD Model (parallelepiped rocks, Siconos engine) ---------------------------------------------------------- .. literalinclude:: ../../examples/3DShape.py *************************************** WebUI *************************************** To start PlatRock-WebUI on the server or the local machine : :: platrock-webui path_to_the_project_dir This command will launch the webserver, reachable locally with a web-browser at ``_. The `path_to_the_project_dir` directory will store all simulations and projects informations, it can be initially empty. Projects Management ---------------------------------------------------------- On the project tab, the left panel is dedicated to project management. The following actions are available: select, add, edit informations, delete, save. On the right tab, all simulations that belong to the currently selected project are displayed. You can either click on a simulation title to display it (hence change to "simulation" tab), or click on one of the small actions icons to achieve quick operations. .. figure:: images/tutos/WebUI_Projects_General.* :width: 100% Simulations Toolbar ---------------------------------------------------------- On the top of the simulations tab, a toolbar allows to perform some actions on the current simulation. It is common for all simulation models: .. figure:: images/tutos/WebUI_Toolbar.* :width: 40% Thus it is possible to: * Save current changes * Reload the current simulation (undo changes) * Run the simulation * Download the simulation results * Backup/download the whole simulation to you computer * Access the log file after simulation has run if errors occured * Download the terrain and its soil parameters to a well-formated csv file TwoD Model ---------------------------------------------------------- Example of a TwoD simulation tab. After you have imported a terrain, you can adjust the parameters thanks to 3 main tables: * rocks start parameters, * checkpoints parameters, * terrain/soil parameters. .. figure:: images/tutos/WebUI_TwoD_General.* :width: 100% .. note:: To import a terrain you will have to input a well formated text file. Please find a description of this file `here `_ or use a template in platrock `examples directory `_. Parameters zones ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ During the terrain importation process PlatRock will automatically define parameters zones (one zone per color in the terrain parameters table). Consecutive terrain segments are grouped in a zone if they have the exact same parameters set. You can then change the parameter of the whole zone by filling the corresponding line in the parameters table. Topography editing ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ One can modify the topography by right-clicking one of the terrain points. A contextual menu will appear, allowing to: * Move an existing point * Remove an existing point * Add a new point * Split a parameters zone into two zones .. figure:: images/tutos/WebUI_TwoD_TopoEdit.* :width: 30% Parameters overrides ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ It is possible to override (replace) the parameters of the whole terrain by specific values. Tick the "Force rebound parameters everywhere" checkbox to activate a new table, then enter the desired parameters. They will be effective for the next runs, but the original terrain parameters can still be restaured by unticking the checkbox. .. figure:: images/tutos/WebUI_TwoD_Overrides.* :width: 60% Forest parameters ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ To take forest into consideration for the rockfall simulation, tick the "enable forest" checkbox. Then the forest parameters can either be: * set into the parameters zones if the forest characteristics are not homegeneous ; * set globally for the whole terrain. .. figure:: images/tutos/WebUI_TwoD_Forest.* :width: 60% TwoDShape Model ---------------------------------------------------------- The TwoDShape simulation tab is similar to the TwoD tab, only some parameters are different. .. figure:: images/tutos/WebUI_TwoDShape_General.* :width: 100% The imported terrain file should follow the template that can be found in the `examples directory `_. Also, the rocks start parameters include some options to define the rocks shape: .. figure:: images/tutos/WebUI_TwoDShape_Shape.* :width: 60% ThreeD Models ---------------------------------------------------------- The simulation tab for ThreeD simulations is slightly different from the TwoD ones. It shares the same toolbar and the main layout, but the parameters handling is different due to their nature: * the parameters applies to polygons (projected on the terrain); * the checkpoints are polylines. .. figure:: images/tutos/WebUI_ThreeD_General.* :width: 100% Terrain importation ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Click "import terrain" to show the corresponding pop-up in which some files will be requested. Each line in the pop-up corresponds to one file, and example files can be find in the `examples directory `_. Hover the lines to get more informations on the requested files specification: `DEM (*.asc)` Digital elevation model in ESRI ASCII grid format. `Rocks parameters (*.geojson)` Polygons data into GeoJSON container with attributes: number, z, vz, (volume || (length, width, height)). `Soil parameters (*.geojson)` Polygons data into GeoJSON container with attributes (depending on rebound types): R_n, R_t, roughness, bounce_mod, phi, v_half, e, mu, mu_r. `Forest parameters (*.geojson, *.xyd)` xyd file OR polygons data into GeoJSON container with attributes: density, dhp_mean, dhp_std. `Checkpoints (*.geojson)` Multilines data into GeoJSON container. The GeoJSON files can be created with `QGIS `_. In case of rocks, soil and forest parameters, polygons or multipolygons should be created and each polygon must contain the corresponding parameters as meta-data. Checkpoints must be multilines, without meta-data. Once the terrain and the parameters are imported, they will show up --and can be modified-- in the main simulation tab. The edition can be done in the same fashion as in TwoD models, and the polygons/multilines will appear as overlays in the graphical view of the terrain. Forest parameters ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ On the terrain importation popup, one can note that the forest can either be a GeoJSON file (in which case the trees will be generated based on the polygons parameters), or a xyd file. In the latter case, a basic text file with trees positions and diameters is expected. Simulation type selection ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The selection between spherical model (builtin physical engine) and the polygonal model (siconos engine, which can deal with rocks shape) can be done thanks to a dropdown menu. Note that the corresponding parameters must be set to be able to select a model, otherwise its selection will be disabled. .. figure:: images/tutos/WebUI_ThreeD_General_ModelSelection.* :width: 60% Simulations results overview ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Once the simulation is finished, the graphical view of the terrain will be updated with: * a sample of trajectories of the rocks ; * various output rasters. .. figure:: images/tutos/WebUI_ThreeD_General_Rasters.* :width: 100% The shown output raster data can be selected in the left-side dropdown menu. To improve their visibility, the parameters polygons and checkpoints can be hidden thanks to buttons on the right side of the graph.