Automated virtual experiment that simulates adsorption isotherms on nanoporous materials using the RASPA software package.
- Launching the virtual experiment
- Using custom database of CIF files
- Help and Support
- Contributing
- License
If you have a container runtime such as docker, podman, rancher desktop, etc available on your system you can execute the experiment by:
- creating a python virtual environment, activating it, and installing the python module
st4sd-runtime-core[develop]>=2.2.0
- cloning this repository
- launching the experiment For example:
#!/usr/bin/env sh
: # Download virtual experiment
git clone https://github.com/st4sd/nanopore-adsorption-experiment.git
: # Setup ST4SD runtime-core
python3 -m venv --copies venv
. venv/bin/activate
python3 -m pip install "st4sd-runtime-core[develop]>=2.2.0"
: # Go inside the directory of this repository.
: # The next command executes the experiment in there
cd nanopore-adsorption-experiment
: # Run the experiment
elaunch.py --applicationDependencySource="nanopore-database=cif:copy" \
--manifest=manifest.yaml \
--input=docker_example/cif_files.dat \
workflow_definitions/adsorption.yaml
Note: Make sure you run the git clone
command in a directory that your container runtime (e.g.docker
, podman
, etc) can mount later when you execute the experiment.
Note: Using a container runtime is intended for small scale experiments and/or debugging your experiments. Use the kubernetes
example below to launch larger experiments.
Follow our end to end example notebook to launch our nanopore-adsorption-experiment
experiment on your ST4SD Cloud instance.
You may download the CIF files of your choosing to a PVC inside your OpenShift cluster (below we use the name nanopore-database-pvc
), mount it as a volume and ask the virtual experiment instance to use the contents of the PVC as the contents of the nanopore-database
application-dependency.
file_names = [""]
payload = {
"volumes": [{
"type": {"persistentVolumeClaim": "nanopore-database-pvc"},
"applicationDependency": "nanopore-database"
}],
# other fields
}
rest_uid = api.api_experiment_start("nanopore-adsorption-experiment", payload)
Note: The example notebook shows a full example.
Please feel free to create an issue and alert the maintainers listed in the MAINTAINERS.md page.
We always welcome external contributions. Please see our guidance for details on how to do so.
This project is licensed under the Apache 2.0 license. Please see details here.