一文读懂opendrive的xodr文件内容

xml opendrive xodr

OpenDRIVE格式使用文件拓展名为xodr的可扩展标记语言(XML)作为描述路网的基础。存储在OpenDRIVE文件中的数据描述了道路的几何形状以及可影响路网逻辑的相关特征(features),例如车道和标志。OpenDRIVE中描述的路网可以是人工生成或来自于真实世界的。OpenDRIVE的主要目的是提供可用于仿真的路网描述,并使这些路网描述之间可以进行交换。

该格式将通过节点(nodes)而被构建,用户可通过自定义的数据扩展节点。这使得各类应用(通常为仿真)具有高度的针对性,同时还保证不同应用之间在交换数据时所需的互通性。

0) 说明是opendrive

<?xml version="1.0"?>
<OpenDRIVE>
...
</OpenDRIVE>

1) header 描述文件整体属性 (仅一个)

<header>元素是 <OpenDRIVE>中的第一个元素。
属性:
注意:instances 意思是实例数,而该实例数要求是1
说明:
(1)revMajor.revMinor就是最终的版本号,比如1.6

(2)north,south,east,west指的是惯性坐标系下的东南西北方向的位置坐标值,也就是惯性坐标系下对应的x,y最大最小值等。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

示例:

<header date="XXXX日期" west="-10" revMinor="2" name="XXX名称" revMajor="1" east="10" north="10" version="1" south="-10"/>

2) road 描述道路属性 (可多个)

在这里插入图片描述
完整道路的表示方式:
①道路参考线 —— <planView>
②一条道路上的单独车道 ——

<lanes> 
	<laneSection> 
		<center/left/right> 
			 <lane> 
		 	 	<width/...> 

③沿道路放置的道路特征(如标志)
在这里插入图片描述
属性:
解释:
1.length就是所有路径geometry长度的累加
2.junction:交叉口的ID,道路作为联接道路属于该交叉口(无(none)使用= -1)
3.使用道路的基本规则; RHT =靠右行车,LHT =靠左行车。当缺少此属性时,将假定为RHT。
在这里插入图片描述
在这里插入图片描述
示例:

<road length="53" id="0" name="XXX名称" junction="-1">

以及

<road id="3" name="prototype" length="5" junction="0">

2.0)link

t_road_link

在OpenDRIVE中,道路连接用 <road> 元素里的 <link> 元素来表示。 <predecessor> 以及 <successor> 元素在 <link> 元素中被定义。对于虚拟和常规的交叉口来说, <predecessor> 以及 <successor> 元素必须使用(shall)不同的属性组。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EVvbaNeA-1608126737951)()]

2.0.1) Successor

前驱

t_road_link_predecessorSuccessor

必须(shall)将不同属性用于虚拟以及常规的交叉口。@contactPoint须(shall)用于常规交叉口;@elementS 和 @elementDir则须(shall)用于虚拟交叉口。

要求:
只有在连接(linkage)清晰的情况下,才能(shall)直接连接两条道路。如果与前驱或后继的关系模糊,则必须(shall)使用交叉口。

示例:

  <link>
     <predecessor elementId="0" elementType="junction"/>
  </link>

以及

<link>
     <predecessor elementId="0" contactPoint="end" elementType="road"/>
     <successor elementId="1" contactPoint="start" elementType="road"/>
</link>
2.0.2) predecessor

后继

t_road_link_predecessorSuccessor

必须(shall)将不同属性用于虚拟以及常规的交叉口。@contactPoint须(shall)用于常规交叉口;@elementS 和 @elementDir则须(shall)用于虚拟交叉口。

2.1)planView

<planView> 元素是每个 <road> 元素里必须要用到的元素。

2.1.1) planView -> geometry

在OpenDRIVE中,参考线的几何形状用<planView>元素里的 <geometry> 元素来表示。

通用属性(对于不同类型的参考线形式,比如螺旋线、样条曲线等,可能有新增的附属属性,通用属性写在<geometry>标签里,而新增的附属属性在<geometry>标签下再写一层):
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7deSCCgK-1608126737952)()]

以下规则适用于道路参考线:

  1. 每条道路必须(shall)有一条参考线。
  2. 每条道路只能(shall)有一条参考线。
  3. 参考线通常在道路中心,但也可能(may)有侧向偏移。
  4. 几何元素应(shall)沿参考线以升序(即递增的s位置)排列。
  5. 一个 元素应(shall)只包含一个另外说明道路几何形状的元素。
  6. 若两条道路不使用交叉口来连接,那么新的道路的参考线应(shall)总是起始于其前驱或后继道路的 。参考线有可能(may)被指向相反方向。
  7. 参考线不能(shall)有断口(leaps)。
  8. 参考线不应(should)有扭结(kinks)。

分类:
1. 直线
2. 螺旋线
3. 弧线

  1. 直线
  2. 螺旋线或回旋曲线(曲率以线性方式改变)
  3. 有恒定曲率的弧线
  4. 三次多项式曲线
  5. 参数三次多项式曲线
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vs7L95sZ-1608126737952)()]

1.直线

在OpenDRIVE中,直线用<geometry> 元素里的 <line> 元素来表示。

示例:

<planView>
<geometry
    s="0.0000000000000000e+00"
    x="-4"
    y="7"
    hdg="6"
    length="5">
    <line/>
</geometry>
</planView>

2.螺旋线Spiral

t_road_planView_geometry_spiral里描述了层次关系,先是road,然后planViewroad的下一层,同理,geometryspiral

螺旋线是以起始位置的曲率(@curvStart)和结束位置的曲率(@curvEnd)为特征。沿着螺旋线的弧形长度(见 <geometry> 元素@length),曲率从头至尾呈线性。

在OpenDRIVE中,螺旋线用<geometry> 元素里的<spiral>元素来表示。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-65iItsbR-1608126737953)()]

示例:

注意:曲率:
正曲率:左曲线(逆时针运动)
负曲率:右曲线(顺时针运动)

<geometry s="100.0" x="38.00" y="-1.81" hdg="0.33" length="30.00">
<spiral curvStart="0.0" curvEnd="0.013"/>
</geometry>

3.弧线

弧线描述了有着恒定曲率的道路参考线。

在OpenDRIVE中,弧线用<geometry> 元素里的<arc>元素来表示。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GLFs4Mxz-1608126737953)()]

示例:

注意:曲率:
正曲率:左曲线(逆时针运动)
负曲率:右曲线(顺时针运动)

<planView>
<geometry
    s="3"
    x="-4"
    y="4"
    hdg="5"
    length="9">
    <arc curvature="-1.2e-01"/>
</geometry>
</planView>

4.组合曲线,连接处

通过对OpenDRIVE中所有可用的几何形状元素进行组合,便可以创建诸多种类的道路线。

示意图:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-x7uNtsdH-1608126737954)()]

示例:

写上连接的路的属性:

这个示例是用圆弧和直线相连,注意后者的起始弧长s处就是前者的起始弧长s加上其长度。

<planView>
    <geometry x="278" y="-828" hdg="0.50" s="0" length="34">
        <arc curvature="0.06"/>
    </geometry>
    <geometry x="2" y="-51" hdg="2.9" s="39.2" length="4.2">
        <line/>
    </geometry>
</planView>

5.三次多项式(弃用)

t_road_planView_geometry_poly3

三次多项式可(may)用来生成衍生于测量数据的复杂道路走向。测量对为x/y坐标系中沿参考线的被测量坐标的指定次序定义了线段的多项式极限。

局部三次多项式描述了道路的参考线。通过对线段极限处的连续性条件例如线段连续性、切线和/或曲率连续性等进行详细说明,可以对多个三次多项式线段进行融合并且为整个道路走向生成一条全局三次样条线插值曲线。另一个优点则是,沿着多项式的路径方式比沿回旋曲线更有效。

局部三次多项式表达式:

v(u) = a + b*u + c*u2 + d*u³

不能用全局三次多项式,原因:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-csJSo3EA-1608126737954)()];

而全局坐标系和局部坐标系之间的转换:
在这里插入图片描述
在这里插入图片描述

在OpenDRIVE中,三次多项式用 <geometry> 元素里的 <poly3> 元素来表示。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gH54co3F-1608126737955)()]

