Metadata-Version: 2.1
Name: hdeeprm
Version: 0.2.1b0
Summary: Evaluate Deep Reinforcement Learning policies for heterogeneous Workload Management
Home-page: https://github.com/RaMdsC/hdeeprm
Author: Adrián Herrera
Author-email: adr.her.arc.95@gmail.com
License: MIT
Keywords: deep reinforcement learning workload management job scheduling resource simulator framework heterogeneous cluster batsim
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3.6
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
Requires-Dist: defusedxml (>=0.5.0)
Requires-Dist: evalys (>=4.0.4)
Requires-Dist: gym (>=0.12.0)
Requires-Dist: lxml (>=4.3.2)
Requires-Dist: matplotlib (>=3.0.3)
Requires-Dist: numpy (>=1.16.2)
Requires-Dist: procset (>=1.0)
Requires-Dist: pybatsim (>=3.1.0)
Requires-Dist: torch (>=1.0.1.post2)

HDeepRM
=======

Framework for evaluating *workload management* policies based on
*deep reinforcement learning* for *heterogeneous* clusters.

.. include-overview-start

Overview
--------

*HDeepRM* is a Python framework for evaluating workload management policies
based on deep reinforcement learning for heterogeneous clusters. It
leverages the `Batsim ecosystem <https://gitlab.inria.fr/batsim>`_
for simulating a heterogeneous workload management context. This is composed
of the *simulator*, `Batsim <https://gitlab.inria.fr/batsim/batsim>`_ and the
*decision system*, `PyBatsim <https://gitlab.inria.fr/batsim/pybatsim>`_.

HDeepRM provides a heterogeneity layer on top of PyBatsim, which adds support
for user-defined resource hierarchies. Memory capacity and bandwidth conflicts
are added along with interdependence when consolidating or scattering jobs across
the data centre.

It offers a flexible API for developing deep reinforcement learning agents.
These may be trained by providing real workload traces in
`SWF format <http://www.cs.huji.ac.il/labs/parallel/workload/swf.html>`_ along
with platforms defined in the format specified in `Platforms <TODO>`_. They can
be further evaluated and tested against classic policies.

Installation Prerequisites
~~~~~~~~~~~~~~~~~~~~~~~~~~

HDeepRM is distributed as a Python package on
`PyPi <https://pypi.org/project/hdeeprm/>`_.
In order to download and install it, the following software is needed:

- Python3.6+, find your OS in this
  `installation guide <https://realpython.com/installing-python/>`_.
- Pip, the Python package manager. If not already available with the Python
  installation, follow the
  `official guide <https://pip.pypa.io/en/stable/installing/>`_.

Installation
~~~~~~~~~~~~

For installing HDeepRM, just download the package from PyPi:

.. code-block:: bash

  pip install --user hdeeprm

If ``pip`` is mapped to Python 2.x, try:

.. code-block:: bash

  pip3 install --user hdeeprm

When working with multiple Python versions, use:

.. code-block:: bash

  python3.6 -m pip install --user hdeeprm

This should download the ``hdeeprm`` package with all its dependencies,
which are:

- ``defusedxml`` >= 0.5.0: secure XML generation and parsing.
- ``gym`` >= 0.12.0: environment, actions and observations definitions.
- ``lxml`` >= 4.3.2: generation of the XML tree. Backend for ``defusedxml``.
- ``numpy`` >= 1.16.2: efficient data structure operations.
- ``procset`` >= 1.0: closed-interval sets for resource selection.
- ``pybatsim`` >= 3.1.0: decision system and main interface to interact
  with Batsim.
- ``torch`` >= 1.0.1.post2: deep learning library for agent definition.

Usage Prerequisites
~~~~~~~~~~~~~~~~~~~

The simulation side is done by Batsim, which is needed in order to run
HDeepRM experiments. Follow the `official installation docs
<https://batsim.readthedocs.io/en/latest/installation.html>`_ for instructions.

Usage
~~~~~

In order to experiment with HDeepRM, an integrated launcher is provided:

.. code-block:: bash

  hdeeprm-launch -a <agent.py> -im <saved_model.pt> -om <to_save_model.pt> <options.json>

The ``options.json`` specifies the experiment parameters. The JSON structure
is as follows:

