Exemple #1
0
/************************************************************************
* 函数名:	ParseGSA
* 描  述:	解析GSA
* 入  参:
* 出  参: 
* 返  回: 
* 备  注: 
$GPGSA, <1>,<2>,<3>,<3>,,,,,<3>,<3>,<3>,<4>,<5>,<6>,<7><CR><LF>
<1>模式 :M = 手动, A = 自动。
<2>定位型式 1 = 未定位, 2 = 二维定位, 3 = 三维定位。
<3>PRN 数字:01 至 32 表天空使用中的卫星编号,最多可接收12颗卫星信息。
<4> PDOP位置精度因子(0.5~99.9)
<5> HDOP水平精度因子(0.5~99.9)
<6> VDOP垂直精度因子(0.5~99.9)
<7> Checksum.(检查位).
************************************************************************/
void CPosData::ParseGSA(PCSTR pcGSA)
{
	//Test
	//GPGSA	= "$GPGSA,A,3,14,15,05,22,18,26,,,,,,,2.1,1.2,1.7*3D";

	WORD wFieldLen	= 0;	//数据段(两个','之间的字符串)的长度
	int		nValue	= 0;	//整型数据段的值
	double	fValue	= 0;	//浮点型数据段的值
	PCSTR pcField	= NULL;

	//移至第一个卫星编号
	pcField	= ScanField(pcGSA, 3, wFieldLen);

	//天空使用中的卫星编号
	memset(g_pPosInfo->gsa_data.wUsedID, NULL, sizeof(g_pPosInfo->gsa_data.wUsedID));
	for ( int i = 0; i < 12; i++ )
	{
		if(NULL == pcField || 0 == wFieldLen)
		{
			g_pPosInfo->gsa_data.wSatNum	= i;	//卫星个数
			break;
		}

		g_pPosInfo->gsa_data.wUsedID[i] = atoi( pcField );
		pcField	= ScanField(pcField, 1, wFieldLen);
	}

	//PDOP位置精度因子(0.5~99.9)
	//MAX_SATE_NUM-g_pPosInfo->gsa_data.wSatNum,跳过剩余空白的卫星编号数
	pcField	= ScanField(pcField, 12-g_pPosInfo->gsa_data.wSatNum, wFieldLen);
	if(NULL == pcField)
		return;
	fValue = atof( pcField );
	g_pPosInfo->gsa_data.dbPdop = fValue;

	//HDOP水平精度因子(0.5~99.9)
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	fValue = atof( pcField );
	g_pPosInfo->gsa_data.dbHdop = fValue;

	//VDOP垂直精度因子(0.5~99.9)
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	fValue = atof( pcField );
	g_pPosInfo->gsa_data.dbVdop = fValue;
}
Exemple #2
0
SdbgMeta &SdbgMeta::Deserialize(std::ifstream &is) {
  size_t num_buckets;
  ScanField(is, "k", k_);
  ScanField(is, "words_per_tip_label", words_per_tip_label_);
  ScanField(is, "num_buckets", num_buckets);
  ScanField(is, "num_files", num_files_);
  std::vector<SdbgBucketRecord> bucket_rec(num_buckets);
  for (size_t i = 0; i < num_buckets; ++i) {
    is >> bucket_rec[i].bucket_id
       >> bucket_rec[i].file_id
       >> bucket_rec[i].starting_offset
       >> bucket_rec[i].num_items
       >> bucket_rec[i].num_tips
       >> bucket_rec[i].num_large_mul;
  }
  return FromBucketRecord(bucket_rec, k_, words_per_tip_label_);
}
Exemple #3
0
/************************************************************************
* 函数名:	ParseGGA
* 描  述:	解析GGA
* 入  参:
* 出  参: 
* 返  回: 
* 备  注: 
$GPGGA,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,M,<10>,M,<11>,<12>*hh<CR><LF>
<1> UTC时间,hhmmss(时分秒)格式
<2> 纬度ddmm.mmmm(度分)格式(前面的0也将被传输)
<3> 纬度半球N(北半球)或S(南半球)
<4> 经度dddmm.mmmm(度分)格式(前面的0也将被传输)
<5> 经度半球E(东经)或W(西经)
<6> GPS状态:0=未定位,1=非差分定位,2=差分定位,6=正在估算
<7> 正在使用解算位置的卫星数量(00~12)(前面的0也将被传输)
<8> HDOP水平精度因子(0.5~99.9)
<9> 海拔高度(-9999.9~99999.9)
<10> 地球椭球面相对大地水准面的高度
<11> 差分时间(从最近一次接收到差分信号开始的秒数,如果不是差分定位将为空)
<12> 差分站ID号0000~1023(前面的0也将被传输,如果不是差分定位将为空)
************************************************************************/
void CPosData::ParseGGA(PCSTR pcGGA)
{
	//Test
	//pcGPGGA	= "$GPGGA,101904.000,3110.4104,N,12123.8126,E,1,04,2.7,91.0,M,8.0,M,,0000*5C";

	WORD wFieldLen	= 0;	//数据段(两个','之间的字符串)的长度
	int		nValue	= 0;	//整型数据段的值
	double	fValue	= 0;	//浮点型数据段的值

	if (NULL == pcGGA)
	{
		return;
	}
	//<9> 海拔高度(-9999.9~99999.9)
	PCSTR pcField	= ScanField(pcGGA, 9, wFieldLen);
	if(NULL == pcField)
		return;
	fValue = atof( pcField );
	g_pPosInfo->rmc_data.dbAltitude	= fValue;
}
Exemple #4
0
/************************************************************************
* 函数名:	ParseGSV
* 描  述:	解析GSV
* 入  参:
* 出  参: 
* 返  回: 
* 备  注: 
$GPGSV, <1>,<2>,<3>,<4>,<5>,<6>,<7>,?<4>,<5>,<6>,<7>,<8><CR><LF>
<1> GSV语句的总数
<2> 本句GSV的编号
<3> 可见卫星的总数,00 至 12。
<4> 卫星编号, 01 至 32。
<5>卫星仰角, 00 至 90 度。
<6>卫星方位角, 000 至 359 度。实际值。
<7>讯号噪声比(C/No), 00 至 99 dB;无表未接收到讯号。
<8>Checksum.(检查位).
************************************************************************/
void CPosData::ParseGSV(PCSTR pcGSV, PCSTR pcSectionGSV)
{
	//Test
	//GPGSV	= "$GPGSV,3,1,10,18,84,067,23,09,67,067,27,22,49,312,28,15,47,231,30*70
	//         $GPGSV,3,2,10,21,32,199,23,14,25,272,24,05,21,140,32,26,14,070,20*7E
	//	       $GPGSV,3,3,10,29,07,074,,30,07,163,28*7D";

	WORD  wFieldLen = 0;	//数据段(两个','之间的字符串)的长度
	int		nValue	= 0;	//整型数据段的值

	WORD	wGSVNum	= 0;	//GSV语句总数
	WORD	wGSVIndex	= 0;	//当前GSV语句序号
	//WORD	wSateNum = 0;	//视野内卫星数
	const WORD	GSV_SATE_NUM	= 4;	//一条GSV语句中最大卫星数

	//memset(g_pPosInfo->gsv_data, NULL, sizeof(g_pPosInfo->gsv_data));

	BOOL	bFirstGSV = TRUE;
	PCSTR	pcField	= pcGSV;

	do
	{
		//GSV语句总数
		pcField	= ScanField(pcField, 1, wFieldLen);
		if(NULL == pcField)
			return;
		if(bFirstGSV)
			wGSVNum = atoi( pcField );
		//当前GSV语句序号
		pcField	= ScanField(pcField, 1, wFieldLen);
		if(NULL == pcField)
			return;
		wGSVIndex = atoi( pcField );
		//视野内卫星数
		pcField	= ScanField(pcField, 1, wFieldLen);
		if(NULL == pcField)
			return;
		if(bFirstGSV)
			g_pPosInfo->rmc_data.pos_state.dwSateNum = atoi( pcField );

		
		for(int i=0; i<GSV_SATE_NUM; i++)
		{
			int j = (wGSVIndex-1)*GSV_SATE_NUM+i;

			if (j >= 12)
			{
				break;
			}
			//最后一颗卫星信息
			if(j == g_pPosInfo->rmc_data.pos_state.dwSateNum)
				break;
			//卫星编号
			pcField	= ScanField(pcField, 1, wFieldLen);
			if(NULL == pcField)
				return;
			g_pPosInfo->gsv_data[j].wSatID	= atoi( pcField );
			//卫星仰角:度
			pcField	= ScanField(pcField, 1, wFieldLen);
			if(NULL == pcField)
				return;
			g_pPosInfo->gsv_data[j].wElevation = atoi( pcField );
			//卫星方位角:度
			pcField	= ScanField(pcField, 1, wFieldLen);
			if(NULL == pcField)
				return;
			g_pPosInfo->gsv_data[j].wAzimuth = atoi( pcField );
			//信噪比
			pcField	= ScanField(pcField, 1, wFieldLen);
			if(NULL == pcField)
				return;
			g_pPosInfo->gsv_data[j].wSNR = atoi( pcField );
			g_pPosInfo->gsv_data[j].bAvailible	= TRUE;
		}
		//最后一条GSV语句
		if(wGSVIndex == wGSVNum)
			break;
		//移至下一条GSV语句
		pcField = strstr(pcField, pcSectionGSV);
		if(NULL == pcField)
			break;
		bFirstGSV	= FALSE;
	} while ( TRUE );

	for(int i = g_pPosInfo->rmc_data.pos_state.dwSateNum; i < MAX_SATE_NUM; i++)
		g_pPosInfo->gsv_data[i].bAvailible	= FALSE;

	return;
}
Exemple #5
0
/************************************************************************
* 函数名:	ParseRMC
* 描  述:	解析RMC
* 入  参:
* 出  参: 
* 返  回: 
* 备  注: 
$GPRMC,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>,<12>*hh<CR><LF>
<1> UTC时间,hhmmss(时分秒)格式
<2> 定位状态,A=有效定位,V=无效定位
<3> 纬度ddmm.mmmm(度分)格式(前面的0也将被传输)
<4> 纬度半球N(北半球)或S(南半球)
<5> 经度dddmm.mmmm(度分)格式(前面的0也将被传输)  
<6> 经度半球E(东经)或W(西经)
<7> 地面速率(000.0~999.9节,前面的0也将被传输)
<8> 地面航向(000.0~359.9度,以真北为参考基准,前面的0也将被传输)
<9> UTC日期,ddmmyy(日月年)格式
<10> 磁偏角(000.0~180.0度,前面的0也将被传输)
<11> 磁偏角方向,E(东)或W(西)
<12> 模式指示(仅NMEA0183 3.00版本输出,A=自主定位,D=差分,E=估算,N=数据无效)
************************************************************************/
void CPosData::ParseRMC(PCSTR pcRMC)
{
	//test
	//pcGPRMC = "$GPRMC,101904.000,A,3110.4104,N,12123.8126,E,0.00,,220707,,,A*71";

	WORD wFieldLen	= 0;	//数据段(两个','之间的字符串)的长度
	int		nValue	= 0;	//整型数据段的值
	double	fValue	= 0;	//浮点型数据段的值


	//<1> UTC时间,hhmmss(时分秒)格式
	PCSTR pcField	= ScanField(pcRMC, 1, wFieldLen);
	if(NULL == pcField)
		return;
	nValue = atoi( pcField );
	g_pPosInfo->rmc_data.UtcTime.wHour		= nValue / 10000;
	g_pPosInfo->rmc_data.UtcTime.wMinute	= nValue / 100 % 100;
	g_pPosInfo->rmc_data.UtcTime.wSecond	= nValue % 100;

	//<2> 定位状态,A=有效定位,V=无效定位
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	if('A' == pcField[0])
	{
		g_pPosInfo->rmc_data.pos_state.cFix	= 1;	//定位状态
	}
	else if('V' == pcField[0])
	{
		g_pPosInfo->rmc_data.pos_state.cFix	= 0;	//定位状态
	}
	else
	{
		return;
	}

	//<3> 纬度ddmm.mmmm(度分)格式(前面的0也将被传输)
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	fValue	= atof( pcField );
	nValue	= (int)fValue / 100;	//计算度
	g_pPosInfo->rmc_data.dbLatitude	= (double)(nValue + (fValue - nValue*100)/60);//纬度 去掉10的6次方,取原值

	//<4> 纬度半球N(北半球)或S(南半球)
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	if('N' == pcField[0])
		g_pPosInfo->rmc_data.pos_state.cLatitudeType	= 0;
	else if('S' == pcField[0])
		g_pPosInfo->rmc_data.pos_state.cLatitudeType	= 1;
	else
		g_pPosInfo->rmc_data.pos_state.cLatitudeType	= 0;

	//<5> 经度dddmm.mmmm(度分)格式(前面的0也将被传输)
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	fValue	= atof( pcField );
	nValue	= (int)fValue / 100;	//计算度
	g_pPosInfo->rmc_data.dbLongitude = (double)(nValue + (fValue - nValue*100)/60);//经度  去掉10的6次方,取原值

	//<6> 经度半球E(东经)或W(西经)
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	if('E' == pcField[0])
		g_pPosInfo->rmc_data.pos_state.cLongitudeType	= 0;
	else if('W' == pcField[0])
		g_pPosInfo->rmc_data.pos_state.cLongitudeType	= 1;
	else
		g_pPosInfo->rmc_data.pos_state.cLongitudeType	= 0;

	//<7> 地面速率(000.0~999.9节,前面的0也将被传输)	1节(海里) = 1.852km/h
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	fValue	= atof( pcField );
	g_pPosInfo->rmc_data.dbSpeed = fValue*1.852+0.5;	//地面速率1.851985

	//<8> 地面航向(000.0~359.9度,以真北为参考基准,前面的0也将被传输)
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	//fValue	= atof( pcField ) + 0.5;	//四舍五入
	fValue	= atof( pcField );
	g_pPosInfo->rmc_data.dbAzimuth	= fValue; //方位角

	//<9> UTC日期,ddmmyy(日月年)格式
	pcField	= ScanField(pcField, 1, wFieldLen);
	if(NULL == pcField)
		return;
	nValue = atoi( pcField );
	g_pPosInfo->rmc_data.UtcTime.wYear	= (nValue % 100) + 2000;
	g_pPosInfo->rmc_data.UtcTime.wMonth	= nValue / 100 % 100;
	g_pPosInfo->rmc_data.UtcTime.wDay	= nValue / 10000;
}