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

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP