• 概述

精密星历是由若干卫星跟踪站的观测数据,经事后处理算得的供卫星精密定位等使用的卫星轨道信息。

IGS精密星历采用sp3格式,其存储方式为ASCII文本文件,内容包括表头信息以及文件体,文件体中每隔15 min给出1个卫星的位置,有时还给出卫星的速度。它的特点就是提供卫星精确的轨道位置。采样率为15分钟,实际解算中可以进行精密钟差的估计或内插,以提高其可使用的历元数。

IGS多系统精密星历下载地址:ftp://cddis.gsfc.nasa.gov/pub/gps/products/mgex/

文件根据GPS周分为很多文件夹,计算GPS周可以通过以下小程序:

https://download.csdn.net/download/gou_hailong/11739153

  • 命名规则

用的sp3格式的命名规则为:tttwwwwd.sp3
其中:ttt表示精密星历的管理机构名称,包括{wum(武汉大学)、tum(慕尼黑大学)}wwww表示GPS周;d表示星期,0表示星期日,1~6表示星期一至星期六。文件名如:igs20121.sp3,其中igs为计算单位名,2012为GPS周,1为星期一。

  • 文件格式

文件可以分为文件头与文件正文两部分,其中文件头格式如下:

第一行:文件版本 年 月 日 时 分 秒  历元数量 数据类型  协调系统 轨道类型  管理机构

第二行:GPS周 第一个历元周内秒 历元间隔 约化儒略历整数 约化儒略历小数

第三至十二行:卫星数量 卫星序号

第十三至二十二行:卫星序号对应的卫星精度

第二十三至二十四行:未使用

。。。。。。

文件正文格式如下:

‘P’表示‘卫星位置’,‘V’表示‘卫星速度’,‘G’表示‘GPS卫星’,‘R’表示'GLONASS卫星',‘E’表示‘伽利略卫星’,‘C’表示‘北斗卫星’

第一列:位置速度选项 系统类型 卫星序号

第二列:x坐标

第三列:y坐标

第四列:z坐标

第五列:钟差

文件读取程序如下:

