2023 年 数维杯(A题)国际大学生数学建模挑战赛 |数学建模完整代码+建模过程全解全析

news2025/1/23 13:55:38

当大家面临着复杂的数学建模问题时,你是否曾经感到茫然无措?作为2021年美国大学生数学建模比赛的O奖得主,我为大家提供了一套优秀的解题思路,让你轻松应对各种难题。
让我们来看看数维杯A题!

在这里插入图片描述

问题重述

1、俯仰力矩和俯仰角变化:
推导俯仰力矩的表达式。
基于给定参数建立俯仰角变化模型。
计算 5 秒、10 秒和 20 秒时的姿态角。

2、滚转、俯仰和偏航力矩:
建立滚转、俯仰和偏航力矩的表达式。
建立姿态角变化模型。
计算 5 秒、10 秒和 20 秒时的姿态角。

3.机动特性:
设计低速和高速飞行的机动以实现平飞任务。

4、加速机动任务:
设计控制输入以实现前进加速和平飞。
考虑低速和高速飞行特性。

问题 1: 俯仰力矩和俯仰角变化

建模思路:
  1. 俯仰力矩表达式:

    • 俯仰力矩主要受到共轴刚性转子、螺旋桨推进器、水平尾翼的影响。

    • 共轴刚性转子产生的气动力矩可以表示为:
      M rotor = K rotor ⋅ ρ ⋅ A ⋅ V tip M_{\text{rotor}} = K_{\text{rotor}} \cdot \rho \cdot A \cdot V_{\text{tip}} Mrotor=KrotorρAVtip

    • 螺旋桨推进器产生的推力和旋转力矩:
      T propeller = C propeller T_{\text{propeller}} = C_{\text{propeller}} Tpropeller=Cpropeller

    • 水平尾翼产生的气动力矩:
      M horizontal tail = C horizontal tail ⋅ q ⋅ S horizontal ⋅ y ˉ horizontal M_{\text{horizontal tail}} = C_{\text{horizontal tail}} \cdot q \cdot S_{\text{horizontal}} \cdot \bar{y}_{\text{horizontal}} Mhorizontal tail=Chorizontal tailqShorizontalyˉhorizontal

  2. 俯仰角变化模型:

    • 利用力矩和力的平衡,可以得到俯仰角变化的微分方程:
      I y y ⋅ θ ˙ = M rotor + T propeller + M horizontal tail I_{yy} \cdot \dot{\theta} = M_{\text{rotor}} + T_{\text{propeller}} + M_{\text{horizontal tail}} Iyyθ˙=Mrotor+Tpropeller+Mhorizontal tail

    • 其中 I y y I_{yy} Iyy 是飞行器绕 y 轴的惯性矩。

  3. 数值求解:

    • 使用数值求解器(例如欧拉法)对微分方程进行离散求解,得到不同时刻的俯仰角。
  4. 初始条件:

    • 使用提供的初始条件(flight altitude, flight speed, control inputs)进行模拟。
import numpy as np
from scipy.integrate import odeint

# 定义常数和初始条件
K_rotor = 0.1
rho = 1.225
A = 10.0
V_tip = 5.0
C_propeller = 0.05
C_horizontal_tail = 0.02
q = 100.0
S_horizontal = 8.0
y_horizontal = 2.0
I_yy = 100.0
initial_conditions = [0.0]  # 初始俯仰角

# 定义微分方程
def pitch_dynamics(theta, t):
    M_rotor = K_rotor * rho * A * V_tip
    T_propeller = C_propeller
    M_horizontal_tail = C_horizontal_tail * q * S_horizontal * y_horizontal

    # 俯仰角变化微分方程
    dtheta_dt = (M_rotor + T_propeller + M_horizontal_tail) / I_yy

    return dtheta_dt

# 定义时间范围
time_points = np.linspace(0, 20, 1000)
#见完整版代码

问题 2: 滚转、俯仰和偏航力矩

