.. _yaml_rst:
YAML Files
==========
Models and communication between models during are specified by the user in one
or more YAML files. YAML files have a human readable structure that can be parsed
by many different programming languages to recreate data structures. While the
YAML language can express very complex data structures (more information can be
found `here `_), only a few key concepts
are needed to create a YAML file for use with the |cis_interface| framework.
* Indentation: Entries with the same indentation belong to the same collection.
* Sequences: Entries that begin with a dash and a space (- ) are members
of a sequence collection. Members of a sequence can be text, collections,
or a mix of both.
* Mappings: Mapping entries use a colon and a space (: ) to seperate a
``key: value`` pair. Keys are text and values can be text or a collection.
Model Options
-------------
At the root level of a |cis_interface| YAML, should be a mapping key ``model:``
or ``models:``. This denotes information pertaining to the model(s) that should
be run. The value for this key can be a single model entry::
models:
name: modelA
language: python
args: ./src/gs_lesson4_modelA.py
or a sequence of model entries::
models:
- name: modelA
language: python
args: ./src/gs_lesson4_modelA.py
- name: modelB
language: c
args: ./src/gs_lesson4_modelB.c
At a minimum, each model entry should contain the following keys:
+---------+--------------------------------------------------------------------+
| Key | Description |
+=========+====================================================================+
| name | Unique name used to identify the model. This will be used to |
| | report errors associated with the model. |
+---------+--------------------------------------------------------------------+
| language| The language that the model is written in. Valid values include: |
| +------------+-------------------------------------------------------+
| | **Value** | **Description** |
| +------------+-------------------------------------------------------+
| | executable | The model is a pre-compiled executable. |
| +------------+-------------------------------------------------------+
| | python | The model is written in Python. |
| +------------+-------------------------------------------------------+
| | matlab | The model is written in Matlab. |
| +------------+-------------------------------------------------------+
| | c | The model is written in C. |
| +------------+-------------------------------------------------------+
| | c++/c | The model is written in C++. |
| +------------+-------------------------------------------------------+
| | make | The model is written in C/C++ and has a Makefile. |
| +------------+-------------------------------------------------------+
| | cmake | The model is written in C/C++ and has a CMakeLists.txt|
| +------------+-------------------------------------------------------+
| | lpy | The model is an LPy lsystem model. |
+---------+------------+-------------------------------------------------------+
| args | The full path to the file containing the model program that will |
| | be run by the driver or a list starting with the program file and |
| | including any arguments that should be passed as input to the |
| | program. |
+---------+--------------------------------------------------------------------+
| inputs | A mapping object containing the entry for a model input channel |
| | or a list of input channel entries. If the model does not get |
| | input from another model, this may be ommitted. |
+---------+--------------------------------------------------------------------+
| outputs | A mapping object containing the entry for a model output channel |
| | or a list of output channel entries. If the model does not output |
| | to another model, this may be ommitted. |
+---------+--------------------------------------------------------------------+
Models entries can also have the following optional keys:
========= ===================================================================
Key Description
========= ===================================================================
is_server If ``True``, this model will be considered to function as a
server for one or more models. The corresponding channel that
should be passed to the |cis_interface| API will be the name of
the model.
client_of The names of one or more models that this model will call as a
server. If there are more than one, this should be specified as
a sequence collection. The corresponding channel(s) that should
be passed to the |cis_interface| API will be the name of the
server model joined with the name of the client model with an
underscore ``_``. There will be one
channel created for each server the model is a client of.
========= ===================================================================
..
Any additional keys in the model entry will be passed to the model driver. A
full description of the available model drivers and potential arguments can be
found :ref:`here `.
Communication Options
---------------------
There are two options for specifying communication channels for the models.
One specifying the connections between communication channels and one
explicitly specifying the drivers.
Connection Method
*****************
To specify communication via connections, each input/output entry for the models
need only contain a unique name for the communication channel. This can be
specified as text::
input: channel_name
or a key, value mapping::
input:
name: channel_name
The key/value mapping form should be used when other information about the
communication channel needs to be provided (e.g. message format, field names,
units).
When using the connection format for specifying communication patterns, the
YAML also needs to contains a ``connections`` key at the same level as the
``models`` key.
Connection Options
------------------
The coordesponding value for the ``connections`` key should be one or more
mapping collections with the following keys:
================== ==========================================================
Key Description
================== ==========================================================
input/input_file The channel/file that messages should be recieved from. To
specify a model channel, this should be the name of an
entry in a model's ``outputs`` section. If this is a file,
it should be the absolute path to the file or the relative
path to the file from the directory containing the YAML.
output/output_file The channel/file that messages recieved from the ``input``
channel/file should be sent to. If the ``input`` value is
a file, the ``output`` value cannot be a file. To specify
a model channel, this should be the name of an entry in a
model's ``inputs`` section.
================== ==========================================================
Connection mappings can also have the following optional keys:
+------------+-----------------------------------------------------------------+
| Key | Description |
+============+=================================================================+
| translator | One or more functions that should be used to tranlate messages |
| | from the connection input before passing it alone to the |
| | connection output. Translators should be specified as strings |
| | with the format ":" such that |
| | can be imported from . |
+------------+-----------------------------------------------------------------+
| format_str | A C-style format string specifying how messages should be |
| | formatted/parsed from/to language specifying types (see |
| | :ref:`C-Style Format Strings `). |
+------------+-----------------------------------------------------------------+
| field_names| A sequence collection of names for the fields present in the |
| | format string. |
+------------+-----------------------------------------------------------------+
| field_units| A sequence collection of units for the fields present in the |
| | format string (see :ref:`Units `). |
+------------+-----------------------------------------------------------------+
| as_array | True or False. If True and filetype is table, the table will |
| | be read in it's entirety and passed as an array. |
+------------+-----------------------------------------------------------------+
| filetype | Only valid for connections that direct messages from a file to |
| | a model input channel or from a model output channel to a file. |
| | Values indicate how messages should be read from the file and |
| | include: |
| +-------------+---------------------------------------------------+
| | **Value** | **Description** |
| +-------------+---------------------------------------------------+
| | binary | The entire contents of the file are read as a |
| | | single message. This is the default if not |
| | | provided. |
| +-------------+---------------------------------------------------+
| | ascii | The contents of the file are read one line at a |
| | | time. |
| +-------------+---------------------------------------------------+
| | table | The file is assumed to be an ASCII table and read |
| | | one row at a time. The format of the table is |
| | | either read from the header or inferred from the |
| | | table. |
| +-------------+---------------------------------------------------+
| | pandas | The file is a table created from a Pandas data |
| | | frame. |
| +-------------+---------------------------------------------------+
| | ply | The file contains a 3D structure in Ply format. |
| +-------------+---------------------------------------------------+
| | obj | The file contains a 3D structure in Obj format. |
+------------+-------------+---------------------------------------------------+
The connection entries are used to determine which driver should be used to
connect communication channels/files. Any additional keys in the connection
entry will be passed to the input/output driver that is created for the
connection. A full description of the available input/output drivers and
potential arguments can be found :ref:`here `.
Driver Method
*************
In specifying communication via drivers, each input/output entry for the models
should be a mapping collection with, at minimum, the following keys:
====== ======================================================================
Key Description
====== ======================================================================
name The name of the channel that will be provided by the model to the
|cis_interface| API. This can be any text, but should be unique.
driver The name of the input/output driver class that should be used.
A list of available input/output drivers can be found
:ref:`here `.
args For connections made to other models, this should be text that matches
that of the other model's corresponding driver. For connections made
to files, this should be the path to the file, relative to the
location of the YAML file.
====== ======================================================================
Any additional keys in the input/output entry will be passed to the input/output
driver. A full description of the available input/output drivers and potential
arguments can be found :ref:`here `.
Validation
----------
|yggdrasil| uses a :ref:`JSON schema ` to validate the provided
YAML specification files. If you would like to validate a set of YAML specification
files without running the integration, this can be done via the ``yggvalidate`` CLI.::
$ yggvalidate name1.yml name2.yml ...