Skip to main content

A NOMAD plugin for analysis of FAIR data.

Project description

NOMAD

NOMAD's Analysis plugin

This is a plugin for NOMAD to facilitate analysis of processed entry archives using classes and functions. The plugin also supports ELN schemas which allow the use of these functions in Jupyter notebooks and persist the analysis workflow.

To install the package as a dependency for your NOMAD Oasis, add it to your pyproject.toml as under project.dependencies table:

[project]
dependencies = [
    ...
    "nomad-analysis",
]

Or you can use pip to install the package in your Python environment:

pip install nomad-analysis

Development

The plugin is still under development. If you would like to contribute, follow these steps:

Install the dependencies

Clone the project and go into the cloned directory. Create and start a virtual environment (note this project uses Python 3.11):

git clone https://github.com/FAIRmat-NFDI/nomad-analysis.git
cd nomad-analysis
python3.11 -m venv .pyenv
source .pyenv/bin/activate

Install the nomad-analysis package in editable mode (with -e flag) along with development dependencies (with '.[dev]'):

pip install --upgrade pip
uv pip install -e '.[dev]'

Note: uv uses NOMAD's internal package registry via index-url defined under tool.uv.index-url in pyproject.toml. If you want to use pip directly without uv wrapper, use the following:

pip install -e '.[dev]' --index-url https://gitlab.mpcdf.mpg.de/api/v4/projects/2187/packages/pypi/simple

Run the tests

You can run the unit testing using the pytest package:

python -m pytest -sv

We recommend to install the coverage and coveralls packages for a more comprehensive output of the testing:

pip install coverage coveralls
python -m coverage run -m pytest -sv

Set up the plugin on your local installation

Read the NOMAD plugin documentation for all details on how to deploy the plugin on your local NOMAD installation. In summary:

  1. Install the plugin repo in your local installation environment

    pip install -e <path to the plugin repo>
    
  2. From the following available entry points, include the ones you want (or all) in the nomad.yaml of your local installation:

    plugins:
      include:
        - nomad_analysis.general:schema
        - nomad_analysis.jupyter:schema
    

Run linting and auto-formatting

Ruff auto-formatting is also a part of the GitHub workflow actions. Make sure that before you make a Pull Request to add your contributions to this repo, the following commands run in your local without any errors otherwise the workflow action will fail.

ruff check .
ruff format . --check

Alternatively, if you are using VSCode as your IDE, we added the settings configuration file, .vscode/settings.json, such that it performs ruff format whenever you save progress in a file.

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

nomad_analysis-0.0.6.tar.gz (124.9 kB view details)

Uploaded Source

Built Distribution

nomad_analysis-0.0.6-py3-none-any.whl (26.4 kB view details)

Uploaded Python 3

File details

Details for the file nomad_analysis-0.0.6.tar.gz.

File metadata

  • Download URL: nomad_analysis-0.0.6.tar.gz
  • Upload date:
  • Size: 124.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for nomad_analysis-0.0.6.tar.gz
Algorithm Hash digest
SHA256 1d10d917d049a6e383b782e5d9004364437be9d1d79937da756e05d1e6f91707
MD5 63f7d87cf5093e7f95c0eb46ce1194d5
BLAKE2b-256 683137e231abe5b22c7e27c8092d64b5689fff307f2b261071401b11a6264a3d

See more details on using hashes here.

File details

Details for the file nomad_analysis-0.0.6-py3-none-any.whl.

File metadata

File hashes

Hashes for nomad_analysis-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 b6c5402aaf41ed8f566974b055d5f57fb7796c0076c2f2cdc5b05466edd1c285
MD5 4c7aa618510ff4f1f0c52d254c2bb127
BLAKE2b-256 ab6cf068505c7ed749359f9505fad7b24bdead08f1319379bf85274da68c9aab

See more details on using hashes here.

Supported by

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