DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1060|回复: 0
打印 上一主题 下一主题

[待整理] 车载GPS定位监控系统中信号的分析与处理

[复制链接]
跳转到指定楼层
楼主
发表于 2015-4-27 21:18:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
引言

随着汽车在日常生产和生活中起的作用越来越突出,如何实现各类车辆的有效指挥、协调控制和管理已经成为交通运输和安全管理部门面临的一个重要问题。为了满足提高运输效率和安全保障的需要,对车辆定位监控系统的研究也日趋迫切。

车载GPS定位监控系统是GSM全球数字蜂窝移动通信技术和GIS地理信息技术、GPS全球卫星定位技术以及计算机网络技术相融合研制开发出来的软件技术。它是通过安装在车辆上的GPS接收机(即车载机)接收卫星信号,监控中心的通信控制器从GPS接收机输出的信号中提取所需要的位置、速度和时间信息,结合车辆身份等信息形成数据报,然后通过无线信道发往控制中心;控制中心的主站接收子站发送的数据,处理接收信息通过短消息的方式逐次直接发送给每一台车载机。最后,将车辆的具体数据和状态在监控中心的电子地图上显示出来。

本文讨论的就是从接收机输出的信号中提取所需要的位置、速度和时间信息的方法,以及中心处理信息后发送命令集的实现过程。

GPS车载机的通信协议

车载机与监控中心之间的通信方式均以中心发送命令,车载机应答的方式进行,所以我们对车载机GPS信号的分析与处理必须完全依据车载GPS接收机与监控中心的通信协议来进行,下面是GPS车载机通信协议的部分内容。

车载机返回信息

一般信息:
*XX,YYYYYYYYYY,V1,HHMMSS,S,latitude,D,longitu de,G,speed,direction,DDMMYY,vehicle_status#

确认信息:
*XX,YYYYYYYYYY,V4,CMD,hhmmss,HHMMSS,S,latitu de,D,longitude,G,speed,direction,DDM MYY,vehicle_status#

区分一般信息和确认信息的方法是看车载机传回来的信息中是否包含“V4”,判断返回信息是否有效的方法是看回传信息中是否包含“HQ(制造商名称)”。

其中:‘*’表示命令头;‘XX’表示制造商名称;‘,’表示分隔符;‘YYYYYYYYYY’表示车载机序列号;‘CMD’表示被确认的中心命令;‘hhmmss’表示被确认命令中的时间值;‘HHMMSS’表示车载机时间;‘S’表示数据有效位;‘latitude’表示纬度;‘D’表示纬度标志;‘longitude’表示经度;‘G’表示经度标志;‘speed ’表示速度;‘direction’表示方位角;‘DDMMYY’表示日/月/年;‘vehicle_status ’表示车辆状态。

车载机返回GPS信息模式有两种,一是返回最近的有效的GPS信息;二是返回最新的GPS信息。

中心发送命令结构和命令集

中心发送命令结构是:*XX,YYYYYYYYYY,CMD,HHMMSS,PARA1,PARA2,...#

在编写中心发送指令时必需按照这个格式来写,下面列出其中的七个中心发送命令。

定位监控命令D1:该指令要求车载机以interval为时间间隔,回传count次定位信息。
自动监控设置命令S17:该指令完成对自动监控参数的设置。
参数设置指令S12:
从车载机接收的GPS信号中判断返回的信息是否有效,如果无效则直接丢弃,如果有效,则确认是一般信息还是确定信息,再接收处理一般信息或确定信息。

区分一般信息和确认信息的依据是参数字符串是否包含“V4”。

Result := False;{初始返回结果}
Result := pos(‘V4’, Str) > 0;{如果str包含“V4”,就返回true,否则false}
判断是否返回有效的信息的依据是参数字符串是否包含"*HQ"。
Result := False; {初始返回结果}
Result := pos('*HQ',Str) > 0;{如果str包含“ *HQ”,就返回true,否则false}

一般信息的标志是V1。车载回传的一般信息中包含的参数有车载序列号、移动电话号码、车牌号、时间、经纬度、速度、方位 、日期。

//获取车载序列号(同样的方法可以获取移动电话号码、车牌号、时间)
sCarNo := copy(RecvGprs, iPos + 4, 10);
//获取纬度(同样的方法可以获得经度)
sLatitude := copy(RecvGprs, iPos + 3, 9);
sLatitude := FloatToStr( StrToFloat(copy(sLatitude, 1, 2)) +StrToFloat(copy(sLatitude, 3, 7)) / 60 );
//获取南纬和北纬(同样的方法可以获得东西经)
iPos := pos(',S,', RecvGprs); {查找",S,"在RecvGprs 的位置}
if iPos > 0 then; {如果RecvGprs 包含',S ,' 就执行下面语句}
sNS := ‘南纬’
else begin
iPos := pos(‘,N,’, RecvGprs); {查找“,N,”
在RecvGprs 的位置}
sNS :=‘北纬’;
end;


//获取速度、方位 、日期
sSpeed := copy(RecvGprs, iPos + 3, 6);{获取速度}
sDirection := copy(RecvGprs, iPos + 10, 3);{获取方位}
sDate := copy(RecvGprs, iPos + 14, 6); {获取日期}
if Pos('.', sSpeed) <= 0 then{判断sSpeed 是否包含'.',如果包含就执行下面语句}
begin
sSpeed := copy(RecvGprs, iPos + 3, 3); {获取
速度}
sDirection := copy(RecvGprs, iPos + 7, 3); {获
取方位}
sDate := copy(RecvGprs, iPos + 11, 6); {获取
日期}
end;

