CARLA (I)--Ubuntu20.04 服务器安装 CARLA_0.9.13服务端和客户端详细步骤

本文主要是介绍CARLA (I)--Ubuntu20.04 服务器安装 CARLA_0.9.13服务端和客户端详细步骤,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 0. 说明
    • 0.1 应用场景:
    • 0.2 本文动机:
  • 1. 准备工作
  • 2. 安装 CARLA 服务端软件【远程服务器】
  • 3. 安装 CARLA 客户端【远程服务器】
    • 3.1 .egg 文件安装:
    • 3.2 .whl 文件安装:
    • 3.3 从Pypi下载Python package
  • 4. 运行服务端程序
  • 5. 运行客户端程序【远程服务器】
  • 6. 另外一种应用模式:服务端程序【远程服务器】<--->客户端程序【本地计算机:客户端+显示】
  • 7. 其他的安装方式参考文献

0. 说明

0.1 应用场景:

  1. 远程服务器:无显示器,具备多个GPU卡,Ubuntu 20.04
  2. 远程服务器上拟安装的Carla版本:0.9.13
  3. Carla的服务端和客户端均运行在远程服务器上
  4. 用户通过本地计算机(Windows10)远程访问和操作服务器
  5. 本地计算机可:
  • 安装并使用MobaXterm软件:利用本地电脑远程登陆和操作服务器,主要使用该软件的SSH来操作服务器终端,SFTP显示和操作服务器的文件夹和文件,或RDP来远程登录服务器界面。
  • 使用Vs Code: 通过建立SSH来直接修改或调试远程服务器上的Python函数。

0.2 本文动机:

随着时间的更新,Carla版本截止发稿前(2024.04)已更新到0.9.15版本。如果按照上述较早前发布的贴子来安装0.9.13等这类非最新早期的版本Carla可能出现问题。
例如,《CARLA 笔记(02)— Ubuntu 安装 CARLA(服务端、客户端、安装 miniconda、创建虚拟环境、更换 pip 源、生成交通流、人工控制车辆按键)》介绍了0.9.13版本的服务器安装。但是,帖子发布时0.9.13版本可能是当时的最新版本,当时安装可能没有问题。但如果现在安装,某些步骤已经不适用(下文结合具体安装步骤说明),例如:由于现在Pypi默认的carla客户端Python库已经更新至最新版本0.9.15,如果采用pip3 install carla来默认安装肯定出错。

1. 准备工作

安装之前,需要熟悉以下几个Carla常用的资源来源网站。

  • a. Carla安装包: https://github.com/carla-simulator/carla/blob/master/Docs/download.md
    CARLA的不同版本安装包点这里
  • b. Carla官网: https://carla.org/
    可以找到DOCUMENTATION说明文档,和GITHUB官网下载链接。
  • c. Pypi-Carla: https://pypi.org/search/?q=carla

The Python Package Index (PyPI) 是Python编程语言的软件仓库repository,帮助我们查找并安装Python community共享的软件。本文中,远程服务器的Carla客户端Python软件来源于Pypi。但须注意安装时,到网站上检查一下Pypi仓库中默认的Carla客户端软件版本,否则可能导致安装失败。

  • d. python库用户使用手册: https://packaging.python.org/en/latest/

2. 安装 CARLA 服务端软件【远程服务器】

以下安装均在远程服务器的个人账号base环境下完成,无须在root管理员账号下安装,亲验有效。注意,后续运行服务端程序时,也同样需在同一个人账号base环境下进行,验证发现root账号下运行carla服务端程序的话,会提示不允许。

  • (1) 下载Carla 0.9.13安装包:
    打开1.a提供的下载网址,找到0.9.13版本,下载下列两个文件:
    在这里插入图片描述
  • (2) 将第一个文件拷贝至服务器某文件夹,进入该文件夹后,解压:
tar -xzvf CARLA_0.9.13.tar.gz
  • (3) 将第二个文件 AdditionalMaps_0.9.13.tar.gz 放到 carla 的 import 目录下。
  • (4) 执行命令导入附加的地图:
cd CARLA_0.9.13/
./ImportAssets.sh

3. 安装 CARLA 客户端【远程服务器】

建议在虚拟环境中安装 CARLA 客户端库,以避免在使用多个版本时发生冲突。在远程服务器建立Anaconda虚拟环境软件,创建所需版本的虚拟环境。
本例中,采用python3.8版本来管理carla客户端库和应用程序。

