【2025年认证杯数学中国数学建模网络挑战赛】A题解题思路与模型代码
【2025年认证杯数学建模挑战赛】A题
该题为典型的空间几何建模+轨道动力学建模+预测问题。
⚙ 问题一:利用多个天文台的同步观测,确定小行星与地球的相对距离
问题分析
- 已知若干地面天文台的观测数据:方位角 (Azimuth) 和 高度角 (Altitude);
- 所有天文台在同一时间观测同一颗小行星;
- 目标是根据这些观测结果三角测量出小行星的空间坐标,进而得出相对于地球的位置(特别是距离)。
解题思路
- 获取每个天文台的地理坐标(经纬度、海拔);
- 将每个天文台的观测方位角、高度角转换为单位观测方向向量(以地心为参考);
- 将地面站的位置用地心坐标表示;
- 利用两台或多台天文台的观测方向和坐标,建立**多射线最近点法(最小距离点)**来确定目标的小行星的位置。
可能用到的数学模型与方法
- 地理坐标系 → 地心坐标系转换;
- 球面坐标系 → 笛卡尔单位向量;
- 多射线几何定位(三维空间中线与线之间的最短距离问题);
- 最小二乘法求解最优交点。
初步代码框架(Python)
import numpy as npdef geo_to_ecef(lat, lon, alt):# WGS84参数a = 6378137.0 # 地球长半轴e = 8.1819190842622e-2 # 偏心率lat, lon = np.radians(lat), np.radians(lon)N = a / np.sqrt(1 - e**2 * np.sin(lat)**2)x = (N + alt) * np.cos(lat) * np.cos(lon)y = (N + alt) * np.cos(lat) * np.sin(lon)z = (N * (1 - e**2) + alt) * np.sin(lat)return np.array([x, y, z])def azel_to_direction(az, el, lat, lon):az, el = np.radians(az), np.radians(el)x = np.cos(el) * np.sin(az)y = np.cos(el) * np.cos(az)z = np.sin(el)# 本地坐标转为地心坐标(简略版)return np.array([x, y, z]) # 需进一步旋转变换def triangulate(positions, directions):# 最小二乘法解多条射线的最近点A, b = [], []for p, d in zip(positions, directions):d = d / np.linalg.norm(d)I = np.eye(3)A.append(I - np.outer(d, d))b.append((I - np.outer(d, d)) @ p)A, b = np.sum(A, axis=0), np.sum(b, axis=0)return np.linalg.lstsq(A, b, rcond=None)[0]# 示例:三台天文台
stations = [{'lat': 34.0, 'lon': -118.0, 'alt': 1000, 'az': 130, 'el': 45},{'lat': 40.0, 'lon': -75.0, 'alt': 500, 'az': 120, 'el': 40},{'lat': 35.0, 'lon': 139.0, 'alt': 20, 'az': 150, 'el': 50},
]positions, directions = [], []
for s in stations:pos = geo_to_ecef(s['lat'], s['lon'], s['alt'])dir = azel_to_direction(s['az'], s['el'], s['lat'], s['lon']) # 简化positions.append(pos)directions.append(dir)asteroid_pos = triangulate(positions, directions)
distance = np.linalg.norm(asteroid_pos) / 1.496e+11 # 转为AU单位
print("小行星距离地球中心:", distance, "AU")
⚙ 问题二:利用多次观测数据,预测小行星未来15或30天的轨道及天文台观测角
问题分析
- 输入:多台天文台对某颗小行星的多时刻观测数据(时刻、方位角、高度角);
- 输出:未来15或30天内,每天某固定时刻的方位角和高度角预测值。
解题思路
- 将观测数据反演为轨道初始状态(即轨道六要素或位置-速度);
- 根据轨道力学模型(两体问题/摄动模型),进行轨道积分,得到未来轨道;
- 对于预测日的每个时间点,将轨道位置转换成各天文台的视角坐标,计算方位角和高度角。
可能用到的数学模型与方法
- Gauss法或Laplace法进行轨道确定(初轨道估计);
- 开普勒轨道传播(Kepler Propagation);
- JPL HORIZONS、NASA SPICE工具可模拟(也可调用简化库如 Skyfield);
- 天球坐标计算公式(向量到方位角、高度角转换);
初步代码框架(Skyfield库)
from skyfield.api import load, Toposts = load.timescale()
ephemeris = load('de421.bsp')
earth = ephemeris['earth']# 假设已知小行星轨道初值(可从MPC或观测数据拟合)
from skyfield.keplerlib import KeplerOrbit
# 伪代码: 构造轨道
# orbit = KeplerOrbit(elements, epoch=ts.utc(2024, 1, 1))# 假设某台站
station = earth + Topos(latitude_degrees=34.0, longitude_degrees=-118.0, elevation_m=1000)# 预测未来30天
t = ts.utc(2024, 1, range(1, 31))
# astrometric = station.at(t).observe(orbit) # 实际需从轨道构造天体
# alt, az, d = astrometric.apparent().altaz()# print("每天12:00的高度角:", alt.degrees)
# print("每天12:00的方位角:", az.degrees)
✅ 总结建议
| 问题 | 本质 | 方法建议 | 数据需求 |
|---|---|---|---|
| 问题一 | 三维空间定位 | 三角测量 + 多射线最短距离 | 多台站的同时观测数据 |
| 问题二 | 轨道传播与预测 | 轨道反演 + 两体运动传播 + 坐标转换 | 多次观测 + 天文台坐标 |
后续会更新详细的解题思路、论文与代码,请看下方~
相关文章:
【2025年认证杯数学中国数学建模网络挑战赛】A题解题思路与模型代码
【2025年认证杯数学建模挑战赛】A题 该题为典型的空间几何建模轨道动力学建模预测问题。 ⚙ 问题一:利用多个天文台的同步观测,确定小行星与地球的相对距离 问题分析 已知若干地面天文台的观测数据:方位角 (Azimuth) 和 高度角 (Altitude)&…...
蓝桥杯备赛 Day16 单调数据结构
单调栈和单调队列能够动态的维护,还需用1-2两个数组在循环时从单调栈和单调队列中记录答案 单调栈 要点 1.时刻保持内部元素具有单调性质的栈(先进后出),核心是:入栈时逐个删除所有"更差的点",一般可分为单调递减栈、单调递增栈、单调不减栈、单调不增…...
轻量级爬虫框架Feapder入门:快速搭建企业级数据管道
一、目标与前置知识 1. 目标概述 本教程的主要目标是: 介绍轻量级爬虫框架 Feapder 的基本使用方式。快速搭建一个采集豆瓣电影数据的爬虫,通过电影名称查找对应的电影详情页并提取相关信息(电影名称、导演、演员、剧情简介、评分…...
golang gmp模型分析
思维导图: 1. 发展过程 思维导图: 在单机时代是没有多线程、多进程、协程这些概念的。早期的操作系统都是顺序执行 单进程的缺点有: 单一执行流程、计算机只能一个任务一个任务进行处理进程阻塞所带来的CPU时间的浪费 处于对CPU资源的利用&…...
深入理解Java Optional:告别NullPointerException的优雅方式
大家好!今天我们来聊聊Java 8引入的一个超实用类 - Optional。不是那个让你重启电脑的CtrlAltDel哦!😄 这是一个能让我们优雅处理null值的工具类,彻底告别烦人的NullPointerException! 一、为什么需要Optional&#x…...
【算法竞赛】树上最长公共路径前缀(蓝桥杯2024真题·团建·超详细解析)
目录 一、题目 二、思路 1. 问题转化:同步DFS走树 2. 优化:同步DFS匹配 3. 状态设计:dfs参数含义 4. 匹配过程:用 map 建立权值索引 5. 终止条件:无法匹配则更新答案 6. 总结 三、完整代码 四、知识点总…...
【windows10】基于SSH反向隧道公网ip端口实现远程桌面
【windows10】基于SSH反向隧道公网ip端口实现远程桌面 1.背景2.SSH反向隧道3.远程连接电脑 1.背景 Windows 10远程桌面协议的简称是RDP(Remote Desktop Protocol)。 RDP是一种网络协议,允许用户远程访问和操作另一台计算机。 远程桌面功…...
Python----概率论与统计(贝叶斯,朴素贝叶斯 )
一、贝叶斯 1.1、贝叶斯定理 贝叶斯定理(Bayes Theorem)也称贝叶斯公式,是关于随机事件的条件概率的定理 贝叶斯的的作用:根据已知的概率来更新事件的概率。 1.2、定理内容 提示: 贝叶斯定理是“由果溯因”的推断&…...
NO.88十六届蓝桥杯备战|动态规划-多重背包|摆花(C++)
多重背包 多重背包问题有两种解法: 按照背包问题的常规分析⽅式,仿照完全背包,第三维枚举使⽤的个数;利⽤⼆进制可以表⽰⼀定范围内整数的性质,转化成01 背包问题。 ⼩建议:并不是所有的多重背包问题都能…...
vue项目打包里面pubilc里的 tinymce里的js文件问题
以下是解决 Vue 项目打包后 public/tinymce 中 JS 文件路径问题的完整方案: 问题原因 当使用 public 目录存放静态资源时,Vue CLI 默认会将 public 下的文件 直接复制到打包目录的根路径,但以下操作可能导致路径错误: 开发环境使…...
Python星球日记 - 第18天:小游戏开发(猜数字游戏)
🌟引言: 上一篇:Python星球日记 - 第17天:数据可视化 名人说:路漫漫其修远兮,吾将上下而求索。(屈原《离骚》) 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 一、游戏概述与原理1. 游戏基本规则2. 编程知识点3.猜数字游戏流程图二、游戏逻辑设计…...
爬虫抓包工具和PyExeJs模块
我们在处理一些网站的时候, 会遇到一些屏蔽F12, 以及只要按出浏览器的开发者工具就会关闭甚至死机的现象. 在遇到这类网站的时候. 我们可以使用抓包工具把页面上屏蔽开发者工具的代码给干掉. Fiddler和Charles 这两款工具是非常优秀的抓包工具. 他们可以监听到我们计算机上所…...
无人机击落技术难点与要点分析!
一、技术难点 1. 目标探测与识别 小型化和低空飞行:现代无人机体积小、飞行高度低(尤其在城市或复杂地形中),雷达和光学传感器难以有效探测。 隐身技术:部分高端无人机采用吸波材料或低可探测设计,进…...
2025年Java无服务器架构实战:AWS Lambda与Spring Cloud Function深度整合
摘要 📝 本文深入探讨如何在2025年Java生态中实现AWS Lambda与Spring Cloud Function的无缝整合。我们将从基础概念讲起,逐步深入到实际部署、性能优化和最佳实践,通过详实的代码示例展示如何构建高效、可扩展的无服务器Java应用。 目录 &a…...
LeetCode 题目 「二叉树的右视图」 中,如何从「中间存储」到「一步到位」实现代码的优化?
背景简介 在 LeetCode 的经典题目 「二叉树的右视图」 中,我们需要返回从右侧看一棵二叉树时所能看到的节点集合。每一层我们只能看到最右边的那个节点。 最初,我采用了一个常规思路:层序遍历 每层单独保存节点值 最后提取每层最后一个节…...
8.第二阶段x64游戏实战-string类
免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 上一个内容:7.第二阶段x64游戏实战-分析人物属性 string类是字符串类,在计算机中…...
Go语言sync.Mutex包源码解读
互斥锁sync.Mutex是在并发程序中对共享资源进行访问控制的主要手段,对此Go语言提供了非常简单易用的机制。sync.Mutex为结构体类型,对外暴露Lock()、Unlock()、TryLock()三种方法,分别用于阻塞加锁、解锁、非阻塞加锁操作(加锁失败…...
C++实现文件断点续传:原理剖析与实战指南
文件传输示意图 一、断点续传的核心价值 1.1 大文件传输的痛点分析 网络闪断导致重复传输:平均重试3-5次。 传输进度不可回溯:用户无法查看历史进度。 带宽利用率低下:每次中断需从头开始。 1.2 断点续传技术优势 指标传统传输断点续传…...
MySQL中FIND_IN_SET函数与INSTR函数用法解析
一、功能定义与语法 1、FIND_IN_SET函数 语法:FIND_IN_SET(str, strlist) 功能:在逗号分隔的字符串列表(strlist)中查找精确匹配的子字符串(str),并返回其位置(从1开始)…...
Python贝叶斯回归、强化学习分析医疗健康数据拟合截断删失数据与参数估计3实例
全文链接:https://tecdat.cn/?p41391 在当今数据驱动的时代,数据科学家面临着处理各种复杂数据和构建有效模型的挑战。本专题合集聚焦于有序分类变量处理、截断与删失数据回归分析以及强化学习模型拟合等多个重要且具有挑战性的数据分析场景,…...
Git 协同开发的常用操作
1. 单仓库(多分支开发) 从远程拉取代码 git clone https://gitee.com/...查看当前分支 git branch -- *master创建并切换到你的开发分支(my-dev) git checkout -b my-dev查看当前分支 git branch -- marster -- *my-dev提交代…...
微信小程序 -- 原生封装table
文章目录 table.wxmltable.wxss注意 table.js注意 结果数据结构 最近菜鸟做微信小程序的一个查询功能,需要展示excel里面的数据,但是菜鸟找了一圈,也没发现什么组件库有table,毕竟手机端好像确实不太适合做table! 菜鸟…...
分布式文件存储系统FastDFS
文章目录 1 分布式文件存储1_分布式文件存储的由来2_常见的分布式存储框架 2 FastDFS介绍3 FastDFS安装1_拉取镜像文件2_构建Tracker服务3_构建Storage服务4_测试图片上传 4 客户端操作1_Fastdfs-java-client2_文件上传3_文件下载4_获取文件信息5_问题 5 SpringBoot整合 1 分布…...
ZKmall开源商城服务端验证:Jakarta Validation 详解
ZKmall开源商城基于Spring Boot 3构建,其服务端数据验证采用Jakarta Validation API(原JSR 380规范),通过声明式注解与自定义扩展机制实现高效、灵活的数据校验体系。以下从技术实现、核心能力、场景优化三个维度展开解析&#…...
深度分页及优化建议
深度分页的定义 深度分页是指在分页查询中,当用户请求非常靠后的页面时,数据库需要处理大量数据,导致查询性能显著下降的情况。例如,一个查询结果有 100 万条记录,而用户要查询第 999 页(每页 10 条记录&a…...
电网电能质量分析:原理、算法及实际应用
一、引言 在现代社会,电力供应的稳定性和可靠性对工业生产、社会生活的各个方面都至关重要。电能质量作为衡量电力系统供电能力的关键指标,其优劣直接影响到电力设备的运行效率、使用寿命以及生产过程的稳定性。随着电力系统规模的不断扩大,新…...
学透Spring Boot — 017. 魔术师—Http消息转换器
本文是我的专栏《学透Spring Boot》的第17篇文章,了解更多请移步我的专栏: 学透 Spring Boot_postnull咖啡的博客-CSDN博客 目录 HTTP请求和响应 需求—新的Media Type 实现—新的Media Type 定义转换器 注册转换器 编写Controller 测试新的medi…...
BOE(京东方)旗下控股子公司“京东方能源”成功挂牌新三板 以科技赋能零碳未来
2025年4月8日,BOE(京东方)旗下控股子公司京东方能源科技股份有限公司(以下简称“京东方能源”)正式通过全国中小企业股份转让系统审核,成功在新三板挂牌(证券简称:能源科技,证券代码:874526),成为BOE(京东方)自物联网转型以来首个独立孵化并成功挂牌的子公司。此次挂牌是BOE(京…...
Airflow集成Lark机器人
🥭1. 实现目标 🕐 通过自定义函数,实现Lark机器人告警功能 🕐 通过Lark机器人代替邮件数据的发送功能 🥭2.自定义函数实现 from airflow import DAG from airflow.operators.python_operator import PythonOperator from airflow.models import Variable import requ…...
Git使用与管理
一.基本操作 1.创建本地仓库 在对应文件目录下进行: git init 输入完上面的代码,所在文件目录下就会多一个名为 .git 的隐藏文件,该文件是Git用来跟踪和管理仓库的。 我们可以使用 tree 命令(注意要先下载tree插件)…...