//数据转换
sSpeed := FormatFloat('0.00' ,StrToFloat(sSpeed) * 1.852);{行驶速度转换}
sSceond := copy(sTime, 5, 2);{时间转换}
if StrToInt(sSceond) < 60 then{时间转换('YYYY-MM-DD HH:MM:SS'表示为:年月日时分秒}
sDate := FormatDateTime('YYYY-MM-DD HH:MM:SS', IncHour(StrToDateTime('20' +copy(sDate, 5, 2) + '-' + copy(sDate, 3, 2) + '-' + copy(sDate, 1, 2) +' ' + copy(sTime, 1, 2) + ':' + copy(sTime, 3, 2) + ':'+ copy(sTime, 5, 2)), 8))
else begin
sDate := FormatDateTime('YYYY-MM-DD HH:MM:SS', IncHour(StrToDateTime('20' +
copy(sDate, 5, 2) + '-' + copy(sDate, 3, 2) + '-' + copy(sDate, 1, 2) +' ' + copy(sTime, 1, 2) + ':' + copy(sTime, 3, 2) + ':'+ '00'), 8));
sDate := FormatDateTime('YYYY-MM-DD HH:MM:SS',
IncMinute(StrToDateTime(sDate), + 1));
end;

确认信息的标志是V4。车载回传的确认信息中包含车辆行驶方位和车辆状态。

处理一般信息中获取的方位信息,由字符类型转换为整型数据,根据数据所在范围确定车辆的行驶方位,小于22.5或大于337.5为正北方向,大于22.5小于67.5为东北方向,大于67.5小于112.5为正东方向,依此类推确认车辆的行驶方向。

处理一般信息中获取的车辆状态,由字符类型转换为二进制数字符串,把二进制数据的每一位存进数组,每一位对应表一中的一个车辆状态。

//获取车辆状态
iPos := Pos('#', RecvGprs);
sCarStatus := copy(RecvGprs, iPos - 8, 8)
//转换为二进制数字符串
sBin := '';
for I := 1 to 8 do
sBin := sBin + HexCng(copy(sCarStatus, I, 1));
//把二进制数据的每一位存进数组
for I := 0 to 31 do
ArrBin[I] := copy(sBin, I + 1, 1);
sCarStatuText := HandleCarStatus(ArrBin);{车辆状态}

监控中心根据每一台车载机传回的信息内容发送不同的命令。发送命令程序需严格按照中心发送命令集规定的的格式来写,下面列举其中的几条命令:

//该指令要求车载机以sInterval为时间间隔,回传sCount次定位信息。
sRightStr := '*HQ,0000000000,D1,' + sTime + ',' +sInterval + ',' + sCount + '#'
//车载机接到这条指令后将清除掉所有报警信息。
sRightStr := '*HQ,0000000000,R7,' + sTime + '#';
if Application.MessageBox(PChar('真的要解除对车辆【‘+CarID+’】报警吗?'),‘提示’, MB_YESNO + MB_DEFBUTTON2) = IDNO then Exit;

这里的CarID指车载机序列号。

//车载机收到这条命令将会启动断油断电。
sRightStr := '*HQ,0000000000,S20,' + sTime + ',1,3,10,3,5,5#';
if Application.MessageBox(PChar('真的要对车辆【'+CarID+'】断油断电吗?'),'提示', MB_YESNO + MB_DEFBUTTON2) = IDNO then Exit;

结语

目前,车载GPS定位监控系统已经被各运输公司使用在出租车、客车以及大型车队上,该软件技术很好的实现了对车辆位置、状态的监控和调度管理。

随着GPS应用领域的扩大,车载GPS导航定位监控软件的系统的功能也将随着导航、通信等需求而不断的增多和完善。GPS车载机通信协议会根据GPS车载机产品的功能升级而不断升级,增加新的命令,相应的软件系统也要增加新的指令,本系统的设计将易于这些升级维护工作的进行。

参考文献:

1. 李丽、题原,GPS在车辆定位系统中的应用,高师理科学刊,2006,26(3),46-49

2. 邓中卫,GPS技术、应用与市场,航空工业出版社,1996:45-51

3. 齐锐、屈韶琳、阳琳,用MapX开发地理信息系统,清华大学出版社,2003:306-309

4. Okatan A,Salih A.Micro-controller based vehicle tracing system via use of GPS and GSM[C]. Proceedings of International conference on recent advances in space teclmologies, 2003:20-25
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|文字版|手机版|DIY编程器网 ( 桂ICP备14005565号-1 )

GMT+8, 2024-12-26 09:32 , 耗时 0.080536 秒, 18 个查询请求 , Gzip 开启.

各位嘉宾言论仅代表个人观点,非属DIY编程器网立场。

桂公网安备 45031202000115号

DIY编程器群(超员):41210778 DIY编程器

DIY编程器群1(满员):3044634 DIY编程器1

diy编程器群2:551025008 diy编程器群2

QQ:28000622;Email:libyoufer@sina.com

本站由桂林市临桂区技兴电子商务经营部独家赞助。旨在技术交流,请自觉遵守国家法律法规,一旦发现将做封号删号处理。

快速回复 返回顶部 返回列表