The ASSAS Data Hub is a web application to store and visualize ASTEC simulation data on the Large Scale Data Facility at KIT. Its database contains the ASTEC archive in binary raw format and offers a conversion in other data formats. At the moment only a conversion in hdf5 data format is supported.
The ASSAS Data Hub is a flask web application, which requires the following additional software packages:
Entrypoint of the application is wsgi.py (Python Web Server Gateway Interface) and can be started with:
$ python wsgi.py
The application starts as a custom flask app. Test version available under http://assas.scc.kit.edu:5000/assas_app/home on a virtual machine inside the KIT infrastructure.
Runs on CONNECTIONSTRING = r'mongodb://localhost:27017/'
.
Restart NoSQL Database:
$ service mongod restart
The following command mounts the LSDF on the server system for the user USER
:
$ sudo mount -t cifs -o vers=2.0,username='USER',uid=$(id -u),gid=$(id -g) //os.lsdf.kit.edu/kit/scc/projects/ASSAS /mnt/ASSAS
The upload of ASTEC data is supported through an upload application under tools/assas_data_uploader.py
.
The use of the upload application requires the following:
- Request of a Partner- and Guest-KIT Account (https://www.scc.kit.edu/en/services/gup.php)
- Access to the LSDF with this Account (https://www.lsdf.kit.edu/)
- Configure a password-less ssh login to the login server of the LSDF (https://www.lsdf.kit.edu/docs/ssh/#using-ssh-on-linux-or-mac-os)
Create a new key pairkey
andkey.pub
with the following command:Transfer the public key to the login server of the LSDF with the following command:$ ssh-keygen
Add the private key as idenitiy on the local machine in executing the following command:$ ssh-copy-id -i ~/.ssh/key.pub <USERNAME>@os-login.lsdf.kit.edu
$ ssh-add ~/.ssh/key
- Installation of
Python3.10+
andrysnc
on the local machine (https://www.python.org/downloads/ and https://wiki.ubuntuusers.de/rsync/) - Definition of the upload parameters of the ASTEC archive according to the commandline interface described in the next section
The commandline interface of the upload application requires the following parameters:
- --user (-u): KIT internal batch which has access to the LSDF
- --source (-s): Path to the directory tree which will be uploaded (ASTEC Project directory)
- --name (-n): Corresponding name of the archive visible in the database
- --description (-d): Corresponding description of the archive visible in the database
- --archives (-a): Sub path to the actual ASTEC archive inside the directory tree, or a list of sub paths
The commandline interface of the upload application has the following optional parameter:
- --uuid (-i): Upload identifier of an upload process which was already started
Note: This parameter can be used to resume an interrupted or failed upload. One must determine the upload uuid from the standard output of the upload application.
The upload application can be executed via commandline as follows:
$ python tools/assas_data_uploader.py -u my_user -s my_source_path -n my_name -d my_description -a my_archive_path
If there is a project tree with several ASTEC runs, one can define a list of archive paths:
$ python tools/assas_data_uploader.py -u my_user -s my_source_path -n my_name -d my_description -a my_archive_path_1, my_archive_path_2, ....
The database view displays a list with all available datasets and provides the following parameters:
Index
: Unique index of datasetSize
: Size of ASTEC binary archiveSize hdf5
: Size of the hdf5 file after conversionDate
: Date of the upload timeUser
: User which has uploaded the datasetStatus
: Status of the uploaded datasetName
: Given name of the uploaded dataset
By click on the column cell File
the user can download the hdf5 file.
By click on the parameter Name
the user comes to a detailed view with following meta information about the dataset.
- Name (same as on the database view)
- Description
The following meta information is extarcted during the upload and conversion process:
- Variables: List of extracted variables
- Channels: Number of ectracted channels
- Meshes: Number of extracted meshes
- Samples: Number of extracted samples
The ASSAS Data Hub provides a RESTful API to query training data in an automated way.