建模思路:
  1. 滚转力矩表达式:

    • 滚转力矩主要由共轴刚性转子和水平尾翼贡献。

    • 共轴刚性转子产生的滚转力矩与问题一中的俯仰力矩相似,可以表示为:
      M roll = K rotor ⋅ ρ ⋅ A ⋅ V tip M_{\text{roll}} = K_{\text{rotor}} \cdot \rho \cdot A \cdot V_{\text{tip}} Mroll=KrotorρAVtip

    • 水平尾翼产生的滚转力矩:
      M horizontal tail = C horizontal tail ⋅ p ⋅ S horizontal ⋅ y ˉ horizontal M_{\text{horizontal tail}} = C_{\text{horizontal tail}} \cdot p \cdot S_{\text{horizontal}} \cdot \bar{y}_{\text{horizontal}} Mhorizontal tail=Chorizontal tailpShorizontalyˉhorizontal

      • C horizontal tail C_{\text{horizontal tail}} Chorizontal tail 是水平尾翼力矩系数, p p p 是滚转角速度, S horizontal S_{\text{horizontal}} Shorizontal 是水平尾翼面积, y ˉ horizontal \bar{y}_{\text{horizontal}} yˉhorizontal 是水平尾翼相对飞行器中心的距离。
  2. 俯仰力矩表达式:

    • 俯仰力矩在问题一中已经建模过,主要由共轴刚性转子和水平尾翼贡献。
  3. 偏航力矩表达式:

    • 偏航力矩主要由共轴刚性转子和垂直尾翼贡献。

    • 共轴刚性转子产生的偏航力矩与滚转和俯仰情形相似:
      M yaw = K rotor ⋅ ρ ⋅ A ⋅ V tip M_{\text{yaw}} = K_{\text{rotor}} \cdot \rho \cdot A \cdot V_{\text{tip}} Myaw=KrotorρAVtip

    • 垂直尾翼产生的偏航力矩:
      M vertical tail = C vertical tail ⋅ r ⋅ S vertical ⋅ y ˉ vertical M_{\text{vertical tail}} = C_{\text{vertical tail}} \cdot r \cdot S_{\text{vertical}} \cdot \bar{y}_{\text{vertical}} Mvertical tail=Cvertical tailrSverticalyˉvertical

      • C vertical tail C_{\text{vertical tail}} Cvertical tail 是垂直尾翼力矩系数,(r) 是偏航角速度, S vertical S_{\text{vertical}} Svertical 是垂直尾翼面积, y ˉ vertical \bar{y}_{\text{vertical}} yˉvertical 是垂直尾翼相对飞行器中心的距离。
  4. 滚转、俯仰和偏航角变化模型:

    • 利用力矩和力的平衡,可以得到滚转、俯仰和偏航角变化的微分方程:
      I roll ⋅ p ˙ = M roll + M horizontal tail I_{\text{roll}} \cdot \dot{p} = M_{\text{roll}} + M_{\text{horizontal tail}} Irollp˙=Mroll+Mhorizontal tail

      I pitch ⋅ q ˙ = M rotor + T propeller + M horizontal tail I_{\text{pitch}} \cdot \dot{q} = M_{\text{rotor}} + T_{\text{propeller}} + M_{\text{horizontal tail}} Ipitchq˙=Mrotor+Tpropeller+Mhorizontal tail

    I yaw ⋅ r ˙ = M yaw + M vertical tail I_{\text{yaw}} \cdot \dot{r} = M_{\text{yaw}} + M_{\text{vertical tail}} Iyawr˙=Myaw+Mvertical tail

    • 其中 I roll I_{\text{roll}} Iroll I pitch I_{\text{pitch}} Ipitch I yaw I_{\text{yaw}} Iyaw分别是飞行器绕 x、y 和 z 轴的惯性矩。
  5. 数值求解:

    • 使用数值求解器(例如欧拉法)对微分方程进行离散求解,得到不同时刻的滚转、俯仰和偏航角。
  6. 初始条件:

    • 使用提供的初始条件(flight altitude, flight speed, control inputs)进行模拟。
import numpy as np
from scipy.integrate import odeint

# 定义常数和初始条件
K_rotor = 0.1
rho = 1.225
A = 10.0
V_tip = 5.0
C_horizontal_tail = 0.02
p = 0.1
S_horizontal = 8.0
y_horizontal = 2.0
C_vertical_tail = 0.03
r = 0.05
S_vertical = 5.0
y_vertical = 1.5
I_roll = 150.0
I_pitch = 100.0
I_yaw = 80.0
initial_conditions = [0.0, 0.0, 0.0]  # 初始滚转、俯仰和偏航角

# 定义微分方程
def dynamics(variables, t):
    p, q, r = variables  # 滚转、俯仰和偏航角速度

    M_roll = K_rotor * rho * A * V_tip + C_horizontal_tail * p * S_horizontal * y_horizontal
    M_pitch = K_rotor * rho * A * V_tip + C_horizontal_tail * q * S_horizontal * y_horizontal
    M_yaw = K_rotor * rho * A * V_tip + C_vertical_tail * r * S_vertical * y_vertical

    # 滚转、俯仰和偏航角速度变化微分方程
    dp_dt = M_roll / I_roll
    dq_dt = M_pitch / I_pitch
    dr_dt = M_yaw / I_yaw

    return [dp_dt, dq_dt, dr_dt]

# 定义时间范围
time_points = np.linspace(0, 20, 1000)

问题 3: 低速和高速飞行的机动特性设计

建模思路:
  1. 低速飞行的机动特性设计:

    • 低速飞行时,主要由共轴刚性转子和螺旋桨推进器提供控制。
    • 设计共轴刚性转子的位置和螺旋桨推进器的工作能力,使飞行器实现水平飞行(零姿态角)。
  2. 高速飞行的机动特性设计:

    • 高速飞行时,主要通过螺旋桨推进器、升降舵和方向舵实现控制。
    • 设计螺旋桨推进器、升降舵和方向舵的控制输入,使飞行器在高速时能够保持水平飞行(零姿态角)。
  3. 设计方法:

    • 使用数值模拟和优化方法,调整共轴刚性转子、螺旋桨推进器、升降舵和方向舵的参数,以满足低速和高速飞行时的控制需求。
    • 可以采用基于物理模型的仿真工具,对不同飞行条件下的机动特性进行模拟。
  4. 优化目标:

    • 低速飞行:使共轴刚性转子和螺旋桨推进器的输出满足水平飞行的需求,即姿态角为零。
    • 高速飞行:通过调整螺旋桨推进器、升降舵和方向舵的输出,使飞行器在高速时能够保持水平飞行。
  5. 约束条件:

    • 考虑飞行器的物理限制,如最大速度、最大推力、最大姿态角等。
  6. 数学表达式:

    • 基于飞行器的物理模型,建立低速和高速飞行时的动力学方程,并在此基础上进行优化。
  7. 数值模拟:

    • 使用数值模拟工具,对设计的参数进行测试,验证低速和高速飞行时的机动特性。
具体步骤:
  1. 低速飞行设计:

    • 设计共轴刚性转子的位置和螺旋桨推进器的工作能力。
    • 利用数值模拟验证在低速条件下,飞行器的机动特性是否满足水平飞行的要求。
  2. 高速飞行设计:

    • 设计螺旋桨推进器、升降舵和方向舵的控制输入。
    • 利用数值模拟验证在高速条件下,飞行器的机动特性是否满足水平飞行的要求。
  3. 参数调整和优化:

    • 根据数值模拟的结果,调整和优化飞行器的参数,以达到设计的低速和高速飞行机动特性。
  4. 验证和测试:

    • 对优化后的飞行器进行验证和测试,确保其在实际飞行中能够实现设计的机动特性。
import numpy as np
from scipy.integrate import odeint
from scipy.optimize import minimize

# 定义初始条件和参数
initial_conditions_low_speed = [0.0, 0.0, 0.0]  # 滚转、俯仰和偏航角
initial_conditions_high_speed = [0.0, 0.0, 0.0]  # 滚转、俯仰和偏航角
params_low_speed = [0.1, 1.0, 5.0]  # 共轴刚性转子和螺旋桨推进器参数
params_high_speed = [1.0, 2.0, 3.0, 1.0, 2.0, 3.0]  # 螺旋桨推进器、升降舵和方向舵参数

# 定义低速飞行动力学方程
def dynamics_low_speed(variables, t, params):
    # 省略动力学方程,根据具体问题补充
    return [0, 0, 0]

# 定义高速飞行动力学方程
def dynamics_high_speed(variables, t, params):
    # 省略动力学方程,根据具体问题补充
    return [0, 0, 0]

# 定义目标函数
def objective(params):
    # 低速飞行
    result_low_speed = odeint(dynamics_low_speed, initial_conditions_low_speed, time_points, args=(params[:3],))

    # 高速飞行
    result_high_speed = odeint(dynamics_high_speed, initial_conditions_high_speed, time_points, args=(params[3:],))

    # 计算目标函数,例如使得姿态角尽量接近零
    error_low_speed = np.sum(np.abs(result_low_speed[:, :3]))
    error_high_speed = np.sum(np.abs(result_high_speed[:, :3]))

    # 返回总体目标函数
    return error_low_speed + error_high_speed

# 定义约束条件
def constraint(params):
    # 可以根据需要添加约束条件
    return [0]

# 定义时间范围
time_points = np.linspace(0, 20, 1000)

# 优化参数
initial_guess = params_low_speed + params_high_speed
result = minimize(objective, initial_guess, constraints={'type': 'eq', 'fun': constraint})

问题四:直升机加速度机动任务

建模思路:
  1. 飞行动力学建模:

    • 基于直升机的飞行动力学,建立飞行器的速度、加速度和力矩之间的关系。
    • 考虑在低速和高速飞行模式下,直升机的动力学特性可能不同,因此需要建立不同飞行模式下的动力学模型。
  2. 控制输入设计:

    • 设计控制输入,如螺旋桨推进器、升降舵和方向舵的工作状态,以实现加速度机动任务。
  3. 目标函数和约束条件:

    • 确定加速度机动任务的目标,例如在给定时间内达到目标速度,并制定相应的目标函数。
    • 添加物理约束条件,如最大速度、最大推力、最大姿态角等。
  4. 数学表达式:

    • 建立描述直升机加速度机动任务的数学模型,考虑飞行器的动力学方程、控制输入和约束条件。
  5. 数值模拟和优化:

    • 使用数值模拟工具,对设计的参数进行测试,并通过优化算法调整参数以满足加速度机动任务的要求。
具体步骤:
  1. 低速和高速动力学模型建立:

    • 建立低速和高速飞行模式下直升机的飞行动力学模型,包括滚转、俯仰、偏航和加速度的方程。
  2. 控制输入设计:

    • 设计螺旋桨推进器、升降舵和方向舵的控制输入,以实现加速度机动任务。
    • 在低速和高速模式下,可能需要不同的控制策略和参数。
  3. 目标函数和约束条件制定:

    • 定义加速度机动任务的目标函数,可能包括最小时间达到目标速度等。
    • 添加物理约束条件,如最大速度、最大推力、最大姿态角等。
  4. 数学模型建立:

    • 将飞行动力学模型、控制输入和约束条件整合为数学模型,以描述直升机在加速度机动任务中的行为。
  5. 数值模拟和优化:

    • 使用数值模拟工具,对设计的参数进行测试,并通过优化算法调整参数以满足加速度机动任务的要求。
    • 可以采用常见的优化算法,如遗传算法、粒子群优化等。
  6. 验证和测试:

    • 对优化后的直升机进行验证和测试,确保其在实际飞行中能够实现设计的加速度机动任务。
import numpy as np
from scipy.integrate import odeint
from scipy.optimize import minimize

# 定义初始条件和参数
initial_conditions = [0.0, 0.0, 0.0, 0.0, 0.0, 0.0]  # 滚转、俯仰、偏航角和速度、加速度
params_low_speed = [0.1, 1.0, 5.0]  # 低速模式下的控制输入参数
params_high_speed = [1.0, 2.0, 3.0, 1.0, 2.0, 3.0]  # 高速模式下的控制输入参数

# 定义低速和高速飞行动力学方程
def dynamics(variables, t, params):
    # 省略动力学方程,根据具体问题补充
    return [0, 0, 0, 0, 0, 0]

