Quadrotor dynamics and control for cable-suspended payload systems
Project description
A Python MuJoCo-based models and controllers for quadcopter cable-suspended payload systems.
Developed as part of the thesis: Dynamics and Control for Collaborative Aerial Manipulation (Kotaru, 2022). Original research code: vkotaru/floating_models. This package is the cleaned-up public release, refactored with Claude.
🚁 Quadrotor dynamics • 🎛 Geometric control on SE(3)/SO(3) • ⛓ Cable-suspended payloads • 🤝 Multi-quad cooperative transport • 🕹 MuJoCo simulation • 🖥 CLI interface
Installation
pip install udaan
MuJoCo is included as a core dependency. Install all extras (dev, docs, RL):
pip install udaan[all]
For development:
git clone https://github.com/vkotaru/udaan.git
cd udaan
pip install -e ".[all]"
Quick Start
CLI
# Quadrotor with geometric SE(3) control
udaan run quadrotor # MuJoCo (default)
udaan run quadrotor -m base # pure dynamics (no viz)
udaan run quadrotor -m vfx # VPython visualization
# Trajectory tracking
udaan run quadrotor --traj hover -p 1,1,0 # hover (default)
udaan run quadrotor --traj spiral -p 0,0,2 # helical spiral
udaan run quadrotor --traj lissajous -p 0,0,2 # 3D Lissajous
udaan run quadrotor --traj circle -p 0,0,1 # circular
# Cable-suspended payload
udaan run quad-payload -t 10 -m tendon # tendon model
udaan run quad-payload -t 10 -m links # rigid links
# Multi-quadrotor cooperative transport
udaan run multi-quad -n 3 -t 10 # N-quad pointmass payload
udaan run multi-quad-rigid -t 10 # rigid-body payload
# Fleet: compare controllers side-by-side
udaan run fleet --demo l1-comparison # L1 adaptive vs PD
udaan run fleet --demo gain-sweep # PD gain comparison
udaan run fleet -n 4 --trail # 4 quads with trails
# Recording
udaan run quadrotor -t 5 -r out.gif # save to GIF
udaan run quadrotor --traj spiral -r spiral.mp4 # save to MP4
Python
from udaan.models.quadrotor import QuadrotorBase, QuadrotorMujoco
# Pure dynamics (no rendering)
mdl = QuadrotorBase()
mdl.simulate(tf=10, position=[1., 1., 0.])
# MuJoCo with visualization
mdl = QuadrotorMujoco(render=True)
mdl.simulate(tf=10, position=[1., 1., 0.])
Documentation
Full API reference, controller roadmap, and tutorials coming soon at udaan.readthedocs.io.
License
BSD 3-Clause License. See LICENSE for details.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file udaan-1.2.1.tar.gz.
File metadata
- Download URL: udaan-1.2.1.tar.gz
- Upload date:
- Size: 73.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
21ed0bd90f9e22376455a48812ce88685830fa8b91e4f8744740f290ceba2f10
|
|
| MD5 |
105871b436f376b6752af17dd51a8e7c
|
|
| BLAKE2b-256 |
fa928b85feb244f354955955e199e58530c8643cd8946c2814a4c83295ed1a11
|
Provenance
The following attestation bundles were made for udaan-1.2.1.tar.gz:
Publisher:
publish.yml on vkotaru/udaan
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
udaan-1.2.1.tar.gz -
Subject digest:
21ed0bd90f9e22376455a48812ce88685830fa8b91e4f8744740f290ceba2f10 - Sigstore transparency entry: 1279402686
- Sigstore integration time:
-
Permalink:
vkotaru/udaan@6d9010d45c80efe190aa088e2477b1d6651a93ed -
Branch / Tag:
refs/tags/v1.2.1 - Owner: https://github.com/vkotaru
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@6d9010d45c80efe190aa088e2477b1d6651a93ed -
Trigger Event:
push
-
Statement type:
File details
Details for the file udaan-1.2.1-py3-none-any.whl.
File metadata
- Download URL: udaan-1.2.1-py3-none-any.whl
- Upload date:
- Size: 97.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3008fd7985c98d6dd1f688d248692d82cbe4805cf46509df35a093b4015478ce
|
|
| MD5 |
e085611f1062977471ef65853bb28020
|
|
| BLAKE2b-256 |
446a9a0ac464c365b90f8aac0f00c4d9a5049471f1a1d2decc76f16df7b3a3bd
|
Provenance
The following attestation bundles were made for udaan-1.2.1-py3-none-any.whl:
Publisher:
publish.yml on vkotaru/udaan
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
udaan-1.2.1-py3-none-any.whl -
Subject digest:
3008fd7985c98d6dd1f688d248692d82cbe4805cf46509df35a093b4015478ce - Sigstore transparency entry: 1279402768
- Sigstore integration time:
-
Permalink:
vkotaru/udaan@6d9010d45c80efe190aa088e2477b1d6651a93ed -
Branch / Tag:
refs/tags/v1.2.1 - Owner: https://github.com/vkotaru
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@6d9010d45c80efe190aa088e2477b1d6651a93ed -
Trigger Event:
push
-
Statement type: