Python bindings for the L2F (Learning to Fly) Simulator
Project description
L2F: Learning to Fly Simulator
pip install l2f
This repo contains Python bindings for the simulator introduced in Learning to Fly in Seconds.
Please check the example for how to use it.
CUDA
For the CUDA usage please refer to rl-tools/l2f-benchmark
Getting Started
Install UIServer (forwards states to HTML/JS UI) and the foundation-policy (a general quadrotor policy)
pip install l2f ui-server foundation-policy
Run the UIServer
ui-server
Navigate to http://localhost:13337 This is run separately from the client code such that you can keep the browser open, without windows popping up and going away when re-running your code. Also the camera perspective is maintained across runs.
Then run e.g.:
from copy import copy
import numpy as np
import asyncio, websockets, json
import l2f
from l2f import vector8 as vector
from foundation_model import QuadrotorPolicy
policy = QuadrotorPolicy()
device = l2f.Device()
rng = vector.VectorRng()
env = vector.VectorEnvironment()
ui = l2f.UI()
params = vector.VectorParameters()
state = vector.VectorState()
observation = np.zeros((env.N_ENVIRONMENTS, env.OBSERVATION_DIM), dtype=np.float32)
next_state = vector.VectorState()
vector.initialize_rng(device, rng, 0)
vector.initialize_environment(device, env)
vector.sample_initial_parameters(device, env, params, rng)
vector.sample_initial_state(device, env, params, state, rng)
async def main():
uri = "ws://localhost:13337/backend"
async with websockets.connect(uri) as websocket:
handshake = json.loads(await websocket.recv(uri))
assert(handshake["channel"] == "handshake")
namespace = handshake["data"]["namespace"]
ui.ns = namespace
ui_message = vector.set_ui_message(device, env, ui)
parameters_message = vector.set_parameters_message(device, env, params, ui)
await websocket.send(ui_message)
await websocket.send(parameters_message)
policy.reset()
for _ in range(500):
vector.observe(device, env, params, state, observation, rng)
action = policy.evaluate_step(observation[:, :22])
dts = vector.step(device, env, params, state, action, next_state, rng)
state.assign(next_state)
ui_state = copy(state)
for i, s in enumerate(ui_state.states):
s.position[0] += i * 0.1 # Spacing for visualization
state_action_message = vector.set_state_action_message(device, env, params, ui, ui_state, action)
await websocket.send(state_action_message)
await asyncio.sleep(dts[-1])
if __name__ == "__main__":
asyncio.run(main())
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file l2f-2.0.12.tar.gz.
File metadata
- Download URL: l2f-2.0.12.tar.gz
- Upload date:
- Size: 463.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1f3943ddcf919dd016d09ba08b29ae0bfd2b49ddce09678823755d7170b9588d
|
|
| MD5 |
02a9a3802f96a46e82f2905c99f92d23
|
|
| BLAKE2b-256 |
24a0f593e43cb67164d59a234fd22b4062ea3c63556a5f5587341011df150148
|