使用编译版rtklib过程中如何进行main的调试(spp ppp)

2023-10-04 16:50

本文主要是介绍使用编译版rtklib过程中如何进行main的调试(spp ppp),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用编译版rtklib过程中如何进行main的调试(spp ppp)

在编译版rtklib的调试过程中,需要在main函数中定义一些参数。
在进行spp(伪距单点定位)的时候,我们通常这样设定相关参数。

// An highlighted blockprcopt_t popt = prcopt_default;solopt_t sopt = solopt_default;filopt_t fopt = { "" };gtime_t ts = { 0 }, te = { 0 };double tint = 0.0;int n = 8;char *infile[] = {{"D:\\data\\2019182\\kat11820.19o"},{"D:\\data\\2019182\\gbm20600.clk"},{"D:\\data\\2019182\\gbm20600.sp3"},{"D:\\data\\2019182\\gbm20601.clk"},{"D:\\data\\2019182\\gbm20601.sp3"},{"D:\\data\\2019182\\gbm20602.clk"},{"D:\\data\\2019182\\gbm20602.sp3"},{"D:\\data\\2019182\\brdm1820.19p"}};char *outfile = { "D:\\data\\2019182\\kat1091820_spp.pos" };#if 1    /* SPP */popt.navsys = SYS_GPS;// GPS+GAL //SYS_ALL;popt.mode = PMODE_SINGLE;popt.sateph = EPHOPT_PREC;popt.elmin = 7 * D2R;popt.ionoopt = IONOOPT_BRDC;popt.ionoopt = IONOOPT_TEC;sopt.posf = SOLF_XYZ;sopt.times = TIMES_GPST;sopt.timef = 1;sopt.timeu = 3;#endifpostpos(ts, te, tint, 0.0, &popt, &sopt, &fopt, infile, n, outfile, "", ""); 

在进行ppp(精密单点定位的时候,因为需要进行dcb(different code bias)改正、pcv改正等等,需要一些额外的文件 如图所示。在这里插入图片描述
那么,如何在编译版的main中进行设置以达到同rtkpost一样的结算结果呢?
我们从代码出发,rtklib通过postpos.c进行后处理

在这里插入图片描述
找到execses函数

/* execute processing session ------------------------------------------------*/
static int execses(gtime_t ts, gtime_t te, double ti, const prcopt_t *popt,const solopt_t *sopt, const filopt_t *fopt, int flag,char **infile, const int *index, int n, char *outfile)

我们便可以找到.blq .erp .dcb等文件的读取方式
在这里插入图片描述
以dcb为例,可以看到,代码中先对fopt->dcb是否为空进行判断,如果其为非空,则进行读取,因此我们可以fop为线索,通过vs中的调用层次结果功能进行查找,进而发现调用结构如下在这里插入图片描述pcv如下在这里插入图片描述

在这里插入图片描述
发现源头在main,可以直接通过 filopt_t fopt = { “” };进行设置

typedef struct {        /* file options type */char satantp[MAXSTRPATH]; /* satellite antenna parameters file */char rcvantp[MAXSTRPATH]; /* receiver antenna parameters file */char stapos [MAXSTRPATH]; /* station positions file */char geoid  [MAXSTRPATH]; /* external geoid data file */char iono   [MAXSTRPATH]; /* ionosphere data file */char dcb    [MAXSTRPATH]; /* dcb data file */char eop    [MAXSTRPATH]; /* eop data file */char blq    [MAXSTRPATH]; /* ocean tide loading blq file */char tempdir[MAXSTRPATH]; /* ftp/http temporaly directory */char geexe  [MAXSTRPATH]; /* google earth exec file */char solstat[MAXSTRPATH]; /* solution statistics file */char trace  [MAXSTRPATH]; /* debug trace file */
} filopt_t;

只需要设置在main中设置好文件路径即可
因此,修改后关于ppp的main函数如下

    prcopt_t popt = prcopt_default;solopt_t sopt = solopt_default;filopt_t fopt = { "" };gtime_t ts = { 0 }, te = { 0 };double tint = 0.0;int n = 8;char *infile[] = {{"D:\\data\\2019182\\kat11820.19o"},{"D:\\data\\2019182\\gbm20600.clk"},{"D:\\data\\2019182\\gbm20600.sp3"},{"D:\\data\\2019182\\gbm20601.clk"},{"D:\\data\\2019182\\gbm20601.sp3"},{"D:\\data\\2019182\\gbm20602.clk"},{"D:\\data\\2019182\\gbm20602.sp3"},{"D:\\data\\2019182\\brdm1820.19p"}};char *outfile = { "D:\\data\\2019182\\kat1091820_spp.pos" };popt.navsys = SYS_GPS;// GPS+GAL //SYS_ALL;popt.mode = PMODE_SINGLE;popt.sateph = EPHOPT_PREC;popt.elmin = 7 * D2R;popt.ionoopt = IONOOPT_TEC;popt.tropopt = TROPOPT_ZTD;sopt.posf = SOLF_XYZ;sopt.times = TIMES_GPST;sopt.timef = 1;sopt.timeu = 3;strcpy(fopt.dcb, "D:\A正在处理\RTK数据\2019244\P1C11909.DCB");strcpy(fopt.eop, "D:\A正在处理\RTK数据\2019244\igs20697.erp");strcpy(fopt.blq, "D:\A正在处理\RTK数据\2019244\ocnload.blq");strcpy(fopt.satantp, "D:\A正在处理\RTK数据\2019244\igs14_gbm.atx");strcpy(fopt.rcvantp, "D:\A正在处理\RTK数据\2019244\igs14_gbm.atx");postpos(ts, te, tint, 0.0, &popt, &sopt, &fopt, infile, n, outfile, "", "");

关于调试后的结果对比,下次再写。

这篇关于使用编译版rtklib过程中如何进行main的调试(spp ppp)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

SpringSecurity6.0 如何通过JWTtoken进行认证授权

《SpringSecurity6.0如何通过JWTtoken进行认证授权》:本文主要介绍SpringSecurity6.0通过JWTtoken进行认证授权的过程,本文给大家介绍的非常详细,感兴趣... 目录项目依赖认证UserDetailService生成JWT token权限控制小结之前写过一个文章,从S

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro