.. _WorkshopAdvanced1-label: ############################################## Workshop Advanced usage of viiaPackage (Day 1) ############################################## The first day of the workshop focusses on the topics 'strengthening' and 'result handling' within the NLTH analysis process. This page contains the materials, the recorded instructions and solutions to the exercises. ========================================================================== General procedure for NLTH model development and analysis with viiaPackage ========================================================================== The general procedure for NLTH is shown in the following figure. This workflow focusses on the model, for the complete NLTH workflow refer to the protocol. .. figure:: _static/GeneralWorkflow.png :align: center General NLTH model procedure. ============= Strengthening ============= Strengthening measures in the GMC --------------------------------- Within the GMC there are 8 categories of strengthening measures: +----------+----------------------------+--------------------------------------------------------------------------+ | Category | Measure for | Description | +==========+============================+==========================================================================+ | L1 | Eliminating acute hazards | Stabilizing elements preventing acute damage like chimney, ducts | +----------+----------------------------+--------------------------------------------------------------------------+ | L2 | Connections | Coupling different structural/non-structural elements to ensure | | | | efficient transfer of forces eg. wall and floor. | +----------+----------------------------+--------------------------------------------------------------------------+ | L3 | Floors and roofs | Improving diaphragm action (shear capacity) | +----------+----------------------------+--------------------------------------------------------------------------+ | L4 | Walls (out-of-plane) | Improving the out-of-plane capacity of walls (both load and non-load | | | | bearing). | +----------+----------------------------+--------------------------------------------------------------------------+ | L5 | Walls (in-plane) | Improving the in-plane capacity of walls(both load and non-load bearing) | +----------+----------------------------+--------------------------------------------------------------------------+ | L6 | Foundation | Improving the bearing capacity of the foundation to ensure transfer of | | | | forces to the soil. | +----------+----------------------------+--------------------------------------------------------------------------+ | L7 | Demolition | Removal of the element from the building | +----------+----------------------------+--------------------------------------------------------------------------+ | L8 | Global behaviour change | Changing the global behavior of the structure so as not have any | | | | additional measures eg. base isolation. | +----------+----------------------------+--------------------------------------------------------------------------+ Table 2.1 - Strengthening measures in the GMC. Strengthening measures in DIANA ------------------------------- Applying measures in DIANA model: +----------+----------------------------+--------------------------------------------------------------------------+ | Category | Application in DIANA | +==========+=======================================================================================================+ | L1 | Not required to model in DIANA. | +----------+-------------------------------------------------------------------------------------------------------+ | L2 | Application of a linear interface and reporting the interface stresses | +----------+-------------------------------------------------------------------------------------------------------+ | L3 | Changing the properties of the floor/roof + addition of existing mass (changing input through | | | viiaPackage) – Will be implemented later. | +----------+-------------------------------------------------------------------------------------------------------+ | **L4** | **Some via functions in viiaPackage and some in DIANA** | +----------+-------------------------------------------------------------------------------------------------------+ | **L5** | **Some via functions in viiaPackage and some in DIANA** | +----------+-------------------------------------------------------------------------------------------------------+ | L6 | Some via functions in viiaPackage and some in DIANA | +----------+-------------------------------------------------------------------------------------------------------+ | L7 | Not required to model in DIANA. | +----------+-------------------------------------------------------------------------------------------------------+ | L8 | Not implemented. | +----------+-------------------------------------------------------------------------------------------------------+ Table 2.2 - Application of strengthening measures in the NLTH model. The available strengthening measures in the viiaPackage are (bold indicated measures are working): * **L2 (linear interface)** * L4 – L4-B, **L4-F**, L4-I, **L4-O**, L4-R, **L4-D** * L5 – L5-A, L5-B, L5-N, **L5-P** * L6 – L6-J Workflow for strengthening -------------------------- * Required input from user for strengthening functions – shape_name/shape_object generally * Default input – This is generally provided from offset values (top and bottom), spacing between members (eg. L4-F, L4-D). Should be given in input argument as per user requirement. * Note: when strengthening is added to an element (wall/floor), its meta_data attribute is filled in with the strengthening measure. .. code-block:: python wall.meta_data('strengthening') = 'L4-F' * For details regarding connections, refer to the material from `'Connections workshop' `__. .. figure:: _static/FlowchartStrengthening.png :align: center Workflow applying strengthening measures in NLTH model. Measure L4-F ------------ This section shows how to apply the L4-F in the NLTH model. .. figure:: _static/MeasureL4F.png :align: center Information on strengthening measure L4-F. Applying the L4-F measure using the viiaPackage: .. code-block:: python project.viia_l4f() Measure L4-D ------------ This section shows how to apply the L4-D in the NLTH model. .. figure:: _static/MeasureL4D.png :align: center Information on strengthening measure L4-D. Applying the L4-D measure using the viiaPackage: .. code-block:: python project.viia_l4d() Measure L5-P ------------ This section shows how to apply the L5-P in the NLTH model. .. figure:: _static/MeasureL5P.png :align: center Information on strengthening measure L5-P. Applying the L5-P measure using the viiaPackage: .. code-block:: python project.viia_l5p() Instructions on applying strengthening measures ----------------------------------------------- The following recording shows the instructions on how to apply strengthening measures in NLTH: .. figure:: _static/recording01.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/2fa599a4-93c2-435e-84a7-830b1d75c065?list=studio Instructions on applying strengthening in the NLTH model. All excercises are to be executed on the following model: :download:`Model for excercises for strengthening measures<./excercises/advanced_strengthening_model.json>` Excercise 1 - Applying the measure ---------------------------------- Add the measure 'L4-F' to the wall with name 'N1-WANDEN-MW-KLEI<1945-150-8' on the inside. :download:`Exercise script<./excercises/advanced_strengthening_01_script.py>` **Solution** The following recording shows the solution of the excercise: .. figure:: _static/recording02.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/aec0c8e1-f960-4770-90dd-2131eb734a14?list=studio Instructions on solution of excercise 1. Create the L4-F measure: .. code-block:: python project.viia_l4f('N1-WANDEN-MW-KLEI<1945-150-8', flip=True) Note: The columns are not created above openings. If the measure is applied to walls with openings, L4-G should be applied. The other elements around the opening and above need to be manually added by the user right now. :download:`Solution<./excercises/advanced_strengthening_01_solution.py>` Excercise 2 - Parts of the function not working ----------------------------------------------- Add the measure 'L4-F' to the wall with name 'N0-WANDEN-MW-KLEI<1945-150-2'. Check the applied measures in DIANA and do the necessary changes (if any). .. note:: For this example we provide you with a broken function l4-F in the script itself. :download:`Exercise script<./excercises/advanced_strengthening_02_script.py>` **Solution** The following recording shows the solution of the excercise: .. figure:: _static/recording03.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/70ebfb5d-7dc9-49cb-ad9b-3c47c636ac41?list=studio Instructions on solution of excercise 2. Create the L4-F measure: .. code-block:: python project.viia_l4f(wall='N0-WANDEN-MW-KLEI<1945-150-2') The eccentricity is not added, this needs to be added after viia_create_model(). .. code-block:: python wall_thickness = fem_find_object( 'N0-WANDEN-MW-KLEI<1945-150-2', project.collections.walls).geometry.geometry_model.thickness column_height = fem_find_object( 'N0-KOLOMMEN-L4F-WAND2-LIN-HOUT-KOLOM-50x75-4', project.collections.columns).geometry.geometry_model.height project.rhdhvDIANA.setParameter( 'GEOMET', 'KOLOM-L4F-50x75-(1,0,0)', 'ECCENT', True) project.rhdhvDIANA.setParameter( 'GEOMET', 'KOLOM-L4F-50x75-(1,0,0)', 'ECCENT/ECCENY', -0.5*(wall_thickness+column_height)) :download:`Solution<./excercises/advanced_strengthening_02_solution.py>` Excercise 3 - Application of measure not available -------------------------------------------------- Apply the measure ‘L3-A’ on the floor with name ‘N1-VLOEREN-LIN-HBV-PLANKEN-0.018-0.080-0.200-0.770-1’. .. note:: This measure is not currently present in the viiaPackage. Also, eccentricity for HBV floors does not have to be applied for now. (For the measure, refer to the UPR) :download:`Exercise script<./excercises/advanced_strengthening_03_script.py>` **Solution** The following recording shows the solution of the excercise: .. figure:: _static/recording04.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/f34f52b3-e469-4b12-ae16-b14081c6fd67?list=studio Instructions on solution of excercise 3. .. code-block:: python floor = fem_find_object('N1-VLOEREN-LIN-HBV-PLANKEN-0.018-0.080-0.200-0.770-1', project.collections.floors) floor_old_mass_density = floor.material.mass_density floor_material = project.viia_create_material('LIN-HBV-PLATEN-0.024-0.080-0.200-0.770') floor.material = floor_material floor.name = 'N1-VLOEREN-LIN-HBV-PLATEN-0.024-0.080-0.200-0.770-1' project.viia_adjust_mass_of_surface(floor_old_mass_density*9.81/fem_area(floor.get_points()),floor) .. note:: This measure will be added later to the viiaPackage. :download:`Solution<./excercises/advanced_strengthening_03_solution.py>` Excercise 4 - Combination of measures ------------------------------------- Apply the measure L5-R for the wall ‘N1-WANDEN-MW-KLEI<1945-150-5’. This measure is used for the combined in-plane and out-of-plane strengthening of masonry walls. Eg. This can be for structures subjected to torsion. Hint: L5-R is not available in the viiaPackage, but is a combination of two measures L4-F and L5-P. :download:`Exercise script<./excercises/advanced_strengthening_04_script.py>` **Solution** The following recording shows the solution of the excercise: .. figure:: _static/recording05.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/fd84d91d-608f-4f62-973a-53f525465110?list=studio Instructions on solution of excercise 4, part 1. .. figure:: _static/recording06.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/66028e21-593e-4dd9-93ba-02de7131720a?list=studio Instructions on solution of excercise 4. part 2. .. code-block:: python project.viia_l4f(wall='N1-WANDEN-MW-KLEI<1945-150-5', flip = True) del fem_find_object('N1-WANDEN-MW-KLEI<1945-150-5', project.collections.walls).meta_data['strengthening'] project.viia_l5p( wall=fem_find_object('N1-WANDEN-MW-KLEI<1945-150-5', project.collections.walls), application_type='Negative’) It should be noted that this way, the eccentricity of the columns is slightly lesser (by 10 mm) and the strengthening is conservative. An alternative to this could be creating the columns at the exact eccentricity and creating ties with the wall. :download:`Solution<./excercises/advanced_strengthening_04_solution.py>` Exercise 5 – Measure with a connection -------------------------------------- Apply the measure 'L4-F' for the wall 'N0-WANDEN-MW-KLEI<1945-150-7' without any offsets. The connections were created as part of the package for this wall with the connecting beams/floor. :download:`Exercise script<./excercises/advanced_strengthening_05_script.py>` :download:`Dat file<./excercises/advanced_strengthening_05_model.dat>` TODO: Add link to BOX folder for the result files. **Solution** The following recording shows the solution of the exercise: .. figure:: _static/recording24.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/5e1d2654-a2bd-4db8-8fad-ef81fc63838a?list=studio .. code-block:: python project.viia_l4f(wall='N0-WANDEN-MW-KLEI<1945-150-7', flip=True, offset_bottom=0.0, offset_top=0.0) project.viia_connect_all_shapes() project.viia_auto_interfaces() # Can be any interface function :download:`Solution<./excercises/advanced_strengthening_05_solution.py>` =============== Result handling =============== This section will focus on the result handling of the NLTH analysis. .. figure:: _static/ResultHandlingOverview.png :align: center Overview of available result handling for NLTH. Convergence graph ----------------- Available in the NLTH result script (template in viiaPackage) within the function viia_results(). * Features: Duration of analysis, Converging steps, Relative energy/displacement/force variation, cracking * Input: Out-file of analysis, parameter variation. * Output: Convergence graph for one analysis. .. figure:: _static/ConvergenceGraph.png :align: center Figure 2.13 - Example convergence graph. Output for geotechnical engineer -------------------------------- Available in the NLTH result script (template in viiaPackage). Function related to the collecting of geotechnical output: * viia_geo_output – Obtaining the maximum base shear per strip/pile from the signal with the time instant. *Indicated* *green part in Figure 2.14.* * viia_geo_output_nls – Obtaining the permanent and variable loads from nonlinear *Indicated* *green part in Figure 2.14.* * viia_geo_output_merge – Combining these two results in a format relevant for geo tool These functions will require the following input and deliver the following output: * Input: .dat , .json, _5A.tb, _5B.tb for all signals (in A12 result folder) and .dat, .json, _5A.tb (in A10 result folder). * Output: A json-file per signal and a single json-file for non-linear static, generated in working folder (both files would contain the dimensions and coordinates of the foundation element). The functions create different parts of the json-file. These are indicated in the following figure: .. figure:: _static/GeoOutput.png :align: center Json-file for output for geotechnical assessment. .. figure:: _static/GeoOutputExplanation.png :align: center Explanation of the elements in the geotechnical output.for output for geotechnical assessment. Base shear ---------- The base shear result handling is part of the result handling (also generated within the Geo output functions if needed for all 7 signals) in the NLTH result-script. The function can also be used seperately: * viia_base_shear - Create the base shear graph. This functions will require the following input and deliver the following output: * Input: _5A.tb file, analysis object. * Output: Base shear graph. .. figure:: _static/BaseShearGraph.png :align: center Example base shear graph. OOP/IP displacements -------------------- The wall displacement result handling is part of the result handling in the NLTH result-script. The function can also be used seperately: * viia_wall_displacements This functions will require the following input and deliver the following output: * Input: OUTPUT_2.tb, list of walls (can be obtained from .json). * Output: The OOP/IP displacement and total displacements per wall along the duration of signal created as png-file in the folder OOP_IP_displacements within the working folder. .. figure:: _static/WallDisplacements.png :align: center Example wall-displacements graph. .. figure:: _static/WallDisplacementsRelativ.png :align: center Example relative wall-displacements graph. Result pictures --------------- The result pictures part of the result handling is done in the NLTH result-script. The functions can also be used seperately: * viia_create_result_pictures This functions will require the following input and deliver the following output: * Input Files: .json, .dat, OUTPUT_4.tb, OUTPUT_1A_max.dnb, OUTPUT_1B_min.dnb, OUTPUT_MOVIE. * Output: The result pictures are created in the analysis folder. Main results are added in the documentation - `LINK`_ .. note:: Alternative result pictures script is available (more based on DIANA commands). Pictures of reinforcements are not created. Generic input for pictures: .. figure:: _static/PictureSettingsGeneric.png :align: center Result picture object. * For creating the result picture dictionary – has a default dictionary of pictures. * Structure – Name of picture *(key)* : Selected shapes/elements *(value)* * Eg. Dynamic-DispX-Max: Maximum displacement in X – Is created for the building, also for interstorey drift and for walls per storey. .. figure:: _static/DefaultPictures.png :align: center Default pictures dictioanry. Some other result handling features ------------------------------------ * Movie maker is available as part of result handling script (Required OpenCv-python package): viia_movie_maker. * project.evaluation_step in case of diverged calculations – for BSC calculations can be helpful sometimes * Additional script (as a last resort). Instructions on result handling ------------------------------- The following recording shows the instructions on how to do result handling in NLTH: .. figure:: _static/recording07.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/1f47cb4d-33dd-4053-9910-5b92e5c2159d?list=studio Instructions on result handling of NLTH analysis. .. figure:: _static/recording08.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/1f47cb4d-33dd-4053-9910-5b92e5c2159d?list=studio Instructions on result handling of NLTH analysis, additional explanations. Excercise 1 - Convergence graph of interrupted analysis ------------------------------------------------------- Try creating the convergence graph for the broken out-file in the same folder. Figure out the issue and make the necessary changes to obtain the convergence graph. :download:`Exercise script<./excercises/advanced_result_handling_01_script.py>` :download:`Outfile<./excercises/advanced_results_handling_01_outfile.out>` **Solution** The following recording shows the solution of the excercise: .. figure:: _static/recording09.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/4b45e003-19e8-4b0b-9b6f-a8b76bfefaef?list=studio Instructions on solution of excercise 1. .. code-block:: python project.viia_convergence_graph(r'location of the convergence outfile') # Remove the parts of text of the incomplete step from the Convergence.out file # Re-run the function :download:`Solution<./excercises/advanced_results_handling_01_solution.py>` Excercise 2 - Base shear of interrupted analysis ------------------------------------------------ The base shear graph is generated as part of the geotechnical output in the workflow. However, the geo-output function is not working. Create the graph in an alternative way. :download:`Exercise script<./excercises/advanced_result_handling_02_script.py>` :download:`Model<./excercises/advanced_results_handling_02_model_S1_v1.json>` :download:`DIANA dat-file<./excercises/advanced_results_handling_02_model_v1.dat>` :download:`Result-file<./excercises/advanced_results_handling_02_OUTPUT_5A.tb>` **Solution** The following recording shows the solution of the excercise: .. figure:: _static/recording10.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/b38a5930-c8dc-44b0-a863-0824e6907ba0?list=studio Figure 2.24 - Instructions on solution of excercise 1. .. code-block:: python # Reading the dump file a project.viia_read_dump('location of dump file', False) analysis_object = project.collections.analyses[-1] project.from_diana(Path('location of dat file')) # Base shear graph project.viia_base_shear('location of OUTPUT_5A.tb file',analysis_object) :download:`Solution<./excercises/advanced_results_handling_02_solution.py>` Excercise 3 - Create result pictures ------------------------------------ Make the following changes for the result pictures script. Change to Advanced_Workshop_Result_pictures branch for this. * Fill in the missing details in the result script. * Make the necessary changes w.r.t Analysis object. * Add the evaluation_step to 88. * Change the limits for the crack pictures to have a limit of 20 mm. **Note: It is not necessary to create the result pictures for the exercise** :download:`Exercise script<./excercises/advanced_result_handling_03_script.py>` :download:`Model<./excercises/advanced_results_handling_03_model.json>` :download:`Additional files<./excercises/exercise_3_files.zip>` **Solution** The following recording shows the solution of the excercise: .. figure:: _static/recording11.png :width: 400px :align: center :target: https://web.microsoftstream.com/video/d20fdfdb-2108-4949-9f5c-2841708951c6?list=studio Part 1 .. code-block:: python # analysis and signal analysis_nr = 'A12' signal = 'S3’ # Work directory work_dir = Path('path to the directory containing the analysis files') Part 2 .. code-block:: python # Using the mainscript, json- and dat-file in the ‘Other files’ folder, recreate the json-file with the analysis # object (in DIANA) Part 3 .. code-block:: python project.evaluation_step = 88 # Added before viia_result_pictures Part 4 .. code-block:: python # Change the limits for the crack pictures in ViiaStatus.py in project.diana_settings.result_pictures :download:`Solution<./excercises/advanced_results_handling_03_solution.py>`