# 定义目标函数
def objective(params):
    # 低速飞行
    result_low_speed = odeint(dynamics, initial_conditions, time_points, args=(params[:3],))

    # 高速飞行
    result_high_speed = odeint(dynamics, initial_conditions, time_points, args=(params[3:],))

    # 计算目标函数,例如使得加速度尽量大
    error_low_speed = -result_low_speed[-1, 4]  # 取负号表示最大化加速度
    error_high_speed = -result_high_speed[-1, 4]

    # 返回总体目标函数
    return error_low_speed + error_high_speed

# 定义约束条件
def constraint(params):
    # 可以根据需要添加约束条件

更多完整的代码和思路看这里:
2023 年 数维杯(A题)国际大学生数学建模挑战赛 |数学建模完整代码+建模过程全解全析

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1214589.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

day23_mysql

今日内容 零、 复习昨日 一、函数[了解,会用] 二、事务[重点,理解,面试] 三、数据库范式 零、 复习昨日 见晨考 一、函数 字符串函数数学函数日期函数日期-字符串转换函数流程函数 1.1 字符串函数 函数解释CONCAT (string2 [,... ]) 连接字串LENGTH (string )string长度REPLAC…

BUUCTF 九连环 1

BUUCTF:https://buuoj.cn/challenges 题目描述: 下载附件,解压得到一张.jpg图片。 密文: 解题思路: 1、一张图片,典型的图片隐写。放到Kali中,使用binwalk检测,确认图片中隐藏zip压缩包。 使…

基于stm32f103系列的简单软件I2C和硬件I2C通讯

这篇文章主要分为三个部分来阐述,分别是I2C的基本知识,软件I2C通讯,硬件I2C通讯。I2C的基本知识这一块,部分讲解以及图表来自b站江科大的up,很感谢这位up,大家可以关注一波。操作实现的时候,up使…

三行Python代码即可将视频转Gif

一、前言 很多网站提供视频转GIF的功能,但要么收费要么有广告 实际上我们通过python,几行代码就能够实现视频转gif 二、教程 1. 安装必备库moviepy pip install moviepy -i https://pypi.tuna.tsinghua.edu.cn/simple 2. 写入代码 from moviepy.edi…

大厂必备的6款React UI框架

优秀的ReactUI框架可以为您节省开发时间,提高开发效率,统一设计语言。你还在为你的项目寻找高质量的ReactUI框架吗?为了让您更容易找到易于使用的UI框架,分享6个优秀的ReactUI框架选项,并介绍了每个UI框架的不同功能和…

ArmV8常用汇编指令2

接上文,我们来分析一些具体指令。 1.加载存储指令 Load/Store可以分为立即数、寄存器等操作,格式如下: 这里Rn和Rt均为4位,原因在于,A32/T32是16个通用寄存器。因此使用4bit刚好可以遍历所有。如果是运行在AArch64&a…

Vue中el与data的两种写法

想必大家对Vue中的el与data并不陌生&#xff0c;接下来&#xff0c;让我为大家介绍一下el与data的两种写法吧&#xff01; 一、el的两种写法 1.new Vue时候配置e1属性。 2.先创建Vue实例&#xff0c;随后再通过vm.$mount(#root)指定el的值 <!DOCTYPE html> <html l…

03.智慧商城——路由配置

01. 路由配置 - 一级路由 但凡是单个页面&#xff0c;独立展示的&#xff0c;都是一级路由 路由设计&#xff1a; 登录页首页架子 首页 - 二级分类页 - 二级购物车 - 二级我的 - 二级 搜索页搜索列表页商品详情页结算支付页我的订单页 router/index.js 配置一级路由&#x…

三种跨域解决方案:HttpClient、注解、网关

注解&#xff1a;CrossOrigin网关整合Httpclient 为什么会有跨域问题 因为浏览器的同源政策&#xff0c;就会产生跨域。比如说发送的异步请求是不同的两个源&#xff0c;就比如是不同的的两个端口或者不同的两个协议或者不同的域名。由于浏览器为了安全考虑&#xff0c;就会产…

systrace分析 之 问题初步定位

