卫星参数转换之二行转轨道六根数转经纬度坐标

生命无罪,健康万岁,我是laity。

我曾七次鄙视自己的灵魂:

第一次,当它本可进取时,却故作谦卑;

第二次,当它在空虚时,用爱欲来填充;

第三次,在困难和容易之间,它选择了容易;

第四次,它犯了错,却借由别人也会犯错来宽慰自己;

第五次,它自由软弱,却把它认为是生命的坚韧;

第六次,当它鄙夷一张丑恶的嘴脸时,却不知那正是自己面具中的一副;

第七次,它侧身于生活的污泥中,虽不甘心,却又畏首畏尾。

说明

基于TLE数据(二行转六根)计算轨道六根数(calculateOrbitElement),再根据六根数求其经纬度(getInfo),通过给出的经纬高求距离太阳的距离(getDistanceToSun),最后通过余弦定理求其关照角(TriangleAngles); 主要依赖为:Java类包Orekit

依赖准备

Orekit依赖下载,下载后直接引入到工程中;
再引入个依赖文件(在使用Orekit库之前,我们需要读取Orekit文件)

代码实现

/*** @author: Laity* @Project: JavaLaity* @Package: Utils.TwoRowsToSixRoots.Demo* @Date: 2024年03月14日 18:50* @Description: */public class Demo {public static void main(String[] args) {// tle测试数据String tle = "USA 310\n" +"1 46918U 20083A   23250.72167034 0.00000000  00000-0  00000-0 0    06\n" +"2 46918  58.5225 136.1602 0006695 326.5223  33.4777  3.76176694    05";// 计算轨道参数计算轨道参数calculateOrbitElement(tle);// 获取数据获取位置getInfo();// 三角角三角形三个角的度数TriangleAngles();}/*** 计算轨道参数 (半长轴,离心率,轨道倾角,升交点赤经,近地点幅角,真近点角)* @param tle tle轨道参数(二行转六根)*/public static void calculateOrbitElement(String tle){File orekitData = new File("D:\\Stay_up_late_champion\\dataStructure\\src\\main\\resources\\file\\orekit-data-master\\");DataProvidersManager manager = DataContext.getDefault().getDataProvidersManager();manager.addProvider(new DirectoryCrawler(orekitData)); // 存放orekitdata路径String[] params = tle.split("\n");String line1= params[1];String line2= params[2];TLE tleObj = new TLE(line1,line2);TLEPropagator  tlePropagator= TLEPropagator.selectExtrapolator(tleObj);Orbit cartesianOrbit = tlePropagator.getInitialState().getOrbit(); // 笛卡尔轨道KeplerianOrbit keplerianOrbit = new KeplerianOrbit(cartesianOrbit);  // 转换为开普勒轨道System.out.println("半长轴:"+keplerianOrbit.getA());System.out.println("离心率:"+keplerianOrbit.getE());System.out.println("轨道倾角:"+keplerianOrbit.getI());System.out.println("升交点赤经:"+Math.toDegrees(keplerianOrbit.getRightAscensionOfAscendingNode())); // 弧度转化为度System.out.println("近地点幅角:"+Math.toDegrees(keplerianOrbit.getPerigeeArgument()));System.out.println("真近点角"+keplerianOrbit.getTrueAnomaly());}public static void getInfo(){// 定义J2000坐标系和ECFF坐标系// 定义J2000坐标系Frame J2000 = FramesFactory.getEME2000();// 定义ECFF坐标系Frame ecff = FramesFactory.getITRF(IERSConventions.IERS_2010, true);// 定义地心引力常数// gravitation coefficientfinal double mu =  3.986004415e+14;// 定义卫星基本参数并计算卫星的PV坐标// 轨道六根数double a = 6931700.6; // 半长轴 (m)double e = 0.001264070355890773;           // 离心率double i = 0.9262838362266536; // 轨道倾角 (弧度)double argOfPerigee = -64.04849998651345; // 升交点赤经 (弧度)double raan = 52.248882667192056;  // 升交点赤纬 (弧度)double meanAnomaly = -0.9119147488086196; // 真近点角 (弧度)// 定义时刻final TimeScale utc = TimeScalesFactory.getUTC();final AbsoluteDate initialDate = new AbsoluteDate(2024, 03, 12, 19, 16, 01.10, utc);// 计算PV坐标final Orbit initialOrbit = new KeplerianOrbit(a, e, i, argOfPerigee, raan, meanAnomaly, PositionAngle.MEAN,J2000, initialDate, mu);// 转换到J2000坐标系// 转换到J2000坐标系PVCoordinates pvCoordinates = initialOrbit.getPVCoordinates(J2000);// 转换到ECFF坐标系PVCoordinates pvInECFF = J2000.getTransformTo(ecff, initialDate).transformPVCoordinates(pvCoordinates);// 获取地球中心的坐标double x = pvInECFF.getPosition().getX();double y = pvInECFF.getPosition().getY();double z = pvInECFF.getPosition().getZ();// 计算经纬度double longitude = Math.atan2(y, x);double latitude = Math.atan2(z, Math.sqrt(x * x + y * y));double altitude = Math.sqrt(x * x + y * y + z * z) - Constants.WGS84_EARTH_EQUATORIAL_RADIUS;System.out.println("经度 (degrees): " + longitude);System.out.println("纬度 (degrees): " + latitude);System.out.println("高度 (meters): " + altitude);getDistanceToSun(longitude, latitude, altitude);}/*** 计算位置与太阳表面的距离* @param longitude 经度 单位:弧度* @param latitude 纬度 单位:弧度* @param altitude 高度 单位:米*/public static void getDistanceToSun(double longitude, double latitude, double altitude) {/* 经度,以弧度表示 *//*double longitude = Math.toRadians();*//* 纬度,以弧度表示 *//*double latitude = Math.toRadians();*//* 高度,以米为单位 *//*double altitude =  ;*/double earthRadius = 6371000; // 以米为单位// 计算太阳中心到地球中心的距离double sunEarthDistance = 149.6e9; // 以米为单位// 计算太阳的视直径double sunDiameter = 2 * Math.asin(696340e3 / (2 * sunEarthDistance)); // 以弧度为单位// 计算从位置到太阳表面的距离// 计算了从给定位置到太阳表面的距离。它利用了地球表面的位置与太阳表面的位置之间的直线距离,以及地球和太阳之间的距离,以及给定位置的海拔高度。double distanceToSun = Math.sqrt(Math.pow((sunEarthDistance * Math.cos(sunDiameter / 2) - earthRadius * Math.cos(latitude)), 2) + Math.pow((sunEarthDistance * Math.sin(sunDiameter / 2) - earthRadius * Math.sin(latitude)), 2) + Math.pow(altitude, 2));// 经度(longitude)并未直接用于计算距离。经度通常用于确定位置的东西方向,但在这种情况下,并不影响计算太阳与地球的距离。相反,纬度(latitude)是在计算中用到的,因为它影响到了太阳在天空中的位置。// double distanceToSun = Math.sqrt(Math.pow((sunEarthDistance * Math.cos(sunDiameter / 2) - earthRadius * Math.cos(latitude)), 2) + Math.pow((sunEarthDistance * Math.sin(sunDiameter / 2) - earthRadius * Math.sin(latitude)), 2) + Math.pow(altitude, 2));System.out.println("位置与太阳表面的距离:" + distanceToSun);}/*** 三角形三个角的度数*/public static void TriangleAngles(){double a = 3;double b = 4;double c = 5;double A = Math.toDegrees(Math.acos((b * b + c * c - a * a) / (2 * b * c)));double B = Math.toDegrees(Math.acos((a * a + c * c - b * b) / (2 * a * c)));double C = Math.toDegrees(Math.acos((a * a + b * b - c * c) / (2 * a * b)));// 角A由边b和边c组成,角B由边a和边c组成,角C由边a和边b组成。System.out.println("Angle A: " + A);System.out.println("Angle B: " + B);System.out.println("Angle C: " + C);}
}

pom文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.example</groupId><artifactId>dataStructure</artifactId><version>1.0-SNAPSHOT</version><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties><dependencies><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-fitting</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-core</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-clustering</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-fft</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-filtering</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-geometry</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-ode</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-optim</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-stat</artifactId><version>3.0</version></dependency><dependency><groupId>org.hipparchus</groupId><artifactId>hipparchus-migration</artifactId><version>3.0</version></dependency></dependencies>
</project>

测试数据

USA 299
1 44071U 19014A   24057.09035528  .00000042  00000-0  00000+0 0  9897
2 44071   0.0276 127.9287 0000244 313.9012 146.3000  1.00266779 18261USA 214
1 38070U 12003A   24066.80118976 -.00000219  00000-0  00000+0 0  9894
2 38070   0.0177 132.4830 0000231  49.8698 349.4673  1.00271171 44370VELOX 20
1 41171U 15077F   24066.46653569  .00065376  00000-0  11856-2 0  9896
2 41171  14.9887 139.0649 0002567  32.3897 317.6586 15.47721355455793

梦想不会逃跑了,逃跑了的永远都是自己。我是Laity,正在前进的Laity。

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

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

相关文章

Linux关机和重启指令

关机 立即关机指令如下&#xff0c; sudo shutdown -h now 延迟关机指令如下&#xff0c;&#xff08;5表示5分钟后执行该操作&#xff09; sudo shutdown -h 5 重启 立即重启指令如下&#xff0c; sudo shutdown -r now 延迟重启指令如下&#xff0c; sudo shutdow…

【Android】源码中的工厂方法模式

本文是基于 Android 14 的源码解析 工厂方法模式应用很广泛&#xff0c;我们平时开发中经常会使用到的数据结构中其实也隐藏着对工厂方法模式的应用&#xff0c;以 List 和 Set 为例&#xff0c;List 和 Set 都继承于 Collection 接口&#xff0c;而 Collection 接口继承于 Ite…

头歌-贪心算法

第1关 找零钱 任务描述 本关任务&#xff1a;设计一个贪婪算法&#xff0c;使得找的钱币张数最少。 商店售货员找给 1 个顾客 n 元&#xff0c;用以下七种面值的纸币&#xff1a;100 元&#xff0c;50 元&#xff0c;20 元&#xff0c;10 元&#xff0c;5 元&#xff0c;2 …

激活函数理解

前言 为什么神经网中非要有各种各样的激活函数&#xff1f;他们有什么用&#xff1f;没有他们会怎样&#xff1f;常见的激活函数有哪些&#xff0c;他们都有什么特点&#xff1f; 如果我们不运用激活函数&#xff0c;神经网络的输出信号将仅仅是一个简单的线性函数。线性方程…

Docker 容器化技术:构建高效、可移植的开发环境和部署流程|Docker 网络

为了支持网络协议栈的多个实例&#xff0c;Linux 在网络协议栈中引入了网络命名空间。这些独立的协议栈被隔离到不同的命名空间中&#xff0c;处于不同命名空间中的网络协议栈是完全隔离的&#xff0c;彼此无法通信。通过对网络资源的隔离&#xff0c;就能在一台宿主机上虚拟多…

L1-019 谁先倒(Java)

一、题目描述&#xff1a; 划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为&#xff1a;每人口中喊出一个数字&#xff0c;同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和&#xff0c;谁就输了&#xff0c;输家罚一杯酒。两人同赢或…

android 事件分发笔记

这是学习笔记,以我看得明白为主。 分为 view.dispatchTouchEvent,---只有事件的处理逻辑 ----- ViewGroup.dispatchTouchEvent---实现了分发流程的逻辑 事件接收流程 setView#ViewRootImpl.java //接收事件的方法 ------> new WindowInputEventReceiver(inputChann…

FFmepg--视频编码流程--yuv编码为h264

文章目录 基本概念流程api核心代码 基本概念 YUV格式&#xff1a;是一种颜色编码方式&#xff0c;YUV分别为三个分量&#xff1a;‘Y’是明亮度&#xff0c;也就是灰度值&#xff1b;‘U’和‘V’是色度 YUV格式的分类&#xff1a; planar的YUV格式&#xff1a;先存储planar的…

初步了解序列化和反序列化

01什么是序列化和反序列化 序列化是将对象转化为字符串以便存储的一种方式。而反序列化恰好是序列化的逆过程&#xff0c;反序列化会将字符串转化为对象供程序使用。 常见的php系列化和反系列化方式主要有&#xff1a;serialize&#xff0c;unserialize&#xff1b;json_enco…

【运维开发岗面试题1】

目录 mkdir -p 中-p 是干什么的&#xff1f;df -h 和 du -h 命令作用&#xff1f;磁盘管理你都用到过什么命令&#xff1f;cp 和 mv 是干什么的&#xff1f;有什么区别内存大小怎么查看&#xff1f;查看内存的运行情况&#xff1f;怎么查看内存&#xff1f;进程杀不掉怎么办如何…

姿态旋转的哥氏定理以及速度微分的推导

姿态旋转中涉及到坐标系的转换&#xff0c;在有相对旋转的两个坐标系中观察一个向量的变化&#xff0c;用到了哥氏定理。 例如在i系中观察e系下的运动&#xff0c;则 哥氏定理的公式 wie是e相对于i的角运动 注意符号i在前e在后。 wie是e相对于i的角运动 注意符号i在前e在…

各个类型和Json类型的相互转换

ObjectMapper类(com.fasterxml.jackson.databind.ObjectMapper)是Jackson的主要类&#xff0c;它可以帮助我们快速的进行各个类型和Json类型的相互转换。 对应maven&#xff1a; <dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId&…

【驱动】编译内核时报错:multiple definition of `yylloc‘

1、问题描述 在Ubuntu22.04中编译Linux kernel4.9源码时报错: /usr/bin/ld: scripts/dtc/dtc-parser.tab.o:(.bss+0x10): multiple definition of `yylloc; scripts/dtc/dtc-lexer.lex.o:(.bss+0x0): first defined here collect2: error: ld returned 1 exit status make[2…

R语言:如何基于地球外辐射(Ra)和相对日照(n/N)计算太阳辐射Rs?

正在编写相关软著&#xff0c;借此机会了解R语言的基本语法和一些处理流程&#xff0c;所以解释稍微繁琐。 Note&#xff1a; 使用的R语言版本是 R version 4.3.2 (2023-10-31 ucrt) 使用的RStudio编辑器版本是&#xff1a; 01 基于随机森林的插值填补缺失值 这是目前处理…

深入探索C与C++的混合编程

实现混合编程的技术细节 混合使用C和C可能由多种原因驱动。一方面&#xff0c;现有的大量优秀C语言库为特定任务提供了高效的解决方案&#xff0c;将这些库直接应用于C项目中可以节省大量的开发时间和成本。另一方面&#xff0c;C的高级特性如类、模板和异常处理等&#xff0c;…

mysql数据库中查询重复数据和去重数据

文章目录 1.查找重复数据2. 查到重复组的唯一数据3.删除重复数据4.注意重复的内容和删除的记录数是否一致 1.查找重复数据 select gene_entrez_id,count(*) a from diag_gene GROUP BY gene_entrez_id HAVING a > 12. 查到重复组的唯一数据 原理 分组后如果组内多个数据…

跨境电商干货|如何在Snapchat上做电商?

Snapchat是一个与用户互动与创意内容为主的平台&#xff0c;也因其广阔的受众群体广受跨境电商卖家的喜爱&#xff0c;成为跨境出海的热门渠道之一。本文将为大家分享&#xff0c;要在Snapchat上进行电子商务&#xff0c;可以遵循以下步骤&#xff1a; 1、创建商业账户 在Snap…

卷积的九大变体算法

注意&#xff1a;本文引用自专业人工智能社区Venus AI 更多AI知识请参考原站 &#xff08;[www.aideeplearning.cn]&#xff09; 引言 卷积神经网络&#xff08;CNN&#xff09;的核心在于其多样化的卷积技术&#xff0c;每种技术针对不同的应用和性能需求有着独特的优势。逐…

力扣46. 全排列

Problem: 46. 全排列 文章目录 题目描述思路及解法复杂度Code 题目描述 思路及解法 回溯可以理解为是在对一个多叉树的操作 1.回溯结束条件&#xff1a;当决策路径的长度等于nums数组的长度时&#xff0c;将当前的结果添加到二维结果集res中&#xff1b; 2.每一次决策的选择处…

javaScript链式调用的简单实现

链式调用在JavaScript很常见&#xff0c;比如jQuery、Promise和其它的插件等&#xff0c;都是使用的链式调用。链式调用可以让我们在进行连续操作时&#xff0c;写出更简洁的代码。 链式调用它允许你在单个对象上连续调用多个方法&#xff0c;每个方法的返回值都是调用它的那个…