Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thibo73800/metacar
A reinforcement learning environment for self-driving cars in the browser.
https://github.com/thibo73800/metacar
autonomous-vehicles browser pixijs reinforcement-learning self-driving-car tensorflowjs
Last synced: 2 months ago
JSON representation
A reinforcement learning environment for self-driving cars in the browser.
- Host: GitHub
- URL: https://github.com/thibo73800/metacar
- Owner: thibo73800
- Created: 2018-06-06T09:00:41.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2020-05-14T17:52:22.000Z (over 4 years ago)
- Last Synced: 2024-08-03T01:38:21.601Z (6 months ago)
- Topics: autonomous-vehicles, browser, pixijs, reinforcement-learning, self-driving-car, tensorflowjs
- Language: TypeScript
- Homepage: https://www.metacar-project.com/
- Size: 897 KB
- Stars: 369
- Watchers: 12
- Forks: 76
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-repositories - thibo73800/metacar - A reinforcement learning environment for self-driving cars in the browser. (TypeScript)
README
# Metacar: A reinforcement learning environment for self-driving cars in the browser.
[](https://www.metacar-project.com)
[![Contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=plastic)](CONTRIBUTING.md)
Metacar is a 2D reinforcement learning environment for autonomous vehicles running in the browser. The project aims to let reinforcement learning be more accessible to everyone through solving fun problems. Metacar comes with a set of a predefined levels, some harder to address than others. More levels and possibile scenarios will be added soon (pedestrian, bikes...). Furthermore, the library let you create your own levels and personalize the environment to create your desired scenario.
If you want to be part of the project, whether to implement features in the environment or demonstrate algorithms, feel free to join
the [slack channel](https://join.slack.com/t/metacar/shared_invite/enQtMzgyODI4NDMzMDc0LTY1MjIwNzk1MTAzOTBiZjJlOGUwM2YyYjA3MzBmNjQyNjUyMDZkOGNkYmU0MmUyYzUzNGRhNGJhZDE1M2EzNzM) to ask questions and talk about all your fantastic ideas!To start developing with metacar check out the Documentation and the [API Reference](http://metacar-project.com/docs/modules/_index_.html)
You can also take a look at the [online demo](https://www.metacar-project.com).
# Documentation
### Table of contents:
1. [Getting Started](#getting-started)
2. [Your first environment](#first-env)
3. [Interact with the environment](#interact-env)
4. [Custom the environment](#configure-env)
5. [Edit your own level](#create-level)### Installing Metacar
You can use Metacar with a direct link in your HTML file or install it from NPM. However, metacar is based on [Pixi.js](http://www.pixijs.com/): 4.7.1, then you need to include pixi.js as a global dependency in your HTML.
```html
Metacar: Documentation
```
#### OR Script Tag and NPM
```shell
npm i metacar
``````html
Metacar: Documentation
```
```javascript
import Metacar from "metacar";
```------------
Your first environment
------------Even if you can [create your own level](#create-level), Metacar comes up with a set of predefined levels accessible under [metacar.level](#). Once your level is selected, you can use it to create a first environment.
```javascript
// Select a level
const level = metacar.level.level1;
// Create the environement
const env = new metacar.env("env", level);
// Load it
env.load();
```You also have to create the container in your HTML file.
```html
```
(NOTE: metacar.env can be instantiated with an object or a string for the level parameters: [doc API](http://metacar-project.com/docs/classes/_metacar_.metacar.html#constructor))Wonderful! You just created your first metacar environment. You can take some time to play around with the arrow keys to move the car. The current collision system supports the detection of the following events:
* Collisions with other vehicles.
* Detection of the vehicles, ground, and road with the lidar.
* Detection of the car going out track.If you want to add new features to the detection system, you can consider [contributing to the project](https://github.com/thibo73800/metacar/blob/master/CONTRIBUTE.md) :)
Interact with the environment
------------### Action space
By default, the environment comes with a simple motion engine ([How to change the motion engine ?](#change-motion)) which lets you control the car with the arrow. Then, the actions are either UP, LEFT, RIGHT, DOWN, WAIT. Once the environment is loaded, you can take a look at the action space.
```javascript
env.load().then(() => {
console.log(env.actionSpace());
});
``````
{
type: "Discrete", // The number is discrete
size: 1, // Only one number is expected
range: [0, 1, 2, 3, 4] // The action can be either 0, 1, 2, 3 or 4
}
```### Play & Stop
Let's suppose your agent is already trained to move forward whatever happens (Fortunately we are in a simulation). Then you might want to test it in real time to see the result.
The quickest way to do so is to just ask the environment to call a given function at each loop turn.
```javascript
env.load().then(() => {env.addEvent("play", () => {
// Move forward
const reward = env.step(0);
// Log the reward
console.log(reward);
});});
```You should see a play button on the screen. On click, the car will move forward, and the reward should be positive as long as the car is on track, then negative when the car leaves the road.
To stop calling your function, you can add a stop button on the screen.
```javascript
env.load().then(() => {env.addEvent("play", () => {
// Move forward
const reward = env.step(0);
// Log the reward
console.log(reward);
});env.addEvent("stop", () => {
console.log("The stop button have been pressed.");
});});
```### Train your agent
During the training, the environment is not rendering on the screen anymore. Once your training is finish you have to notify the environment by calling env.render(true) to render the environment again.
The state of the environment is made of four fields:
```
{
a: number|undefined // Acceleration of the car (if any)
lidar: number[][] // Lidar points values
linear: number[] // The flatten lidar values + the current speed of the car
steering: number|undefined // Steering angle of the car (if any)
}
```Here is an example of simple training loop.
```javascript
env.load().then(() => {env.addEvent("train", () => {
for (let s=0; s < 100; s++){
// Get the current state of the lidar
const state = env.getState();
// Move forward
const reward = env.step(0);
}
// Log the reward
env.render(true);
});});
```### Reset and shuffle env
To reset the environment, you can either call
```javascript
env.reset();
```Or add a button to do it from the web page.
```javascript
env.load().then(() => {env.addEvent("custom", () => {
env.reset();
});});
```You can also shuffle the position of vehicles (agent and other cars) on the map.
```javascript
env.load().then(() => {env.addEvent("Shuffle only the agent", () => {
env.shuffle({cars: false});
});env.addEvent("Shuffle all", () => {
env.shuffle();
});});
```
Custom the environement
------------!WARNING: The method presented in this section must be called BEFORE loading the environment.
There are two motion engine available: BasicMotion and ControlMotion.
#### BasicMotion
This is the default motion engine. Movement of the car is either up, down, left, right or wait. The car turns from a given angle for the left and right action.
You can change the parameters of the motion engine using the setMotion method.
```javascript
env.setAgentMotion(metacar.motion.BasicMotion, {rotationStep: 0.25});
// Load the environment after having changed the properties.
env.load();
```#### ControlMotion
The motion control is based on two continuous values for the throttle and steering angle of the car. Then the action is an array of two floating values. (see [actionSpace](http://metacar-project.com/docs/classes/_metacar_.metacar.html#actionspace))
```javascript
env.setAgentMotion(metacar.motion.ControlMotion);
// Load the environment after having changed the properties.
env.load();
```### Change the lidar properties
There are four properties you can change. The number of points (pts) per line, the width and height of the area covered by the lidar and the position (pos) with respect to the car.
```javascript
env.setAgentLidar({pts: 3, width: 1.5, height: 1.5, pos: 1});
// Load the environment after having changed the properties.
env.load();
```### Stop the others vehicles
You can choose to move or stop the other vehicles with env.carsMoving()
```javascript
env.carsMoving(false);
// Load the environement after changing the propeties.
env.load();
```### Load a file from your computer
This features can be useful to load the content of one file from your computer (the result of a trained model for
instance).```javascript
env.load().then(() => {env.addEvent("load", (content) => {
// Here the content of the loaded file.
console.log(content);
},{local: true});});
```### Save a file on your computer
Also, you might want to save the result of a trained model on your computer.
```javascript
env.save("content of my model", "model.metacar")
```### Add a custom event
env.addEvent() comes with a set of predefined event ("train", "play", "stop", "reset_env", "load") but you can also create custom event with an associated button on the page. Bellow, an example of custom event saving a file onClick.
```javascript
env.load().then(() => {env.addEvent("My custom event", () => {
env.save("content of my model", "model.metacar");
});});
```Only three lines are required to create the editor:
```javascript
const level = metacar.level.level1;
var editor = new metacar.editor("env", level);
editor.load();
```Left click on one item to select it. Then Left click on the map to set the item.
Right click is used to remove an item.### Save the level
```javascript
editor.load().then(() => {editor.addEvent("save", (content) => {
// Save the content into the localstorage here or just
// retrieve the downloaded json.
}, {download: true, name: "mylevel.json"});});
```