Skip to main content

Description pending.

Project description

aiida-calcmonitor

AiiDA plugin that contains tools for monitoring ongoing calculations.

Development Install

git clone git@github.com:ramirezfranciscof/aiida-calcmonitor.git .
cd aiida-calcmonitor
pip install --upgrade pip
pip install -e .

# These are not available yet!
pip install -e .[pre-commit,testing]  # install extra dependencies
pre-commit install  # install pre-commit hooks
pytest -v  # discover and run all tests

Running the monitor test

To run the monitoring test you need to have an existing aiida profile. You must set up a computer in which to run the toymodel code (the aiida_calcmonitor/utils/toymodel_code.sh needs to be copied into the computer and you also need to setup a code in AiiDA). You can set up the localhost like this:

$ verdi computer setup -L localhost -H localhost -T local -S direct -w /scratch/{username}/aiida/ --mpiprocs-per-machine 1 -n
$ verdi computer configure local localhost --safe-interval 5 -n

For running the calcjob monitor calcjob, you will need to set up a special kind of localhost with the following Mpirun command: verdi -p <PROFILE_NAME> run (replacing <PROFILE_NAME> with the corresponding one). It also needs to have a prepend that activates the virtual environment that aiida is using. For a typical python virtual environment you can do something like this:

source /home/username/.virtualenvs/aiida/bin/activate

Once all if this is set up, you can use the example in /examples/example01/submit_everything.py as a template on how to prepare and submit a toymodel calculation and monitor.

Creating your own monitors

To create your own monitor, you need to subclass the MonitorBase class. This is a data type derived from Dict, so the idea is that you are going to create a sub-data type with a method that describes the checking procedure, you then are going to create a data node from that subtype which contains a dict with the options for that procedure, and the monitor code will get that data node input and call the checking method.

This is just an example to show the critical variables that are accessible from the parent class (self[...]) and the returns that need to be used, but the structure can be modified however it is necessary (no need to set and use the error_detected boolean for example, you can just return error messages in the middle of the checks).

class NewMonitorSubclass(MonitorBase):  # pylint: disable=too-many-ancestors
    """Example of monitor for the toy model."""

    def monitor_analysis(self):
        
        sources = self['sources']
        # this contains the mapping to the actual filepaths (see below)

        options = self['options']
        # this contains the specific options for this method (the structure is determined here in this method and the user must know what is expected when constructing it)

        retrieve = self['retrieve']
        # there will also be a list of files to retrieve if the original calculation is killed, but this should probably not be needed here

        internal_naming = sources['internal_naming']['filepath']
        # This is how you access the mapping for the files; now internal_naming contains the actual path to the file it requires

        with open(internal_naming) as fileobj:
            # Here one performs the parsing of the files and checking.
            # Setups the variables error_detected and error_msg or equivalent

        if error_detected:
            return f'An error was detected: {error_msg}'        
            # The calcjob_monitor will interpret string returns as errors and will kill the process
        else:
            return None
            # The calcjob_monitor will interpret None returns to mean everything is going fine

In order to be usable, you also need to add this as an entry point / plugin, inside of the pyproject.toml for example:

[project.entry-points."aiida.data"]
"calcmonitor.monitor.toymodel" = "aiida_calcmonitor.data.monitors.monitor_toymodel:MonitorToymodel"
"calcmonitor.monitor.newmonitor" = "aiida_calcmonitor.data.monitors.newmonitor_file:NewMonitorSubclass"

License

MIT

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

aiida_calcmonitor-0.1.0.tar.gz (100.5 kB view details)

Uploaded Source

Built Distribution

aiida_calcmonitor-0.1.0-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

Details for the file aiida_calcmonitor-0.1.0.tar.gz.

File metadata

  • Download URL: aiida_calcmonitor-0.1.0.tar.gz
  • Upload date:
  • Size: 100.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.28.1

File hashes

Hashes for aiida_calcmonitor-0.1.0.tar.gz
Algorithm Hash digest
SHA256 d1648730bc16df856f466805613dab79aa3b78969e0de351fa547cc0a1765ed2
MD5 d8683c3764e0590d4b2e12378127456b
BLAKE2b-256 35b1f12958f0e764b5ce38809fc362886996a95701965164e290a6df3347b013

See more details on using hashes here.

File details

Details for the file aiida_calcmonitor-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for aiida_calcmonitor-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cff141b562f6c74a48cf75d2a1b7a0da2387f238f4b4dc7150e5d6e7ac4b7320
MD5 31b3ba9da56936e6692e4fb54ef0db84
BLAKE2b-256 3360c5032f381b8f1c8d0084bba3f3ace9136b7f9b29d982e1c1bb6dfd125b48

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