How to create output for geo
This page will explain how to create the required output for the geotechnical advisor.
Non Linear Time History Analysis
For NLTH, the output is collected from nonlinear static analysis of the model (A10/A13), combined with the results of the nonlinear time-history analysis (A12/A15). Before sending, these two results are combined in one file which is required to be sent to the geotechnical advisor.
Note
For NLTH, if your object requires no strengthening (only the BSC phase is performed), then running the geo-output functions with the A10 calculation result files in combination with the A12 calculation result files is sufficient. If your object does require strengthening, then A10 and A13 calculations files in combination with A15 calculation result files are needed. In case of strengthening, make sure that version of at least 2 is set for A13 and A15 calculation result files.
If there is no strengthening in the model, following are the steps:
Handling non-linear static analysis results A10 geo results
Handling NLTH analysis results and combining with A10 A12 geo results
If there is strengthening in the model, following are the steps:
Handling non-linear static analysis results A10 geo results
Handling non-linear static analysis results with strengthening A13 geo results
Handling NLTH analysis results and combining with A10 and A13 A15 geo results
A10 geo results
For DIANA
After running the analysis, the following files should be available in your A10 folder:
xxx.json
xxx.dat
xxx_OUTPUT_5A.tb (for foundation strips)
xxx_OUTPUT_5B.tb (for piles)
your folder will look like:
Figure 1 - A10 folder setup.
Then, run the result functions for A10.
project = viia_create_project(project_name='xxx', analysis_type='NLTH', version_nr=1)
project.current_analysis_folder = Path(r'Cxxx\A10 - Non-linear static flex base\20210803xxxxxx-v001')
project.viia_results(analysis_nr='A10')
Behind the scene, the package will process the stress data collected for foundation strip element in 5A.tb and the force data collected for pile element in 5B.tb in vertical direction. It will sum up all the force for each foundation strip and pile. Eventually, you will see the geo_output_nls.json written in the analysis folder.
For each foundation strip, the corresponding boundary interface is linked, the total vertical force after static load, variable load are stored as well as the element labels. While for piles, the pile node is recorded together with the vertical force after static and variable load.
Figure 2 - A10 json-file content.
For ABAQUS
To create output for geo, you need to generate output request for ABAQUS, and this request can append to your envelope_results.json from your A12 analysis. This can be done by running the function.
project.viia_append_envelope_requests_geo_abaqus(json_path=r"Cxxx\envelope_results.json")
After running the function, you should be able to find the “section_force_requests” (and “displacement_request” if you have piles) in your json. Additionally, to speed up the process, you can delete the text in “envelope_request” if you have already finished your envelope results postprocessing for A12.
In the end, the envelope_results.json for geo output should look like this:
Figure 3 - ABAQUS envelope_results.json for gro output.
Then, after running A10 analysis on server, the following files should be available in your folder:
A10-Niet-lineair_statische_analyse_met_flexbase.odb
postprocessing (folder)
postprocessing.bat
Then, copy the envelope_results.json you just created to the this folder. Also, check the postprocessing.bat by right clicking and selecting edit, and make sure it calls your latest json. The content of batch should look like this:
call abaqus python postprocessing/postprocessor.py --odb_path A10-Niet-lineair_statische_analyse_met_flexbase.odb --spec_path envelope_results.json
pause
Then run this batch file by double clicking. After it is finished, a new json file called A10-Niet-lineair_statische_analyse_met_flexbase_postprocessed_data.json should appear in your folder.
Within this file, the section forces for each foundation strips in all directions are stored. While piles, the relative displacements from pile top to bottom for each pile are also stored. You should copy this file from server to the working folder in your laptop.
Once you have A10-Niet-lineair_statische_analyse_met_flexbase_postprocessed_data.json on your working folder, run the function:
project.viia_create_geo_output_static_analysis(
abaqus_results=Path(r"Cxxx\A10 - Non-linear static flex base\A10-Niet-lineair_statische_analyse_met_flexbase_postprocessed_data.json"),
output_dir=Path(r"Cxxx"),
foundation_type='strips') # or piles, mixed
Then you should have a new json generated called geo_output_nls.json. The file looks like this:
Figure 4 - ABAQUS geo_output_nls.
A12 geo results
For DIANA
After the A12 analyses are finished, the following files should be available in A12 folder:
xxx.json
xxx.dat
xxx_OUTPUT_5A.tb (for foundation strips)
xxx_OUTPUT_5B.tb (for piles)
At this point, your analysis folder for a signal would look like this:
Figure 5 - A12 folder setup.
Following this, run the result functions for A12:
project = viia_create_project(project_name='xxx', analysis_type='NLTH', version_nr=1)
project.viia_results(
analysis_nr='A12', signal='S1', geo_output=True, bsc_nls_dir=bsc_nls_folder)
The most important attributes for the geo-output within the _viia_results()
is the boolean
geo_output which should be set to True, the path variable bsc_nls_dir, which is the location of the A10 folder where
the geo_output_nls.json can be obtained for the BSC analysis. This folder location can be assigned manually. If not
assigned, then the latest analysis folder for A10 is selected for generating the .json file. The results from this .json
file is used to produce the final merged json-file.
Once these functions have run through, the GeoOuput folder is created in the working folder. Within this folder, you would find either a fstrips folder or piles folder or both depending on the foundation type. The final geo-output json-files can be found inside those. This needs to be done with each signal individually. The final geo-output structure will be as shown in the figure below.
Figure 6 - Geo output structure in the working folder
It is essential to do some checks on the geo output depending on your foundation type. In Figure 5 the geo output for a single foundation fstrip element and Figure 6 shows the ge output for a single foundation pile element.
The generic check for both cases is the structure of the forces and displacement in case of pile foundation.The seismic forces should have 24 rows with 6 situations (maximum and minimum for each global direction ) and the non-linear static forces should have 4 rows. Additionally for pile foundation, the displacement should have 12 rows with 6 situations (maximum and minimum for each global direction). Since there are no measures applied, there should be no differences between the BSC and TVA A10 results in the merged .json.
When the output is taken for fstrips, the parameters including direction, length, material, width, coordinates (x, y, z_min, z_max) should be present.
Figure 7 - NLTH geo-output data for shallow foundations.
When the output is taken for piles, the parameters including material, pile ID, pile group, coordinates (x, y, z) should be present.
Figure 8 - NLTH geo-output data for piles.
For ABAQUS
You can use the same envelope_results.json created in A10 and copy it to every signal folder of your A12 analysis on server.
You should have finished all A12 analysis already, then the following files should be available in the folder for every signal:
A12-Niet-lineair_seismische_analyse_met_flexbase.odb
postprocessing (folder)
postprocessing.bat
Then, also check the postprocessing.bat, the content should look like this:
call abaqus python postprocessing/postprocessor.py --odb_path A12-Niet-lineair_seismische_analyse_met_flexbase.odb --spec_path envelope_results.json
pause
Then run the batch file for every signal. After finished, a new json file called A12-Niet-lineair_seismische_analyse_met_flexbase_postprocessed_data.json should appear in every signal’s folder.
Within this file, the section forces for each foundation strips in all directions are stored. While piles, the relative displacements from pile top to bottom for each pile are also stored. You should copy this file from server to the working folder in your laptop.
Once your have all A12-Niet-lineair_seismische_analyse_met_flexbase_postprocessed_data.json in your working folder, run the function for every signal:
project.viia_create_geo_output_nlth(
signal=signal_x, # for each signal
bsc_nls_dir=Path(r"Cxxx"), # This should be the path of your geo_output_nls generated from A10
abaqus_results=Path(r"Cxxx\Sx\A12-Niet-lineair_seismische_analyse_met_flexbase_postprocessed_data.json"))
After finished all 7 of your signals, you should have a folder called GeoOutput in your working directory. Within this folder, you should find the output foe geo like this:
Figure 9 - NLTH geo-output files for ABAQUS.
You can send these files to geo engineers. The data and format in this files are the same as DIANA geo output.
A13 geo results
For DIANA
After running the analysis, the A13 folder should have the same files as that of the A10 folder (Figure 1). Only the version of the files should be greater that 1.
Then, run the result functions for A10.
project = viia_create_project(project_name='xxx', analysis_type='NLTH', version_nr=2)
project.current_analysis_folder = Path(r'Cxxx\A13 - Non-linear static flex base strengthening \20210803xxxxxx-v001')
project.viia_results(analysis_nr='A13')
The resulting .json file in the A13 folder will have the same content as that from the .json generated in the A10 folder (Figure 2).
For ABAQUS
The same procedure should be followed as for A10. Pay attention to the working directory in batch file.
A15 geo results
For DIANA
After the A15 analyses are finished, the same files as A12 should be available in the A15 folder (Figure 5). Only the version of the files should be greater that 1.
Following this, run the result functions for A15:
project = viia_create_project(project_name='xxx', analysis_type='NLTH', version_nr=2)
project.viia_results(
analysis_nr='A15', signal='S1', geo_output=True, bsc_nls_dir=bsc_nls_folder, tva_nls_dir=tva_nls_folder)
The most important attributes for the geo-output within the _viia_results()
is the boolean
geo_output which should be set to True, the path variable bsc_nls_dir, which is the location of the A10 folder where
the geo_output_nls.json can be obtained for the BSC analysis, and if you have TVA analysis, then tva_nls_dir should
also be assigned, which is the location of the A13 folder where the geo_output_nls.json can be obtained for the TVA
analysis. These folder can be manually assigned in the result script. If not assigned, then the latest analysis files
from the A10 and A13 folders are respectively taken for the BSC and TVA analysis to generate the geo_output_nls .json
file. The results from these .json files are used to produce the final merged json-file.
Once these functions have run through, the GeoOuput folder is created similar to how it is described for the A12 Geo Output (Figure 6).
It is essential to do some checks on the geo output depending on your foundation type. These checks are the same as that for the A12 Geo Output except for one essential difference in the first check. There should be differences between the BSC and TVA results for the static analysis in the merged .json since these are taken for two different analyses. For the rest the structures should be exactly the same as that for the A12 Geo Output (Figures 7 and 8 as reference).
For ABAQUS
The same procedure should be followed as for A12. Pay attention to the working directory in batch file.