# 创建虚拟环境,指定python版本
conda create --name your_env_name python=3.8
# 激活虚拟环境
activate your_env_name
# 退出虚拟环境
deactivate 
# 删除虚拟环境
conda remove --name your_env_name --all
# 查看所有虚拟环境
conda info --envs
conda env list
# 查看活跃环境下的所有包
conda list
# 为指定环境安装某个包
conda install -n env_name package_name

conda 虚拟环境中包的安装: 如果不能通过conda install来安装,更习惯用pip直接安装。pip在Anaconda中已安装好,不需要单独为每个环境安装pip。如需要用pip管理包,activate环境后直接使用即可。

CARLA 0.9.12+ 以上版本提供了三种安装客户端库的方式。
本例使用第二种whl安装方式成功安装,注意此处有,请看下文。

3.1 .egg 文件安装:

CARLA 在== PythonAPI/carla/dist/== 中为不同的 Python 版本提供了.egg 文件,开箱即可使用。
在== PythonAPI/examples== 中的每个例子脚本都包括一个自动寻找这个文件的代码片段。

注意:
(1)在 Linux 中,可能需要把这个文件添加到你的 PYTHONPATH 中。
(2)如果之前用 pip 安装了客户端库,它将优先于 .egg 文件,如果想使用.egg客户端库,需要先卸载之前的库。
(3)CARLA 0.9.12 之前的版本不需要安装 Python 库,都带有一个 .egg 文件,开箱就可以使用。

3.2 .whl 文件安装:

(1)启动虚拟环境,定位到.whl文件:

  • CARLA 为不同的 Python 版本提供 .whl 文件,需要安装 .whl 文件。
    .whl 文件可以在 ==PythonAPI/carla/dist/ == 中找到。
  • 每个支持的 Python 版本有一个文件,用文件名表示 (例如,carla-0.9.12-cp36-cp36m-manylinux_2_27_x86_64.whl 表示Python 3.6)。
  • 如果以前安装了客户端库,应该在安装新库之前卸载旧库。

在操作中发现Carla0.9.13版本的PythonAPI/carla/dist/下只有python 2.7和python 3.7版本的whl文件,没有本例中虚拟环境python 3.8对应的whl文件。此时,要作以下两步:

  • a. 从Pypi.org下载Carla 0.9.13版本的Python 3.8的 客户端whl文件。
    下载地址:https://pypi.org/project/carla/0.9.13/#files
# 找到并下载下列whl文件:
carla-0.9.13-cp38-cp38-manylinux_2_27_x86_64.whl 
  • b. 修改whl名称,以便符合规范,否则运行下面的安装命令会出错。
    可参见这个帖子的解决方案,将whl文件名改为符合python3.8版本的文件安装的命名规范。
# cd到whl文件所在目录,利用mv命令重命名文件
mv carla-0.9.13-cp38-cp38-manylinux_2_27_x86_64.whl  carla-0.9.13-cp38-cp38-manylinux_2_27_x86_64.whl

(2) 安装.whl文件

# Python 3
pip3 install <wheel-file-name>.whl# Python 2
pip install <wheel-file-name>.whl
./ImportAssets.sh

3.3 从Pypi下载Python package

CARLA 客户端库可以从 PyPi 下载。要安装它,需要 pip/pip3 的20.3版本或以上。

# 激活虚拟环境
conda activate XXX
# 如果 pip 需要升级,则执行命令
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pip -U
# 如果需要,可永久更换 pip 源为清华源
pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple
# 在 虚拟环境中安装 CARLA 执行所需要的依赖
pip install pygame numpy
# 在 虚拟环境中安装客户端
pip install carla
  • 本例曾经使用第三种方式pip安装失败,经查看pypi库是安装时的版本已经更新至0.9.15,因此不能使用pip install carla来安装(默认0.9.15,与本例carla版本不一致)。
  • 本例尝试使用pip install carla==0.9.13来安装指定版本,仍然失败,原因未知,有知道的请评论区提示。

4. 运行服务端程序

由于carla服务端程序安装在远程服务器的个人账号下,须首先进入个人账号base环境,然后启动carla运行服务端程序,并保持运行。

  • 安装依赖项:
apt-get install -y libomp5
  • 命令行启动Carla, 正常模式
