【四旋翼飞行器】【模拟悬链机器人的动态】设计和控制由两个四旋翼飞行器推动的缆绳研究(Matlab代码实现)

2023-12-05

???????????????? 欢迎来到本博客 ❤️❤️????????

????博主优势: ???????????? 博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️ 座右铭: 行百里者,半于九十。

???????????? 本文目录如下: ????????????

目录

????1 概述

????2 运行结果

????3 参考文献

????4 Matlab代码实现


????1 概述

四旋翼飞行器是一种能够垂直起降和悬停的飞行器,由四个独立的旋翼推进器提供动力。它们通常被用于航拍、搜救和军事应用等领域。而悬链机器人是一种由缆绳悬挂并由外部推动的机器人,常用于高空作业和建筑清洁等领域。

设计和控制由两个四旋翼飞行器推动的缆绳研究,可以将两个四旋翼飞行器连接在一起,通过缆绳将它们与悬链机器人连接。这样的设计可以使悬链机器人具有更强的动力和稳定性,从而提高其在高空作业和其他领域的应用效率。

在控制方面,需要设计一套复杂的控制系统来协调两个四旋翼飞行器的动作,确保它们能够有效地推动悬链机器人并保持平衡。这可能涉及到对飞行器的姿态控制、飞行路径规划和动力分配等方面的研究。

综上,设计和控制由两个四旋翼飞行器推动的缆绳研究是一项复杂而具有挑战性的工作,但它有望为悬链机器人的应用带来新的突破和进展。通过充分发挥四旋翼飞行器的优势,可以为悬链机器人赋予更大的动力和灵活性,从而拓展其在各种领域的应用范围。

???? 2 运行结果

部分代码:

%% plot function
function plott(t,x,xdA,posA_err_fx,velA_err_fx, xdB,posB_err_fx,velB_err_fx, xC, xdC,params)
disp('Plotting graphs...');
index = round(linspace(1, length(t), round(1*length(t))));
figure(1);
subplot(3,1,1);
plot(t(index),x(index,1),'Color',[0.3010 0.7450 0.9330],'LineWidth',2); hold on;
%         plot(t(index),xdA(index,1),':r','LineWidth',2);
plot(t(index),x(index,19),'Color',[0.9290 0.6940 0.1250],'LineWidth',2);
%         plot(t(index),xdB(index,1),':r','LineWidth',2);
plot(t(index),xC(index,1),'b','LineWidth',2);
plot(t(index),xdC(index,1),':r','LineWidth',2);


hold off;
%axis equal;
grid on;
legend('$x_A$','$x_B$','$x_C$','$x_C$ desired','Interpreter','latex');%axis equal;
ylabel('$x(m)$','Interpreter','latex');set(gca,'xticklabel',[])

subplot(3,1,2);
plot(t(index),x(index,2),'Color',[0.3010 0.7450 0.9330],'LineWidth',2); hold on;
%         plot(t(index),xdA(index,2),':r','LineWidth',2);
plot(t(index),x(index,20),'Color',[0.9290 0.6940 0.1250],'LineWidth',2);
%         plot(t(index),xdB(index,2),':r','LineWidth',2);
plot(t(index),xC(index,2),'b','LineWidth',2);
plot(t(index),xdC(index,2),':r','LineWidth',2);hold off;
%axis equal;
grid on;
legend('$x_A$','$x_B$','$x_C$','$x_C$ desired','Interpreter','latex');
ylabel('$y(m)$','Interpreter','latex');set(gca,'xticklabel',[])

subplot(3,1,3);
plot(t(index),x(index,3),'Color',[0.3010 0.7450 0.9330],'LineWidth',2); hold on;
plot(t(index),x(index,21),'Color',[0.9290 0.6940 0.1250],'LineWidth',2);
plot(t(index),xC(index,3),'b','LineWidth',2);
plot(t(index),xdC(index,3),':r','LineWidth',2);hold off;
%axis equal;

grid on;
legend('$x_A$','$x_B$','$x_C$','$x_C$ desired','Interpreter','latex');
xlabel('$t(s)$','Interpreter','latex');ylabel('$z(m)$','Interpreter','latex');
print('../results/FigTrajectory','-dpng')

