【四旋翼飞行器】【模拟悬链机器人的动态】设计和控制由两个四旋翼飞行器推动的缆绳研究(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 的命令窗口中获取旧式帮助

    问题的简短版本 在最新版本的 Matlab 中 我在 Windows 上的 R2014b 和 R2015a 中看到过 当您键入help foo你得到一个简要描述 简介函数及其签名 例如 输入help bsxfun产生类似这样的东西 只有更好
  • 我如何编写一个名为 dedbi 的 MATLAB 函数,它将输入 xtx 作为字符串并返回另一个字符串 xtxx 作为输出。

    dedbi 反转单词 即 a 将被 z 替换 b 将被 y 替换 c 将被 x 替换 依此类推 dedbi 将对大写字母执行相同的操作 即将字符串 A 替换为 Z 将 B 替换为 Y 将 C 替换为 X 依此类推 如果我给函数这个字符串 a
  • for 循环中的绘图没有可见点

    我正在努力解决我想使用 for 循环制作的情节 我知道当我在循环之后添加它时它会起作用 只是一个简单的图 但我想用另一种方式尝试一下 fib ones 1 10 for k 3 10 hold on fib k fib k 1 fib k
  • 在matlab中,如何读取python pickle文件?

    在 python 中 我生成了一个 p 数据文件 pickle dump allData open myallData p wb 现在我想在Matlab中读取myallData p 我的Matlab安装在Windows 8下 其中没有Pyt
  • matlab中更快的插值方法

    我正在使用 interp1 来插值一些数据 temp 4 30 4 rand 365 10 depth 1 10 dz 0 5 define new depth interval bthD min depth dz max depth ne
  • 将 Matlab 数组移植到 C/C++

    我正在将 matlab 程序移植到 C C 我有几个问题 但最重要的问题之一是 Matlab 将任何维度的数组都视为相同 假设我们有一个这样的函数 function result f A B C result A 2 B C A B and
  • FMINCON 的替代方案

    除了 fmincon 之外还有其他更快 更高效的求解器吗 我正在使用 fmincon 来解决特定问题 但对于中等大小的向量变量来说 我的内存不足 我也没有任何超级计算机或云计算选项可供使用 我知道任何替代解决方案仍然会耗尽内存 但我只是想看
  • 通过多次合并相同的行向量来构建矩阵

    有没有一个matlab函数可以让我执行以下操作 x 1 2 2 3 然后基于x我想建立矩阵m 1 2 2 3 1 2 2 3 1 2 2 3 1 2 2 3 您正在寻找REPMAT http www mathworks com help t
  • 通过 cuFFT 进行逆 FFT 缩放

    每当我使用 cuFFT 绘制程序获得的值并将结果与 Matlab 的结果进行比较时 我都会得到相同形状的图形 并且最大值和最小值位于相同的点 然而 cuFFT 得到的值比 Matlab 得到的值大得多 Matlab代码是 fs 1000 s
  • 图像梯度角计算

    我实际上是按照论文的说明进行操作的 输入应该是二进制 边缘 图像 输出应该是一个新图像 并根据论文中的说明进行了修改 我对指令的理解是 获取边缘图像的梯度图像并对其进行修改 并使用修改后的梯度创建一个新图像 因此 在 MATLAB Open
  • matlab 中的动画绘图

    我正在尝试创建一个三角形的动画图 最终结果应该是十个三角形 后面跟着两个更大的三角形 后面跟着一条直线 使用matlab文档 https de mathworks com help matlab ref drawnow html 我最终得到
  • 更新:随机将行添加到矩阵中,但遵循严格的规则

    以下是一个更大的矩阵的一部分 0 1 0000 1 0000 77 0000 100 0000 0 0 2500 0 1 0000 1 0000 72 0000 100 0000 0 2500 0 2500 0 1 0000 1 0000
  • 轴标注问题

    通过运行我编写的以下 matlab 函数 可以互换图中的 x 轴和 y 轴 谁能告诉我问题出在哪里或者帮我解决它吗 预先感谢您的任何帮助 function axislabeling n x 1 1 n y 1 1 n z zeros n n
  • 拟合具有扭曲时基的正弦波

    我想知道在 Matlab 中拟合具有扭曲时基的正弦波的最佳方法 时间失真由 n 阶多项式 n 10 给出 其形式为t distort P t 例如 考虑失真t distort 8 12t 6t 2 t 3 这只是幂级数展开 t 2 3 这将
  • 霍夫变换检测和删除线

    我想使用霍夫变换检测图像中的线条 但是我不想绘制线条 而是想删除原始图像中检测到的每条线条 image imread image jpg image im2bw image BW edge image canny imshow BW fig
  • Blob 的簇生长

    考虑以下来自 Mathworks 的图像 我已经用标签标记了斑点 L num bwlabel I 如何迭代连接所有斑点 即从一个斑点开始 找到离它最近的一个 考虑最左边的两个斑点 可以从一个斑点的许多点绘制许多条线来连接到另一个斑点blob
  • 如何在matlab中使矩阵图平滑

    就像上图一样 怎样才能让画面更流畅呢 或者缩小y轴的范围 数据来自二维矩阵 然后我用plot data 请随意提出任何想法 平滑线条的一种方法涉及样本点之间数据的非线性插值 当你这样做时plot x y o http www mathwor
  • 计算给出数组中最小标准差的子集

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

    我有以下脚本来最终绘制 4 x 2 子图 files getAllFiles preliminaries n size files cases cell 1 n m cell 1 n for i 1 1 n S load files i c
  • 在 Matlab/Java 中将手部运动建模为 3D 曲线

    我只需要一些关于我遇到的问题 在哪里查看等的指导 我在我的一个项目中使用了运动跟踪手套 它返回每个手指和手掌的 X Y 和 Z 值 我想做的是首先根据这些坐标创建每个手指运动的表示 然后将它们每个附加到手掌的运动 以获得手的表示 一旦我完成

随机推荐