forked from ndhuan/GPSRTK
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrtksvr.c
96 lines (85 loc) · 1.95 KB
/
rtksvr.c
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
95
96
#include <cstdlib>
#include "main.h"
#include "rtk.h"
static eph_t eph[2*MAX_SAT];
static eph_t REph[MAX_SAT];
static eph_t BEph[MAX_SAT];
static alm_t Ralm[MAX_SAT];
static alm_t Balm[MAX_SAT];
//static obsd_t RObsData[MAX_OBS] ;
//static obsd_t BObsData[MAX_OBS];
/* -- void rtksvrstart(rtksvr_t* svr) --------------------------------------
*
* Description :
* Parameters :
* Return :
*/
void rtksvrstart(rtksvr_t* svr)
{
int i;
// sol_t sol0 = {{0}};//time
eph_t eph0 = {0,-1,-1};//sat numer, iode, iodc
gtime_t time0={0};
rtkinit(&svr->rtk,&default_opt);//base position is set here
svr->nb[0]=svr->nb[1]=0;
svr->buffPtr[0]=svr->buffPtr[1]=0;
// svr->solbuf = sol0;
init_raw(svr->raw,REph,Ralm);
init_raw(svr->raw+1,BEph,Balm);
svr->ftime = time0;
svr->obs[0].n=0;
svr->obs[1].n=0;
for (i=0;i<2*MAX_SAT;i++)
{
eph[i]=eph0;
eph[i].ttr = time0;
eph[i].sat=0;
}
svr->nav.eph = eph;
svr->nav.n = 2*MAX_SAT;
svr->format[0] = STRFMT_UBX;//rover
svr->format[1] = STRFMT_UBX;//base
}
/* -- void updatesvr(rtksvr_t* svr,Error Err, int index) --------------------------------------
*
* Description :
* Parameters : index
* 0 rover
* 1 base
* Return :
*/
void updatesvr(rtksvr_t* svr,Error Err, int index)
{
int i,sat;
obs_t *obs,*svrobs;
eph_t *eph1,*eph2,*eph3;
switch(Err)
{
case (OBS)://tai sao nhet vao svr->obs chi, nhet thang vo obsd trong main luon???????????????????????????
{
obs =&svr->raw[index].obs;
svrobs = svr->obs+index;
svrobs->n=0;
for (i=0;i<obs->n;i++)
{
svrobs->data[svrobs->n]=obs->data[i];
svrobs->data[(svrobs->n)++].rcv=index+1;
}
break;
}
case (EPHEMERIS):
{
sat = svr->raw[index].ephsat;
eph1 = svr->raw[index].nav.eph+sat-1;
eph2 = svr->nav.eph+sat-1;
eph3 = eph2 + MAX_SAT;
if ((eph2->ttr.time == 0) ||
((eph1->iode!=eph2->iode)&&(eph1->iode!=eph3->iode)))
{
*eph3 = *eph2;
*eph2 = *eph1;
}
break;
}
}
}