MOdel and method DEfinitions
Project description
mode
MOdel DEfinitions in JS/TS/Py - houses entity definitions for:
Method- See Method OverviewModel- See Model Overview
Installation
For usage within a JavaScript project:
npm install @mat3ra/mode
For development:
git clone https://github.com/Exabyte-io/mode.git
Contribution
This repository is an open-source work-in-progress and we welcome contributions.
We regularly deploy the latest code containing all accepted contributions online as part of the Mat3ra.com platform, so contributors will see their code in action there.
See ESSE for additional context regarding the data schemas used here.
Useful commands for development:
# run linter without persistence
npm run lint
# run linter and save edits
npm run lint:fix
# compile the library
npm run transpile
# run tests
npm run test
How to Add New Models and Methods
!NOTE: this section is moved to @mat3ra/standata.
The list of model and method entities is compiled from Yaml assets located in the ./assets directory
using the build_entities.js script. The assets processed by this script usually involve custom Yaml
types such as !combine to generate several entity configurations at once.
A new model or method may be added either by extending parameters of an existing entity or by adding a new asset file such as the following:
!combine
name:
template: 'Model{{ "-" + parameters.example }}' # set the model name using a template
# Loop over parameters to create combinations
forEach:
- !parameter
key: parameters.example # path of where to set the property
values: ["A", "B", "C"] # values to iterate over
isOptional: true
# static configuration (same for all created entities
config:
tags:
- example_model
- tutorial
schema: !esse 'schema-id-placeholder' # add a schema using the !esse type to validate each configuration
The above asset file will create four model configurations, "Model-A", "Model-B", "Model-C",
and "Model". The latter entity is created due to the isOptional flag of the example parameter.
There are a few more options available to customize the entity asset, for instance, the !combine type
has an exclusions property where conflicting pairs of entity properties can be defined, so that
combinations of those will be avoided.
For more examples, please see the asset files in ./assets or code.js
for the definition of Yaml types such as !combine or !parameter.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mat3ra_mode-2026.3.4.post0.tar.gz.
File metadata
- Download URL: mat3ra_mode-2026.3.4.post0.tar.gz
- Upload date:
- Size: 121.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/8.7.1 pkginfo/1.12.1.2 requests/2.32.5 requests-toolbelt/1.0.0 tqdm/4.67.3 CPython/3.10.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6df1ff29e84503d1a6056c2f488816d678d6754e7b17cc90836e3c71ef9f812d
|
|
| MD5 |
d1e4afb3a82cc5b06ce6dc2caa1f66e9
|
|
| BLAKE2b-256 |
94913f8dd2354476e70dd48573ec414b16e8954307bd8d4f6fe48e7704be6fae
|
File details
Details for the file mat3ra_mode-2026.3.4.post0-py3-none-any.whl.
File metadata
- Download URL: mat3ra_mode-2026.3.4.post0-py3-none-any.whl
- Upload date:
- Size: 8.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/8.7.1 pkginfo/1.12.1.2 requests/2.32.5 requests-toolbelt/1.0.0 tqdm/4.67.3 CPython/3.10.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
78cc4b1b38aa4079e5caa0208ddb60ce96a06589f33e1ce9b9b93a4ea0bc8de8
|
|
| MD5 |
59cb6939344f2f0e4134a776980f2d24
|
|
| BLAKE2b-256 |
b33ab6848a12da81537e6f613bfeb6c30a5a8da235339d13b9a2597fb4adc20f
|