⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 adjpro050404.cpp

📁 GPS网平差计算
💻 CPP
📖 第 1 页 / 共 5 页
字号:
	  double mY;                    // y坐标中误差
	  double mp;                    // 点位中误差
	  double E;                     // 误差椭圆长半轴 
	  double F;                     // 误差椭圆短半轴
	  double T;                     // 误差椭圆长半轴方向  
	  int fixed;                    // 是否控制点(控制点为1;未知点为0)
	  int i;                        // 点号(0-->allpnum-1)
};

//*****************************对点的"=="的重载***************************************************
int operator ==(XYP &a,XYP &b)
{
	
    if(strnicmp(b.name,a.name,20))
     return 1;                 
     else return 0;
}
 
//***********************************平面网观测值结构*********************************************
struct obser{
      XYP *startp;                  // 观测值起点指针
      XYP *endp;                    // 观测值终点指针
      double dist;                  // 距离观测值
	  double dist0;                 // 近似距离
	  double angle;                 // 方向观测值
      double A;                     // 观测值方位角
	  double A0;                    // 近似方位角 
	  double m0;                    // 观测值平差值精度 
	  int i;                        // 测站的观测值序号
      int sti;                      // 测站序号
	  int style;                    // 角度测量=1;距离测量=2;固定方位角=3;固定边长=4 
};

//******************************平面网测站结构****************************************************
struct stat{
      XYP *stp;
	  int obnum;                    // 测站观测值总数 
	  int disnum;                   // 测站距离观测值个数
	  int aglnum;                   // 测站方向观测值个数     
	  int i;                        // 测站序号  
};
//********************************平面网结构******************************************************
struct XYnet{
      char netname[40];             //  网名
      int allpnum;                  //  总点数
	  int fixpnum;                  //  控制点个数
	  int statnum;                  //  测站数
	  int obnum;                    //  观测值总数
	  int fixdisn;                  //  固定边长个数
	  int fixafn;                   //  固定方位角个数
	  int anglenum;                 //  方向观测值总数
	  int distnum;                  //  距离观测值总数
      double mangle;                //  验前方向观测值误差
	  double msa;                   //  距离误差加常数
	  double msb;                   //  距离误差乘常数
	  stat st[MAX];                 //  定义平面网测站结构 
	  XYP Pt[MAX];                  //  平面网点结构
	  obser L[MAX];                 //  平面网观测值结构
	  adj aa;                       //  平面网平差结构
};

//************************* 坐标反算距离**********************************************************
double dist(XYP &a,XYP &b)        
{
	if(a.X!=-PI && b.X!=-PI)
   	return sqrt((b.X-a.X)*(b.X-a.X)+(b.Y-a.Y)*(b.Y-a.Y));
  if(a.X0!=-PI && b.X0!=-PI)
	return sqrt((b.X0-a.X0)*(b.X0-a.X0)+(b.Y0-a.Y0)*(b.Y0-a.Y0));
     return -PI;
}


//************************* 坐标反算方位角********************************************************
double afa(XYP &a,XYP &b)                    
{
     if(a.X!=-PI && b.X!=-PI)
  {
	  double d=dist(a,b);
	  double t=acos((b.X-a.X)/d);
      if(b.Y-a.Y<0.0) t=2.0*PI-t;
      return t;
  }
   if(a.X0!=-PI && b.X0!=-PI)
  {
	  double d=dist(a,b);
	  double t=acos((b.X0-a.X0)/d);
      if(b.Y0-a.Y0<0.0) t=2.0*PI-t;
      return t;
  }
  return -PI;
}

