【DeepSeek】Deepseek辅组编程-通过卫星轨道计算终端距离、相对速度和多普勒频移
引言
笔者在前面的文章中,介绍了基于卫星轨道参数如何计算终端和卫星的距离,相对速度和多普勒频移。
【一文读懂】卫星轨道的轨道参数(六根数)和位置速度矢量转换及其在终端距离、相对速度和多普勒频移计算中的应用
Matlab程序
本文笔者将尝试通过deepseek-R1模型,编写Matlab程序,完成上文中的运算过程。
以下是根据文档内容创建的MATLAB程序,用于计算卫星与地面终端之间的距离、相对速度及多普勒频移:
% 定义轨道六要素和地球参数
a = 7.0e7; % 半长轴(单位:米)
e = 0.1; % 偏心率
i = 45 * pi/180; % 轨道倾角(弧度)
Ω = 120 * pi/180; % 升交点赤经(弧度)
ω = 30 * pi/180; % 近地点幅角(弧度)
ν = 0 * pi/180; % 真近点角(弧度)μ = 3.986e14; % 地球标准重力参数(m³/s²)
R = 6378137; % 地球赤道半径(米)
earth_ω = 7.2921e-5; % 地球自转角速度(rad/s)% 计算轨道半径
r = a * (1 - e * cos(ν));% 近焦点坐标系下的位置和速度矢量
r_perifocal = [r * cos(ν), r * sin(ν), 0];
v_perifocal = [-sqrt(μ * a) * e * sin(ν) / (r), sqrt(μ * a) * (1 + e * cos(ν)) / r, 0];% 构建旋转矩阵
Q = dcm_body_to_eci(ω, i, Ω);% 轨道坐标系到ECI坐标系的转换
r_eci = Q * r_perifocal';
v_eci = Q * v_perifocal';% 转换到ECEF坐标系
[lat, lon, h] = eci_to_ecef(r_eci, v_eci, earth_ω);% 地面终端位置(示例:北京)
lat0 = 39.9042 * pi/180; % 纬度
lon0 = 116.4074 * pi/180; % 经度
h0 = 50; % 高度(米)% 地理坐标转ECEF坐标
[r_ecef, v_ecef] = geodetic_to_ecef(lat0, lon0, h0);% 计算距离
distance = norm(r_eci - r_ecef);% 计算相对速度
velocity_diff = v_eci - v_ecef;
relative_speed = norm(velocity_diff);% 计算多普勒频移
c = 299792458; % 光速
f0 = 1.5e9; % 载波频率(示例值)
doppler_shift = (relative_speed / c) * f0;% 输出结果
fprintf('卫星与地面终端的距离:%.2f km\n', distance / 1000);
fprintf('相对速度:%.2f m/s\n', relative_speed);
fprintf('多普勒频移:%.2f Hz\n', doppler_shift);
功能说明
- 轨道参数初始化:定义卫星的轨道六要素和地球参数。 轨道半径计算:根据开普勒运动公式计算当前位置的轨道半径。
- 位置和速度矢量:在近焦点坐标系中计算卫星的位置和速度。 坐标转换:通过旋转矩阵将近焦点坐标系的位置和速度转换到ECI坐标系。
- ECEF坐标转换:考虑地球自转效应,将ECI坐标转换为ECEF坐标。 地面终端位置计算:将地理坐标转换为ECEF坐标。
- 距离、速度和多普勒频移计算:计算卫星与地面终端之间的关键参数。
测试验证
使用示例参数运行程序,验证输出结果是否合理。
检查单位是否一致(例如:距离单位为米,速度单位为米/秒)。
确保所有角度转换为弧度进行计算。
注意事项
确保所有角度参数在计算前已转换为弧度。
检查坐标系转换矩阵的正确性。
确保地球自转角速度的方向和大小与参数一致。
验证程序
以下是为验证主程序功能而创建的测试程序,包含多个测试用例和结果验证:
% 测试用例集合
test_cases = struct('a', {7.0e7, 8.0e7, 7.2e7}, ...'e', {0.1, 0.2, 0}, ...'i', {45*pi/180, 60*pi/180, 30*pi/180}, ...'Ω', {120*pi/180, 180*pi/180, 60*pi/180}, ...'ω', {30*pi/180, 45*pi/180, 15*pi/180}, ...'ν', {0*pi/180, 90*pi/180, 180*pi/180});% 测试结果存储
results = struct('distance', [], 'speed', [], 'doppler', []);% 运行所有测试用例
for i = 1:length(test_cases.a)a = test_cases.a{i};e = test_cases.e{i};i_angle = test_cases.i{i};Ω = test_cases.Ω{i};ω = test_cases.ω{i};ν = test_cases.ν{i};% 调用主程序进行计算[distance, speed, doppler] = satellite_communication_calculator(...a, e, i_angle, Ω, ω, ν);% 存储结果results.distance(end+1) = distance;results.speed(end+1) = speed;results.doppler(end+1) = doppler;% 显示当前测试进度fprintf('测试用例 %d/%d 已完成\n', i, length(test_cases.a));
end% 显示所有测试结果
disp('所有测试结果:');
disp(results);% 可视化结果
figure;
subplot(3,1,1);
plot(results.distance);
title('距离(米)');
xlabel('测试用例');
ylabel('距离');subplot(3,1,2);
plot(results.speed);
title('相对速度(米/秒)');
xlabel('测试用例');
ylabel('速度');subplot(3,1,3);
plot(results.doppler);
title('多普勒频移(Hz)');
xlabel('测试用例');
ylabel('频移');
测试程序说明
1. 测试用例定义:包含了不同轨道参数的多组测试用例,覆盖:
- 不同轨道半长轴(a)
- 不同偏心率(e)
- 不同轨道倾角(i)
- 不同升交点赤经(Ω)
- 不同近地点幅角(ω)
- 不同真近点角(ν)
2.自动化测试流程:
- 遍历所有测试用例
- 调用主程序进行计算
- 存储结果
- 显示进度
3.结果可视化:
- 绘制距离、速度和多普勒频移的变化趋势
- 方便直观验证结果的合理性
4.功能验证:
- 验证不同轨道参数对距离计算的影响
- 检查相对速度计算的准确性
- 确认多普勒频移计算的正确性
使用方法
- 确保主程序satellite_communication_calculator.m已经保存在MATLAB路径中
- 运行测试程序
- 查看控制台输出和图形结果
- 根据需要调整测试用例或添加新的测试参数
这个测试程序能够全面验证主程序的功能和准确性,同时也便于调试和优化。
相关文章:
【DeepSeek】Deepseek辅组编程-通过卫星轨道计算终端距离、相对速度和多普勒频移
引言 笔者在前面的文章中,介绍了基于卫星轨道参数如何计算终端和卫星的距离,相对速度和多普勒频移。 【一文读懂】卫星轨道的轨道参数(六根数)和位置速度矢量转换及其在终端距离、相对速度和多普勒频移计算中的应用 Matlab程序 …...
【kafka实战】05 Kafka消费者消费消息过程源码剖析
1. 概述 Kafka消费者(Consumer)是Kafka系统中负责从Kafka集群中拉取消息的客户端组件。消费者消费消息的过程涉及多个步骤,包括消费者组的协调、分区分配、消息拉取、消息处理等。本文将深入剖析Kafka消费者消费消息的源码,并结合…...
[EAI-033] SFT 记忆,RL 泛化,LLM和VLM的消融研究
Paper Card 论文标题:SFT Memorizes, RL Generalizes: A Comparative Study of Foundation Model Post-training 论文作者:Tianzhe Chu, Yuexiang Zhai, Jihan Yang, Shengbang Tong, Saining Xie, Dale Schuurmans, Quoc V. Le, Sergey Levine, Yi Ma 论…...
算法与数据结构(字符串相乘)
题目 思路 这道题我们可以使用竖式乘法,从右往左遍历每个乘数,将其相乘,并且把乘完的数记录在nums数组中,然后再进行进位运算,将同一列的数进行相加,进位。 解题过程 首先求出两个数组的长度,…...
DeepSeek从入门到精通:全面掌握AI大模型的核心能力
文章目录 一、DeepSeek是什么?性能对齐OpenAI-o1正式版 二、Deepseek可以做什么?能力图谱文本生成自然语言理解与分析编程与代码相关常规绘图 三、如何使用DeepSeek?四、DeepSeek从入门到精通推理模型推理大模型非推理大模型 快思慢想&#x…...
【Pytorch函数】PyTorch随机数生成全解析 | torch.rand()家族函数使用指南
🌟 PyTorch随机数生成全解析 | torch.rand()家族函数使用指南 🌟 📌 一、核心函数参数详解 PyTorch提供多种随机数生成函数(注意:无直接torch.random()函数),以下是常用函数及参数:…...
vue print 打印
vue 点击打印页面部分内容,或者打印弹窗内的内容 打印页面部分内容 <template><div><div id"print"><div class"info"><div class"bx_title">费用报销单<span class"code">NO.<s…...
【异常解决】在idea中提示 hutool 提示 HttpResponse used withoud try-with-resources statement
博主介绍:✌全网粉丝22W,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…...
【Uniapp-Vue3】UniCloud云数据库获取指定字段的数据
使用where方法可以获取指定的字段: let db uniCloud.database(); db.collection("数据表").where({字段名1:数据, 字段名2:数据}).get({getOne:true}) 如果我们不在get中添加{getOne:true},在只获取到一个数据res.result.data将会是一个数组&…...
信息科技伦理与道德3-2:智能决策
2.2 智能推荐 推荐算法介绍 推荐系统:猜你喜欢 https://blog.csdn.net/search_129_hr/article/details/120468187 推荐系统–矩阵分解 https://blog.csdn.net/search_129_hr/article/details/121598087 案例一:YouTube推荐算法向儿童推荐不适宜视频 …...
openssl使用
openssl使用 提取密钥对 数字证书pfx包含公钥和私钥,而cer证书只包含公钥。提取需输入证书保护密码 openssl pkcs12 -in xxx.pfx -nocerts -nodes -out pare.key提取私钥 openssl rsa -in pare.key -out pri.key提取公钥 openssl rsa -in pare.key -pubout -ou…...
Visual Studio 2022 中使用 Google Test
要在 Visual Studio 2022 中使用 Google Test (gtest),可以按照以下步骤进行: 安装 Google Test:确保你已经安装了 Google Test。如果没有安装,可以通过 Visual Studio Installer 安装。在安装程序中,找到并选择 Googl…...
SpringBoot3 + Jedis5 + Redis集群 如何通过scan方法分页获取所有keys
背景: 由于需要升级老项目代码,从SpringBoot1.5.x 升级到 SpringBoot3.3.x,框架中引用的Jedis自动升级到了 5.x;正好代码中有需要获取Redis集群的所有keys的需求存在;代码就不适用了,修改如下: POM 由于…...
WGCLOUD监控系统部署教程
官网地址:下载WGCLOUD安装包 - WGCLOUD官网 第一步、环境配置 #安装jdk 1、安装 EPEL 仓库: sudo yum install -y epel-release 2、安装 OpenJDK 11: sudo yum install java-11-openjdk-devel 3、如果成功,你可以通过运行 java …...
协议-WebRTC-HLS
是什么? WebRTC(Web Real-Time Communication) 实现 Web 浏览器和移动应用程序之间通过互联网直接进行实时通信。允许点对点音频、视频和数据共享,而无需任何插件或其他软件。WebRTC 广泛用于构建视频会议、语音通话、直播、在线游…...
jQuery UI 下载指南
jQuery UI 下载指南 引言 jQuery UI 是一个基于 jQuery 的用户界面和交互库,它提供了一套丰富的交互组件和视觉效果,可以帮助开发者快速构建美观、交互性强的网页应用。本文将为您详细介绍如何下载 jQuery UI,并指导您进行安装和使用。 jQ…...
MySQL系列之数据类型(String)
导览 前言一、字符串类型知多少 1. 类型说明2. 字符和字节的转换 二、字符串类型的异同 1. CHAR & VARCHAR2. BINARY & VARBINARY3. BLOB & TEXT4. ENUM & SET 结语精彩回放 前言 MySQL数据类型第三弹闪亮登场,欢迎关注O。 本篇博主开始谈谈MySQ…...
Kotlin 2.1.0 入门教程(十)if、when
if 表达式 if 是一个表达式,它会返回一个值。 不存在三元运算符(condition ? then : else),因为 if 在这种场景下完全可以胜任。 var max aif (a < b) max bif (a > b) {max a } else {max b }max if (a > b) a…...
编程式路由
<script> export default {name: video-Info1,created () {setTimeout(() > {this.$router.push({ name: home })}, 3000)} } </script> 编程式路由:实现 不需要用户点击router-link,由代码实现路由跳转。 应用场景:用户登录…...
openAI官方prompt技巧(一)
1. 使用最新的模型 2. 将指令放在提示词的开头,并使用 ### 或 """ 来分隔指令和上下文,例如 错误示范❌ 将下面的文本总结为一个要点列表,列出最重要的内容。 Summarize the text below as a bullet point list of the most…...
利用 Python 爬虫获取按关键字搜索淘宝商品的完整指南
在电商数据分析和市场研究中,获取商品的详细信息是至关重要的一步。淘宝作为中国最大的电商平台之一,提供了丰富的商品数据。通过 Python 爬虫技术,我们可以高效地获取按关键字搜索的淘宝商品信息。本文将详细介绍如何利用 Python 爬虫技术获…...
LeetCode 0080.删除有序数组中的重复项 II:双指针 - C++/Java5 行版
【LetMeFly】80.删除有序数组中的重复项 II:双指针 - C/Java5 行版 力扣题目链接:https://leetcode.cn/problems/remove-duplicates-from-sorted-array-ii/ 给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使得出现次数超…...
【C++高并发服务器WebServer】-15:poll、epoll详解及实现
本文目录 一、poll二、epoll2.1 相对poll和select的优点2.2 epoll的api2.3 epoll的demo实现2.5 epoll的工作模式 一、poll poll是对select的一个改进,我们先来看看select的缺点。 我们来看看poll的实现。 struct pollfd {int fd; /* 委托内核检测的文件描述符 */s…...
MapReduce是什么?
MapReduce 是一种编程模型,最初由 Google 提出,旨在处理大规模数据集。它是分布式计算的一个重要概念,通常用于处理海量数据并进行并行计算。MapReduce的基本思想是将计算任务分解为两个阶段:Map 阶段和 Reduce 阶段。 Map 阶段&a…...
git提交到GitHub问题汇总
1.main->master git默认主分支是maser,如果是按照这个分支名push,GitHub会出现两个branch,与预期不符 解决方案:更改原始主分支名为main git config --global init.defaultBranch main2.git:OpenSSL SSL_read: SS…...
CNN-GRU卷积神经网络门控循环单元多变量多步预测,光伏功率预测(Matlab完整源码和数据)
代码地址:CNN-GRU卷积神经网络门控循环单元多变量多步预测,光伏功率预测(Matlab完整源码和数据) CNN-GRU卷积神经网络门控循环单元多变量多步预测,光伏功率预测 一、引言 1.1、研究背景和意义 随着全球能源危机和环境问题的日…...
编译原理面试问答
编译原理面试拷打 1.编译原理的基本概念 编译原理是研究如何将高级程序语言转换为计算机可执行代码的理论与技术,其核心目标是实现高效、正确的代码翻译。 **编译器:**将源代码转化为目标代码(机器码、字节码等)。一次翻译整个程…...
LIMO:上海交大的工作 “少即是多” LLM 推理
25年2月来自上海交大、SII 和 GAIR 的论文“LIMO: Less is More for Reasoning”。 一个挑战是在大语言模型(LLM)中的复杂推理。虽然传统观点认为复杂的推理任务需要大量的训练数据(通常超过 100,000 个示例),但本文展…...
Java 魔法:精准掌控 PDF 合同模板,指定页码与关键字替换签章日期
朋友们!在实际业务场景中,经常会碰到处理 PDF 合同模板的需求,要在几十页的合同里对指定页面替换公章、签名和日期,还涉及多人签名以及多个公司盖公章。下面就给大家分享两种用 Java 处理这类问题的方法,一种是通过指定…...
Ollama 部署本地大语言模型
一、下载安装ollama 1.百度 ollama Ollama 2.点击下载 可以复制下载链接,使用下载器下载。 3.双击安装 默认安装目录:C:\Users\用户名\AppData\Local\Programs\Ollama 二、更改模型下载目录 0.默认下载目录 (跳过) 之前没下载过模型,不…...