figure(2)
plot3(x(index,1),x(index,2),x(index,3),'-b','LineWidth',2); hold on;
plot3(xdA(index,1),xdA(index,2),xdA(index,3),'-.r','LineWidth',3.5);

plot3(x(index,19),x(index,20),x(index,21),'-k','LineWidth',2);
plot3(xdB(index,1),xdB(index,2),xdB(index,3),':r','LineWidth',3.5);

plot3(xC(index,1),xC(index,2),xC(index,3),'Color',[0.4660 0.6740 0.1880],'LineWidth',2);
plot3(xdC(index,1),xdC(index,2),xdC(index,3),'or','LineWidth',5);
plot3(x(end,1),x(end,2),x(end,3),'ok','LineWidth',4);
plot3(x(end,19),x(end,20),x(end,21),'ok','LineWidth',4);

plot3(x(1,1),x(1,2),x(1,3),'or','LineWidth',2);
plot3(x(1,19),x(1,20),x(1,21),'or','LineWidth',2);

????3 参考文献

文章中一些内容引自网络,会注明出处或引用为参考文献,难免有未尽之处,如有不妥,请随时联系删除。

[1]宋曜先.四旋翼无人飞行器编队控制算法的研究[D].杭州电子科技大学[2023-11-22].DOI:CNKI:CDMD:2.1017.133374.

[2]庞庆霈,李家文,黄文浩.四旋翼飞行器设计与平稳控制仿真研究[J].电光与控制, 2012, 19(3):5.DOI:10.3969/j.issn.1671-637X.2012.03.012.

[3]曹健,丁力.四旋翼飞行器的动态滑模轨迹跟踪控制研究[J].组合机床与自动化加工技术, 2019(8):5.DOI:CNKI:SUN:ZHJC.0.2019-08-022.

