Skip to content

Latest commit

 

History

History
85 lines (57 loc) · 2.06 KB

README.md

File metadata and controls

85 lines (57 loc) · 2.06 KB

clj-gym

Clojure bindings for OpenAI's gym-http-api server.

Installation

With Leiningen/Boot:

[mthomure/clj-gym "0.1.1-SNAPSHOT"]

With deps.edn:

mthomure/clj-gym {:mvn/version "0.1.1-SNAPSHOT"}

Usage

The clj-gym.core namespace follows OpenAI's API description.

(require '[clj-gym.core :as gym])

(gym/create "CartPole-v0")
"2f7eef5a"

(gym/envs)
{"2f7eef5a" "CartPole-v0"}

(gym/reset "2f7eef5a")
{:observation [0.023710455775827657 0.019351021639290936 0.011374305124354243 -0.016630857354495036]}

(gym/step "2f7eef5a" 0)
{:done false, :info {}, :observation [0.024097476208613477 -0.1759321880637575 0.011041687977264342 0.2796189824583605], :reward 1.0}

Get an idea of valid actions and observations using:

(gym/action-space "2f7eef5a")
{:n 2, :name "Discrete"}

(gym/observation-space "2f7eef5a")
{:high [4.8 3.4028234663852886E38 0.41887902047863906 3.4028234663852886E38], :low [-4.8 -3.4028234663852886E38 -0.41887902047863906 -3.4028234663852886E38], :name "Box", :shape [4]}

Talking to a remote server instance? Use the *url* dynamic variable.

(binding [gym/*url* "http://HOST:PORT"] (gym/envs))

Running the Server

The server is available from DockerHub. To render a video and access it in the monitor files:

docker run -p 5000:5000 -v /tmp:/tmp mthomure/openai-gym-server

Then run in a REPL:

(let [id (gym/create "CartPole-v0")]
  (gym/start-monitor id "/tmp/monitor" :video-callable true)
  (gym/reset id)
  (gym/step id 0 :render? true)
  (gym/close-monitor id))

The monitor files should be in /tmp/monitor on the host filesystem. Note the use of :video-callable and :render?, above.

Warning: If you start-monitor with an existing directory, you'll get an HTTP 500 error. In this case, use :force? or :resume?.

Rebuilding the Docker Image

cd docker/
docker build -t mthomure/openai-gym-server .
docker login
docker push mthomure/openai-gym-server