Tip |
---|
Quote of the day: |
Info |
---|
In this tutorial
|
Table of Contents | |
---|---|
|
Warning |
---|
Warning Stop here for a moment. Make sure you have followed the configuration setup before proceeding any further! Configuration related tutorial is here -> Click me! <- |
2.1. MDSPlus database
MDSplus is a set of software tools for data acquisition and storage and a methodology for management of complex scientific data (source).
In order to benefit from UAL layer, scientific data must be stored in MDSPlus database. Before you will be able to use it, you have to create database's structure. This is fairly simple. All you have to do is to execute following commands:
source $ITMSCRIPTDIR/ITMv1 kepler test 4.10b > /dev/null $ITMSCRIPTDIR/create_user_itm_dir test 4.10b
At this point, you can check your public directory and browse through the database structure.
cd $HOME/public/itmdb/itm_trees
Explanation of the tree structure:
location | description |
---|---|
$HOME/public/itmdb/itm_trees/$TOKAMAKNAME example: ~owsiak/public/itmdb/itm_trees/test) | defines the equipment used for acquiring the results; "test" - is most commonly used for artificial, test data |
$HOME/public/itmdb/itm_trees/$TOKAMAKNAME/$DATAVERSION/mdsplus example: ~owsiak/public/itmdb/itm_trees/test/4.10b/mdsplus | contains experimental data for given UAL version |
$HOME/public/itmdb/itm_trees/$TOKAMAKNAME/$DATAVERSION/$MDSPLUS_TREE_BASE_$NUMBER/ example: ~/public/itmdb/itm_trees/test/4.10b/mdsplus/0 | Contains all the shot and runs for given data tree |
$HOME/public/itmdb/itm_trees/$TOKAMAKNAME/$DATAVERSION/mdsplus/$MDSPLUS_TREE_BASE_$NUMBER/euitm_$SHOT example: ~/public/itmdb/itm_trees/test/4.10b/mdsplus/euitm_120001. | Contains data for given shot |
euitm_####.datafile, euitm_####.tree, euitm_####.characteristics | Contain data for givet shot/run |
2.2. Accessing MDSPlus database data
From the user's point of view, there are few characteristics that define single data tree:
Parameter | Environment variable | Description |
---|---|---|
User name | $USER | Defines the name of the user who owns the data |
Tokamak name | $TOKAMAKNAME | Defines the name of the machine that was used during simulation (test - contains testing data) |
UAL database version | $DATAVERSION | Specifies UAL data version |
Run number | not defined | Run number is represented by last four digits in database file euitm_SSSSRRRR.* |
Shot number | not defined | Shot number is represented by first digits in database file euitm_SSSSRRRR.*; there is no limit for number of digits used |
Info |
---|
ITMv1 script {{source $ITMSCRIPTDIR/ITMv1 kepler test 4.10b > /dev/null}} |
|
2.2.1 Listing pulse files
Info | ||
---|---|---|
| ||
Usage: itmdbs [OPTIONS] [COMMAND] This program lists existing ITM databases. Possible commands are: list <shot number>- list existing databases slices <shot number> <run number> - list existing databases, including number of timeslices and time range for time-dependent CPOs times <shot number> <run number> - list existing databases, including number of timeslices their time points for time-dependent CPOs tokamak - list existing tokamaks (with data versions) dataversion - list existing dataversions (with tokamaks) If the optional arguments shot number and run number are given, only databases with these numbers will be shown. If no command is given, the list command is performed. To see databases stored in the public itm database, use 'public' as the user name. Options: -h, --help show this help message and exit -u USER, --user=USER Show databases of specified user -t TOKAMAK, --tokamak=TOKAMAK Show only databases for specified tokamaks -v VERSION, --version=VERSION Show only databases for specified data version --backend=BACKEND Show databases written with given backend(s). Comma- separated list of backends (Currently supported: mdsplus, hdf5). By default all backends are shown. -c, --compact Compact/reduced output |
Code Block |
---|
shell> itmdbs -t test slices 14 4
Tokamak: test
Data version: 4.10b
UAL Backend: mdsplus
Shot 14
Run: 4
equilibrium: 100 slices ( 0.0 - 99.0) |
2.2.
12 Copying database files directly
In case you know user name, machine name, shot number and run number, you can import users' database files copying them directly from the users' public directories. Database files are located inside:
Code Block |
---|
~$USERNAME/public/itmdb/itm_trees/$TOKAMAKNAME/$DATAVERSION/mdsplus/0/euitm_SSSSRRRR.* |
Take a look at the example below. We will copy data from user michalo, machine test, shot: 12 and run: 2
Code Block |
---|
# change directory in your $HOME cd $HOME/public/itmdb/itm_trees/test/4.10b/mdsplus/0/ # copy data files (pay attention to *_dot_* at the end of command line!) cp ~michalo/public/itmdb/itm_trees/test/4.10b/mdsplus/0/euitm_120002.* . cp ~michalo/public/itmdb/itm_trees/test/4.10b/mdsplus/0/euitm_130003.* . |
We will discuss this later, during tutorial sessions.