//**********************************两方向交会近似坐标计算****************************************
int XY0ang(obser &a1,obser &a2)           // 两方向交会近似坐标计算
{  
	if(a1.A0==-PI || a2.A0 ==-PI || a1.A0==a2.A0 )  return 0; 
	if(d_h(a1.A0)==d_h(a2.A0)+PI || d_h(a1.A0)==d_h(a2.A0)-PI) return 0;
    if(a1.dist!=-PI || a1.dist0!=-PI || a2.dist!=-PI || a2.dist0!=-PI) return 0; 

	double k,B[MAX][MAX],A[MAX][MAX],L[MAX][1],X[MAX][1];
	if(a1.startp==a2.startp && a1.startp->X0==-PI && a1.endp->X0!=-PI && a2.endp->X0!=-PI)
    {
        
			k=tan(d_h(a1.A0));
		    A[0][0]=k;A[0][1]=-1;
		    L[0][0]=k*a1.endp->X0-a1.endp->Y0;
		  k=tan(d_h(a2.A0));
        A[1][0]=k;A[1][1]=-1;
		L[1][0]=k*a2.endp->X0-a2.endp->Y0;
        inverse(A,B,2);
        AXB(B,L,X,2,2);
		a1.startp->X0=X[0][0];
		a1.startp->Y0=X[1][0];
//		cout<<"XY0ang****1   "<<endl;
		return 1;
	}
/*
    if(a1.endp==a2.endp && a1.startp->X0!=-PI && a2.startp->X0!=-PI && a1.endp->X0==-PI)
   {
		k=tan(d_h(a1.A0));
		A[0][0]=-k;A[0][1]=1;
		L[0][0]=-(k*a1.startp->X0-a1.startp->Y0);
        k=tan(d_h(a2.A0));
        A[1][0]=-k;A[1][1]=1;
		L[1][0]=-(k*a2.startp->X0-a2.startp->Y0);
       	inverse(A,B,2);
//		cout<<"XY0ang****3   "<<endl;

        AXB(B,L,X,2,2);
		a1.endp->X0=X[0][0];
		a1.endp->Y0=X[1][0];
			return 1;
	}
  
   	 if(a1.startp==a2.endp && a1.startp->X0==-PI && a1.endp->X0!=-PI && a2.startp->X0!=-PI)
    {
		k=tan(d_h(a1.A0));
		A[0][0]=k;A[0][1]=-1;
		L[0][0]=k*a1.endp->X0-a1.endp->Y0;
        k=tan(d_h(a2.A0));
        A[1][0]=-k;A[1][1]=1;
		L[1][0]=-(k*a2.startp->X0-a2.startp->Y0);
        inverse(A,B,2);
        AXB(B,L,X,2,2);
		a1.startp->X0=X[0][0];
		a1.startp->Y0=X[1][0];
//			cout<<"XY0ang****3   "<<endl;
		return 1;
	}
	
   if(a1.endp==a2.startp && a1.endp->X0==-PI && a1.startp->X0!=-PI && a2.endp->X0!=-PI)
    {
		k=tan(d_h(a1.A0));
		A[0][0]=-k;A[0][1]=1;
		L[0][0]=-(k*a1.startp->X0-a1.startp->Y0);
        k=tan(d_h(a2.A0));
        A[1][0]=k;A[1][1]=-1;
		L[1][0]=k*a2.endp->X0-a2.endp->Y0;
        inverse(A,B,2);
        AXB(B,L,X,2,2);
		a1.endp->X0=X[0][0];
		a1.endp->Y0=X[1][0];
	//			cout<<"XY0ang****4   "<<endl;
		return 1;
	}*/	
    return 0;
}
//**********************************三边交会法计算近似坐标****************************************
int XY0dist(obser &a,obser &b,obser &c) // 三边交会法计算近似坐标
{  
	if(a.dist0==-PI || b.dist0==-PI || c.dist0==-PI )  return 0; 
	if(a.startp!=b.startp || a.startp!=c.startp || b.startp!=c.startp) return 0;
    if(a.endp==b.endp || a.endp==c.endp || b.endp==c.endp) return 0;
	if(a.endp->X0==-PI || b.endp->X0==-PI || c.endp->X0==-PI || a.startp->X0!=-PI) return 0;
    double a1=afa(*(a.endp),*(b.endp))-afa(*(a.endp),*(c.endp));	
	if(fabs(a1)<0.2*PI || fabs(fabs(a1)-PI)<0.2) return 0;
	double B[MAX][MAX],A[MAX][MAX],L[MAX][1],X[MAX][1];

		    A[0][0]=a.endp->X0-b.endp->X0;  A[0][1]=a.endp->Y0-b.endp->Y0;
		    L[0][0]=(-a.dist0*a.dist0+b.dist0*b.dist0+a.endp->X0*a.endp->X0
				-b.endp->X0*b.endp->X0+a.endp->Y0*a.endp->Y0-b.endp->Y0*b.endp->Y0)/2.0;
		
            A[1][0]=a.endp->X0-c.endp->X0;  A[1][1]=a.endp->Y0-c.endp->Y0;
		    L[1][0]=(-a.dist0*a.dist0+c.dist0*c.dist0+a.endp->X0*a.endp->X0
				-c.endp->X0*c.endp->X0+a.endp->Y0*a.endp->Y0-c.endp->Y0*c.endp->Y0)/2.0;
        inverse(A,B,2);
        AXB(B,L,X,2,2);
		a.startp->X0=X[0][0];
		a.startp->Y0=X[1][0];
//  	cout<<"XY0dist****1   "<<endl;
		return 1;
}
//***********************************坐标正算法近似坐标计算***************************************

