-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathRinex.h
94 lines (85 loc) · 2.62 KB
/
Rinex.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#ifndef RINEX_H_
#define RINEX_H_
#include <stdio.h>
#include <fstream>
//#include <iostream>
#include <string>
#include <vector>
#include <sstream>
#include <algorithm>
#include <iomanip>
#include <math.h>
#include <map>
#include "Time_utility.h"
extern double tint;
extern double DTTOL;
typedef std::pair<int, vector<double>> SDpair;
typedef std::map <int, vector<double> > SDmp;//存放某卫星ID 和 对应的多普勒
class NAV_RINEX {
public:
NAV_RINEX(string file) { filename = file; }
~NAV_RINEX() {};
void NAV_RINEX_CLEAR();
void display();
void readfile();
void solve_epoch(string buff, ifstream &navfile, vector<int> & GNSS_ID, vector<double> & GNSS_NAV_DATA, vector<int> & GNSS_TOC);
string filename;
int LEAP_SECONDS;
vector<string > CORR_TYPE;
vector<double > ION_CORR;
vector<double > TIME_CORR;
vector<int > GPS_ID;
vector<int > BDS_ID;
vector<int > GPS_TOC;
vector<int > BDS_TOC;
vector<double> GPS_NAV_DATA;
vector<double> BDS_NAV_DATA;
};
class OBS_RINEX {
public:
OBS_RINEX(string fileB, string fileR) { filenameBase = fileB; filenameRover = fileR; GPS_L2duplicate_flag = 0; base_interval = 0; rover_interval = 0; }
gtime_t readheader();
gtime_t obtainheadparas(string file,char mode);
void findfirstepoch(ifstream &fileB, ifstream &fileR,string &buffB,string &buffR,gtime_t headtime);
void getepochdata(int,ifstream &fileB,char mode);
void getepochdatabody(int Frequency_num,int duplicate_flag,string buff, vector<int>&, vector<int>&, vector<double>&);
void readepoch(ifstream &fileB, ifstream &fileR,string buffB,string buffR, int &Bupdateflag, int &Rupdateflag, int &Btintflag, int &Rtintflag);
/*与获得观测量有关的函数*/
void getdoppler();
void printfdoppler();
string filenameBase,filenameRover;
int GPS_Fnum_B;
int BDS_Fnum_B;
int GPS_Fnum_R;
int BDS_Fnum_R;
int GPS_L2duplicate_flag;
vector<double> GPS_fre_B;
vector<double> BDS_fre_B;
vector<double> GPS_fre_R;
vector<double> BDS_fre_R;
int epochflag_B;
int epochflag_R;
int cur_sat_num_B;
int cur_sat_num_R;
vector<int > GPS_satID_B;
vector<int > BDS_satID_B;
vector<int > GPS_flags_B;
vector<int > BDS_flags_B;
vector<double > GPS_measurements_B;
vector<double > BDS_measurements_B;
gtime_t GPStime_B;
vector<int > GPS_satID_R;
vector<int > BDS_satID_R;
vector<int > GPS_flags_R;
vector<int > BDS_flags_R;
vector<double > GPS_measurements_R;
vector<double > BDS_measurements_R;
gtime_t GPStime_R;
/*与提取观测量有关的结构*/
SDmp sat_doppler;
/*与文件时间间隔有关系的量*/
double base_interval;
double rover_interval;
};
#endif // !RINEX_H_
#pragma once