cd CARLA_0.9.13/
./CarlaUE4.sh
  • 命令行启动Carla, off-screen mode
./CarlaUE4.sh -RenderOffScreen

由于远程服务器没有显示器,本例采用off-screen mode 启动carla服务端程序:即Unreal Engine 正常运行,正常进行渲染计算 rendering,但是没有显示信号输出,GPU 的虚拟传感器可以正常返回有效数据

  • 如果电脑显卡性能较差,可以添加如下可选参数调低渲染 level:
 ./CarlaUE4.sh -quality-level=Low

启动时可选de配置选项包括:

配置参数含义
carla-rpc-port=N侦听端口 N 处的客户端连接。默认情况下,流式端口 Streaming port 设置为 N+1
carla-streaming-port=N指定用于传感器数据流的端口。 使用 0 获取随机未使用的端口。 第二个端口将自动设置为 N + 1
quality-level={Low,Epic}更改图形质量级别
-carla-server让 carla以服务的方式运行
-benchmark -fps=15引擎以1/15秒的固定时间逐步运行
-windowed -ResX=800 -ResY=600屏幕窗口大小

5. 运行客户端程序【远程服务器】

服务端运行之后,等待客户端与之连接,可以用下面的方法连接服务端。

(1) 进入虚拟环境,生成交通流。命令行执行后不要关闭。

cd PythonAPI\examples
python3 -m pip install -r requirements.txt 
python3 generate_traffic.py  

(2) 人工控制1

cd PythonAPI\examples
python3 manual_control.py 

6. 另外一种应用模式:服务端程序【远程服务器】<—>客户端程序【本地计算机:客户端+显示】

  • 参见参考1:《Carla学习笔记(一)服务器跑carla本地显示窗口》
  • 参见参考2:《Carla学习笔记(二)服务器跑carla,本地运行carla-ros-bridge并用rviz显示

7. 其他的安装方式参考文献

  1. 《Carla 安装详细教程 —— Ubuntu 20.04 安装 Carla》
  2. 《ubuntu安装carla0.9.14打包版+编译版教程》
  3. 《Ubuntu20.04 安装 Nvidia GTX 1050 ti GPU 驱动运行Carla详细过程》

  1. 由于本地计算机提供键盘输入,并在本地计算机显示器来显示远程服务器的carla Python客户端GUI界面,因此实际应用中可能有延迟和卡顿。https://blog.csdn.net/wohu1104/article/details/125464837 ↩︎

这篇关于CARLA (I)--Ubuntu20.04 服务器安装 CARLA_0.9.13服务端和客户端详细步骤的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/939835

相关文章

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

mac安装redis全过程

《mac安装redis全过程》文章内容主要介绍了如何从官网下载指定版本的Redis,以及如何在自定义目录下安装和启动Redis,还提到了如何修改Redis的密码和配置文件,以及使用RedisInsig... 目录MAC安装Redis安装启动redis 配置redis 常用命令总结mac安装redis官网下

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

Apache Tomcat服务器版本号隐藏的几种方法

《ApacheTomcat服务器版本号隐藏的几种方法》本文主要介绍了ApacheTomcat服务器版本号隐藏的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1. 隐藏HTTP响应头中的Server信息编辑 server.XML 文件2. 修China编程改错误

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

更改docker默认数据目录的方法步骤

《更改docker默认数据目录的方法步骤》本文主要介绍了更改docker默认数据目录的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1.查看docker是否存在并停止该服务2.挂载镜像并安装rsync便于备份3.取消挂载备份和迁

如何在一台服务器上使用docker运行kafka集群

《如何在一台服务器上使用docker运行kafka集群》文章详细介绍了如何在一台服务器上使用Docker运行Kafka集群,包括拉取镜像、创建网络、启动Kafka容器、检查运行状态、编写启动和关闭脚本... 目录1.拉取镜像2.创建集群之间通信的网络3.将zookeeper加入到网络中4.启动kafka集群

SpringBoot集成SOL链的详细过程

《SpringBoot集成SOL链的详细过程》Solanaj是一个用于与Solana区块链交互的Java库,它为Java开发者提供了一套功能丰富的API,使得在Java环境中可以轻松构建与Solana... 目录一、什么是solanaj?二、Pom依赖三、主要类3.1 RpcClient3.2 Public

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、