2、systrace分析 之 问题初步定位 1、找到问题点2、有buffer&#xff0c;SF却什么没有取 2.1、GPU 处理时间长导致2.2、区分HWC release 是否有异常&#xff1a;2.3、SF 异常导致2.4、SF 自身处理时间长2.5、RenderThread处理时间长3、案例分享 1、找到问题点 2、有buffer&a…

【PHP】医院麻醉临床信息系统源码

麻醉临床信息系统以服务围术期临床业务工作的开展为核心&#xff0c;为医护人员、业务管理人员、院级领导提供流程化、信息化、自动化、智能化的临床业务综合管理平台。 麻醉信息系统处理的数据包含病人的手术信息、麻醉信息、病人手术过程中从监护仪上采集到的数据和病人情况等…

解决STM32F429烧录程序后还需复位才能植入程序的bug

1.打开魔术棒&#xff0c;打开debug 2.打开setting 3.打开Flas Download 4.开启Reset and Run 5.点进去Pack选项页面&#xff0c;去掉enable

合肥数字孪生赋能工业制造,加速推进制造业数字化转型

聚焦国家战略需求和先进制造业发展方向&#xff0c;加快数字化发展战略部署&#xff0c;数字孪生、工业互联网、工业物联网已被广泛认为是工业革命的新引擎。合肥数字孪生正在推动工业制造从制造转向智造。通过数字化建模和仿真的方式&#xff0c;优化设计、生产、质量管理、供…

centos图形化桌面中火狐浏览器无法访问项目页面问题处理

项目场景&#xff1a; 使用centos环境中的火狐浏览器访问项目界面 问题描述&#xff1a; 在客户的demo环境中部署了项目&#xff0c;但是使用机器上自带的火狐浏览器访问界面确实白屏&#xff0c;联系开发同事后认为是浏览器版本的问题。 更新火狐浏览器版本后&#xff0c;问…

Python 3.6.10 中的 requests 库 TLS 1.2 强制使用问题及解决方案

Python 3.6.10中&#xff0c;requests库已经强制使用TLS 1.2协议&#xff0c;不再支持TLS 1.3协议。这一变化可能会导致在使用Python 3.6.10时&#xff0c;与使用TLS 1.3的服务器进行通信时出现问题。为了解决这个问题&#xff0c;我们可以采取一些措施来确保安全且有效的网络通…

寒冬只是表象,网安才是归宿

“简历基本没人看” “已读不回” “简历都没看直接告诉你不合适” “能约面试的很少” 据统计&#xff0c;现在的互联网行业都是上面这几种情况。不仅是今年&#xff0c;这两三年以来&#xff0c;互联网大厂的工作岗位缩减了又缩减&#xff0c;计算机专业的毕业生工作难上加难…

振弦传感器表面应变计与振弦采集仪形成岩土工程监测的解决方案

振弦传感器表面应变计与振弦采集仪形成岩土工程监测的解决方案 振弦传感器表面应变计与振弦采集仪可以结合使用&#xff0c;形成岩土工程监测的解决方案。具体的方案包括以下几个步骤&#xff1a; 1. 安装振弦传感器表面应变计&#xff1a;首先需要在需要监测的岩土结构表面安…

前三季度亏损近亿元,「缺钱」的北斗智联拟变更控股股东

本月初&#xff0c;北斗星通发布《关于深圳证券交易所重组问询函回复的公告》&#xff0c;针对公司全资子公司拟出售孙公司北斗星通智联科技有限责任公司&#xff08;以下简称北斗智联&#xff09; 15%的股权事宜做出进一步解读。 按照此前计划&#xff0c;15%的股权&#xff0…

Windows10关闭系统自动更新

1.背景 2.步骤 第一步: 第二步: 完美

基础课5——垂直领域对话系统架构

垂直领域对话系统是指针对特定领域或行业的需求而构建的对话系统。这种系统通常需要具备高度的专业知识和对特定领域的知识库进行深入的学习和训练&#xff0c;以便能够提供准确、高效、实用的服务。 垂直领域对话系统的构建通常包括以下步骤&#xff1a; 确定目标领域或行业…