Model Registration
Contents
- Getting Started
- Documenting the Model
- Model Geographic Coverage
- Container Set Up
- Build your model
- Configuration File Annotation
- Directive Annotation
- Output File Annotation
- Completing the Registration
Overview
There are two broad sections while registering your model:
Model Description
: You will start the registration process by filling out two forms and choosing any relevant geographic regions so Dojo can capture and store metadata about your model.Model Container Build
: Once the forms are completed and geographies selected, you will be directed to the model execution environment. In this environment, you will teach Dojo how to run your model, what parameters you would like to expose, your model’s output location, and metadata about your output file. The final step in the model registration process will be to publish your model’s image*.
*Some models have pre-built images and do not require a new model image to be published. See Container Set Up for more information.
You may begin by navigating to https://phantom.dojo-test.com. Please reach out to dojo@jataware.com for credentials or help with the application. Once you have accessed Dojo, on the opening Welcome to Dojo
screen select Go!
under A Model
to begin registering your model:
Model Registration
Documenting the Model
The first two pages are forms that capture metadata about your model and you. It’s important to be as thorough as possible to ensure the end-user can understand at a high-level what your model does, how it does it, and what it produces.
Model Overview Form
:
The Model Overview Form captures metadata about your model. There is a demonstration video below, as well as definitions for each field:
Model Overview Form Field Definitions:
Model Name
: The end-user will see this name when running your model. While spaces and upper/lower case are allowed, do not use special characters, to include parenthesis.Model Website
: This can be a link to your model repository or another website that you may maintain that provides additional context about your model.Model Family
: Model family refers to a group of models with similar characteristics. If you have several procedures based on the same underlying model family, you can link those models or model procedures here under a common family name of your choosing, such asLPJmL
. If your model does not have a natural grouping with other models, you can name it under an appropriate category related to your model or repeat your model name.Model Description
: Your description here is the forward-facing documentation about your model that the end-user will see. Include as much information as possible to explain what your model does and what it produces. Include any notes that may be required to explain any model idiosyncrasies. If your model takes a long time to run, you may want to include an estimated run time.
Model Specifics Form
:
The Model Specifics Form captures general metadata about you and your model. There is a short demo video below, as well as definitions for each field:
Model Specifics Form Field Definitions:
Maintainer Name
: The primary point of contact for the model.Maintainer Email
: The primary point of contact’s e-mail address. If you have one, a group e-mail is also acceptable.Maintainer Organization
: The organization that developed the model.Is this model stochastic?
: Check yes or no depending on your model.-
Category
: Common groupings that you would like your model categorized as. After typing your desired category, press the space bar to add additional categories. The categories associated with your model enable better discoverability of your model when the end-user searches for a broad model-type.Note: Spaces are not allowed when entering your category. To include a multi-word category, replace spaces with underscores. For example,
crop production
would be entered ascrop_production
.
There may be an option at the bottom of the screen asking Would you like to reconnect to an existing model?
If you are returning to Dojo and would like to continue working in your pre-existing container (with all of your previous work), select your active model container to be re-directed to the model execution environment.
Model Geographic Coverage
Model Geographic Coverage allows you to define the geographic areas that your model can be run over. You can add geographic areas by either selecting your area by name or building a bounding box around your area of interest.
Steps to add a geographic coverage by administration levels:
- Click on
ADD REGIONS BY NAME
- In the search box, enter a place name, country, or any admin-level 1 through 3.
- Select your desired region from the dropdown menu.
- Your selection will appear in the search box: click on
ADD REGION
to add it to theSelected Regions
. - Repeat the process to add any other geographic areas.
Steps to add a geographic coverage by building a bounding box:
- Click on
ADD REGIONS BY COORDINATES
- Enter your bounding box coordinates:
- Corner 1: The latitude and longitude of the northwest corner of your bounding box.
-
Corner 2: The latitude and longitude of the southeast corner of your bounding box.
Note : Westerly longitudes and Southern latitudes are negative
- Select
ADD REGION TO MAP
Once you have added your geographic areas, Click SUBMIT MODEL
to move the next step in the registration process.
Container Set Up
To launch the model execution environment, you will need to select a base image.
Your model may have a pre-built image available; to check, click on Ubuntu
, look through the drop down menu, and select your bespoke image. If you do not have an image here, choose Ubuntu
.
After selecting the appropriate image, select an Available Worker. An Available Worker will both indicate it is Available
and have no connections or containers. Click LAUNCH
to move into the model execution environment.
Build your model
You will build your image in the model execution environment (a Docker container). While all models are different, the general approach is to:
- Clone your model code into the container.
- Install any requirements needed to run your model.
- Test model execution. This can be an iterative approach in that you can make several test runs to ensure that you model is running and producing the expected results.
- Once you have a successful model run, Dojo will need to learn how you run your model, what input parameters you want to expose to the end-user, metadata about your output file(s), and the directory where your results are located. Quick Reference is a short introduction to the commands you will need followed by more in depth discussions and demonstration videos of each command.
Quick Command Reference:
You can leverage the commands below while registering your model:
edit <filename.ext>
: launch editor to modify any of your files.config <path_to_config_file.json>
: launch a tool to define and annotate parameters.tag <path_to_outputfile.csv>
: launch an annotation tool to define and classify the columns of your data.
Configuration File Annotation
If your model has configuration files with parameters or tunable knobs you wish to expose to users, you will need to annotate them in order to expose parameters to the end-user. Once the annotation window is launched, you can annotate each parameter and provide metadata and detailed information.
With Dojo, you can annotate any plain text/ascii configuration file, including .txt
, .yaml
, .json
, .xml
, etc.
Below is a demonstration video with details about each field following the video.
To launch the config annotation window run (replace <path_to_config_file.json>
with the appropriate file path and name):
config <path_to_config_file.json>
- Selecting your parameter. Only highlight the parameters you wish to expose to the end-user. After highlighting only the parameter value you wish to expose (i.e. do not highlight the quotes of strings or the variable name), Dojo will launch an annotation window to describe your parameter.
- Available fields:
Name
: The natural language name that want to call your parameter; string only and spaces are allowed.Description
: As with your model description, the parameter description should be detailed. The end-user will rely on this description to gain an understanding of the parameter. For non-standard formats, be sure to include not only an explanation, but also an example. For example, if choosing input Parameter A requires the end-user to select a subset from input Parameter B, be sure to include that here.Type
: Available options include string, integer, float, Date/time, and boolean. Choose the type from the dropdown that classifies your parameter.Pre-Defined Options
: A checkbox option if you would like to constrain the available parameter values to the end-user. Selecting the checkbox will expand the annotation window and allow you to enter any desired parameter values. These values must align with your model. I.E., if your model is expecting an underscore between countries with 2+ names, then your entry here must include the underscore. SelectAdd option
as needed to include additional parameter values.Default Value
: While not required, it is recommended to provide a default parameter value.Unit
: Required if applicable to your parameter. There is a field below to describe the unit, so here simply enter the units such as KG/HA or kilograms per hectare.Unit Description
: Add detail here to fully explain the parameter’s unit. For example, kilograms of crop produced per hectare during the rainy season.Data Type
: Available options include nominal, ordinal, numerical, and freeform. Choose the appropriate data-type from the dropdown for your parameter.Allow users to change this value
: A checkbox option. If you would like to expose this parameter to the end-user, keep the box checked. If you only want to provide additional information about the parameter to enhance explainability, uncheck the box. The end-user will then not be able to change the value but will be able to view the details of the parameter.Save
: Select save when complete. You can also select cancel should you no longer want to annotate the parameter and your updates will not be saved.
Repeat the above process for every applicable parameter value in your configuration file. Once complete, select save in the upper right-hand corner; this will save your annotated configuration file in Dojo.
Note: upon model execution, Dojo accepts parameter selections from end users and “rehydrates” the relevant config files with those parameter selections.
Directive Annotation
On the right-hand side of the terminal there is a dialog box; some entries will be flagged with an option to MARK AS MODEL DIRECTIVE
. Next to the appropriate model run command, select this flag to launch an annotation window. Annotating the directive allows you to expose and describe parameters to the end-user. Below is a demonstration video with details about each field following the video.
The same process applies to directive annotations as applied to configuration annotation.
Repeat the annotation process for every applicable parameter value in your model execution. Once complete, select save in the upper right-hand corner; this will save your annotated directive in Dojo.
Note: your model can have only one directive. If running your model is a multi-step process, you must combine those steps into a single executable script or command.
Output File Annotation
Once your model has run you will need to annotate your output file(s). This step provides the required metadata to geocode, associate and format columns, and convert your output to a Causemos-compliant dataset.
Currently, Dojo supports
.csv
,.nc
(NetCDF), and.tiff
(GeoTIFF). The files must have these correct extensions. For example, a.txt
file that is,
delimited, though technically a “CSV”, will not be handled correctly by Dojo.
To launch the output file annotation tool, run (replace <path_to_output_file.csv>
with the appropriate file path and name):
tag <path_to_output_file.csv>
Below is a video demonstrating how to invoke the model output annotation interface:
For a detailed description on how to do this, please go to Data Registration. Some of the form elements differ slightly from the data registration workflow, but the annotation process remains the same.
Completing the Registration
When you have completed the above steps, you are ready to publish your model image to DockerHub. This image will be utilized downstream from the model registration process and allow end-users to change exposed parameters, run the updated model, and then inspect and conduct analyses with the results in the Causemos interface.
As a recap, before publishing your image, you should have:
- Uploaded your model.
- Installed any dependencies.
- Iteratively tested your model and verified model behavior / results.
- For directive-type models: annotated all desired parameters on the command line; this includes both parameters you want to expose and parameters you wish to remain static but wish to provide additional explainability.
- For configuration-type models: annotated all desired parameters in the configuration file.
- Annotated the model output file(s) to define the metadata, geocode, and transform your output to a Causemos-compliant dataset.
- Defined the location / directory of your output file(s). This is required in order to mount your model output and complete the geocoding and causemosification transform of the results.
If you have done all the above, you are ready to publish your image. Select END SESSION
; you will be asked if you want to publish the image. Select yes
and monitor the publication progress. When complete, you can go to https://hub.docker.com/repository/docker/jataware/dojo-publish and look under the tags section to verify that your image was pushed to DockerHub. You may need to expand the tags section.
Note: As discussed before, some models have custom images pre-built. If your model has a pre-built image, you do not need to publish the image
IMPORTANT
If for some reason you do not wish to publish a container image, you must select ABANDON SESSION
. As you noticed when launching into the model execution environment, there are a limited number of workers available. If you do not abandon your session, the container will continue to run and your worker will not be available to others wishing to register a model.