ﺏ
The 2022 Gamma Team Integrated Swarm System Repository Reduced In Scope for 1 Drone Navigation Flight. It is open to development and its usability has been confirmed in swarm studies. This repository covers Minimum Snap Aggressive Trajectory Generation that passes through specific waypoints.
The 2022 Gamma Team Minimum Snap Trajectory Repository reduced in scope for 1 drones that covers this action:
- Takeoff
- Loiter
- Navigation Flight
- Landing
with CrazyFlie 2.1 drones. It is open to development and its usability has been confirmed in swarm studies.
Or you can look Teknofest 2023 Heterogeneous Swarm Robots Competition Project Report at 2️⃣'nd place team❗
Real Flight Test videos will be uploaded soon!
🆗 After our tests, we guarantee that the real flight and simulation behavior will be largely similar. For this reason, do not hesitate to develop algorithms on simulation.
This repository was developed on Ubuntu 20.04 and all tests were performed in this environment with ROS Noetic. The system is built on the ROS Noetic version. It is recommended to use the following configurations:
Ubuntu 20.04
ROS Noetic :
http://wiki.ros.org/noetic/Installation/Ubuntu
Firs create folder with name:
cd
mkdir catkin_ws
Download the package with git clone or from IDE.
cd catkin_ws
git clone https://github.com/imamim/minsnap-crazyflie.git
Then run the catkin_make
command at main directory.
cd minsnap-crazyflie
catkin_make
After make, install pybullet
cd src/minsnap/src/
pip3 install -e .
Go the main directory catkin_ws and do catkin_make
cd
cd catkin_ws/minsnap-crazyflie
catkin_make
Lastly add your setup.bash file your system .bashrc
gedit ~/.bashrc
Then if you don't source ROS do this:
source /opt/ros/noetic/setup.bash
And add this two line you last line of .bashrc file:
source /home/Your_Computer_username/catkin_ws/minsnap-crazyflie/devel/setup.bash
After that close current terminal and open new terminal.
For V1.0 of system, you can use this 1 line code (After Setup Process you can do this):
roslaunch minsnap allRun.launch
If you want configure of mission parameter please refer this code:
src/minsnap/src/minsnap/mainSystem/mission.py
For more information about all parameters please refer this 2 code which that given relative path!
src/minsnap/src/minsnap/mainSystem/Parameters.py
src/minsnap/src/minsnap/simulationSystems/SimulationParameter.py
You will find a simple example of creating a mission under this heading. For detailed information about where each parameter is used, please review the wiki. (Or create discussion)
Let the requirements of the task we want to do be as follows. Let's say we have 4 aircraft. We want to lift these vehicles to a height of 1 meter and form them into a two-dimensional V-shaped formation in the air. After this formation is taken, it is desired to navigate to a certain point while preserving the formation. After completing these tasks, the aircraft land.
Open src/GammaSwarm/src/GammaSwarm/mainSystem/mission.py
It is very important for the flight order that the swarm forms a formation before each navigation. Navigation without entering the formation is not recommended. If you want the aircraft to navigate on its own, please see the Individual Navigation resource ❗
modeList = [
#TODO Simulation does not work with 1 agent, this mainSystem can work 1 drone but we have problem at simulation. Can't render drone.
#For information of parameters pls look at Parameters.py
{MISSIONMODES.initialize : InitializerParams(number_of_agent = 4,simulation_enabled = True,real_enabled = False, starting_formation = FORMATIONTYPES.common, area_dimension = [(-1.6, 1.6), (-1.9, 1.9), (0, 1.5)])},
{MISSIONMODES.take_off : TakeoffParams(takeoff_height = 1.0 ,threshold = 0.08)} ,
{MISSIONMODES.loiter : LoiterParams(loiter_time = 3)} ,
{MISSIONMODES.formation2D : FormationParams2D(formation_type = FORMATIONTYPES.v,each_distance = 0.65,corner_count = 4,threshold=0.07)},
{MISSIONMODES.loiter : LoiterParams(loiter_time = 3)},
{MISSIONMODES.navigation : NavigationParams(agressiveness_kt = 30 ,max_velocity = 1, navigation_waypoints = [Position(1,1,1)], threshold = 0.08)},
{MISSIONMODES.formation2D : FormationParams2D(formation_type = FORMATIONTYPES.v,each_distance = 0.65,corner_count = 4,threshold=0.07)},
{MISSIONMODES.loiter : LoiterParams(loiter_time = 3)},
{MISSIONMODES.landing : LandingParams(threshold = 0.07)},
{MISSIONMODES.completed : True}
]
First open src/GammaSwarm/src/GammaSwarm/realSystems/realManager.py
-> Line of codes for URI's of CrazyFlies
self.uris = [
"radio://0/125/2M/E7E7E7E7C1",
"radio://0/125/2M/E7E7E7E7C2",
"radio://1/115/2M/E7E7E7E7C3",
"radio://1/115/2M/E7E7E7E7C4",
"radio://2/105/2M/E7E7E7E7C9"
] #TODO degisecek
cflib-python referenced below uses a structure called URI to connect to drones. For more detailed information, please review User Guide.
The format that the library mentioned above uses for URI's :
"radio://dongle_id/channel/radio_bandwith/E7E7E7E7hex_number_of_id"
-
dongle_id : It is assigned automatically, does not require any settings. Only the channel of the devices assigned for each dongle_id must be the same.
-
channel : It is the channel value you assign to the drone via cfclient. Between each dongle the channel should be reduced by 10's. (125,115,105...)
-
radio_bandwith : It is the communication bandwidth of the vehicle. Normally it can be edited via cfclient. However, making changes is not recommended. (2 Mbit/s)
-
hex_number_of_id : It corresponds to the last 2 digits of the address that identifies the vehicle. These last two digits must be the hex equivalent of a decimal number you want. It can be continued by starting from C1.
Points to be taken into consideration are as follows:
-
Healthy results were obtained when 2 drones were as#to each CrazyRadio Dongle.
-
Set the channel and URI settings for your drones so that there are 2 drones for each channel, with the channel value starting from 125!
Edit the CrazyFlie2.1 URI's and channels you will use, paying attention to the necessary points. Then, when you integrate these into the code, you can perform the real flight. Your flight will start 10 seconds after initializing the code
-
Initialize mode will already be in the main source code. This mode should always be at the top of the list and only its parameters should be edited.
-
If we want to make our flight only in a simulation environment
(
simulation_enabled = True
,real_enabled = False
) -
If we want to make our flight only in its real application
(
simulation_enabled = False
,real_enabled = True
)❗ The situation where both real and simulation environments work simultaneously has not been implemented.
-
Let's have 4 aircraft (
number_of_agent = 4
) -
The starting formation must remain common.
(
starting_formation = FORMATIONTYPES.common
)❗ Area dimensions does not matter! It is taken only as input to be used in other tasks.
-
Let's add Takeoff mode to the list
{MISSIONMODES.take_off : TakeoffParams(takeoff_height = 0.7 ,threshold = 0.08)} ,
-
We want all vehicles to take off 1 meter above the ground.
(
takeoff_height = 1.0
) -
A loiter should be added between each mode. Loiter time can be adjusted to the desired value as long as it is not too small.
{MISSIONMODES.loiter : LoiterParams(loiter_time = 3)} ,
-
Now the takeoff is over and we can get into formation.
{MISSIONMODES.formation2D : FormationParams2D(formation_type = FORMATIONTYPES.v,each_distance = 0.65,corner_count = 4,threshold=0.07)} ,
-
Some parameters need to be adjusted so that our formation type, the distance between each aircraft (distance between corners or points, not diagonal distance) and the number of corners are equal to the number of vehicles. You can check out the wiki for detailed explanations.
(
formation_type = FORMATIONTYPES.v
,each_distance = 0.65
) -
A certain amount of loiter is added.
{MISSIONMODES.loiter : LoiterParams(loiter_time = 3)} ,
-
Navigation can now begin after the vehicles become stable. Desired destination:
-
📍 [x = 1 meter , y = 1 meter , z = 1 meter] ->
navigation_waypoints = [Position(1,1,1)]
-
The maximum speed of the swarm center during navigation will be 1 [m/s].
-
The formation type should be the same as the formation we are in (
FORMATIONTYPES.v
) and the distance between them should remain the same (each_distance = 0.65
): -
1️⃣
{MISSIONMODES.navigation : NavigationParams(agressiveness_kt = 30 ,max_velocity = 1, navigation_waypoints = [Position(1,1,1)], threshold = 0.08)},
-
2️⃣
{MISSIONMODES.formation2D : FormationParams2D(formation_type = FORMATIONTYPES.v,each_distance = 0.65,corner_count = 4,threshold=0.07)},
-
3️⃣
{MISSIONMODES.loiter : LoiterParams(loiter_time = 3)},
-
-
Then, finally, landing should be done.
MISSIONMODES.landing : LandingParams(threshold = 0.07)},
-
The following task should also be added so that the system understands that the task is completed.
{MISSIONMODES.completed : True}
Feel free to open an issue for development activities or ask any questions you want in the discussion section. In the Issue tab you will always find a pinned topic related to the tasks that need to be done!
[1] Simulation Environment with some arrangements : https://github.com/utiasDSL/gym-pybullet-drones
[2] For Real Flight Implementation we are use cflib-python : https://github.com/bitcraze/crazyflie-lib-python
[3] The Trajectory generation algorithm was written using this source : https://github.com/Bharath2/Quadrotor-Simulation
[4] Brambilla, M., Ferrante, E., Birattari, M., & Dorigo, M. (2013). Swarm robotics: a review from the swarm engineering perspective. Swarm Intelligence, 7(1), 1–41. https://doi.org/10.1007/s11721-012-0075-2
[5] Mellinger, D., & Kumar, V. (2011). Minimum snap trajectory generation and control for quadrotors. 2011 IEEE International Conference on Robotics and Automation. https://doi.org/10.1109/icra.2011.5980409
[6] Moon, S., Lee, D., Lee, D., Kim, D., & Bang, H. (2021). Energy-Efficient Swarming Flight Formation Transitions Using the Improved Fair Hungarian Algorithm. Sensors, 21(4), 1260. https://doi.org/10.3390/s21041260
[7] Implemented for both Individual and Swarm Navigation Flight : Richter, C., Bry, A., & Roy, N. (2016). Polynomial trajectory planning for aggressive quadrotor flight in dense indoor environments. Springer Tracts in Advanced Robotics, 649–666. https://doi.org/10.1007/978-3-319-28872-7_37
--> Use launch files to configure standardized packages
--> Do not use any recursive or try-expect function
--> After every Ros dependent change (msg,service vs.), do the catkin_make at main dir
Gamma Swarm
├── CMakeLists.txt
├── launch
│ └── allRun.launch
├── msg
│ ├── example.msg
│ ├── FullCommand.msg
│ ├── FullState.msg
│ ├── FullTrajectoryCommand.msg
│ ├── TrajectoryCommand.msg
│ ├── UavCommand.msg
│ └── UavState.msg
├── package.xml
├── runSystem.sh
├── setup.py
├── src
│ ├── CITATION.cff
│ ├── GammaSwarm
│ │ ├── logging
│ │ │ ├── classes.py
│ │ │ ├── gammaAnalyser.py
│ │ │ ├── gammaLogger.py
│ │ │ └── logo.png
│ │ └── mainSystem
│ │ │ ├── enums.py
│ │ │ ├── gammaSwarm.py
│ │ │ ├── Initializer.py
│ │ │ ├── initializer_util.py
│ │ │ ├── MerkezcilClass.py
│ │ │ ├── mission.py
│ │ │ ├── Modes.py
│ │ │ ├── Parameters.py
│ │ │ ├── State.py
│ │ │ ├── UavClass.py
│ │ │ └── utils.py
│ │ └── simulationSystems
│ │ │ ├── ControllerUtils.py
│ │ │ ├── environment.py
│ │ │ ├── obstacle.urdf
│ │ │ ├── simulation_executer.py
│ │ │ └── SimulationParameter.py
│ │ └── realSystems
│ │ │ ├── cfSwarm.py
│ │ │ ├── realExecuter.py
│ │ │ └── realManager.py
│ ├── LICENSE
│ ├── README.md
│ └── setup.py
└── srv
├── RealServiceMessage.srv
└── ServiceMessage.srv