Skip to main content

MOdel and method DEfinitions

Project description

npm version License: Apache

mode

MOdel DEfinitions in JS/TS/Py - houses entity definitions for:

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mat3ra_mode-2026.3.4.post0.tar.gz (121.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mat3ra_mode-2026.3.4.post0-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

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

Hashes for mat3ra_mode-2026.3.4.post0.tar.gz
Algorithm Hash digest
SHA256 6df1ff29e84503d1a6056c2f488816d678d6754e7b17cc90836e3c71ef9f812d
MD5 d1e4afb3a82cc5b06ce6dc2caa1f66e9
BLAKE2b-256 94913f8dd2354476e70dd48573ec414b16e8954307bd8d4f6fe48e7704be6fae

See more details on using hashes here.

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

Hashes for mat3ra_mode-2026.3.4.post0-py3-none-any.whl
Algorithm Hash digest
SHA256 78cc4b1b38aa4079e5caa0208ddb60ce96a06589f33e1ce9b9b93a4ea0bc8de8
MD5 59cb6939344f2f0e4134a776980f2d24
BLAKE2b-256 b33ab6848a12da81537e6f613bfeb6c30a5a8da235339d13b9a2597fb4adc20f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page