// 坐标正算
int zheng(obser &a)
{
  if(a.startp->X0==-PI && a.endp->X0==-PI || a.startp->X0!=-PI && a.endp->X0!=-PI 
	  || a.dist0==-PI || a.A0==-PI) 
	  return 0;
 if(a.startp->X0!=-PI && a.endp->X0==-PI) 
 {
	 a.endp->X0=a.startp->X0+cos(d_h(a.A0))*a.dist0;                     // 要求方位角为弧度制
     a.endp->Y0=a.startp->Y0+sin(d_h(a.A0))*a.dist0;
     return 1;
 }

 if(a.startp->X0==-PI && a.endp->X0!=-PI) 
 {
	 a.startp->X0=a.endp->X0-cos(d_h(a.A0))*a.dist0;                     // 要求方位角为弧度制
     a.startp->Y0=a.endp->Y0-sin(d_h(a.A0))*a.dist0;
     return 1;
 }
   return 0;
}
//*********************************角度后方交会法计算近似坐标*************************************

//角度后方交会法计算近似坐标
int houj(obser &a,obser &b,obser &c)
{ 
 if(a.startp!=b.startp || a.startp!=c.startp || b.startp!=c.startp) return 0;
  if(a.endp->X0==-PI || b.endp->X0==-PI || c.endp->X0==-PI) return 0; 
  if(a.angle==-PI || b.angle==-PI || c.angle==-PI) return 0;
  if(a.A0!=-PI || b.A0!=-PI || c.A0!=-PI || a.startp->X0!=-PI) return 0;
// add code here...
 obser L1,L2,L0;
 int i=0;
  if(i<a.i) {i=a.i; L2=a;} if(i<b.i) {i=b.i;L2=b;} if(i<c.i) {i=c.i; L2=c;}
   i=1000000;
  if(i>a.i) {i=a.i; L0=a;} if(i>b.i) {i=b.i; L0=b;} if(i>c.i) {i=c.i; L0=c;}
  if((a.i==L0.i || a.i==L2.i) && (b.i==L0.i || b.i==L2.i))  L1=c;
  if((a.i==L0.i || a.i==L2.i) && (c.i==L0.i || c.i==L2.i))  L1=b;
  if((b.i==L0.i || b.i==L2.i) && (c.i==L0.i || c.i==L2.i))  L1=a;
  double A,B,C,af,bt,B1,B2; 
    B=afa(*(L1.endp),*(L0.endp))-afa(*(L1.endp),*(L2.endp));   //弧度
	A=afa(*(L0.endp),*(L2.endp))-afa(*(L0.endp),*(L1.endp));   //弧度
    C=afa(*(L2.endp),*(L1.endp))-afa(*(L2.endp),*(L0.endp));   //弧度
	B=fabs(B); if(B>PI) B=2*PI-B;
    A=fabs(A); if(A>PI) A=2*PI-A;
	C=fabs(C); if(C>PI) C=2*PI-C;
	
	af=d_h(L1.angle)-d_h(L0.angle);     //弧度

	if(af>PI) af=2*PI-af;
	bt=d_h(L2.angle)-d_h(L1.angle);     //弧度
	if(bt>PI) bt=2*PI-bt;
  
	B1=atan((1/tan(A)-1/tan(bt))/(1-1/tan(A)/tan(af)-1/tan(B)*(1/tan(af)+1/tan(bt))));
    if(B1<0)B1+=PI;
	B2=atan((1/tan(C)-1/tan(af))/(1-1/tan(C)/tan(bt)-1/tan(B)*(1/tan(af)+1/tan(bt))));
	if(B2<0)B2+=PI;
//	cout<<h_d(B1+B2-B)<<endl;
    L1.A0=h_d(afa(*(L1.endp),*(L0.endp))-B1+PI);
    if(L1.A0>360) L1.A0=h_d(d_h(L1.A0)-2*PI);
	double dd=d_h(L1.angle)-d_h(L1.A0);
	L0.A0=h_d(d_h(L0.angle)-dd);  
    L2.A0=h_d(d_h(L2.angle)-dd);
    
    XY0ang(L0,L1);
//    cout<<L0.startp->X0<<"    "<<L0.startp->Y0<<endl;
	 
	return 1;
}

