Skip to content

Experimental Evaluation of Deep Learning on Imbalanced Data Sets and Training for Rare Events

License

Notifications You must be signed in to change notification settings

lifezoned4/ImbalancedDataAndRareEventsInDeepLearning

Repository files navigation

Experimental Evaluation of Deep Learning on Imbalanced Data Sets and Training for Rare Events

Experimental part of master thesis at the university of Duisburg-Essen at the department of "Modellierung Adaptiver Systeme". Read the thesis for further understanding of the experiments.

Experimental running guide:

Be aware about the fact that these experiments were only tested on Linux (using Ubuntu 16.04 LTS). Experiment 1 can probably run on MS Windows 10, but experiment 2 depends on atari_py using ALE which was in context of OpenAI's gym not runnable on Windows 10.

A GPU is needed to run them effectively. We tested this experiments on a Nvidia Geforce 1070 Ti with 8 GB of VRAM.

Both experiments depend on Rscript, python 3.6 and needed following R libraries.

Do this in your user/global R environment:

install.packages("tidyverse")
install.packages("scales")
install.packages("Hmisc")

Experiment 1 (supervised experiment):

  1. Copy code on a read-write medium (skip if you git clone)
  2. Install dependencies
    1. Create a virtual python environment and active it.
    virtualenv -p python3 ./src.experiment1/
    source src.experiment1/bin/activate
    1. Install numpy.
    pip3 install -U numpy==1.14.5
    1. Install tensorflow in GPU mode and check if it runs correctly. (Beware of addition steps need in GPU mode. You need proprietary libraries from e.g. Nvidia )
    pip3 install -U tensorflow-gpu==1.8
    python -c "import tensorflow as tf; print(tf.__version__)"
    1. Install pandas.
    pip3 install -U pandas
    1. Install scikit-learn.
    pip3 install -U sklearn
    1. Install imbalanced-learn.
    pip3 install -U imblearn
  3. Create a new directory which will contain the results.
mkdir ./src.experiment1/<timestamp>.data
  1. Change directory to the data folder.
cd ./src.experiment1/<timestamp>.data
  1. Run the core experiment (will take approximately more than 48h).
bash ../run_experiment1.sh
  1. Yield results.

Experiment 2 (DQN experiment):

  1. Copy code on a read-write medium (skip if you git clone)
  2. Install dependencies
    1. Create a virtual python environment and activate it.
    virtualenv -p python3 ./src.experiment1/
    source src.experiment1/bin/activate
    1. Install numpy.
    pip3 install -U numpy==1.14.5
    1. Install tensorflow in GPU mode and check if it runs correctly. (Beware of addition steps need in GPU mode. You need proprietary libraries from e.g. Nvidia )
    pip3 install -U tensorflow-gpu==1.8
    python -c "import tensorflow as tf; print(tf.__version__)"
    1. Install opencv. It is needed by baselines.
    pip3 install -U opencv-python
    1. Install atari_py. It is needed by gym.
    pip3 install -U atari_py
    1. Install OpenAI gym.
    pip3 install -U gym==0.10.5
    1. Install OpenAI baselines. Note that baselines is monkey punched and is already in the repository.
    cd ./src.experiment2/baselines/
    pip3 install -U -e .
  3. Create a new directory which will contain the results.
mkdir ./baselines/deepq/experiments/<timestamp>.data
  1. Change directory to the data folder.
cd ./baselines/deepq/experiments/<timestamp>.data
  1. Run the core experiment (will take approximately more than 48h).
bash ../run_pong_experiment.sh
  1. Yield results.

Experiment 1 and 2:

Option to run both experiments after each other (first experiment1, second experiment2):

  1. Do both step 1 and step 2 from instructions from each experiment.
  2. Run script (takes more than four days of computation)
bash run_all_experiment.sh
  1. enjoy the results in the folders mentioned in top part.

Possible issues:

python packages version missmatch

Be aware when some packages forcing numpy, tensorflow-gpu or gym to be on wrong version. Check on each step if any new versions of this packages were forced to be installed.

No tensorflow-gpu

Check if no tensorflow duplicate packages are in environment.

pip3 list | grep tensorflow

Should return that only tensorflow-gpu is installed and no tensorflow (without gpu) is installed.

Tensorflow in CPU mode:

When no GPU is available you can install tensorflow in CPU mode Replace step 1.3 in the experiments by

pip3 install -U tensorflow==1.8

Be warned that running the experiment on CPU takes ages.

Experiments run "damn too slow"

Check if you using GPU (on NVIDIA for example with)

nvidia-smi

GPU VRAM is too small:

Experiments will fail when they not fit in VRAM. We tested only with 8 GB of VRAM. When fewer VRAM is available the running scripts should be adjusted by hand to do smaller parallel runs of in each experiment. (just put some 'wait' between the calls)

You can check available VRAM for example on a nvidia GPU with:

nvidia-smi

About

Experimental Evaluation of Deep Learning on Imbalanced Data Sets and Training for Rare Events

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published