要求:
<geometry>元素的起始点(@x,@y)定位在局部u/v坐标系的v轴上。

示例:

<geometry
s="0.0000000000000000e+00"
x="-6.8858131487889267e+01"
y="4.1522491349480972e-01"
hdg="6.5004409066736524e-01"
length="2.5615689718113455e+01">
<poly3
    a="0.0000000000000000e+00"
    b="0.0000000000000000e+00"
    c="1.4658732624442020e-02"
    d="-5.7746497381565959e-04"/>
</geometry>

6.参数三次曲线

t_road_planView_geometry_paramPoly3

只需使用x轴和y轴便可以用参数三次曲线生成道路线。为保持三次多项式的连贯性,可(may)利用u轴和v轴同时将它们计算到三次多项式里。

参数三次曲线表达式:

u(p) = aU + bU*p + cU*p2 + dU*p³
v(p) = aV + bV*p + cV*p2 + dV*p³

示意图:

u(p) = aU + bU*p + cU*p2 + dU*p³:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-K6p56DP1-1608126737956)()]

v(p) = aV + bV*p + cV*p2 + dV*p³:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5mHFw6Ea-1608126737956)()]

u(p) = aU + bU*p + cU*p2 + dU*p³
v(p) = aV + bV*p + cV*p2 + dV*p³

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jnwtOE7P-1608126737957)()]

在OpenDRIVE中,参数三次曲线用 <geometry> 元素里的 <paramPoly3> 元素来表示。

要求:
若@pRange=“arcLength”,那么p可(may)在[0, @length from ]范围内对其赋值。

若@pRange=“normalized”,那么p可(may)在[0, 1]范围内对其赋值。

属性:
在这里插入图片描述

在这里插入图片描述
示例:

<planView>
<geometry
    s="0"
    x="6.8"
    y="5.4"
    hdg="5.2"
    length="6.56">
    <paramPoly3
    aU="0"
    bU="1.0"
    cU="-4.66e-09"
    dU="-2.62e-08"
    aV="0.00e+00"
    bV="1.66e-16"
    cV="-1.98e-04"
    dV="-1.31e-09"
    pRange="arcLength">
    </paramPoly3>
</geometry>
</planView>

2.2) elevationProfile

2.2.1) elevationProfile -> elevation

t_road_elevationProfile_elevation

纵向。

在OpenDRIVE中,高程Road elevation 用 <elevationProfile> 元素中的 <elevation> 元素来表示。

该属性定义了参考线上给定点处的高程元素。此外,必须(shall)沿参考线按升序对元素进行定义。s的长度不随高程而改变。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HqC7MZTk-1608126737958)()]

表达式:

elev(ds) = a + b*ds + c*ds² + d*ds³

示例:

  <elevationProfile>
     <elevation b="1.2" s="0" c="0.175" d="-0.0175" a="0"/>
     <elevation b="-0.5499999999999989" s="10" c="-0.5800000000000002" d="0.04050000000000001" a="12"/>
     <elevation b="0" s="20" c="0" d="0" a="-11"/>
  </elevationProfile>

2.3) lateralProfile

2.3.1) lateralProfile -> superelevation

t_road_lateralProfile_superelevation

在OpenDRIVE中,超高程用<lateralProfile>元素中的 <superelevation> 元素来表示。

横向。

超高程从数学角度被定义为围绕参考线的道路横截面的倾斜角。这意味着超高程对于向右边倾斜的道路具有正值,对于向左边倾斜的道路具有负值。

该属性被定义为围绕着s轴的路段倾斜角。必须(must)沿参考线按升序定义元素。元素的参数将持续有效,直到下一个元素开始或道路参考线结束。道路的超高程程默认为零。

给定位置的超高程表达式:

sElev (ds) = a + b*ds + c*ds2 + d*ds3

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LVSIK8y2-1608126737959)(images/超高程属性.png)]

示例:

      <lateralProfile>
     <superelevation b="0" s="0" c="0" d="0" a="0"/>
     <crossfall b="0" s="0" side="both" c="0" d="0" a="0"/>
  </lateralProfile>
2.3.2) lateralProfile -> shape

t_road_lateralProfile_shape

