Skip to main content

A Python library to train machine learning models for defect prediction of infrastructure code.

Project description

Build Documentation LGTM Grade pypi-version pypi-status release-date python-version

radon-defect-prediction

The RADON command-line client for Infrastructure-as-Code Defect Prediction.

How to Install

From PyPI:

pip install radon-defect-predictor

From source code:

git clone https://github.com/radon-h2020/radon-defect-prediction.git
cd radon-defect-predictor
pip install -r requirements.txt
pip install .

Quick Start

usage: radon-defect-predictor [-h] [-v] {train,predict,model} ...

A Python library to train machine learning models for defect prediction of infrastructure code

positional arguments:
  {train,predict,model}
    train               train a brand new model from scratch
    model               get a pre-trained model to test unseen instances
    predict             predict unseen instances

optional arguments:
  -h, --help            show this help message and exit
  -v, --version         show program's version number and exit

How to build Docker container

docker build --tag radon-dp:latest .

How to run Docker container

First, create a host volume to share data and results between the host machine and the Docker container:

mkdir /tmp/radon-dp-volume/

Train

Create a training dataset metrics.csv and copy/move it to /tmp/radon-dp-volume/. See how to generate the training data for defect prediction here.

Run:

docker run -v /tmp/radon-dp-volume:/app radon-dp:latest radon-defect-predictor train metrics.csv ...

See the docs for more details about this command.

The built model can be accessed at /tmp/radon-dp-volume/radondp_model.joblib.

Model

Run:

docker run -v /tmp/radon-dp-volume:/app radon-dp:latest radon-defect-predictor download-model ...

See the docs for more details about this command.

The downloaded model can be accessed at /tmp/radon-dp-volume/radondp_model.joblib.

Predict

Move the model and the files to predict in the shared volume. For example, if you want to run the prediction on a .csar, then

cp patah/to/file.csar /tmp/radon-dp-volume.

Alternatively, you can create a volume from the folder containing the .csar (in that case, make sure to move the model within it).

Run:

docker run -v /tmp/radon-dp-volume:/app radon-dp:latest radon-defect-predictor predict ...

See the docs for more details about this command.

The predictions can be accessed at /tmp/radon-dp-volume/radondp_predictions.json.

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

radon-defect-predictor-0.2.7.tar.gz (13.5 kB view details)

Uploaded Source

Built Distribution

radon_defect_predictor-0.2.7-py3-none-any.whl (15.1 kB view details)

Uploaded Python 3

File details

Details for the file radon-defect-predictor-0.2.7.tar.gz.

File metadata

  • Download URL: radon-defect-predictor-0.2.7.tar.gz
  • Upload date:
  • Size: 13.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.5

File hashes

Hashes for radon-defect-predictor-0.2.7.tar.gz
Algorithm Hash digest
SHA256 3b13cb01af853399d69ddbd6c757235337020211dc3484027653038856f70b89
MD5 0f444a0c55b850aa3cde86710b52b526
BLAKE2b-256 1a182a5eae2c8a7023c549bd9243a91604d064ea19bff2626300161478e3fe7b

See more details on using hashes here.

File details

Details for the file radon_defect_predictor-0.2.7-py3-none-any.whl.

File metadata

  • Download URL: radon_defect_predictor-0.2.7-py3-none-any.whl
  • Upload date:
  • Size: 15.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.5

File hashes

Hashes for radon_defect_predictor-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 9ef9a0e3a098db215a2bdf328854bc1f56d2de77b277d070876d40e710fd1626
MD5 7aa534d7b147c2d602fe703ab57d266a
BLAKE2b-256 a22bb1f6e3d115a559a992092b069bd4e4865616c4ff7bc3f21e48f67b8fa6b3

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