Setting up Stable Baselines with Python 3.7 and WSL 2
data:image/s3,"s3://crabby-images/817b4/817b47542912128244e80d96a496adcab148f0ab" alt="Setting up Stable Baselines with Python 3.7 and WSL 2"
I've been playing around a bit with Stable Baselines lately for an upcoming project. However while playing, I encountered some issues seeing that Stable Baselines currently requires Tensorflow <= 1.14 which is only supported through Python < 3.8. Due those difficulties, I thought it would be interesting to share how I set up my personal development environment from scratch to play around with Stable Baselines.
Setting up WSL
First we need to set-up WSL. To do this, we enable te WSL platform as well as the VM platform. We can do this through the following commands in an elevated PowerShell window:
# Enable WSL
dism.exe /online /enable-feature /featurename:Microsoft-Windows-Subsystem-Linux /all /norestart
# Enable VM Platform
dism.exe /online /enable-feature /featurename:VirtualMachinePlatform /all /norestart
Once this is done, we can go to the Microsoft store and browse for the distribution we want and install it.
data:image/s3,"s3://crabby-images/96fbf/96fbf48505b47fa56c12a741edcfc759767606ce" alt=""
After installation, the last thing we have to do is to search for it in the Windows search bar, boot it and configure our username and password
data:image/s3,"s3://crabby-images/b71f1/b71f16139bd49faf502e90238d2e5ef34731cf4e" alt=""
data:image/s3,"s3://crabby-images/e2c02/e2c0234fecce573ded48f03dc497256eb51052dc" alt=""
WSL should now be set-up and ready to go!
Installing Python 3.7
By default Ubuntu 20.04 LTS comes with Python 3.8 (python3 --version
). We require Python 3.7, so we should change this. To change this, we can use the following commands:
# Install Deadsnales for Python3.7 package
sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt update
# Install Python 3.7
sudo apt install python3.7
# Set Python 3.7 as our default
sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.7 1
# Install Pip (also for sudo)
curl -s https://bootstrap.pypa.io/get-pip.py | python3
sudo curl -s https://bootstrap.pypa.io/get-pip.py | sudo python3
# Reconfigure Apt
sudo apt-get remove python3-apt
sudo apt-get install python3-apt
When we now check our package with python3 --version
, we can see that it shows Python 3.7.7
.
Installing Tensorflow 1.14
Now we have the correct Python version, we are able to install Tensorflow 1.14. For this we can simply run pip3 install tensorflow==1.14
which will download the tensorflow we require.
Running Stable Baselines
On to the interesting stuff, running stable baselines. For this we need to install its dependencies:
sudo apt update
sudo apt install cmake libopenmpi-dev python3-dev zlib1g-dev
pip3 install stable-baselines # Install without MPI
Whereafter we can run the following in a test.py
script and execute it with python3 test.py
:
import gym
from stable_baselines.common.policies import MlpPolicy
from stable_baselines.common.vec_env import DummyVecEnv
from stable_baselines import PPO2
env = gym.make('CartPole-v1')
# Optional: PPO2 requires a vectorized environment to run
# the env is now wrapped automatically when passing it to the constructor
# env = DummyVecEnv([lambda: env])
model = PPO2(MlpPolicy, env, verbose=1)
model.learn(total_timesteps=10000)
obs = env.reset()
for i in range(1000):
action, _states = model.predict(obs)
obs, rewards, dones, info = env.step(action)
env.render()
env.close()
Which will start-up the learning process! Congratulations, you are now ready to go and play with stable baselines 😉
data:image/s3,"s3://crabby-images/1206f/1206fa82e81c5520246e999e4d5dba8ca4a376f8" alt=""
Member discussion