该属性被定义为相对于参考水平面路段的路面。一个拥有不同t值的s位置上可(may)存在多个形状,从而对道路的弯曲形状进行描述。

给定位置参考平面上方的高度表达式:

hShape (ds)= a + b*dt + c*dt2 + d*dt3

2.4) lanes

2.5) type

t_road_type

Road type 道路类型

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Wq3NTYeY-1608126737960)()]

示例:

  <type s="0" type="motorway"/>
2.5.1)type -> speed

t_road_type_speed

在OpenDRIVE中,速度限制用 <type> 元素里的 <speed> 元素来表示。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wCSWnhs4-1608126737961)()]

示例:

<speed max="-1" sOffset="0" unit="m/s"/>

2.6) surface

t_road_surface_CRG

2.7) Lanes

在OpenDRIVE中,所有道路都包含了车道。每条道路必须(shall)拥有至少一条宽度大于0的车道,并且每条道路的车道数量不受限制。

需要使用中心车道对OpenDRIVE中的车道进行定义和描述。中心车道没有宽度,并被用作车道编号的参考,自身的车道编号为0。对其他车道的编号以中心车道为出发点:车道编号向右呈降序,也就是朝负t方向;向左呈升序,也就是朝正t方向。

在OpenDRIVE中,车道用 <road> 元素里的 <lanes> 元素来表示。

示例:

<lanes>
    <laneSection s="0.0">
        <left>
            <lane id="2" type="border" level="false">
                <link>
                </link>
                <width sOffset="0.0" a="1.0" b="0.0" c="0.0" d="0.0"/>
            </lane>
            <lane id="1" type="driving" level="false">
                <link>
                </link>
                <width sOffset="0.0" a="4.0" b="0.0" c="0.0" d="0.0"/>
            </lane>
        </left>
        <center>
            <lane id="0" type="none" level="false">
                <link>
                </link>
            </lane>
        </center>
        <right>
            <lane id="-1" type="driving" level="false">
                <link>
                </link>
                <width sOffset="0.0" a="4.0" b="0.0" c="0.0" d="0.0"/>
            </lane>
            <lane id="-2" type="border" level="false">
                <link>
                </link>
                <width sOffset="0.0" a="1.0" b="0.0" c="0.0" d="0.0"/>
            </lane>
        </right>
    </laneSection>
</lanes>
2.7.1) Lanes -> laneSection

t_road_lanes_laneSection

在OpenDRIVE中,车道组用 <laneSection> 元素内的 <center><right><left> 元素来表示。ID属性用嵌套在 <center><right><left> 元素里的 <lane> 元素来定义。

在OpenDRIVE中 ,车道段用 <lanes> 元素里的 <laneSection> 元素来表示。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OOieIgXk-1608126737961)()]

示例:

<laneSection s="0" singleSide="false">
...
</laneSection>
2.7.1.1 Lanes -> laneSection -> center

t_road_lanes_laneSection_center

2.7.1.1.1 Lanes -> laneSection -> center -> lane

t_road_lanes_laneSection_center_lane

车道元素被包括在左/中/右元素中。车道元素必须(should)使用降序ID从左到右展示车道。

lane属性:
level, type

level: 0 —— 不采用超高程;1 —— 采用超高程。

type: 每条车道都会被定义一个类型。车道类型定义了车道的主要用途及与其相对应的交通规则。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-g6Yf8ewI-1608126737962)()]

包括:
路肩shoulder:描述了道路边缘的软边界。
边界border:描述了道路边缘的硬边界。其与正常可供行驶的车道拥有同样高度。
驾驶driving:描述了一条“正常”可供行驶、不属于其他类型的道路。
停stop:高速公路的硬路肩,用于紧急停车。
无none:描述了道路最远边缘处的空间,并无实际内容。其唯一用途是在(人类)驾驶员离开道路的情况下,让应用记录OpenDRIVE仍在运行。
限制restricted:描述了不应有车辆在上面行驶的车道。该车道与行车道拥有相同高度。通常会使用实线以及虚线来隔开这类车道。
泊车parking:描述了带停车位的车道。
分隔带median:描述了位于不同方向车道间的车道。在城市中通常用来分隔大型道路上不同方向的交通。
自行车道biking:描述了专为骑自行车者保留的车道。
人行道sidewalk:描述了允许行人在上面行走的道路。
路缘curb:描述了路缘石。路缘石与相邻的行车道在高度有所不同。
出口exit:描述了用于平行于主路路段的车道。主要用于减速。
入口entry:描述了用于平行于主路路段的车道。主要用于加速。
加速车道onramp:由乡村或城市道路引向高速公路的匝道。
减速车道offRamp:驶出高速公路,驶向乡村或城市道路所需的匝道。
连接匝道connectingRamp:连接两条高速公路的匝道。例如高速公路路口。

