[已更新问题一代码]2024数学建模国赛高教社杯A题:“板凳龙” 闹元宵 思路代码文章助攻手把手保姆级

本文主要是介绍[已更新问题一代码]2024数学建模国赛高教社杯A题:“板凳龙” 闹元宵 思路代码文章助攻手把手保姆级,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题1

问题描述

舞龙队沿着螺距为55 cm的等距螺旋线顺时针盘入。龙头前把手的速度保持在1m/s,初始位置在螺旋线的第16 圈(点A,坐标为 (880 cm, 0))。螺旋线的终点为 (0, 0)。任务是计算从0秒到300秒间,每秒龙头、龙身、龙 尾的每个前把手和龙尾后把手的中心位置和速度,并将结果保存到文件 result1 .xlsx 中。
解决思路

螺旋线的参数化方程

螺旋线是从外向内盘旋,因此其参数方程应描述半径逐渐减小的情况螺旋线的参数化方程为: x(t) = r(t) ⋅ cos(−θ(t)), y(t) = r(t) ⋅ sin(−θ(t))
其中: 螺旋线的参数化方程为:

x(t) = r(t) ⋅ cos(−θ(t)), y(t) = r(t) ⋅ sin(−θ(t))

其中:

r(t) = r0 − p ⋅ t表示随着时间 (t) 增加,半径逐渐减小。
r0 = 880cm (起始半径) p = 55cm (螺距)
θ(t) =
C = 2πp 表示每一圈的圆周长度,负号用于表示顺时针方向。

  1. 初始条件和时间步长
    初始位置:龙头初始位置在A点,即第16圈, r0=880&nbsp ;cmr_0 = 880 \text{ cm}r0=880&nb。sp ;cm 时间步长:每秒钟计算一次,从0秒到300秒,时间间隔为1秒。
  2. 速度和位置计算
    . 龙头前把手的速度为常量1 m/s,即100 cm/s。 。 使用龙头的速度,逐秒计算其位移。
    根据龙头的位置和速度,利用刚体运动学原理推导龙身和龙尾每个前把手的位置信息。
  3. MATLAB编程步骤
    定义螺旋线的方程,建立从0秒到300秒的时间序列。
    。 计算每个时间点上,龙头和龙身的各个把手的位置和速度。 输出结果至Excel文件 result1 .xlsx 。

在平面螺旋线(如阿基米德螺旋线)上计算两点间的弧长,首先我们需要知道平面螺旋线的公式。阿基米德螺 旋线的极坐标形式是:
r = a + bθ
其中,

r 是从原点到曲线上某点的距离,
θ 是从极轴到该点的线段与正X轴之间的角度(以弧度为单位),
e a 和 b 是常数,分别代表螺旋线的起始半径和螺旋间的距离(螺距)。 为了计算两点间的弧长,我们可以 使用曲线的弧长公式。对于极坐标下的曲线 r(θ),弧长 s 从 θ1 到 θ2 可以通过以下公式计算:

对于阿基米德螺旋线, 我们有 r = a + bθ , 因此 将 r = a + bθ 和 代入弧长公式中,我们得 到:

t=0时刻下的分布

%  二分法查找函数 ,用于找到下一个点的角度
function  theta_B  =  findNextTheta(theta_A ,  pitch ,  d) %  设置二分法的初始区间 [theta_low ,  theta_high]
theta_low  =  theta_A  +  Θ . Θ1;
theta_high  =  theta_A  +  1Θ;  %  初始高值可适当调大%  设置允许的误差范围
tolerance  =  Θ . ΘΘΘΘ1;%  二分法查找满足条件的 theta_B
while  (theta_high  -  theta_low)  >  tolerance
theta_B  =  (theta_low  +  theta_high)  /  2;  %  中间值 r_A  =  pitch  /  (2  *  pi)  *  theta_A;
r_B  =  pitch  /  (2  *  pi)  *  theta_B; x_A  =  r_A  *  cos(theta_A);
y_A  =  r_A  *  sin(theta_A); %  计算 A  和 B  点之间的距离
distance_AB  =  sqrt((x_B  -  x_A)^2  +  (y_B  -  y_A)^2);%  检查是否满足条件
if  abs(distance_AB  -  d)  <  tolerance  &&  r_B  >  r_A break;  %  找到满足条件的 B  点 ,跳出循环
elseif  distance_AB  <  d   ||  r_B  <=  r_A theta_low  =  theta_B;  %  增加下限
else
theta_high  =  theta_B;  %  减小上限
end end
clc;clear  all;
%  定义螺旋线的参数  pitch  =  55;  %  螺距
r_start  =  0;  %  螺旋线起始半径 point_num=223+1;
%  固定的相邻两点之间的距离
fixed_distance  =ones(point_num-1 ,  1) .*(220-27 .5*2); fixed_distance(1)=341-27 .5*2;
fixed_distance(end)=fixed_distance(1); %  初始化点数组 ,储存所有点的位置 (x ,  y)    points  =  zeros(point_num ,  2);%  初始点 A  的位置和角度
points(1 ,   :)  =  [880 ,  0] ;  %  A  点在 (0 ,  0) theta_A  =  (880  *  2  *  pi)  /  pitch;%  使用二分法查找每个点 for  i  =  2:point_num
theta_B  =  findNextTheta(theta_A ,  pitch ,  fixed_distance(i-1));  %  计算下一个点的角度 r_B  =  pitch  /  (2  *  pi)  *  theta_B;
x_B  =  r_B  *  cos(theta_B); y_B  =  r_B  *  sin(theta_B);%  更新下一个起始点  theta_A  =  theta_B;
end%  显示前10个点
fprintf('前10个点的坐标:\n ') ; disp(points(1 :10 ,  :)) ;%  绘制螺旋线及前10个点
theta  =  linspace(0 ,  theta_A  +  2  *  pi ,  1000); r  =  pitch  /  (2  *  pi)  *  theta;
x  =  r   .*  cos(theta); y  =  r  .*  sin(theta);figure;
plot(x ,  y ,   'b ') ;  %  绘制螺旋线 hold  on;plot(points(1 ,  1) ,  points(1 ,  2)	,   '	go ' ,  'MarkerSize ' ,  8 ,   'MarkerFaceColor ' ,   'g ') ;
plot(points(2 :10 ,  1) ,  points(2 :	10 ,	2) ,  'ro ' ,   'MarkerSize ' ,  8 ,   'MarkerFaceColor ' ,   'r ') ;xlabel( 'X ') ; ylabel( 'Y ') ;

https://docs.qq.com/doc/DVUxsQXZXaUtLYXVl

在这里插入图片描述

这篇关于[已更新问题一代码]2024数学建模国赛高教社杯A题:“板凳龙” 闹元宵 思路代码文章助攻手把手保姆级的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142492

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只