10-记录器

10-记录器carla 脚本 timexdatarec

大家好,欢迎来到IT知识分享网。

    这个功能允许记录和重现以前的模拟。所有发生的事件都记录在记录器文件 recorder file中。

    1 记录

    所有数据仅在服务器端以二进制文件的形式写入。但是,记录器是使用 carla.Client管理的。

    注意:在回放结束时,车辆将被设置为自动驾驶,但行人会停下来。

    记录器文件包含关于许多不同元素的信息。

    actor。创建和销毁,边界和触发框。

    交通灯。状态变化和时间设置。

    车辆。位置和方向,线速度和角速度,灯光状态和物理控制。

    行人。位置和方向,线速度和角速度。

    灯光。来自建筑物、街道和车辆的灯光状态。

    要开始录制,只需要一个文件名。在文件名中使用\、/或:再加上绝对路径。如果未指定详细路径,则保存在“CarlaUE4/ saved”中。

client.start_recorder("/home/carla/recording01.log")

    默认情况下,记录器设置为仅存储回放仿真所需的信息。为了保存前面提到的所有信息,必须在开始记录时配置参数additional_data。

client.start_recorder("/home/carla/recording01.log", True)

    注意:additional_data包括:车辆和行人的线速度和角速度,交通灯时间设置,执行时间,演员车的触发器和边界框,以及车辆的物理控制。

    需要停止记录时使用以下函数:

client.stop_recorder()

2 仿真回放

    回放可以在仿真过程中的任何点开始。除了日志文件的路径外,该方法还需要一些参数。

client.replay_file("recording01.log", start, duration, camera)
参数 描述 注意事项
start 以秒为单位记录仿真开始的时间 如果是正值,则从录制开始就考虑时间。
如果是否定的,将从最后录制考虑时间。
duration 播放秒数。0是播放全部记录。 在回放结束时,车辆将被设置为自动驾驶,行人将停下来。
camera 摄像机将聚焦的演员的ID。 将其设置为0,观测者视角就可以自由移动。
client.set_replayer_time_factor(2.0)
参数 默认 加速 减速
time_factor 1.0 >1.0 <1.0

    如果time_factor>2.0,则禁用演员车的位置插值,只更新。行人的动画不受时间因素的影响。

    当时间因子约为20倍时,观察交通流较为方便。

3 记录文件

    可以使用简单的API调用来检索记录的详细信息。默认情况下,它只检索那些注册了事件的帧。设置参数show_all将返回每一帧的所有信息。有关如何存储数据的细节在记录仪的参考资料recorder’s reference中有详细说明。

# Show info for relevant frames print(client.show_recorder_file_info("recording01.log"))
Version: 1 Map: Town05 Date: 02/21/19 10:46:20 Frame 1 at 0 seconds Create 2190: spectator (0) at (-260, -200, 382.001) Create 2191: traffic.traffic_light (3) at (4255, 10020, 0) Create 2192: traffic.traffic_light (3) at (4025, 7860, 0) ... Create 2258: traffic.speed_limit.90 (0) at (21651.7, -1347.59, 15) Create 2259: traffic.speed_limit.90 (0) at (5357, 21457.1, 15) Frame 2 at 0.0 seconds Create 2276: vehicle.mini.cooperst (1) at (4347.63, -8409.51, 120) number_of_wheels = 4 object_type = color = 255,241,0 role_name = autopilot ... Frame 2350 at 60.2805 seconds Destroy 2276 Frame 2351 at 60.3057 seconds Destroy 2277 ... Frames: 2354 Duration: 60.3753 seconds

4 查询

4.1 碰撞

    车辆必须有一个碰撞探测器来记录碰撞。这些都可以查询,使用参数来过滤碰撞中涉及的参与者的类型。例如,h标识role_name = hero的角色,通常分配给由用户管理的车辆。有一组特定的参与者类型可用于查询。

  • h = Hero
  • v = Vehicle
  • w = Walker
  • t = Traffic light
  • o = Other
  • a = Any

    注意:manual_control.py脚本为ego车辆分配role_name = hero。

    碰撞查询需要两个标志来过滤冲突。下面的例子将显示车辆和任何其他物体之间的碰撞。

print(client.show_recorder_collisions("recording01.log", "v", "a"))

    输出总结了碰撞的时间,以及涉及的参与者的类型、ID和描述。

Version: 1 Map: Town05 Date: 02/19/19 15:36:08 Time Types Id Actor 1 Id Actor 2 16 v v 122 vehicle.yamaha.yzf 118 vehicle.dodge_charger.police 27 v o 122 vehicle.yamaha.yzf 0 Frames: 790 Duration: 46 seconds 

    由于记录碰撞的是hero或ego车辆,因此它将始终是Actor 1。

    可以通过使用记录器并在事件发生前几秒设置它来重现碰撞。

client.replay_file("col2.log", 13, 0, 122)

    在这种情况下,回放显示了如下:

10-记录器

print(client.show_recorder_actors_blocked("recording01.log", min_time, min_distance)) 
参数 描述 默认
min_time 移动’ min_distance ‘的最小秒数。 30s
min_distance 移动不被认为堵塞的最小距离。 10cm

    注意:有时车辆在交通灯前停留的时间比预期的要长。

    下面的例子认为车辆在60秒内移动不到1米时被阻塞。

client.show_recorder_actors_blocked("col3.log", 60, 100) 

    输出按持续时间排序,持续时间表示停止被“阻塞”并移动min_distance所需的时间。

Version: 1 Map: Town05 Date: 02/19/19 15:45:01 Time Id Actor Duration 36 173 vehicle.nissan.patrol 336 75 214 vehicle.chevrolet.impala 295 302 143 vehicle.bmw.grandtourer 67 Frames: 6985 Duration: 374 seconds 

    173号车在36秒时被停了336秒。在36秒前几秒可以进行回放查看。

client.replay_file("col3.log", 34, 0, 173)

10-记录器

5 示例python脚本

    PythonAPI/示例中提供的一些脚本有助于使用记录器。
    start_recording.py文件可以设置录制的持续时间,并且可以在开始时生成演员车。

参数 描述
-f 文件名
-n (可选) 车辆生成。默认为10s。
-t (可选) 记录多长时间

    start_replaying.py启动记录回放。可以设置开始时间、持续时间和要跟踪的演员车。

参数 描述
-f 文件名
-s (可选) 开始时间。默认值是10。
-d (可选) 持续时间。默认就是从开始时间播放全部记录的内容。
-c (可选) 所要跟踪演员车的id

    show_recorder_file_info.py显示记录文件中的所有信息。默认情况下,它只显示记录事件的帧。

参数 描述
-f 文件名
-s (可选) 标记以显示所有细节。

    show_recorder_collisions.py显示了A类和b类角色的两个标志之间记录的碰撞。-t = vv将显示车辆之间的所有碰撞。

参数 描述
-f 文件名
-t 所有场景中角色类型的标志位
h = hero
v = vehicle
w = walker
t = traffic light
o = other
a = any

    show_recorder_actors_blocked.py列出了被认为被阻塞的车辆。当演员车在一定时间内没有移动最小距离时,被认为是受阻的。

参数 描述
-f 文件名
-t (可选) 移动到指定距离所用的时间(阻塞)
-d (可选) 移动到不被认为被阻塞的距离。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/151578.html

(0)
上一篇 2025-03-12 20:45
下一篇 2025-03-12 21:00

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信