高速公路的车道类型:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JnYZcISw-1608126737962)()]

在OpenDRIVE中,车道类型用<lane>元素内属性@type元素来表示。

示例:

<lane level="0" id="0" type="border">
2.7.1.1.1.1 Lanes -> laneSection -> center -> lane -> link

t_road_lanes_laneSection_lcr_lane_link

在OpenDRIVE中,车道连接用<lane>元素里的<link>元素来表示。<predecessor><successor>元素在<link>元素内得到定义。

2.7.1.1.1.1.1 Lanes -> laneSection -> center -> lane -> link -> predecessor

t_road_lanes_laneSection_lcr_lane_link_predecessorSuccessor

<predecessor><successor>元素在<link>元素内得到定义。

要求:
一条车道可(may)拥有另外一条车道作为其前驱或后继。
只有当两条车道的连接明确时,它们才能(shall)被连接。若与前驱或后继部分的关系比较模糊,则必须(shall)使用交叉口。
若车道结束于一个路口内或没有任何连接,则必须(shall)删除 <link> 元素。

示例:

<lane level="0" id="-1" type="driving">
              <link>
                 <predecessor id="-1"/>
                 <successor id="-1"/>
              </link>
...
</lane>
2.7.1.1.1.2 Lanes -> laneSection -> center -> lane -> width

t_road_lanes_laneSection_lr_lane_width

车道属性描述了车道的用途以及形状。每个车道段都定义了一条车道属性,该属性也可能(may)在该车道段中有变化。如果没有特意为车道段定义一条属性,应用便可(can)采用默认属性。

车道属性的示例是车道宽度、车道边界和限速。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fLab3NEH-1608126737962)()]

车道的宽度是沿t坐标 (s坐标系下的横向偏移) 而定义的。车道的宽度有可能(may)在车道段内产生变化。

车道宽度与车道边界元素在相同的车道组内互相排斥。若宽度以及车道边界元素在OpenDRIVE文件中同时供车道段使用,那么应用必须(must)使用 <width> 元素提供的信息。

在OpenDRIVE中,车道宽度由 元素中的 <width> 元素来描述。

表达式:

Width (ds) = a + b*ds + c*ds² + d*ds³

示例:

<width b="0" sOffset="0" c="0" d="0" a="3.75"/>
2.7.1.1.1.3 Lanes -> laneSection -> center -> lane -> speed

t_road_lanes_laneSection_lr_lane_speed

在OpenDRIVE中,车道速度用<lane>元素内的<speed>元素来表示。

该属性定义了给定车道上允许的最大行驶速度。直到新的元素得到定义,每个元素都在s坐标的增长方向中继续有效。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1lduAPp8-1608126737963)()]

示例:

<speed max="-1" sOffset="0" unit="m/s"/>

以及

<lane id="-1" type="driving" level="false">
    <link>
        <successor id="-3"/>
    </link>
    <width sOffset="0.0" a="2.0" b="0.0" c="0.0" d="0.0"/>
    <speed sOffset="0.0" max="80.0" unit="km/h"/>
    <height sOffset="0.0" inner="0.12" outer="0.12"/>
</lane>
2.7.1.1.1.4 Lanes -> laneSection -> center -> lane -> border

车道边界是用来描述车道宽度的另一种方法,它并不会直接定义宽度,而是在独立于其内部边界参数的情况下,对车道的外部界限进行定义。根据上述情况,内车道也被定义为车道,该车道虽然与当前被定义的车道有着相同ID符号,但内车道的ID绝对值要更小。

相比较对宽度进行详细说明而言,此类定义要更加地便利。尤其是在道路数据是源自于自动测量结果的情况下,该方式可以避免多个车道段被创建。