//**************************键盘输入未知点近似坐标************************************************
void kinXY0(XYnet &a)     // 键盘输入未知点近似坐标
{
for(int i=a.fixpnum;i<a.allpnum;i++)
{
  cout<<a.Pt[i].name<<" x0= ";cin>>a.Pt[i].X0;cout<<endl;
  cout<<a.Pt[i].name<<" y0= ";cin>>a.Pt[i].Y0;cout<<endl;
}

}
//****************************文件输入未知点近似坐标**********************************************
int finXY0(XYnet &a,char *XY0filename)      // 文件输入未知点近似坐标
{
// add code here
	return 1;

}
//****************************************逐测站近似方位角推算************************************
void statangc(XYnet &a)
{
	int n1=0;
	int n=a.obnum+a.fixafn+a.fixdisn;
	   for(int i=0;i<a.statnum;i++) // 逐测站
		   {
			   for(int j=n1;j<n1+a.st[i].aglnum;j++) //  测站首观测值的序号 
			  {
		       if(a.L[j].A0!=-PI)
			   {
			     double df=d_h(a.L[j].angle)-d_h(a.L[j].A0);
			     for(int k=j-a.L[j].i;k<j-a.L[j].i+a.st[a.L[j].sti].aglnum;k++) 
				 if(a.L[k].A0==-PI)
				 {
				   if(d_h(a.L[k].angle)-df>=0) a.L[k].A0=h_d(d_h(a.L[k].angle)-df);
				   if(d_h(a.L[k].angle)-df>=2*PI) a.L[k].A0=h_d(d_h(a.L[k].angle)-df-2*PI); 
				   if(d_h(a.L[k].angle)-df<0) a.L[k].A0=h_d(d_h(a.L[k].angle)-df+2.0*PI);
		          
				   for(int k1=0;k1<n;k1++)            //  已知近似方位角的传递
				   {
				     if(a.L[k1].A0==-PI && a.L[k1].startp==a.L[k].endp 
						 && a.L[k1].endp==a.L[k].startp)
					    if(d_h(a.L[k].A0)-PI>=0) a.L[k1].A0=h_d(d_h(a.L[k].A0)-PI);
						 else a.L[k1].A0=h_d(d_h(a.L[k].A0)+PI);
				     if(a.L[k1].A0==-PI && a.L[k1].startp==a.L[k].startp 
						 && a.L[k1].endp==a.L[k].endp)
					      a.L[k1].A0=a.L[k].A0;
				   }
				  break;
				 }
			   }
			  }
		      n1+=a.st[i].disnum+a.st[i].aglnum;      //  下一个测站
}}
//****************************************???三角形结构*******************************************
 struct Triangle              
{
  XYP p1;
  XYP p2;
  XYP p3;
  double p1ang;
  double p2ang;
  double p3ang;
  double d12;
  double d13;
  double d23;
  double adajian180;
};
//************************无定向导线计算未知点的近似坐标******************************************
int Udxdsetx0y0(XYnet &a)      // 用于三角网控制点不相邻且无方向观测情况  
{ 
// add code here
	int obi,flag;
	for(int i=0;i<a.obnum;i++)
     if(a.L[i].startp->fixed==1 && a.L[i].endp->fixed || a.L[i].A0!=-PI) return 0;
// 1号以上控制点近似坐标归零    
	 for(i=1;i<a.fixpnum;i++)
			a.Pt[i].X0=a.Pt[i].Y0=-PI;
// 起始边确定	
	 for(i=0;i<a.obnum;i++)
		if(a.L[i].startp->i==0 && a.L[i].endp->fixed==0 
			||a.L[i].startp->fixed==0 && a.L[i].endp->i==0) { obi=i;break;}
// 假设方位角与边长	 
		if(a.L[obi].A0==-PI)a.L[obi].A0=0;
        if(a.L[obi].dist0==-PI)a.L[obi].dist0=1;
		XYP end;
		zheng(a.L[obi]);
// 假设方位角计算		
		do{flag=0;
			statangc(a);
			for(int i=0;i<a.obnum;i++)
				if(a.L[i].A0==-PI){flag=1;break;}
		}while(flag==1);
// 假设近似坐标计算 
		flag=0;      
		do{
		for(int i=0;i<a.obnum-1;i++)
	    for(int j=i+1;j<a.obnum;j++)
	     	XY0ang(a.L[i],a.L[j]);
			 flag++;
        	}while(flag<a.obnum);
		end.X0=a.Pt[1].X0;end.Y0=a.Pt[1].Y0;
		end.X=end.Y=-PI;
	
// 计算改正后起始坐标方位角与长度        
		a.L[obi].dist0*=dist(a.Pt[0],a.Pt[1])/dist(a.Pt[0],end); 
	    double ddf=afa(a.Pt[0],a.Pt[1])-afa(a.Pt[0],end);
		if(ddf<0) ddf+=2*PI;
		a.L[obi].A0+=h_d(ddf);
// 各点近似坐标归零        
		 for(i=1;i<a.allpnum;i++)
		  if(i<a.fixpnum){a.Pt[i].X0=a.Pt[i].X;a.Pt[i].Y0=a.Pt[i].Y;}
		  else a.Pt[i].X0=a.Pt[i].Y0=-PI;
		 
// 近似方位角归零        

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -