mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2024-12-14 12:10:34 +00:00
Merge branch 'next' of https://github.com/carlesfernandez/gnss-sdr into next
This commit is contained in:
commit
7685531033
@ -625,161 +625,6 @@ int readdcb(const char *file, nav_t *nav, const sta_t *sta)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* add satellite fcb ---------------------------------------------------------*/
|
|
||||||
int addfcb(nav_t *nav, gtime_t ts, gtime_t te, int sat,
|
|
||||||
const double *bias, const double *std)
|
|
||||||
{
|
|
||||||
fcbd_t *nav_fcb;
|
|
||||||
int i;
|
|
||||||
int j;
|
|
||||||
|
|
||||||
if (nav->nf > 0 && fabs(timediff(ts, nav->fcb[nav->nf - 1].ts)) <= 1e-3)
|
|
||||||
{
|
|
||||||
for (i = 0; i < 3; i++)
|
|
||||||
{
|
|
||||||
nav->fcb[nav->nf - 1].bias[sat - 1][i] = bias[i];
|
|
||||||
nav->fcb[nav->nf - 1].std[sat - 1][i] = std[i];
|
|
||||||
}
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
if (nav->nf >= nav->nfmax)
|
|
||||||
{
|
|
||||||
nav->nfmax = nav->nfmax <= 0 ? 2048 : nav->nfmax * 2;
|
|
||||||
if (!(nav_fcb = static_cast<fcbd_t *>(realloc(nav->fcb, sizeof(fcbd_t) * nav->nfmax))))
|
|
||||||
{
|
|
||||||
free(nav->fcb);
|
|
||||||
nav->nf = nav->nfmax = 0;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
nav->fcb = nav_fcb;
|
|
||||||
}
|
|
||||||
for (i = 0; i < MAXSAT; i++)
|
|
||||||
{
|
|
||||||
for (j = 0; j < 3; j++)
|
|
||||||
{
|
|
||||||
nav->fcb[nav->nf].bias[i][j] = nav->fcb[nav->nf].std[i][j] = 0.0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (i = 0; i < 3; i++)
|
|
||||||
{
|
|
||||||
nav->fcb[nav->nf].bias[sat - 1][i] = bias[i];
|
|
||||||
nav->fcb[nav->nf].std[sat - 1][i] = std[i];
|
|
||||||
}
|
|
||||||
nav->fcb[nav->nf].ts = ts;
|
|
||||||
nav->fcb[nav->nf++].te = te;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* read satellite fcb file ---------------------------------------------------*/
|
|
||||||
int readfcbf(const char *file, nav_t *nav)
|
|
||||||
{
|
|
||||||
FILE *fp;
|
|
||||||
gtime_t ts;
|
|
||||||
gtime_t te;
|
|
||||||
double ep1[6];
|
|
||||||
double ep2[6];
|
|
||||||
double bias[3] = {};
|
|
||||||
double std[3] = {};
|
|
||||||
char buff[1024];
|
|
||||||
char str[32];
|
|
||||||
char *p;
|
|
||||||
int sat;
|
|
||||||
|
|
||||||
trace(3, "readfcbf: file=%s\n", file);
|
|
||||||
|
|
||||||
if (!(fp = fopen(file, "re")))
|
|
||||||
{
|
|
||||||
trace(2, "fcb parameters file open error: %s\n", file);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
while (fgets(buff, sizeof(buff), fp))
|
|
||||||
{
|
|
||||||
if ((p = strchr(buff, '#')))
|
|
||||||
{
|
|
||||||
*p = '\0';
|
|
||||||
}
|
|
||||||
if (sscanf(buff,
|
|
||||||
"%lf/%lf/%lf %lf:%lf:%lf %lf/%lf/%lf %lf:%lf:%lf %s"
|
|
||||||
"%lf %lf %lf %lf %lf %lf",
|
|
||||||
ep1, ep1 + 1, ep1 + 2, ep1 + 3, ep1 + 4, ep1 + 5,
|
|
||||||
ep2, ep2 + 1, ep2 + 2, ep2 + 3, ep2 + 4, ep2 + 5, str, bias, std, bias + 1, std + 1,
|
|
||||||
bias + 2, std + 2) < 17)
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (!(sat = satid2no(str)))
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
ts = epoch2time(ep1);
|
|
||||||
te = epoch2time(ep2);
|
|
||||||
if (!addfcb(nav, ts, te, sat, bias, std))
|
|
||||||
{
|
|
||||||
fclose(fp);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fclose(fp);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* compare satellite fcb -----------------------------------------------------*/
|
|
||||||
int cmpfcb(const void *p1, const void *p2)
|
|
||||||
{
|
|
||||||
auto *q1 = (fcbd_t *)p1;
|
|
||||||
auto *q2 = (fcbd_t *)p2;
|
|
||||||
double tt = timediff(q1->ts, q2->ts);
|
|
||||||
return tt < -1e-3 ? -1 : (tt > 1e-3 ? 1 : 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* read satellite fcb data -----------------------------------------------------
|
|
||||||
* read satellite fractional cycle bias (dcb) parameters
|
|
||||||
* args : char *file I fcb parameters file (wild-card * expanded)
|
|
||||||
* nav_t *nav IO navigation data
|
|
||||||
* return : status (1:ok,0:error)
|
|
||||||
* notes : fcb data appended to navigation data
|
|
||||||
*-----------------------------------------------------------------------------*/
|
|
||||||
int readfcb(const char *file, nav_t *nav)
|
|
||||||
{
|
|
||||||
char *efiles[MAXEXFILE] = {};
|
|
||||||
int i;
|
|
||||||
int n;
|
|
||||||
|
|
||||||
trace(3, "readfcb : file=%s\n", file);
|
|
||||||
|
|
||||||
for (i = 0; i < MAXEXFILE; i++)
|
|
||||||
{
|
|
||||||
if (!(efiles[i] = static_cast<char *>(malloc(1024))))
|
|
||||||
{
|
|
||||||
for (i--; i >= 0; i--)
|
|
||||||
{
|
|
||||||
free(efiles[i]);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
n = expath(file, efiles, MAXEXFILE);
|
|
||||||
|
|
||||||
for (i = 0; i < n; i++)
|
|
||||||
{
|
|
||||||
readfcbf(efiles[i], nav);
|
|
||||||
}
|
|
||||||
for (i = 0; i < MAXEXFILE; i++)
|
|
||||||
{
|
|
||||||
free(efiles[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (nav->nf > 1)
|
|
||||||
{
|
|
||||||
qsort(nav->fcb, nav->nf, sizeof(fcbd_t), cmpfcb);
|
|
||||||
}
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* polynomial interpolation by Neville's algorithm ---------------------------*/
|
/* polynomial interpolation by Neville's algorithm ---------------------------*/
|
||||||
double interppol(const double *x, double *y, int n)
|
double interppol(const double *x, double *y, int n)
|
||||||
{
|
{
|
||||||
|
@ -72,27 +72,29 @@ const double EXTERR_CLK = 1e-3; /* extrapolation error for clock (m/s) */
|
|||||||
const double EXTERR_EPH = 5e-7; /* extrapolation error for ephem (m/s^2) */
|
const double EXTERR_EPH = 5e-7; /* extrapolation error for ephem (m/s^2) */
|
||||||
|
|
||||||
int code2sys(char code);
|
int code2sys(char code);
|
||||||
|
|
||||||
int readsp3h(FILE *fp, gtime_t *time, char *type, int *sats,
|
int readsp3h(FILE *fp, gtime_t *time, char *type, int *sats,
|
||||||
double *bfact, char *tsys);
|
double *bfact, char *tsys);
|
||||||
|
|
||||||
int addpeph(nav_t *nav, peph_t *peph);
|
int addpeph(nav_t *nav, peph_t *peph);
|
||||||
|
|
||||||
void readsp3b(FILE *fp, char type, int *sats, int ns, const double *bfact,
|
void readsp3b(FILE *fp, char type, int *sats, int ns, const double *bfact,
|
||||||
char *tsys, int index, int opt, nav_t *nav);
|
char *tsys, int index, int opt, nav_t *nav);
|
||||||
|
|
||||||
int cmppeph(const void *p1, const void *p2);
|
int cmppeph(const void *p1, const void *p2);
|
||||||
|
|
||||||
void combpeph(nav_t *nav, int opt);
|
void combpeph(nav_t *nav, int opt);
|
||||||
|
|
||||||
void readsp3(const char *file, nav_t *nav, int opt);
|
void readsp3(const char *file, nav_t *nav, int opt);
|
||||||
|
|
||||||
int readsap(const char *file, gtime_t time, nav_t *nav);
|
int readsap(const char *file, gtime_t time, nav_t *nav);
|
||||||
|
|
||||||
int readdcbf(const char *file, nav_t *nav, const sta_t *sta);
|
int readdcbf(const char *file, nav_t *nav, const sta_t *sta);
|
||||||
|
|
||||||
int readdcb(const char *file, nav_t *nav, const sta_t *sta);
|
int readdcb(const char *file, nav_t *nav, const sta_t *sta);
|
||||||
int addfcb(nav_t *nav, gtime_t ts, gtime_t te, int sat,
|
|
||||||
const double *bias, const double *std);
|
|
||||||
int readfcbf(const char *file, nav_t *nav);
|
|
||||||
int readdcb(const char *file, nav_t *nav, const sta_t *sta);
|
|
||||||
int addfcb(nav_t *nav, gtime_t ts, gtime_t te, int sat,
|
|
||||||
const double *bias, const double *std);
|
|
||||||
int readfcbf(const char *file, nav_t *nav);
|
|
||||||
int cmpfcb(const void *p1, const void *p2);
|
|
||||||
int readfcb(const char *file, nav_t *nav);
|
|
||||||
double interppol(const double *x, double *y, int n);
|
double interppol(const double *x, double *y, int n);
|
||||||
|
|
||||||
int pephpos(gtime_t time, int sat, const nav_t *nav, double *rs,
|
int pephpos(gtime_t time, int sat, const nav_t *nav, double *rs,
|
||||||
double *dts, double *vare, double *varc);
|
double *dts, double *vare, double *varc);
|
||||||
|
|
||||||
@ -101,6 +103,7 @@ int pephclk(gtime_t time, int sat, const nav_t *nav, double *dts,
|
|||||||
|
|
||||||
void satantoff(gtime_t time, const double *rs, int sat, const nav_t *nav,
|
void satantoff(gtime_t time, const double *rs, int sat, const nav_t *nav,
|
||||||
double *dant);
|
double *dant);
|
||||||
|
|
||||||
int peph2pos(gtime_t time, int sat, const nav_t *nav, int opt,
|
int peph2pos(gtime_t time, int sat, const nav_t *nav, int opt,
|
||||||
double *rs, double *dts, double *var);
|
double *rs, double *dts, double *var);
|
||||||
|
|
||||||
|
@ -471,15 +471,6 @@ int decoderaw(rtksvr_t *svr, int index)
|
|||||||
/* decode download file ------------------------------------------------------*/
|
/* decode download file ------------------------------------------------------*/
|
||||||
void decodefile(rtksvr_t *svr, int index)
|
void decodefile(rtksvr_t *svr, int index)
|
||||||
{
|
{
|
||||||
int i = 0;
|
|
||||||
char glo_fcn[MAXPRNGLO + 1];
|
|
||||||
|
|
||||||
// Allocate space for GLONASS frequency channels depending on availability
|
|
||||||
for (i = 0; i < MAXPRNGLO + 1; i++)
|
|
||||||
{
|
|
||||||
glo_fcn[i] = '0';
|
|
||||||
}
|
|
||||||
|
|
||||||
nav_t nav{};
|
nav_t nav{};
|
||||||
char file[1024];
|
char file[1024];
|
||||||
int nb;
|
int nb;
|
||||||
|
Loading…
Reference in New Issue
Block a user