车道宽度与车道边界元素在相同的车道组内互相排斥。若宽度以及车道边界元素在OpenDRIVE文件中同时供车道段使用,那么应用必须(must)使用 <width> 元素提供的信息。

在OpenDRIVE中,车道边界用 <lane>元素中的 <border> 元素来表示。

表达式:

tborder (ds) = a + b*ds + c*ds² + d*ds³

示例:

           <lane level="0" id="0" type="border">
              <link/>
              <userdata value="0" code="frictionCoeff"/>
              <userdata value="0" code="adhesionCoeff"/>
              <width b="0" sOffset="0" c="0" d="0" a="0"/>
              <border b="0" sOffset="0" c="0" d="0" a="0"/>
           </lane>
2.7.1.1.1.5 Lanes -> laneSection -> center -> lane -> material

t_road_lanes_laneSection_lr_lane_material

在OpenDRIVE中,车道材质用<lane>元素内的<material>元素来表示。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-V3hB4MWY-1608126737963)()]

2.7.1.1.1.6 Lanes -> laneSection -> center -> lane -> access

t_road_lanes_laneSection_lr_lane_access

车道可(can)局限于特定的道路使用者,例如卡车或公共汽车。这类限制可(may)在道路标识描述的限制之上另外在OpenDRIVE中得到定义。

OpenDRIVE在 <lane> 元素内提供了 <access> 元素,以便描述车道使用规则。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YUISQTaV-1608126737964)()]

示例:

<lane id="2" type="driving" level="false">
    <link>
        <successor id="2"/>
    </link>
    <width sOffset="0.0" a="2.0" b="0.0" c="0.0" d="0.0"/>
    <access sOffset="0.0" rule="allow" restriction="bus"/>
</lane>
2.7.1.1.1.7 Lanes -> laneSection -> center -> lane -> height

t_road_lanes_laneSection_lr_lane_height

在这里插入图片描述

在OpenDRIVE中,车道高度用<lane>元素内的<height>元素来表示。

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HL3lNbyY-1608126737965)()]

示例:

<lane id="-2" type="sidewalk" level="false">
    <link>
        <successor id="-3"/>
    </link>
    <width sOffset="0.0" a="2.0" b="0.0" c="0.0" d="0.0"/>
    <height sOffset="0.0" inner="0.12" outer="0.12"/>
</lane>
2.7.1.1.1.8 Lanes -> laneSection -> center -> lane -> roadMark

t_road_lanes_laneSection_lcr_lane_roadMark
该属性定义了车道外边界线条的样式。而分隔左右车道的中心线的样式由专为中心车道而设的路标元素来确定。

t_road_lanes_laneSection_lcr_lane_roadMark_type

t_road_lanes_laneSection_lcr_lane_roadMark_type_line

道路上的车道可(can)拥有不同的车道标识,比如不同颜色和样式的线。OpenDRIVE为路标提供了 <roadMark> 元素。路标信息定义了车道外边界上的线的样式,在左车道上则为左边界,在右车道则为右边界。而作为分隔左右车道的中心线的样式则由中心车道路标元素来确定。

可(may)为道路横断面内的每一条车道定义多个路标元素。也可(may)使用多个属性(如@type, @weight和 @width)来描述车道标志的属性。

有两种规定路标类型的方法:
(1) 通过<roadMark>元素内的@type属性可以输入存储在应用内的关键词。这些关键词被用于描述简化的路标类型如实线、虚线或草地。
(2) <type>元素包含了更多<line>元素,这些元素将对路标进行更详细的描述。

在OpenDRIVE中,路标用 <lane> 元素内的 <roadMark> 元素来表示。

属性:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

示例:

<roadMark color="standard" sOffset="0" weight="standard" laneChange="none" width="0.13" material="none" height="0.004999999888241291" type="solid"/>
2.7.1.1.1.8.1 Lanes -> laneSection -> center -> lane -> roadMark -> sway

t_road_lanes_laneSection_lcr_lane_roadMark_sway
可(may)使用 <sway> 元素来描述非直线但有侧边曲线的车道标志。 <sway> 元素为以下的(显性)类型定义转移了横向参考位置,从而定义了一个偏移。横向偏移曲线(sway)偏移将相对于车道标识的名义参考位置,即车道边界。

