专利摘要
本发明公开了一种基于软件定义的车载网实现方法,所述车载网络包括基站和车辆节点;每个基站具有唯一的坐标,每个基站和车辆节点各自分别具有一个唯一的硬件ID;车载网传输的数据由数据ID唯一标识,每个数据包含两个以上的数据分片,每个数据分片由分片ID唯一标识,分片ID对应为每个分片的顺序编号;车辆节点通过本发明所提供的车载网实现方法能够从距离最近的车辆节点以单播方式获取服务数据,缩短了获取服务数据的延迟和代价,提高了服务质量,本发明可应用于道路路况监测、车辆管理等领域,具有广泛的应用前景。
权利要求
1.一种基于软件定义的车载网实现方法,其特征在于,所述车载网络包括基站和车辆节点;每个基站具有唯一的坐标,每个基站和车辆节点各自分别具有一个唯一的硬件ID;一个基站和所有符合条件1的车辆节点构成子网;
条件1:在所有基站中,该车辆节点与该基站距离最近;
车载网传输的数据由数据ID唯一标识,每个数据包含两个以上的数据分片,每个数据分片由分片ID唯一标识,分片ID对应为每个数据分片的顺序编号;
车载网传输的消息由消息类型定义,消息名称和消息类型的对应关系如下所示:消息名称包括注册消息、更新消息、请求消息、分片请求消息、分片响应消息以及响应消息,对应的消息类型的值分别为1、2、3、4、5和6;
一个基站保存一个索引表,索引表的一个索引表项包含硬件ID、数据ID和分片ID集合;
注册消息由消息类型、硬件ID、源坐标、目的坐标、数据ID和分片ID集合构成;
在数据DA1由数据ID DID1定义,数据DA1包含N1个数据分片,车辆节点V1能提供数据DA1中的数据分片,所述数据分片的分片ID构成分片ID集合S1的条件下,车辆节点V1启动后,通过电子地图获取所有基站的坐标,选择距离车辆节点V1自己最近的基站BS1,并执行下述注册操作:
步骤101:开始;
步骤102:车辆节点V1发送注册消息,该注册消息的消息类型为1,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,数据ID为DID1,分片ID集合为S1;
步骤103:基站BS1如果接收到注册消息,则执行步骤107,否则执行步骤104;
步骤104:接收到注册消息的车辆节点查看该注册消息的目的坐标与自己坐标的距离,判断该距离是否小于该注册消息目的坐标与源坐标之间的距离,如果是,则执行步骤106,否则执行步骤105;
步骤105:接收到注册消息的车辆节点丢弃该注册消息;
步骤106:接收到注册消息的车辆节点将该注册消息的源坐标更新为自己的坐标,转发该注册消息,执行步骤103;
步骤107:基站BS1接收到注册消息后查看索引表,如果存在一个索引表项,该索引表项的硬件ID等于该注册消息的硬件ID,则执行步骤108,否则执行步骤109;
步骤108:基站BS1丢弃接收到的注册消息,执行步骤110;
步骤109:接收到注册消息的基站BS1创建一个索引表项,该索引表项的硬件ID、数据ID和分片ID集合分别等于该注册消息的硬件ID、数据ID和分片ID集合;
步骤110:结束;
车辆节点V1进入一个新子网后,向该新子网的基站执行步骤101-步骤110的注册过程。
2.根据权利要求1所述的一种基于软件定义的车载网实现方法,其特征在于,基站保存一个车辆表,车辆表的一个车辆表项包含坐标域、硬件ID和生命周期;
更新消息包含消息类型、硬件ID、源坐标、目的坐标和负载;
如果车辆节点V1所在子网的基站为BS1,车辆节点V1执行注册操作后,执行下述操作建立车辆表:
步骤201:开始;
步骤202:车辆节点V1发送更新消息,该更新消息的消息类型为2,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,负载为车辆节点V1的坐标;
步骤203:基站BS1如果接收到更新消息,则执行步骤207,否则执行步骤204;
步骤204:接收到更新消息的车辆节点查看该更新消息目的坐标与自己坐标的距离,判断该距离是否小于该更新消息目的坐标与源坐标之间的距离,如果是,则执行步骤206,否则执行步骤205;
步骤205:接收到更新消息的车辆节点丢弃该更新消息;
步骤206:接收到更新消息的车辆节点将该更新消息的源坐标更新为自己的坐标,转发该更新消息,执行步骤203;
步骤207:基站BS1接收到更新消息后查看车辆表,如果存在一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,则执行步骤208,否则执行步骤209;
步骤208:接收到更新消息的基站BS1选择一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,将该车辆表项的坐标更新为该更新消息负载中的坐标,将生命周期设置为最大值,执行步骤220;
步骤209:接收到更新消息的基站BS1创建一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,坐标域等于该更新消息负载中的坐标,将生命周期设置为最大值;
步骤220:结束;
如果基站BS1检测到一个车辆表项的生命周期等于0,生命周期随着机器时钟自动衰减,则选择一个索引表项,该索引表项的硬件ID等于该车辆表项的硬件ID,并删除该车辆表项和索引表项。
3.根据权利要求1所述的一种基于软件定义的车载网实现方法,其特征在于,在车辆节点V1的硬件ID为HID1,所在子网的基站为基站BS1,从基站BS1到车辆节点V1的路由路径由硬件ID集合表示,该硬件ID集合由该路由路径所包含的车辆节点的硬件ID构成的条件下,基站BS1执行下述操作获取该硬件ID集合:
步骤301:开始;
步骤302:基站BS1设置一个硬件ID集合参数hs1,参数hs1的初始值为空集;基站BS1选择一个车辆表项E1,车辆表项E1的硬件ID等于HID1;如果基站BS1的坐标与车辆表项E1的坐标之间的距离不大于传输半径R,则执行步骤306,否则执行步骤303;
步骤303:基站BS1选择一个车辆表项E2,车辆表项E2的坐标域值与基站BS1的坐标域值之间的距离小于传输半径R,且车辆表项E2的坐标域值与车辆表项E1的坐标域值之间的距离最小,基站BS1将车辆表项E2的硬件ID加入到参数hs1并作为最后一个元素;
步骤304:基站BS1选择车辆表项E3,车辆表项E3的硬件ID等于参数hs1的最后一个元素,如果车辆表项E3的坐标与车辆表项E1的坐标之间的距离不大于传输半径R,则执行步骤306,否则执行步骤305;
步骤305:基站BS1选择一个车辆表项E4,车辆表项E4的坐标与车辆表项E3的坐标之间的距离小于传输半径R,且车辆表项E4的坐标与车辆表项E1的坐标之间的距离最小,基站BS1将车辆表项E4的硬件ID加入到参数hs1中并作为最后一个元素,执行步骤304;
步骤306:基站BS1将硬件ID HID1加入到参数hs1中并作为最后一个元素;
步骤307:结束。
4.根据权利要求3所述的一种基于软件定义的车载网实现方法,其特征在于,
请求消息由消息类型、硬件ID、源坐标、目的坐标和数据ID构成;
分片请求消息由消息类型、硬件ID、硬件ID集合、数据ID和负载构成;
分片响应消息由消息类型、硬件ID、硬件ID集合、数据ID和负载构成;
响应消息由消息类型、硬件ID集合、数据ID和负载构成;
在车辆节点V2所在子网的基站为BS1,数据DA1由数据ID DID1定义,由N1个数据分片构成的条件下,车辆节点V2通过下述过程获取数据DA1:
步骤401:开始;
步骤402:车辆节点V1发送一个请求消息,该请求消息的消息类型为4,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,数据ID为DID1;
步骤403:基站BS1如果接收到请求消息,则执行步骤407,否则执行步骤404;
步骤404:接收到请求消息的车辆节点查看该请求消息的目的坐标与自己的坐标之间的距离,判断该距离是否小于该请求消息的目的坐标与源坐标之间的距离,如果是,则执行步骤406,否则执行步骤405;
步骤405:接收到请求消息的车辆节点丢弃该请求消息;
步骤406:接收到请求消息的车辆节点将该请求消息的源坐标更新为自己的坐标,发送该请求消息,执行步骤403;
步骤407:基站BS1接收到请求消息后,选择符合条件2的所有索引表项,针对每个选中的索引表项,基站BS1执行步骤301-307获取基站BS1到达硬件ID等于该索引表项的硬件ID的车辆节点的路由路径的参数hs1,基站BS1发送一个分片请求消息,该分片请求消息的消息类型为5,硬件ID等于该请求消息的硬件ID,硬件ID集合等于参数hs1,数据ID等于该请求消息的数据ID,负载为参数hs1;
条件2:这些索引表项的数据ID等于该请求消息的数据ID且这些索引表项的分片ID集合的并集等于,
步骤408:车辆节点接收到分片请求消息,如果该车辆节点的硬件ID等于该分片请求消息的硬件ID集合中的第一个元素,则执行步骤410,否则执行步骤409;
步骤409:接收到分片请求消息的车辆节点丢弃该分片请求消息,执行步骤412;
步骤410:接收到分片请求消息的车辆节点从该分片请求消息的硬件ID集合中删除第一个元素;如果该分片请求消息的硬件ID集合为空,则执行步骤412,否则执行步骤411;
步骤411:接收到分片请求消息的车辆节点转发该分片请求消息,执行步骤408;
步骤412:接收到分片请求消息的车辆节点构建一个分片响应消息,该分片响应消息的消息类型为6,硬件ID等于该分片请求消息中的硬件ID,硬件ID集合等于该分片请求消息中负载中的参数hs1,数据ID等于该分片请求消息中的数据ID,负载等于该车辆节点所能提供的所有该分片请求消息数据ID所标识的数据的数据分片,其中一个数据分片由二元组<分片ID,数据分片值>表示,二元组的第一个元素为分片ID,第二个元素为该分片请求消息的数据ID以及该分片ID所标识的数据分片值,其中,数据ID标识一种数据,分片ID标识该数据中的一个数据分片;该车辆节点从该分片响应消息的硬件ID集合中删除最后一个元素,将基站BS1的硬件ID计入到该分片响应消息的硬件ID集合中并作为第一个元素,发送该分片响应消息;
步骤413:基站BS1如果接收到分片响应消息,则执行步骤417,否则执行步骤414;
步骤414:接收到分片响应消息的车辆节点查看自己的硬件ID是否等于该分片响应消息的硬件ID集合中的最后一个元素,如果是,则执行步骤416,否则执行步骤415;
步骤415:接收到分片响应消息的车辆节点丢弃该分片响应消息;
步骤416:接收到分片响应消息的车辆节点从该分片响应消息的硬件ID集合中删除最后一个元素,发送该分片响应消息,执行步骤413;
步骤417:基站BS1接收到所有的分片响应消息后,根据这些分片响应消息中的负载构建由该分片响应消息中的数据ID所标识的数据;基站BS1执行步骤301-307获取基站BS1到达硬件ID等于该分片响应消息中的硬件ID的车辆节点的路由路径的参数hs1,发送一个响应消息,该响应消息的消息类型为7,硬件ID集合为hs1,数据ID等于该分片响应消息中的数据ID,负载为构建的数据;
步骤418:车辆节点接收到响应消息;如果该车辆节点的硬件ID等于该响应消息的硬件ID集合中的第一个元素,则执行步骤420,否则执行步骤419;
步骤419:接收到响应消息的车辆节点丢弃该响应消息,执行步骤422;
步骤420:接收到响应消息的车辆节点从该响应消息的硬件ID集合中删除第一个元素,如果该响应消息的硬件ID集合为空,则执行步骤422,否则执行步骤421;
步骤421: 接收到响应消息的车辆节点转发该响应消息,执行步骤418;
步骤422:接收到响应消息的车辆节点V2接收到该响应消息,保存该响应消息负载中的数据;
步骤423:结束。
说明书
技术领域
本发明涉及一种车载网实现方法,尤其涉及的是一种基于软件定义的车载网实现方法。
背景技术
车载网能提供本地服务的一种服务模式。近年来,很多研究工作致力于车载网,以便使车辆驾驶人能够快速获取网络服务。随着车载网技术的发展,车载网会成为未来提供服务的一种模式。
目前,车载网的实现模式是通过广播来实现,因此延迟和代价都比较大,降低了网络服务性能。因此,如何降低车载网提供服务的延迟和代价成为近年来研究的热点问题。
发明内容
发明目的:本发明所要解决的技术问题是针对现有技术的不足,提供一种基于软件定义的车载网实现方法。
技术方案:本发明公开了一种基于软件定义的车载网实现方法,所述车载网络包括基站和车辆节点;每个基站具有唯一的坐标,每个基站和车辆节点各自分别具有一个唯一的硬件ID,硬件ID例如可以设置为MAC地址;一个基站和所有符合条件1的车辆节点构成子网;
条件1:在所有基站中,该车辆节点与该基站距离最近;
车载网传输的数据由数据ID唯一标识,每个数据包含两个以上的数据分片,每个数据分片由分片ID唯一标识,分片ID对应为每个数据分片的顺序编号;例如第一个分片的顺序编号为1,则该分片的分片ID为1,以此类推;
车载网传输的消息由消息类型定义,消息名称和消息类型的对应关系如下表所示:
一个基站保存一个索引表,索引表的一个索引表项包含硬件ID、数据ID和分片ID集合;
注册消息由消息类型、硬件ID、源坐标、目的坐标、数据ID和分片ID集合构成;
在数据DA1由数据ID DID1定义,数据DA1包含N1个数据分片,N1取值范围可以为[2,20];车辆节点V1能提供数据DA1中的数据分片,所述数据分片的分片ID构成分片ID集合S1的条件下,车辆节点V1启动后,通过电子地图获取所有基站的坐标,选择距离车辆节点V1自己最近的基站BS1,并执行下述注册操作:电子地图包含所有基站的坐标,为预先设置,车辆节点自动加载该电子地图获取所有基站的坐标;
步骤101:开始;
步骤102:车辆节点V1发送注册消息,该注册消息的消息类型为1,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,数据ID为DID1,分片ID集合为S1;
步骤103:基站BS1如果接收到到注册消息,则执行步骤107,否则执行步骤104;
步骤104:接收到注册消息的车辆节点查看该注册消息的目的坐标与自己坐标的距离,判断该距离是否小于该注册消息目的坐标与源坐标之间的距离,如果是,则执行步骤106,否则执行步骤105;
步骤105:接收到注册消息的车辆节点丢弃该注册消息,执行步骤107;
步骤106:接收到注册消息的车辆节点将该注册消息的源坐标更新为自己的坐标,转发该注册消息,执行步骤103;
步骤107:基站BS1接收到注册消息后查看索引表,如果存在一个索引表项,该索引表项的硬件ID等于该注册消息的硬件ID,则执行步骤108,否则执行步骤109;
步骤108:基站BS1丢弃接收到的注册消息,执行步骤110;
步骤109:接收到注册消息的基站BS1创建一个索引表项,该索引表项的硬件ID、数据ID和分片ID集合分别等于该注册消息的硬件ID、数据ID和分片ID集合;
步骤110:结束;
车辆节点V1进入一个新子网后,向该新子网的基站执行步骤101-步骤110的注册过程。
车辆节点通过上述过程向所在子网的基站进行注册操作,基站能获取所在子网的车辆节点所能提供的数据分片,从而向车辆节点提供这些数据,从而提高数据通信成功率以及数据通信效率。
本发明所述方法中,基站保存一个车辆表,车辆表的一个车辆表项包含坐标域、硬件ID和生命周期,生命周期一般设置为10s-30s;
更新消息包含消息类型、硬件ID、源坐标、目的坐标和负载;
如果车辆节点V1所在子网的基站为BS1,车辆节点V1执行注册操作后,执行下述操作建立车辆表:
步骤201:开始;
步骤202:车辆节点V1发送更新消息,该更新消息的消息类型为2,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,负载为车辆节点V1的坐标;
步骤203:基站BS1如果接收到更新消息,则执行步骤207,否则执行步骤204;
步骤204:接收到更新消息的车辆节点查看该更新消息目的坐标与自己坐标的距离,判断该距离是否小于该更新消息目的坐标与源坐标之间的距离,如果是,则执行步骤206,否则执行步骤205;
步骤205:接收到更新消息的车辆节点丢弃该更新消息,执行步骤207;
步骤206:接收到更新消息的车辆节点将该更新消息的源坐标更新为自己的坐标,转发该更新消息,执行步骤203;
步骤207:基站BS1接收到更新消息后查看车辆表,如果存在一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,则执行步骤208,否则执行步骤209;
步骤208:接收到更新消息的基站BS1选择一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,将该车辆表项的坐标更新为该更新消息负载中的坐标,将生命周期设置为最大值,执行步骤220;
步骤209:接收到更新消息的基站BS1创建一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,坐标域等于该更新消息负载中的坐标,将生命周期设置为最大值;
步骤220:结束;
车辆表项的生命周期随着机器时钟自动衰减,如果基站BS1检测到一个车辆表项的生命周期衰减为0,则选择一个索引表项,该索引表项的硬件ID等于该车辆表项的硬件ID,并删除该车辆表项和索引表项。所有的生命周期都随着机器时钟自动衰减,比如生命周期设置为10s,然后机器时钟过了3s后,生命周期变为7s了。
车辆节点通过上述过程向所在子网的基站进行更新操作,基站能获取该车辆节点的实时坐标,建立到达目的车辆节点的路由路径,从而提高数据通信成功率以及数据通信效率。
本发明所述方法中,在车辆节点V1的硬件ID为HID1,所在子网的基站为基站BS1,从基站BS1到车辆节点V1的路由路径由硬件ID集合表示,该硬件ID集合由该路由路径所包含的车辆节点的硬件ID构成的条件下,基站BS1执行下述操作获取该硬件ID集合:
步骤301:开始;
步骤302:基站BS1设置一个硬件ID集合参数hs1,参数hs1的初始值为空集;基站BS1选择一个车辆表项E1,车辆表项E1的硬件ID等于HID1;如果基站BS1的坐标与车辆表项E1的坐标之间的距离不大于传输半径R,传输半径R为100m-300m,则执行步骤306,否则执行步骤303;
步骤303:基站BS1选择一个车辆表项E2,车辆表项E2的坐标域值与基站BS1的坐标域值之间的距离小于传输半径R,且车辆表项E2的坐标域值与车辆表项E1的坐标域值之间的距离最小,基站BS1将车辆表项E2的硬件ID加入到参数hs1并作为最后一个元素;
步骤304:基站BS1选择车辆表项E3,车辆表项E3的硬件ID等于参数hs1的最后一个元素,如果车辆表项E3的坐标与车辆表项E1的坐标之间的距离不大于传输半径R,则执行步骤306,否则执行步骤305;
步骤305:基站BS1选择一个车辆表项E4,车辆表项E4的坐标与车辆表项E3的坐标之间的距离小于传输半径R,且车辆表项E4的坐标与车辆表项E1的坐标之间的距离最小,基站BS1将车辆表项E4的硬件ID加入到参数hs1中并作为最后一个元素,执行步骤304;
步骤306:基站BS1将硬件ID HID1加入到参数hs1中并作为最后一个元素;
步骤307:结束。
基站通过上述过程建立到达所在子网任何一个车辆节点的路由路径,上述过程通过车辆表项中的车辆节点坐标来建立路由路径,由于车辆表项中保存的车辆节点坐标实时更新,从而确保了路由路径的有效性,提高了数据通信的成功率和性能。
本发明所述方法中,请求消息由消息类型、硬件ID、源坐标、目的坐标和数据ID构成;
分片请求消息由消息类型、硬件ID、硬件ID集合、数据ID和负载构成;
分片响应消息由消息类型、硬件ID、硬件ID集合、数据ID和负载构成;
响应消息由消息类型、硬件ID集合、数据ID和负载构成;
在车辆节点V2所在子网的基站为BS1,数据DA1由数据ID DID1定义,由N1个数据分片构成的条件下,车辆节点V2通过下述过程获取数据DA1:
步骤401:开始;
步骤402:车辆节点V1发送一个请求消息,该请求消息的消息类型为4,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,数据ID为DID1;
步骤403:基站BS1如果接收到请求消息,则执行步骤407,否则执行步骤404;
步骤404:接收到请求消息的车辆节点查看该请求消息的目的坐标与自己的坐标之间的距离,判断该距离是否小于该请求消息的目的坐标与源坐标之间的距离,如果是,则执行步骤406,否则执行步骤405;
步骤405:接收到请求消息的车辆节点丢弃该请求消息,执行步骤407;
步骤406:接收到请求消息的车辆节点将该请求消息的源坐标更新为自己的坐标,发送该请求消息,执行步骤403;
步骤407:基站BS1接收到请求消息后,选择符合条件2的所有索引表项,针对每个选中的索引表项,基站BS1执行步骤301-307获取基站BS1到达硬件ID等于该索引表项的硬件ID的车辆节点的路由路径的参数hs1,基站BS1发送一个分片请求消息,该分片请求消息的消息类型为5,硬件ID等于该请求消息的硬件ID,硬件ID集合等于参数hs1,数据ID等于该请求消息的数据ID,负载为参数hs1;
条件2:这些索引表项的数据ID等于该请求消息的数据ID且这些索引表项的分片ID集合的并集等于 x为分片ID;
步骤408:车辆节点接收到分片请求消息,如果该车辆节点的硬件ID等于该分片请求消息的硬件ID集合中的第一个元素,则执行步骤410,否则执行步骤409;
步骤409:接收到分片请求消息的车辆节点丢弃该分片请求消息,执行步骤412;
步骤410:接收到分片请求消息的车辆节点从该分片请求消息的硬件ID集合中删除第一个元素;如果该分片请求消息的硬件ID集合为空,则执行步骤412,否则执行步骤411;
步骤411:接收到分片请求消息的车辆节点转发该分片请求消息,执行步骤408;
步骤412:接收到分片请求消息的车辆节点构建一个分片响应消息,该分片响应消息的消息类型为6,硬件ID等于该分片请求消息中的硬件ID,硬件ID集合等于该分片请求消息中负载中的参数hs1,数据ID等于该分片请求消息中的数据ID,负载等于该车辆节点所能提供的所有该分片请求消息数据ID所标识的数据的数据分片,其中一个数据分片由二元组<分片ID,数据分片值>表示,二元组的第一个元素为分片ID,第二个元素为该分片请求消息的数据ID以及该分片ID所标识的数据分片值,其中,数据ID标识一种数据,分片ID标识该数据中的一个数据分片;该车辆节点从该分片响应消息的硬件ID集合中删除最后一个元素,将基站BS1的硬件ID计入到该分片响应消息的硬件ID集合中并作为第一个元素,发送该分片响应消息;
步骤413:基站BS1如果接收到分片响应消息,则执行步骤417,否则执行步骤414;
步骤414:接收到分片响应消息的车辆节点查看自己的硬件ID是否等于该分片响应消息的硬件ID集合中的最后一个元素,如果是,则执行步骤416,否则执行步骤415;
步骤415:接收到分片响应消息的车辆节点丢弃该分片响应消息,执行步骤417;
步骤416:接收到分片响应消息的车辆节点从该分片响应消息的硬件ID集合中删除最后一个元素,发送该分片响应消息,执行步骤413;
步骤417:基站BS1接收到所有的分片响应消息后,根据这些分片响应消息中的负载构建由该分片响应消息中的数据ID所标识的数据;基站BS1执行步骤301-307获取基站BS1到达硬件ID等于该分片响应消息中的硬件ID的车辆节点的路由路径的参数hs1,发送一个响应消息,该响应消息的消息类型为7,硬件ID集合为hs1,数据ID等于该分片响应消息中的数据ID,负载为构建的数据;
步骤418:车辆节点接收到响应消息;如果该车辆节点的硬件ID等于该响应消息的硬件ID集合中的第一个元素,则执行步骤420,否则执行步骤419;
步骤419:接收到响应消息的车辆节点丢弃该响应消息,执行步骤422;
步骤420:接收到响应消息的车辆节点从该响应消息的硬件ID集合中删除第一个元素,如果该响应消息的硬件ID集合为空,则执行步骤422,否则执行步骤421;
步骤421:接收到响应消息的车辆节点转发该响应消息,执行步骤418;
步骤422:接收到响应消息的车辆节点V2接收到该响应消息,保存该响应消息负载中的数据;
步骤423:结束。
车辆节点通过上述过程获取所需数据,基站通过索引表获取能提供数据分片的车辆节点信息,通过车辆表的实时坐标建立到达目的节点的路由路径,从而能够快速实现数据通信,并提高数据通信的成功率,降低数据通信延迟。
有益效果:本发明提供了一种基于软件定义的车载网实现方法,车辆节点通过本发明所提供的车载网实现方法能够从距离最近的车辆节点以单播方式获取服务数据,缩短了获取服务数据的延迟和代价,提高了服务质量,本发明可应用于道路路况监测、车辆管理等领域,具有广泛的应用前景。
附图说明
下面结合附图和具体实施方式对本发明做更进一步的具体说明,本发明的上述和/或其他方面的优点将会变得更加清楚。
图1为本发明所述的注册流程示意图。
图2为本发明所述的建立车辆表流程示意图。
图3为本发明所述的获取硬件ID集合流程示意图。
图4为本发明所述的获取数据流程示意图。
具体实施方式:
本发明提供了一种基于软件定义的车载网实现方法,车辆节点通过本发明所提供的车载网实现方法能够从距离最近的车辆节点以单播方式获取服务数据,缩短了获取服务数据的延迟和代价,提高了服务质量,本发明可应用于道路路况监测、车辆管理等领域,具有广泛的应用前景。
图1为本发明所述的注册流程示意图。所述车载网络包括基站和车辆节点;每个基站具有唯一的坐标,每个基站和车辆节点各自分别具有一个唯一的硬件ID,例如MAC地址;一个基站和所有符合条件1的车辆节点构成子网;
条件1:在所有基站中,该车辆节点与该基站距离最近;
车载网传输的数据由数据ID唯一标识,每个数据包含两个以上的数据分片,每个数据分片由分片ID唯一标识,分片ID对应为每个分片的顺序编号;
车载网传输的消息由消息类型定义,消息名称和消息类型的对应关系如下表所示:
一个基站保存一个索引表,索引表的一个索引表项包含硬件ID、数据ID和分片ID集合;
注册消息由消息类型、硬件ID、源坐标、目的坐标、数据ID和分片ID集合构成;
在数据DA1由数据ID DID1定义,数据DA1包含N1个数据分片,车辆节点V1能提供数据DA1中的数据分片,所述数据分片的分片ID构成分片ID集合S1的条件下,车辆节点V1启动后,通过电子地图获取所有基站的坐标,选择距离车辆节点V1自己最近的基站BS1,并执行下述注册操作:电子地图包含所有基站的坐标,为预先设置,车辆节点自动加载该电子地图获取所有基站的坐标;
步骤101:开始;
步骤102:车辆节点V1发送注册消息,该注册消息的消息类型为1,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,数据ID为DID1,分片ID集合为S1;
步骤103:基站BS1如果接收到到注册消息,则执行步骤107,否则执行步骤104;
步骤104:接收到注册消息的车辆节点查看该注册消息的目的坐标与自己坐标的距离,判断该距离是否小于该注册消息目的坐标与源坐标之间的距离,如果是,则执行步骤106,否则执行步骤105;
步骤105:接收到注册消息的车辆节点丢弃该注册消息,执行步骤107;
步骤106:接收到注册消息的车辆节点将该注册消息的源坐标更新为自己的坐标,转发该注册消息,执行步骤103;
步骤107:基站BS1接收到注册消息后查看索引表,如果存在一个索引表项,该索引表项的硬件ID等于该注册消息的硬件ID,则执行步骤108,否则执行步骤109;
步骤108:基站BS1丢弃接收到的注册消息,执行步骤110;
步骤109:接收到注册消息的基站BS1创建一个索引表项,该索引表项的硬件ID、数据ID和分片ID集合分别等于该注册消息的硬件ID、数据ID和分片ID集合;
步骤110:结束;
车辆节点V1进入一个新子网后,向该新子网的基站执行步骤101-步骤110的注册过程。
车辆节点通过上述过程向所在子网的基站进行注册操作,基站能获取所在子网的车辆节点所能提供的数据分片,从而向车辆节点提供这些数据,从而提高数据通信成功率以及数据通信效率。
图2为本发明所述的建立车辆表流程示意图。基站保存一个车辆表,车辆表的一个车辆表项包含坐标域、硬件ID和生命周期,一般设置为10s-30s;;
更新消息包含消息类型、硬件ID、源坐标、目的坐标和负载;
如果车辆节点V1所在子网的基站为BS1,车辆节点V1执行注册操作后,执行下述操作建立车辆表:
步骤201:开始;
步骤202:车辆节点V1发送更新消息,该更新消息的消息类型为2,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,负载为车辆节点V1的坐标;
步骤203:基站BS1如果接收到更新消息,则执行步骤207,否则执行步骤204;
步骤204:接收到更新消息的车辆节点查看该更新消息目的坐标与自己坐标的距离,判断该距离是否小于该更新消息目的坐标与源坐标之间的距离,如果是,则执行步骤206,否则执行步骤205;
步骤205:接收到更新消息的车辆节点丢弃该更新消息,执行步骤207;
步骤206:接收到更新消息的车辆节点将该更新消息的源坐标更新为自己的坐标,转发该更新消息,执行步骤203;
步骤207:基站BS1接收到更新消息后查看车辆表,如果存在一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,则执行步骤208,否则执行步骤209;
步骤208:接收到更新消息的基站BS1选择一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,将该车辆表项的坐标更新为该更新消息负载中的坐标,将生命周期设置为最大值,执行步骤220;
步骤209:接收到更新消息的基站BS1创建一个车辆表项,该车辆表项的硬件ID等于该更新消息的硬件ID,坐标域等于该更新消息负载中的坐标,将生命周期设置为最大值;
步骤220:结束;
如果基站BS1检测到一个车辆表项的生命周期衰减为0,则选择一个索引表项,该索引表项的硬件ID等于该车辆表项的硬件ID,并删除该车辆表项和索引表项。
车辆节点通过上述过程向所在子网的基站进行更新操作,基站能获取该车辆节点的实时坐标,建立到达目的车辆节点的路由路径。,从而提高数据通信成功率以及数据通信效率。
图3为本发明所述的获取硬件ID集合流程示意图。在车辆节点V1的硬件ID为HID1,所在子网的基站为基站BS1,从基站BS1到车辆节点V1的路由路径由硬件ID集合表示,该硬件ID集合由该路由路径所包含的车辆节点的硬件ID构成的条件下,基站BS1执行下述操作获取该硬件ID集合:
步骤301:开始;
步骤302:基站BS1设置一个硬件ID集合参数hs1,参数hs1的初始值为空集;基站BS1选择一个车辆表项E1,车辆表项E1的硬件ID等于HID1;如果基站BS1的坐标与车辆表项E1的坐标之间的距离不大于传输半径R,传输半径R为100m-300m,则执行步骤306,否则执行步骤303;
步骤303:基站BS1选择一个车辆表项E2,车辆表项E2的坐标域值与基站BS1的坐标域值之间的距离小于传输半径R,且车辆表项E2的坐标域值与车辆表项E1的坐标域值之间的距离最小,基站BS1将车辆表项E2的硬件ID加入到参数hs1并作为最后一个元素;
步骤304:基站BS1选择车辆表项E3,车辆表项E3的硬件ID等于参数hs1的最后一个元素,如果车辆表项E3的坐标与车辆表项E1的坐标之间的距离不大于传输半径R,则执行步骤306,否则执行步骤305;
步骤305:基站BS1选择一个车辆表项E4,车辆表项E4的坐标与车辆表项E3的坐标之间的距离小于传输半径R,且车辆表项E4的坐标与车辆表项E1的坐标之间的距离最小,基站BS1将车辆表项E4的硬件ID加入到参数hs1中并作为最后一个元素,执行步骤304;
步骤306:基站BS1将硬件ID HID1加入到参数hs1中并作为最后一个元素;
步骤307:结束。
基站通过上述过程建立到达所在子网任何一个车辆节点的路由路径,上述过程通过车辆表项中的车辆节点坐标来建立路由路径,由于车辆表项中保存的车辆节点坐标实时更新,从而确保了路由路径的有效性,提供了数据通信的成功率和性能。
图4为本发明所述的获取数据流程示意图。请求消息由消息类型、硬件ID、源坐标、目的坐标和数据ID构成;
分片请求消息由消息类型、硬件ID、硬件ID集合、数据ID和负载构成;
分片响应消息由消息类型、硬件ID、硬件ID集合、数据ID和负载构成;
响应消息由消息类型、硬件ID集合、数据ID和负载构成;
在车辆节点V2所在子网的基站为BS1,数据DA1由数据ID DID1定义,由N1个数据分片构成的条件下,车辆节点V2通过下述过程获取数据DA1:
步骤401:开始;
步骤402:车辆节点V1发送一个请求消息,该请求消息的消息类型为4,硬件ID为车辆节点V1的硬件ID,源坐标为车辆节点V1的坐标,目的坐标为基站BS1的坐标,数据ID为DID1;
步骤403:基站BS1如果接收到请求消息,则执行步骤407,否则执行步骤404;
步骤404:接收到请求消息的车辆节点查看该请求消息的目的坐标与自己的坐标之间的距离,判断该距离是否小于该请求消息的目的坐标与源坐标之间的距离,如果是,则执行步骤406,否则执行步骤405;
步骤405:接收到请求消息的车辆节点丢弃该请求消息,执行步骤407;
步骤406:接收到请求消息的车辆节点将该请求消息的源坐标更新为自己的坐标,发送该请求消息,执行步骤403;
步骤407:基站BS1接收到请求消息后,选择符合条件2的所有索引表项,针对每个选中的索引表项,基站BS1执行步骤301-307获取基站BS1到达硬件ID等于该索引表项的硬件ID的车辆节点的路由路径的参数hs1,基站BS1发送一个分片请求消息,该分片请求消息的消息类型为5,硬件ID等于该请求消息的硬件ID,硬件ID集合等于参数hs1,数据ID等于该请求消息的数据ID,负载为参数hs1;
条件2:这些索引表项的数据ID等于该请求消息的数据ID且这些索引表项的分片ID集合的并集等于 x为分片ID;
步骤408:车辆节点接收到分片请求消息,如果该车辆节点的硬件ID等于该分片请求消息的硬件ID集合中的第一个元素,则执行步骤410,否则执行步骤409;
步骤409:接收到分片请求消息的车辆节点丢弃该分片请求消息,执行步骤412;
步骤410:接收到分片请求消息的车辆节点从该分片请求消息的硬件ID集合中删除第一个元素;如果该分片请求消息的硬件ID集合为空,则执行步骤412,否则执行步骤411;
步骤411:接收到分片请求消息的车辆节点转发该分片请求消息,执行步骤408;
步骤412:接收到分片请求消息的车辆节点构建一个分片响应消息,该分片响应消息的消息类型为6,硬件ID等于该分片请求消息中的硬件ID,硬件ID集合等于该分片请求消息中负载中的参数hs1,数据ID等于该分片请求消息中的数据ID,负载等于该车辆节点所能提供的所有该分片请求消息数据ID所标识的数据的数据分片,其中一个数据分片由二元组<分片ID,数据分片值>表示,二元组的第一个元素为分片ID,第二个元素为该分片请求消息的数据ID以及该分片ID所标识的数据分片值,其中,数据ID标识一种数据,分片ID标识该数据中的一个数据分片;该车辆节点从该分片响应消息的硬件ID集合中删除最后一个元素,将基站BS1的硬件ID计入到该分片响应消息的硬件ID集合中并作为第一个元素,发送该分片响应消息;
步骤413:基站BS1如果接收到分片响应消息,则执行步骤417,否则执行步骤414;
步骤414:接收到分片响应消息的车辆节点查看自己的硬件ID是否等于该分片响应消息的硬件ID集合中的最后一个元素,如果是,则执行步骤416,否则执行步骤415;
步骤415:接收到分片响应消息的车辆节点丢弃该分片响应消息,执行步骤417;
步骤416:接收到分片响应消息的车辆节点从该分片响应消息的硬件ID集合中删除最后一个元素,发送该分片响应消息,执行步骤413;
步骤417:基站BS1接收到所有的分片响应消息后,根据这些分片响应消息中的负载构建由该分片响应消息中的数据ID所标识的数据;基站BS1执行步骤301-307获取基站BS1到达硬件ID等于该分片响应消息中的硬件ID的车辆节点的路由路径的参数hs1,发送一个响应消息,该响应消息的消息类型为7,硬件ID集合为hs1,数据ID等于该分片响应消息中的数据ID,负载为构建的数据;
步骤418:车辆节点接收到响应消息;如果该车辆节点的硬件ID等于该响应消息的硬件ID集合中的第一个元素,则执行步骤420,否则执行步骤419;
步骤419:接收到响应消息的车辆节点丢弃该响应消息,执行步骤422;
步骤420:接收到响应消息的车辆节点从该响应消息的硬件ID集合中删除第一个元素,如果该响应消息的硬件ID集合为空,则执行步骤422,否则执行步骤421;
步骤421:接收到响应消息的车辆节点转发该响应消息,执行步骤418;
步骤422:接收到响应消息的车辆节点V2接收到该响应消息,保存该响应消息负载中的数据;
步骤423:结束。
车辆节点通过上述过程获取所需数据,基站通过索引表获取能提供数据分片的车辆节点信息,通过车辆表的实时坐标建立到达目的节点的路由路径,从而能够快速实现数据通信,并提高数据通信的成功率,降低数据通信延迟。
实施例1
基于表1的仿真参数,本实施例模拟了本发明中的一种基于软件定义的车载网实现方法,性能分析如下:当能够提供数据分片的车辆节点数量增加时,获取数据的延迟随之降低;当能够提供数据分片的车辆节点数量减少时,获取数据的延迟随之增加。车辆节点获取数据的平均延迟为32.3ms。
表1仿真参数
本发明提供了一种基于软件定义的车载网实现方法的思路,具体实现该技术方案的方法和途径很多,以上所述仅是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视为本发明的保护范围。本实施例中未明确的各组成部份均可用现有技术加以实现。
一种基于软件定义的车载网实现方法专利购买费用说明
Q:办理专利转让的流程及所需资料
A:专利权人变更需要办理著录项目变更手续,有代理机构的,变更手续应当由代理机构办理。
1:专利变更应当使用专利局统一制作的“著录项目变更申报书”提出。
2:按规定缴纳著录项目变更手续费。
3:同时提交相关证明文件原件。
4:专利权转移的,变更后的专利权人委托新专利代理机构的,应当提交变更后的全体专利申请人签字或者盖章的委托书。
Q:专利著录项目变更费用如何缴交
A:(1)直接到国家知识产权局受理大厅收费窗口缴纳,(2)通过代办处缴纳,(3)通过邮局或者银行汇款,更多缴纳方式
Q:专利转让变更,多久能出结果
A:著录项目变更请求书递交后,一般1-2个月左右就会收到通知,国家知识产权局会下达《转让手续合格通知书》。
动态评分
0.0