计算GDOP

Posted 莫水千流

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了计算GDOP相关的知识,希望对你有一定的参考价值。

#include <iostream>
#include <fstream>
#include "..\include\CPosition.h"
#include "..\include\Constant.h"
#include "..\include\Data.h"
#include<stdio.h>
#define MATHRES 1E-12
#define FOUR 4
typedf struct{
 
       int prn;
       XYZCoor pos;
}SVPosStruct;
int Maxsat;
int ReadSatPosFile(FILE*SVPosFile,SVPosStruct*SV);
int fun(int n);
void ComputeDOP2(XYZCoor Obs,XYZCoor SV[4],DOPStruct*DOP);
void main()
{
 
  double a=6378137.0;
  double e2=0.00669342162297;
  double PAI=3.1415926535898;
  double P0=PAI/180.0;
  double N;
  XYZCoor ObsPos;
  int LatDeg,LonDeg,LatMin,LonMin;
  float LatSec,LonSec,H,B,L;
  FILE*SVPosFile,*SVDOPFile;
  int i,j,k,ri,num;
  int array[4];
  int temp;
  XYZCoor SV[4];
  int SVNo[4];
  SVPosStruct*SVPos;
  DOPStruct DOP;
  prinf("Please Input local Lat(dd mm.mmmm):");
  scanf("%i %f",&LatDeg,&LatMin);
  B=((float)LatDeg+LatMin/60.0)*P0;
  prinf("Please Input local Lon(ddd mm.mmmm):");
  scanf("%i %f",&LonDeg,&LonMin);
  L=((float)LonDeg+LonMin/60.0)*P0;
  prinf("Please Input local Height(meter):");
  scanf("%f",&H);
  B=(LatDeg+LatMin/60.0+LatSec/3600.0)*P0;
  L=(LonDeg+LonMin/60.0+LonSec/3600.0)*P0;
  N=a/sqr(1.0-e2*sin(B)*sin(B));
  ObsPos.X=(N+H)*cos(B)*cos(L);
  ObsPos.Y=(N+H)*cos(B)*sin(L);
  ObsPos.Z=(N*(1.0-e2)+H)*sin(B);
  if((SVPosFile=fopen("satpos.out","r"))==NULL)
    {
prinf("cannot open input file\n");
     exit(1);
      
}
  if((SVDOPFile=fopen("satdop.out","w"))==NULL)
    {
prinf("cannot open output file\n");
     exit(1);
      
}
  if((SVPos=(SVPosStruct*)malloc(sizeof(SVPosStruct)*12))==NULL)
    {
prinf("not enough memory to allocate buffer\n");
     exit(1);
      
}
  MaxSat=0;
  i=0;
  do
     {
 
      if(ReadSatPosFile(SVPosFile,(SVPos+i)))break;
      i++;
      if(i>=12)break;
      
}while(1);
  if(MaxSat<4)
    {
prinf("not enough satellite to compute DOP\n");
     exit(1);
     
}
  num=fun(MaxSat)/(fun(MaxSat-4)*fun(4));
  fprinf(SVDOPFile,"SV Combinnation GDOP\n");
  ri=1;
  array[1]=MaxSat;
  do
     {
 
      if(ri!=FOUR)
      if((ri+array[ri])>FOUR)
      {
array[ri+1]=array[ri]-1;
       ri++:
       
}
      else
     {
ri--;array[ri]--;
}
      else
     {
for(j=1;j<=FOUR;j++)
       {
SVNo[j-1]=(SVPos+array[j]-1)->prn;
        SV[j-1].X=(SVPos+array[j]-1)->pos.X
        SV[j-1].Y=(SVPos+array[j]-1)->pos.Y
        SV[j-1].Z=(SVPos+array[j]-1)->pos.Z;
        
}
      ComputeDOP2(ObsPos,SV,&DOP);
      fprinf(SVDOPFile,"%02d %02d-%02d-%02d %6.1f\n",SVNo[0],SVNo[1],SVNo[2],SVNo[3],DOP.GDOP);
      if(array[FOUR]--1)
        {
ri--;array[ri]--;
}
      else
        {
array[ri]--;
}
       
}
       
}while(array[1]!=FOUR-1);
      fclose(SVPosFile);
      fclose(SVDOPFile);
      free(SVPos); 
  int fun(int n)
    {
 int i;
      int res;
      if(n<0)return0;
      res=1;
      for(i=1;i<=n;i++)res*=i;
      return res;
     
}
  int ReadSatPosFile(FILE*SVPosFile,SVPosStruct*SV)
    {
 char t1[30],t2[30],t3[30];
      if(fscanf(SVPosFile,"%d%s%s%s\n",&SV->prn,t1,t2,t3))
      return 1;
      SV->pos.X=atof(t1);
      SV->pos.Y=atof(t2);
      SV->pos.Z=atof(t3);
      MaxSat++;
      if(MaxSat>=12)return 1;
      return 0;
     
}
  void ComputeDOP2(XYZCoor Obs.XYZCoor SV[4],DOPStract*DOP)
    {
 double PAI=3.1415926535898;
      double P0=PAI/180.0;
      int Row=4,Col=4;
      int n=Row;
      double Qp[4][4];
      double Qpt[4][4];
      double QptXQp[4][4]; 
      double Q[4][4];
      int i,j,k,ii,jj;
      double Temp;
      double b,max,A[4][4];
      int *z;
      for(i=0;i<Row;i++)
        {
Temp=sqrt((Obs.X-SV[i].X)*(Obs.X-SV[i].X)+(Obs.Y-SV[i].Y)*(Obs.X-SV[i].Y)+(Obs.Z-SV[i].Z)*(Obs.X-SV[i].Z));
         Qp[i][0]=(SV[i].X-Obs.X)/Temp;
         Qp[i][1]=(SV[i].Y-Obs.Y)/Temp;
         Qp[i][2]=(SV[i].Z-Obs.Z)/Temp;
         Qp[i][3]=1.0;
         
}
      for(i=0;i<Row;i++)
      for(j=0;j<Col;j++)
         Qpt[i][j]=Qpt[j][i];
      for(i=0;i<Row;i++)
        {
for(j=0;j<Col;j++)
           {
Temp=0.0;
            for(k=0;k<4;k++)Temp=Qpt[i][k]*Qp[k][j];
            QptXQp[i][j]=Temp;
            
}
          
}
      z=(int*)malloc(sizeof(int)*2*n);
      for(i=0;i<Row;i++)
        {
for(j=0;j<Col;j++)
         A[i][j]=QptXQp[j][i];
         
}
      for(k=0;k<n;k++)
        {
max=0;
         for(i=k;i<n;i++)
      for(j=k;j<n;j++)
        {
b=fabs(A[i][j]);
         if(max<b)
          {
ii=i;jj=j;max=b;
           
}
         
}
         if(max<MATHRES)
          {
free(z);
           prinf(The matrix isnt rank enough...");
           
}
         max=1.0/((A[ii][jj]));
         A[ii][jj]=1;
         z[2*k]=ii;
         A[2*k+1]=jj
         if(ii!=k)
          {
for(j=0;j<n;j++)
            {
b=A[ii][j];A[ii][j]=A[k][j];A[k][j]=b;
             
}
           
}
         if(jj!=k)
          {
for(j=0;j<n;j++)
            {
b=A[j][jj];A[jj][j]=A[j][k];A[j][k]=b;
 
             
}
           
}
         for(j=0;j<n;j++)
           A[k][j]*=max;
         for(i=0;i<n;i++) 
          {
if(i!=k)
            {
max=A[i][k]; A[i][k]=0.0;
             for(j=0;j<n;j++) A[i][j]=A[i][j]-max*A[k][j];
             
}
           
}
         for(k=n-2;k>=0;k--)
          {
ii=z[2*k+1];jj=[2*k];
            if(ii!=k)
             {
for(j=0;j<n;j++)
               {
b=A[ii][j];A[ii][j]=A[k][j];A[k][j]=b;
                
}
              
}
            if(jj!=k)
             {
for(j=0;j<n;j++)
               {
b=A[j][ii];A[j][ii]=A[j][k];A[j][k]=b;
                
}
              
}
           
}
         for(i=0;i<Row;i++)
          {
for(j=0;j<Col;j++)
           Q[i][j]=A[i][j];
           
}
         free(z);
         Temp=0.0;for(i=0;i<n;i++)Temp+=Q[i][i];DOP->GDOP=sqrt(Temp);
      
}

 

以上是关于计算GDOP的主要内容,如果未能解决你的问题,请参考以下文章

各种不同几何形状布局布阵下的GDOP相对值图

基于DOA联合TDOA时间积累的二维GDOP仿真分析

使用从循环内的代码片段中提取的函数避免代码冗余/计算开销

从JVM的角度看JAVA代码--代码优化

Vue3官网-高级指南(十七)响应式计算`computed`和侦听`watchEffect`(onTrackonTriggeronInvalidate副作用的刷新时机`watch` pre)(代码片段

golang代码片段(摘抄)