横向曲线的主要应用案例为创建穿过施工现场的道路。行车道在黄线之间,白线被横向偏移(swayed),并只作为标志存在。
示意图:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tNiESEG6-1608126737967)()]

表达式:

tOffset (ds) = a + b*ds + c*ds² + d*ds³
2.7.1.2 Lanes -> laneSection -> left

t_road_lanes_laneSection_left

为了能够便利地在OpenDRIVE的道路描述中进行查找,一个车道段内的车道可分为左、中和右车道。每个车道段均必须(shall)包含一个<center>元素和至少一个<right><left>元素。

2.7.1.2.1 Lanes -> laneSection -> left -> lane

t_road_lanes_laneSection_left_lane

2.7.1.3 Lanes -> laneSection -> right

t_road_lanes_laneSection_right

2.7.1.3.1 Lanes -> laneSection -> right -> lane

t_road_lanes_laneSection_right_lane

2.7.2) Lanes -> laneOffset

t_road_lanes_laneOffset

在OpenDRIVE中,车道偏移用<lanes>元素内的<laneOffset>元素来表示。

车道偏移可(may)用于将中心车道从道路参考线上位移。

表达式:

offset (ds) = a + b*ds + c*ds² + d*ds³

属性:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-S9dZGAU4-1608126737968)()]

要求:
若边界定义已存在,则不允许(shall)出现偏移。

示例:

<lanes>
    <laneOffset s="25.0" a="0.0" b="0.0" c="3.9e-03" d="-5.2e-05"/>
    <laneOffset s="75.0" a="3.25" b="0.0" c="0.0" d="0.0"/>
    …
<\lanes>

3) junction 描述交叉路口属性 (可多个)

t_junction

交叉口指的是三条或更多道路相聚的地方,与其相关的道路被分为两种类型:含有驶向交叉口车道的道路称为来路Incoming roads。

在这里插入图片描述
在这里插入图片描述

特点:
与道路不同,交叉口并不具备任何前驱或后继交叉口。

3.1) connection

在OpenDRIVE中,交叉口用 <junction> 元素来表示。联接道路则用 <junction> 元素中的 <connection> 元素来表示。OpenDRIVE并未特意将去路定义为元素或属性,来路也可被视作为去路,因此二者在此处可被相提并论。通往该道路的联接道路将此类道路隐性地定义为去路。

为能详细说明一条作为来路的道路,将通过在 <connection> 元素中使用@incomingRoad属性来引用该道路的ID。

示意图:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aXfuMjmV-1608126737969)()]

属性:
解释:

  1. incomingRoad 表示连接的两条车道的进入交叉路口的车道(Incoming roads)的id

  2. connectingRoad 表示交叉路口中间新增的车道(Connecting roads)(会同时在road里也更新一条路来,该路的junction属性不为-1)的id
    示例:

     <road length="64.18763436526746" id="20" name="prototype" junction="2">
    
  3. contactPoint 表示联接道路的方向:
    "start"值必须(shall)用于标明联接道路正在沿<laneLink>元素中的连接延伸。
    "end"值必须(shall)用于标明联接道路正在沿<laneLink>元素中的连接的反方向延伸。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-u7cxQ7wm-1608126737970)()]

3.1.1) connection -> laneLink

t_junction_connection_laneLink
该属性提供了关于在一条来路和一条联接道路之间被连接的车道信息。强烈建议使用该元素。忽略<laneLink>元素的做法已经不符合时宜。

联接道路将基于其车道对路线进行描述。联接道路详细说明了相同交叉口的来路和去路的车道之间的连接。如果该车道并没有被连接,就意味着这些车道之间的路线不通。

[外链图片转存中...(img-T7AOxbYR-1608126737971)]

示例:

<junction name="myJunction" id="555" >
<connection id="0"
            incomingRoad="1"
            connectingRoad="2"
            contactPoint="start">
    <laneLink from="-2" to="-1"/>
</connection>
</junction>
  • 23
    点赞
  • 111
    收藏
    觉得还不错? 一键收藏
  • 12
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值