Skip to main content

Voilà/Jupyter client for searching through OPTIMADE databases.

Project description

OPTIMADE client (in Voilà)

Materials Cloud Binder

Query for and import structures from OPTIMADE providers (COD, Materials Cloud, 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

Default

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

from optimade_client 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 in App Mode
_ = 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.

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 -U numpy
$ pip install --no-binary :all: scipy
$ pip install optimade-client

or

$ pip install optimade-client
$ pip uninstall -y scipy
$ pip install --no-binary :all: scipy

GitHub

$ git clone https://github.com/CasperWA/voila-optimade-client.git
$ cd voila-optimade-client
voila-optimade-client$ pip install -r requirements.txt
voila-optimade-client$ pip install .

Note, both of these methods install scipy by rebuilding the binaries based on the local numpy installation. This can take a considerable time, but will result in a more stable application, especially concerning converting structures to other data formats for download.

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 at the URL.

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
...
[Voila] Voila is running at:
http://localhost:8866/
...

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

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"
...
[Voila] Voila is running at:
http://localhost:8866/
...

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

License

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

Contact

casper.andersen@epfl.ch
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-2020.9.15.dev2.tar.gz (44.4 kB view details)

Uploaded Source

File details

Details for the file optimade-client-2020.9.15.dev2.tar.gz.

File metadata

  • Download URL: optimade-client-2020.9.15.dev2.tar.gz
  • Upload date:
  • Size: 44.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.8.5

File hashes

Hashes for optimade-client-2020.9.15.dev2.tar.gz
Algorithm Hash digest
SHA256 01048b234a0f2f518ec3c97046fef1bbb98a638222db2c6b66e7b92530a53045
MD5 8cf74706790a0a582b18106407e60ec9
BLAKE2b-256 0ae3b18be46e27f7657c5fda08e626c59d04c9c7f14ed2e5f4b81f83c65ca3e3

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