.. code-block:: json

  {
    "seed": "",
    "nb_resources": "",
    "nb_jobs": "",
    "workload_file_path": "",
    "platform_file_path": "",
    "pybatsim": {
      "log_level": "",
      "env": {
        "objective": "",
        "queue_sensitivity": ""
      },
      "agent": {
        "type": "",
        "policy_pair": "",
        "run": "",
        "hidden": "",
        "lr": "",
        "gamma": ""
      }
    }
  }

Global options:

* ``seed`` - The random seed for evaluation reproducibility.
* ``nb_resources`` - Total number of cores in the simulated platform.
* ``nb_jobs`` - Total number of jobs to generate in the workload.
* ``workload_file_path`` - Location of the original SWF formatted workload.
* ``platform_file_path`` - Location of the original
  HDeepRM JSON formatted platform.

PyBatsim options:

* ``log_level`` - Logging level for showing insights from the simulation. See `Logging <https://docs.python.org/3.6/howto/logging.html>`_ for reference on possible values.

PyBatsim - Environment options:

* ``objective`` - Metric to be optimised by the agent. See `Objectives <TODO>`_ for an explanation and recognised values.
* ``queue_sensitivity`` - Sensitivity of the observation to variations in job queue size. See `Hyperparameters - Queue Sensitivity <TODO>`_.

PyBatsim - Common agent options:

* ``type`` - Type of the scheduling agent, one of *CLASSIC* or *LEARNING*.

PyBatsim - `Classic <https://hdeeprm.readthedocs.io/en/latest/source/packages/hdeeprm.agent.html#hdeeprm.agent.ClassicAgent>`_ agent options:

* ``policy_pair`` - The job and resource selection policies. Policy pairs are further described in `Environment - Action Space <TODO>`_.

PyBatsim - `Learning <https://hdeeprm.readthedocs.io/en/latest/source/packages/hdeeprm.agent.html#hdeeprm.agent.LearningAgent>`_ agent options:

* ``run`` - Type of run for the learning agent, one of *train* or *test*.
  When training, the agent's inner model is updated,
  whereas testing is meant for evaluation purposes.
* ``hidden`` - Number of units in each hidden layer from the agent's inner model. See `Hyperparameters - Hidden units <TODO>`_.
* ``lr`` - Learning rate for updating the agent's inner model. See `Hyperparameters - Learning rate <TODO>`_.
* ``gamma`` - Discount factor for rewards. See `Hyperparameters - Reward Discount Factor <TODO>`_.

This is an example of an ``options.json`` file
for a classic agent:

.. code-block:: json

  {
    "seed": 2009,
    "nb_resources": 2280,
    "nb_jobs": 10000,
    "workload_file_path": "/workspace/workloads/my_workload.swf",
    "platform_file_path": "/workspace/platforms/my_platform.json",
    "pybatsim": {
      "log_level": "DEBUG",
      "env": {
        "objective": "avg_utilization",
        "queue_sensitivity": 0.05
      },
      "agent": {
        "type": "CLASSIC",
        "policy_pair": "shortest-high_flops"
      }
    }
  }


This is another example of an ``options.json`` file,
in this case for a learning agent:

.. code-block:: json

  {
    "seed": 1995,
    "nb_resources": 2280,
    "nb_jobs": 10000,
    "workload_file_path": "/workspace/workloads/my_workload.swf",
    "platform_file_path": "/workspace/platforms/my_platform.json",
    "pybatsim": {
      "log_level": "WARNING",
      "env": {
        "objective": "makespan",
        "queue_sensitivity": 0.01
      },
      "agent": {
        "type": "LEARNING",
        "run": "train",
        "hidden": 128,
        "lr": 0.001,
        "gamma": 0.99
      }
    }
  }

Extra command line arguments are available for learning agent simulations:

- The ``agent.py`` file contains your developed learning agent for evaluation.
  See `agent examples <TODO>`_ for reference.

- The ``inmodel`` optional argument may be used for providing a path
  to a previously trained and saved model. HDeepRM will load this model
  before starting the run.

- The ``outmodel`` optional argument may be specified as a path for
  saving the model after the run is finished. If not provide, the model
  won't be saved. This is usually combined with *train* runs.

.. include-overview-end


