aboutsummaryrefslogtreecommitdiff
path: root/dga/README.md
blob: 1ea4323f944199e91422a6ae444d03b31c323284 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# Overview

This folder contains training and inference scripts for two models based on different technologies: MLP (multi-layer perceptron) using scikit-learn and an LSTM-based neural network using TensorFlow. Each model has its own folder with training and testing scripts. Developers interested in DGA detection in nDPI should also visit [this folder](../tests/dga) containing the original ML implementation.

The test scripts only show how to use an already-trained model.

## Requirements

To install the necessary dependencies, run

```bash
pip install -r requirements.txt
```

## How to use the scripts

### 1. scikit-learn (MLP model)

**Folder**: `scikit-learn_tests`.

#### Training

To train the MLP model, run the training script:

```bash
python scikit-learn_tests/training_script.py
```

#### Inference

After training, you can perform inference using the test script:

```bash
python scikit-learn_tests/test_script.py
```

### 2. TensorFlow (LSTM model)

**Folder**: `tensorflow_tests`.

#### Training

To train the LSTM model, run the training script

```bash
python tensorflow_tests/training_script.py
```

#### Inference

Once training is complete, you can run inference on the test set with

```bash
python tensorflow_tests/test_script.py
```