【Tello无人机】无人机编队操作面板实现

为了方便进行无人机的编队演示,以及在各种场景下实现队形的灵活切换,开发了一套专门的上位机控制平台。本文将重点介绍应用于tello无人机的编队操作面板及其核心功能。

操作面板页面

下图展示了操作面板,其中包含5种编队动作和3个可选位置设定。用户可以根据实际需求选择动作,并对动作参数进行配置。该平台嵌入了两套通讯系统:仿真系统和物理系统。用户可以在仿真环境中验证动作的合理性和安全性,然后在物理系统中进行实验。接下来将在仿真环境中介绍各个动作。

仿真动作
启动仿真

点击启动仿真,可运行嵌入系统中的pybullet组件,并初始化无人机位置如下:(复位即此位置)

位置1,一字排开,为执行动作4,动作5做准备

动作1

三个无人机滚动交换位置,实现三个无人机换位置的效果

代码实现:

def shift_drone_positions(current_pos, target_position, task_stage_count):

if np.all(target_position == None):

target_position = current_pos

if np.linalg.norm(current_pos - target_position) < 0.05:

target_position = np.roll(target_position, 1, axis=0)

task_stage_count += 1

return target_position, task_stage_count

逻辑:

  1. 首先检查是否有指定的目标位置,如果没有,则将目标位置设定为当前位置。
  2. 计算当前位置与目标位置之间的欧几里得距离,如果小于 0.05,则执行下一步。
  3. 将目标位置在坐标轴上向前滚动一个单位,模拟位置的移动。
  4. 增加任务阶段计数。
  5. 返回更新后的目标位置和任务阶段计数。

动作2

无人机两两交换位置,同时采用CBF进行避障运动,保证运动的同时不会与其他无人机发生碰撞

代码实现:

def swap_drone_positions(current_pos, target_position, swap_count):

if np.all(target_position == None):

target_position = current_pos

new_drone_positions = np.copy(target_position)

if np.linalg.norm(current_pos - target_position) < 0.05:

if swap_count % 2 == 0:

01-10

temp = copy.deepcopy(new_drone_positions0)

new_drone_positions0 = new_drone_positions1

new_drone_positions1 = temp

elif swap_count % 2 == 1:

12-21

temp = copy.deepcopy(new_drone_positions1)

new_drone_positions1 = new_drone_positions2

new_drone_positions2 = temp

swap_count += 1

return new_drone_positions, swap_count

逻辑:

  1. 首先,函数检查是否有指定的目标位置,如果没有,则将目标位置设定为当前位置。
  2. 然后,函数创建了一个新的数组 new_drone_positions,用于存储目标位置的副本。
  3. 接着,函数计算当前位置与目标位置之间的欧几里得距离,如果小于 0.05,则执行下一步。
  4. 如果 swap_count 是偶数,则执行第一个交换操作,将第一个和第二个飞行器的位置交换。
  5. 如果 swap_count 是奇数,则执行第二个交换操作,将第二个和第三个飞行器的位置交换。
  6. 每次执行交换操作后,增加 swap_count。
  7. 最后,返回更新后的飞行器位置和增加后的交换次数 swap_count。

动作3

圆形运动,三个无人机以设定的半径及角速度进行圆形机动,实现画圆的效果

代码实现:

def rotational_motion(current_pos, radius=0.5, delta_theta_val=0.003,

last_angle=np.zeros(3),

first_call=True):

current_angle = np.arctan2(current_pos:, 1, current_pos:, 0)

current_angle = (current_angle + 2 * np.pi) % (2 * np.pi)

if first_call:

first_call = False

last_angle = copy.deepcopy(current_angle)

delta_theta = np.array(delta_theta_val, delta_theta_val, delta_theta_val)

R = radius

new_angle = last_angle + delta_theta

target_x = R * np.cos(new_angle)

target_y = R * np.sin(new_angle)

target_position = np.array(target_x, target_y, \[current_pos\[02] * 3]).T

return target_position, np.array(new_angle), first_call

点击【Tello无人机】无人机编队操作面板实现 - 古月居可查看全文

相关推荐
24年生活经验_小旻12 天前
ROS2+Ardupilot+Gazebo通信仿真基本环境搭建
无人机
嘉子的秃头日记13 天前
TRO 2026|无人机能不能像积木一样,拼出不同形态?
无人机
YOLO数据集集合13 天前
无人机航拍地质灾害智能识别 山体滑坡实例分割数据集落地实战 | 泥石流监测 道路险情封堵 深度学习模型训练方案10296期
人工智能·深度学习·yolo·目标检测·无人机
海砥装备HardAus14 天前
大载重工业无人机高空风扰建模与ADRC自抗扰抗风控制实现
无人机·adrc·工业无人机
海砥装备HardAus14 天前
大载重工业无人机动力容错控制:单电机失效下的应急重构算法设计
算法·重构·嵌入式·无人机
中科固源14 天前
飞控里的“暗战”:无人机软件栈中的控制权风险
网络安全·无人机·低空经济
YOLO数据集集合14 天前
无人机风电设备智能巡检 风机叶片缺陷目标检测数据集实战 | 表面腐蚀漏油识别 工业视觉质检 深度学习模型训练落地10337期
人工智能·深度学习·目标检测·计算机视觉·无人机
飞手早知道14 天前
一站式选机服务落地 赋能无人机行业采购提质增效
无人机
LONGZETECH14 天前
无人机仿真教学软件选型实战:5 个硬核技术维度,避开实训建设踩坑
3d·无人机·交互·cocos2d
渡众机器人14 天前
智能体对抗挑战赛和空地协同侦排挑战赛的报名流程
人工智能·自动驾驶·无人机·智能体·报名流程