%读取精密星历文件夹中的数据
global SP3_data
folders = dir('C:\Users\zhupf\Desktop\IGS数据\SP3\DATA\mix\解压后');
folders = {folders.name};
folders = setdiff(folders,{'.','..'})';
num = length(folders);
t=1;
for j = 1:numtline = folders{j};fid=fopen(['C:\Users\zhupf\Desktop\IGS数据\SP3\DATA\mix\解压后\' tline ],'rt');
Head_data=struct;
SP3_data =struct;
if(fid==-1)msgbox('输入的文件或者路径不正确,无法正确打开sp3文件','警告信息');return;
end
% 读取文件头,并将其存入Head_data结构数组中
Head=[];
for i=1:31 %制度文件头的前16行line=fgetl(fid);Head=[Head;line];%将sp3文件的文件头以字符的形式显示出来,切记此处要保证sp3文件中的头文件的每行字符数是相同的,否则读取将失败
end
line=fgetl(fid);
%提取文件头第一行的数据
Head_data.Version=Head(1,1:2);
Head_data.P_or_V=Head(1,3);
Head_data.start_year=str2num(Head(1,4:7));
Head_data.start_month=str2num(Head(1,9:10));
Head_data.start_day=str2num(Head(1,12:13));
Head_data.start_hour=str2num(Head(1,15:16));
Head_data.start_minute=str2num(Head(1,18:19));
Head_data.start_second=str2num(Head(1,21:31));
Head_data.EpochNum=str2num(Head(1,33:39));
Head_data.data_type=Head(1,41:45);
Head_data.Coordinate_system=Head(1,47:51);
Head_data.Orbit_type=Head(1,53:55);
Head_data.Institution=Head(1,57:60);
%第二行
Head_data.GPS_week=str2num(Head(2,4:7));
Head_data.FirstEpoch_weeksecond=str2num(Head(2,9:23));
Head_data.Epoch_interval=str2num(Head(2,25:38));
Head_data.MJD_zhengshu=str2num(Head(2,40:44));
Head_data.MJD_xiaoshu=str2num(Head(2,46:60));
%第三 至 七行-------提取观测卫星的PRN编号
Head_data.SatNum=str2num(Head(3,5:6));
PRN=strcat(Head(3,10:60),Head(4,10:60),Head(5,10:60),Head(6,10:60),Head(7,10:60));
L=length(PRN)/3;
SP3_PRN=[];
for i=1:LSp3_PRN=str2num(PRN((3*i-1):3*i));if Sp3_PRN==0continue;endSP3_PRN=[SP3_PRN Sp3_PRN];
end
Head_data.SP3_PRN=SP3_PRN;
%第十三 至 十七行-----提取相应卫星的精度
SatAccu=strcat(Head(13,10:60),Head(14,10:60),Head(15,10:60),Head(16,10:60),Head(17,10:60));
L=length(SP3_PRN);
SP3_SatAccu=[];
for i=1:LSp3_SatAccu=str2num(SatAccu((3*i-1):3*i));if Sp3_SatAccu==0continue;endSP3_SatAccu=[SP3_SatAccu Sp3_SatAccu];
end
Head_data.SP3_SatAccu=SP3_SatAccu;
%第二十五,二十六行-----读取标准差的浮点基数
Head_data.pos_jishu=str2num(Head(25,4:13));
Head_data.Satclock_jishu=str2num(Head(25,15:26));
%--------------------End of the reading of the Fileheader------------------%--------------------读取卫星坐标及卫星钟钟差--------------------------------
%读取的卫星的三维坐标的单位为km,卫星钟差的单位为uswhile 1 line=fgetl(fid);result=findstr(line,'EOF');if(isempty(result))SP3_data(t).year=str2num(line(4:7));SP3_data(t).month=str2num(line(9:10));SP3_data(t).day=str2num(line(12:13));SP3_data(t).hour=str2num(line(15:16));SP3_data(t).minute=str2num(line(18:19));SP3_data(t).second=str2num(line(21:22));SP3_data(t).mm=SP3_data(t).hour*60+SP3_data(t).minute+ SP3_data(t).second/60;%将该历元的时分秒化为分钟,方便后面和观测历元比较for j=1:Head_data.SatNumline=fgetl(fid);SP3_data(t).PRN(j)=str2num(line(3:4));%将每个历元的卫星编号保存在一个数组中SP3_data(t).x(j)=str2num(line(5:18)); %提取卫星的三维坐标,单位为kmSP3_data(t).y(j)=str2num(line(19:32));SP3_data(t).z(j)=str2num(line(33:46));SP3_data(t).Clock_corr(j)=str2num(line(47:60));%提取卫星钟差,单位为us%判断是否有坏的或空缺的位置值if(SP3_data(t).x(j)==0||SP3_data(t).y(j)==0||SP3_data(t).z(j)==0)fprintf('注意:星历文件中的第%g个历元的%g号卫星的位置值是坏的或空缺的!\n',t,SP3_data(t).PRN(j))end%判断是否为坏的或空缺的钟差值if(SP3_data(t).Clock_corr(j)==999999.999999)fprintf('注意:星历文件中的第%g个历元的%g号卫星的钟差值是坏的或空缺的!\n',t,SP3_data(t).PRN(j))end%判断X的标准差是否为未知,若是将其置为0if(length(line)>=73 && isempty(str2num(line(62:63))))SP3_data(t).X_mi(j)=0;elseif(length(line)>=73 && ~isempty(str2num(line(62:63))))SP3_data(t).X_mi(j)=str2num(line(62:63));end%判断Y的标准差是否为未知,若是将其置为0if(length(line)>=73 && isempty(str2num(line(65:66))))SP3_data(t).Y_mi(j)=0;elseif(length(line)>=73 && ~isempty(str2num(line(65:66))))SP3_data(t).Y_mi(j)=str2num(line(65:66));end%判断Z的标准差是否为未知,若是将其置为0if(length(line)>=73 && isempty(str2num(line(68:69))));SP3_data(t).Z_mi(j)=0;elseif(length(line)>=73 && ~isempty(str2num(line(68:69))))SP3_data(t).Z_mi(j)=str2num(line(68:69));end%判断卫星钟差的标准差是否为未知,若是将其置为0if(length(line)>=73 && isempty(str2num(line(71:73))))SP3_data(t).Clock_mi(j)=0;elseif(length(line)>=73 && ~isempty(str2num(line(71:73))))SP3_data(t).Clock_mi(j)=str2num(line(71:73));end%查看某个卫星坐标和星站距离变化if PRN(3*j-2:3*j) == 'G01' %选择需要查看的卫星序号x(t) = SP3_data(t).x(j);y(t) = SP3_data(t).y(j);z(t) = SP3_data(t).z(j);if t== 96*7QD = [-2665073.9893,4556123.9737,3776821.7794];  %测站坐标d = sqrt((x*1000-QD(1)).^2+(y*1000-QD(2)).^2+(z*1000-QD(3)).^2);figure(1);plot(x,'r','LineWidth',2.5);ylabel('x坐标');xlabel('时间');title('GPS 1号卫星x坐标');set(gca,'Xtick',[0 96 192 288 384 480 576]);set(gca,'Xticklabel',{'星期日','星期一','星期二','星期三','星期四','星期五','星期六'});figure(2);plot(y,'r','LineWidth',2.5);ylabel('y坐标');xlabel('时间');title('GPS 1号卫星y坐标');set(gca,'Xtick',[0 96 192 288 384 480 576]);set(gca,'Xticklabel',{'星期日','星期一','星期二','星期三','星期四','星期五','星期六'});figure(3);plot(z,'r','LineWidth',2.5);ylabel('z坐标');xlabel('时间');title('GPS 1号卫星z坐标');set(gca,'Xtick',[0 96 192 288 384 480 576]);set(gca,'Xticklabel',{'星期日','星期一','星期二','星期三','星期四','星期五','星期六'});figure(4);plot(d,'r','LineWidth',2.5);ylabel('星站距离');xlabel('时间');title('GPS 1号卫星与测站距离');
%                     legend('星站距离');set(gca,'Xtick',[0 96 192 288 384 480 576]);set(gca,'Xticklabel',{'星期日','星期一','星期二','星期三','星期四','星期五','星期六'});endendendelseif(~isempty(result))break;%判断读到文件的末尾,到达文件尾则退出endt=t+1;%记录文件体的行数
end
fclose(fid);
end

程序运行结果:

多系统精密星历下载与分析相关推荐

  1. Windows 2003 系统应用故障的分析

    Windows 2003 系统应用故障的分析                                                            2009-02-06 背景 2月5日 ...

  2. GIS+=地理信息+行业+大数据——纽约公开11亿条出租车和Uber原始数据下载及分析

    一览众山小编辑团队 原文/ Todd Schneider 翻译/ 沈玮薇 陈翚 文献/ 蒋理 校核/ 众山小编辑/ 众山小 排版/ 徐颖 2014-2015 © 转载请注明:源自公众号"一览 ...

  3. GIS+=地理信息+行业+大数据——纽约公开11亿条出租车和Uber原始数据下载及分析...

    一览众山小编辑团队 原文/ Todd Schneider 翻译/ 沈玮薇 陈翚 文献/ 蒋理 校核/ 众山小编辑/ 众山小 排版/ 徐颖 2014-2015 © 转载请注明:源自公众号"一览 ...

  4. 获取蓝奏网盘无密码下载链接分析思路

    获取蓝奏网盘无密码下载链接分析思路 先准备准备一个 lanzou链接 链接(自己准备一个该链接只作为演示):https://wwd.lanzouw.com/i269V065bmza 打开浏览器抓包(开 ...

  5. Windows系统安全登录日志分析工具logonTracer汉化修正版

    logonTracer基础使用指南 Windows系统安全登录日志分析工具logonTracer汉化修正版 安装neo4j cd neo4j ./bin/neo4j start 下载logonTrac ...

  6. android系统浏览器下载流程

    android系统浏览器下载流程 标签: android browser download 简介 当我们用浏览器点开一个下载链接,然后去下载,从宏观上认识,有下载进度的实时更新和界面的跳转.整个过程中 ...

  7. matlab语音频谱,信号与系统:用matlab分析wav音频的频谱

    信号与系统:用matlab分析wav音频的频谱 [天水浪客一门课程的平时作业,matlab确实强大,用它做这个有点杀鸡用牛刀的意味 ... 软件太大了,直接靠安装了此软件的同学搞定,程序也是参考网上的 ...

  8. 【下载器篇】IDM下载记录分析(简)

    [下载器篇]IDM下载记录分析(简) IDM下载记录分析-未完待续-[蘇小沐] 文章目录 [下载器篇]IDM下载记录分析(简) 1.实验环境 (一)IDM下载记录分析-未完待续 临时文件夹 下载痕迹 ...

  9. Android系统的JNI原理分析(二)- 数据类型转换和方法签名

    声明 前阶段在项目中使用了Android的JNI技术,在此文中做些技术知识总结. 本文参考了一些书籍的若干章节,比如<Android进阶解密-第9章-JNI原理>.<深入理解Andr ...

  10. 一款好用的Linux系统服务器性能监控分析工具介绍

    软件性能测试过程中经常要对服务器性能指标(比如CPU.内存.磁盘IO及网络IO等等)进行监控以分析出软件在此服务器上的性能瓶颈以便进行后续的服务器调优及软件性能优化.下面为大家介绍一款小编认为比较好用 ...

最新文章

  1. Python之Scrapy爬虫的常用命令
  2. 树莓派安装 MySQL 时出现错误的解决方法
  3. DataFactory连接MySQL数据库
  4. Gerrit代码审核服务器搭建全过程
  5. 递归下降分析器的设计java_数据结构(Java版)教与学(48和60学时教学大纲)
  6. countdownlatch用法
  7. python 机器学习——从感知机算法到各种最优化方法的应用(python)
  8. 阶段5 3.微服务项目【学成在线】_day02 CMS前端开发_03-vuejs研究-vuejs基础-入门程序...
  9. javafx 通过 css 去掉 tableView 滑动条
  10. WEB安全基础 - - -漏洞扫描器
  11. CMSIS到底是个什么东西
  12. opencms的安装
  13. CM311-1a YST(2G+16G)刷Armbian后的网络设置
  14. 用户行为分析zhi应用分析模型
  15. PS新手教程!手把手教你临摹一枚经典的SIRI拟物图标
  16. Redis的常用应用场景
  17. 关于CSP-S2021
  18. Linux经典练习题
  19. 双硬盘+双系统引导出问题的另类解决方法
  20. 二、Oracle数据库的创建—通用

热门文章

  1. WooCommerce税收入门指南,第2部分
  2. 多用户远程(RDP Wrapper)安装及使用步骤
  3. 2021百度之星报名开启 特设“小星星”奖项鼓励少年AI人才
  4. 常见Sql面试题及答案
  5. 网络安全面试题及答案
  6. transE(Translating Embedding)详解+简单python实现
  7. 硬盘总是在计算机中消失了,我计算机的D盘,E盘和F盘都消失了,只有C盘了. 这是怎么回事? -d驱动器c驱动器...
  8. JAVA之stream汪文君_Java8新特性之Stream API
  9. java8新特性 lambda Stream map(函数式编程)
  10. abc类地址是如何划分的? (转)