???? 4 Matlab代码实现

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【四旋翼飞行器】【模拟悬链机器人的动态】设计和控制由两个四旋翼飞行器推动的缆绳研究(Matlab代码实现) 的相关文章

  • 如何获取MATLAB句柄对象的ID?

    当我尝试使用时出现问题MATLAB 句柄对象 http www mathworks com help techdoc ref handle html作为关键值MATLAB 容器 Map http www mathworks com help
  • 平衡两轮机器人而不使其向前/向后漂移

    我正在尝试设计一个控制器来平衡 2 轮机器人 约 13 公斤 并使其能够抵抗外力 例如 如果有人踢它 它不应该掉落 也不应该无限期地向前 向后漂移 我对大多数控制技术 LQR 滑模控制 PID 等 都很有经验 但我在网上看到大多数人使用 L
  • 如何为已编译的 MATLAB 创建安装程序并要求用户接受我们的许可条款?

    我正在 MATLAB 中编写程序分发给 Windows 用户 我使用 MATLAB 编译器和 MATLAB r2014a 版本来创建程序 我可以使用 MATLAB 应用程序编译器创建 Windows 安装程序 并且它的工作效果可以接受 但是
  • getappdata 在 MATLAB 中返回空矩阵

    我有一段代码 我在其中使用setappdata然后我使用以下方式调用数据getappdata即使它不为空 它也会返回一个空矩阵 我的一段简化代码如下 function edit1 Callback hObject eventdata han
  • 如何正确从表中删除 NaN 值

    在 Matlab 中阅读 Excel 电子表格后 不幸的是 我的结果表中包含了 NaN 例如这个 Excel 表格 将产生此表 其中出现额外的 NaN 列 我尝试使用以下代码片段删除 NaN measurementCells readtab
  • 在matlab中不使用for循环检查数组中的成员资格

    我想简化这段代码 使其无需 for 循环即可工作 for i 1 N for j 1 N if ismember j A PID i i TFP i j PID i i end end end 其中A是一个包含一些标签的矩阵 我之前存储的T
  • 如何在 MATLAB 编译的应用程序中运行外部 .m 代码? [复制]

    这个问题在这里已经有答案了 我有一个 MATLAB 项目 我使用 MCC 对其进行编译以获得单个可执行文件 然后我想知道外部程序员是否可以在 exe 中执行他的一些 m 文件 而无需重新编译整个项目 重点是提供一个应用程序 其他开发人员可以
  • 将 kinect RGB 和深度值转换为 XYZ 坐标

    我正在寻找一种简单的方法将 kinect RGB 和深度值转换为 XYZ 坐标 使用 MATLAB 我的目标是一个输入为以下内容的函数 每个点的 RGB 和深度值Kinect相机 并输出 每个点的 x y 和 z 值 RGB 深度 RGB
  • 在 MATLAB 中绘图后恢复轴

    从文本文件绘制多种方法的输出后 未显示轴的右侧和上侧 我需要拥有它们并将它们加粗 就像当前的轴一样 绘制的数据来自存储每种方法数据的文件 每个数据文件都是一个 256x2 文件 包含 0 1 之间的值 第一列是精度 第二列是召回率 figu
  • 将向量(或弧)绘制到玫瑰图上。 MATLAB

    我有两个数据集 其中详细列出了angles 我正在绘制玫瑰图 angles 0 8481065519 0 0367932161 2 6273740453 n 另一个 从这组角度详细说明方向统计 angle error 0 848106563
  • matlab 中的动画绘图

    我正在尝试创建一个三角形的动画图 最终结果应该是十个三角形 后面跟着两个更大的三角形 后面跟着一条直线 使用matlab文档 https de mathworks com help matlab ref drawnow html 我最终得到
  • 保存符号方程以供以后使用?

    From here http www mathworks com help releases R2011a toolbox symbolic brvfu8o 1 html brvfxem 1 我正在尝试求解这样的符号方程组 syms x y
  • 帮助我理解FFT函数(Matlab)

    1 除了负频率之外 FFT 函数提供的最小频率是多少 是零吗 2 如果它为零 我们如何在对数刻度上绘制零 3 结果总是对称的 或者只是看起来是对称的 4 如果我使用abs fft y 来比较2个信号 我是否会失去一些准确性 1 除了负频率之
  • Matlab:2行10列的子图

    如何在 matlab 中绘制 20 幅图像 2 行 10 列 我知道我必须使用 子图 功能 但我对给出的参数感到困惑 我尝试给予 子图 2 10 行索引 列索引 但它似乎不起作用 请帮忙 的前两个参数subplot函数分别给出图中子图的总行
  • 考虑预分配速度[重复]

    这个问题在这里已经有答案了 我正在做以下事情 for i 1 m index 0 for j 1 n index index values i j 2 j 1 if j 1 symbol chip chip values index 1 e
  • 如何在Matlab中将图像从笛卡尔坐标更改为极坐标?

    我正在尝试将图像的像素从 x y 坐标转换为极坐标 但我遇到了问题 因为我想自己编写该函数 这是我到目前为止所做的代码 function newImage PolarCartRot read and show the image image
  • 基本矩阵错误?

    我试图通过扫描从相机拍摄的两个图像 检测图像中的特征 匹配它们 创建基本矩阵 使用相机内在函数计算基本矩阵 然后分解它以找到旋转和翻译 这是matlab代码 I1 rgb2gray imread 1 png I2 rgb2gray imre
  • Blob 的簇生长

    考虑以下来自 Mathworks 的图像 我已经用标签标记了斑点 L num bwlabel I 如何迭代连接所有斑点 即从一个斑点开始 找到离它最近的一个 考虑最左边的两个斑点 可以从一个斑点的许多点绘制许多条线来连接到另一个斑点blob
  • 计算给出数组中最小标准差的子集

    让我们有一个大小的向量N 例如 x rand N 1 我想计算长度子集的最小标准差K在向量中 When N and K很小 很容易找到最好的子集 因为我可以使用nchoosek N K 枚举所有可能的子集 但是当值N and K比我们说的要
  • Matlab下降低图像质量

    问候 我正在尝试找到一种简单的方法来处理图像 以便将其质量从 8 位降低到 3 位 实现这一目标的最简单方法是什么 干杯 如果要线性缩放 只需将每个像素值除以 255 7 即 如果原始图像存储在矩阵 I 中 则让低分辨率图像 J I 255

随机推荐