Skip to main content

Voilà/Jupyter client for searching through OPTIMADE databases.

Project description

OPTIMADE client (in Voilà)

MaterialsCloud Binder

Query for and import structures from OPTIMADE providers (COD, MaterialsCloud, NoMaD, Materials Project, ODBX, OQMD, and more ...).

Current supported OPTIMADE API versions: 1.0.0, 1.0.0-rc.2, 1.0.0-rc.1, 0.10.1

Run the client

This Jupyter-based app is intended to run either:

For AiiDAlab, use the App Store in the Home App to install it.

Usage

AiiDAlab

To use the OPTIMADE structure importer in your own AiiDAlab application write the following:

from aiidalab_widget_base import OptimadeQueryWidget
from aiidalab_widgets_base.viewers import StructureDataViewer
from ipywidgets import dlink

structure_query = OptimadeQueryWidget()
structure_viewer = StructureDataViewer()

# Save to `_` in order to suppress output
_ = dlink((structure_query, 'structure'), (structure_viewer, 'structure'))

display(structure_query)
display(structure_viewer)

This will immediately display a query widget with a dropdown of current structure databases that implements the OPTIMADE API.

Then you can filter to find a family of structures according to elements, number of elements, chemical formula, and more. See the OPTIMADE API specification for the full list of filter options and their description.

In order to delve deeper into the details of a particular structure, you can also import and display OptimadeResultsWidget.
See the notebook OPTIMADE-Client.ipynb for an example of how to set up a general purpose OPTIMADE importer.

Embedded

The query widget may also be embedded into another app.
For this a more "minimalistic" version of the widget can be used by passing embedded=True upon initiating the widget, i.e., structure_query = OptimadeQueryWidget(embedded=True).

Everything else works the same - so you would still have to link up the query widget to the rest of your app.

General Jupyter notebook

The package's widgets can be used in any general Jupyter notebook as well as AiiDAlab. Example:

from optimade_client import
    OptimadeQueryProviderWidget,
    OptimadeQueryFilterWidget,
    OptimadeSummaryWidget
from ipywidgets import dlink

database_selector = OptimadeQueryProviderWidget()
structure_query = OptimadeQueryFilterWidget()
structure_viewer = OptimadeSummaryWidget()

# Save to `_` in order to suppress output
_ = dlink((database_selector, 'database'), (structure_query, 'database'))
_ = dlink((structure_query, 'structure'), (structure_viewer, 'entity'))

display(database_selector, structure_query, structure_viewer)

This will use the package's own structure viewer and summary widget.

Note, the OptimadeQueryWidget mentioned above is a special wrapper widget in AiiDAlab for the OptimadeQueryProviderWidget and OptimadeQueryFilterWidget widgets.

Running application locally

First, you will need to install the package either from PyPI or by retrieving the git repository hosted on GitHub.

PyPI

pip install optimade-client[server]

GitHub

git clone https://github.com/CasperWA/voila-optimade-client.git
cd voila-optimade-client
pip install .[server]

Note, it is important to install the server extra in order to also install the voila package (and the ase package for a wider variety of download formats).

To now run the application (notebook) OPTIMADE-Client.ipynb you can simply run the command optimade-client in a terminal and go to the printed URL (usually http://localhost:8866) or pass the --open-browser option to let the program try to automatically open your default browser.

The application will be run in Voilà using Voilà's own tornado-based server. The configuration will automatically be copied to Jupyter's configuration directory before starting the server.

optimade-client

For a list of all options that can be passed to optimade-client use the -h/--help option.

Contribute

If you wish to contribute to the application, you can install it in "editable" mode by using the -e flag: pip install -e .[dev]. It is recommended that you use the GitHub-route mentioned above.

You should also install pre-commit in the cloned git repository by running:

pre-commit install

To start making contributions, fork the repository and create PRs.

Configuration (Voilà)

For running the application (in Voilà) on Binder, the configuration file jupyter_config.json can be used.
If you wish to start the Voilà server locally with the same configuration, either copy the jupyter_config.json file to your Jupyter config directory, renaming it to voila.json or pass the configurations when you start the server using the CLI.

Note: jupyter_config.json is automatically copied over as voila.json when running the application using the optimade-client command.

Locate your Jupyter config directory:

jupyter --config-dir
/path/to/jupyter/config/dir

Example of passing configurations when you start the Voilà server using the CLI:

voila --enable_nbextensions=True --VoilaExecutePreprocessor.timeout=180 "OPTIMADE-Client.ipynb"

To see the full list of configurations you can call voila and pass --help-all.

Running with "development" providers (Materials Cloud-specific)

Set the environment variable OPTIMADE_CLIENT_DEVELOPMENT_MODE to 1 (the integer version for True (1) or False (0)) in order to force the use of development servers for providers (currently only relevant for Materials Cloud).

License

MIT. The terms of the license can be found in the LICENSE file.

Acknowledgements

BIG-MAP BIG-MAP; This project has received funding from the European Union’s Horizon 2020 research and innovation programme under grant agreement No 957189. The project is part of BATTERY 2030+, the large-scale European research initiative for inventing the sustainable batteries of the future.

Contact

casper+github@welzel.nu
aiidalab@materialscloud.org

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

optimade-client-2023.8.30.tar.gz (178.2 kB view details)

Uploaded Source

Built Distribution

optimade_client-2023.8.30-py3-none-any.whl (181.8 kB view details)

Uploaded Python 3

File details

Details for the file optimade-client-2023.8.30.tar.gz.

File metadata

  • Download URL: optimade-client-2023.8.30.tar.gz
  • Upload date:
  • Size: 178.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for optimade-client-2023.8.30.tar.gz
Algorithm Hash digest
SHA256 efb580977043b0b6a9625437c782772b3a0907f8c18caa59a1499918b701bd65
MD5 b9bee504d2fb7d2e07d34a51908db96e
BLAKE2b-256 d30c685701b05d458a7a9d326524765b913a61bad37ad992694b0421b5b4c9c4

See more details on using hashes here.

File details

Details for the file optimade_client-2023.8.30-py3-none-any.whl.

File metadata

File hashes

Hashes for optimade_client-2023.8.30-py3-none-any.whl
Algorithm Hash digest
SHA256 3a190ac92acf44ef2aed519c81b1a90d3e760ce83c3981f2fb4152389cfc4a08
MD5 2bc452675cac01623ae0728ede7fe361
BLAKE2b-256 78523fa63d96a8ebb1d226165dcc7087017bac3549c9e19429f1dc77bf99f28b

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