Orbit 使用指南 02 | 在场景中生成原始对象| Isaac Sim | Omniverse

如是我闻: Orbit使用指南02将

  1. 深入探讨如何使用Python代码在Orbit中向场景生成各种对象(或原始对象)。
  2. 一起探索如何生成地面平面、灯光、基本图形形状以及来自USD文件的网格。
  3. 前置知识:如何生成空白场景,Orbit 使用指南 01

指南02对应于orbit/source/standalone/tutorials/00_sim目录下的spawn_prims.py脚本。让我们先瞅一瞅这个Python脚本:

# Copyright (c) 2022-2024, The ORBIT Project Developers.
# All rights reserved.
#
# SPDX-License-Identifier: BSD-3-Clause

"""This script demonstrates how to spawn prims into the scene.

.. code-block:: bash

    # Usage
    ./orbit.sh -p source/standalone/tutorials/00_sim/spawn_prims.py

"""

from __future__ import annotations

"""Launch Isaac Sim Simulator first."""
import argparse

from omni.isaac.orbit.app import AppLauncher

# create argparser
parser = argparse.ArgumentParser(description="Tutorial on spawning prims into the scene.")
# append AppLauncher cli args
AppLauncher.add_app_launcher_args(parser)
# parse the arguments
args_cli = parser.parse_args()
# launch omniverse app
app_launcher = AppLauncher(args_cli)
simulation_app = app_launcher.app

"""Rest everything follows."""

import traceback

import carb
import omni.isaac.core.utils.prims as prim_utils

import omni.isaac.orbit.sim as sim_utils
from omni.isaac.orbit.utils.assets import ISAAC_NUCLEUS_DIR


def design_scene():
    """Designs the scene by spawning ground plane, light, objects and meshes from usd files."""
    # Ground-plane
    cfg_ground = sim_utils.GroundPlaneCfg()
    cfg_ground.func("/World/defaultGroundPlane", cfg_ground)

    # spawn distant light
    cfg_light_distant = sim_utils.DistantLightCfg(
        intensity=3000.0,
        color=(0.75, 0.75, 0.75),
    )
    cfg_light_distant.func("/World/lightDistant", cfg_light_distant, translation=(1, 0, 10))

    # create a new xform prim for all objects to be spawned under
    prim_utils.create_prim("/World/Objects", "Xform")
    # spawn a red cone
    cfg_cone = sim_utils.ConeCfg(
        radius=0.15,
        height=0.5,
        visual_material=sim_utils.PreviewSurfaceCfg(diffuse_color=(1.0, 0.0, 0.0)),
    )
    cfg_cone.func("/World/Objects/Cone1", cfg_cone, translation=(-1.0, 1.0, 1.0))
    cfg_cone.func("/World/Objects/Cone2", cfg_cone, translation=(-1.0, -1.0, 1.0))

    # spawn a green cone with colliders and rigid body
    cfg_cone_rigid = sim_utils.ConeCfg(
        radius=0.15,
        height=0.5,
        rigid_props=sim_utils.RigidBodyPropertiesCfg(),
        mass_props=sim_utils.MassPropertiesCfg(mass=1.0),
        collision_props=sim_utils.CollisionPropertiesCfg(),
        visual_material=sim_utils.PreviewSurfaceCfg(diffuse_color=(0.0, 1.0, 0.0)),
    )
    cfg_cone_rigid.func(
        "/World/Objects/ConeRigid", cfg_cone_rigid, translation=(0.0, 0.0, 2.0), orientation=(0.5, 0.0, 0.5, 0.0)
    )

    # spawn a usd file of a table into the scene
    cfg = sim_utils.UsdFileCfg(usd_path=f"{ISAAC_NUCLEUS_DIR}/Props/Mounts/SeattleLabTable/table_instanceable.usd")
    cfg.func("/World/Objects/Table", cfg, translation=(0.0, 0.0, 1.05))


def main():
    """Main function."""

    # Initialize the simulation context
    sim_cfg = sim_utils.SimulationCfg(dt=0.01, substeps=1)
    sim = sim_utils.SimulationContext(sim_cfg)
    # Set main camera
    sim.set_camera_view([2.0, 0.0, 2.5], [-0.5, 0.0, 0.5])

    # Design scene by adding assets to it
    design_scene()

    # Play the simulator
    sim.reset()
    # Now we are ready!
    print("[INFO]: Setup complete...")

    # Simulate physics
    while simulation_app.is_running():
        # perform step
        sim.step()


if __name__ == "__main__":
    try:
        # run the main execution
        main()
    except Exception as err:
        carb.log_error(err)
        carb.log_error(traceback.format_exc())
        raise
    finally:
        # close sim app
        simulation_app.close()

代码解析

Omniverse中的场景设计始终绕不过去一个名为USD(Universal Scene Description,通用场景描述)的软件系统和文件格式。它允许以类似文件系统的层次方式来描述3D场景。由于USD是一个全面的框架,推荐阅读USD的文档以深入了解它。

为了让大家全面了解,这里介绍一些必须掌握的USD概念。

  • 原始对象(Primitives,简称Prims):这些是USD场景的基本构建块。可以将它们视为场景图中的节点。每个节点可以是一个网格(mesh)、灯光(light)、相机(camera)或变换(transform)。它也可以是一组其他的原始对象。

  • 属性(Attributes):这些是原始对象的属性。可以将它们视为键值对。例如,一个原始对象可以有一个名为颜色的属性,其值为红色。

  • 关系(Relationships):这些是原始对象之间的连接。可以将它们视为指向其他原始对象的指针。例如,一个网格原始对象可以与一个材质原始对象有一个关系,用于遮光。

这些原始对象及其属性和关系的集合被称为USD展台(stage)。它可以被视为场景中所有原始对象的容器。当我们说我们在设计一个场景时,实际上我们是在设计一个USD展台。

虽然直接使用USD API提供了很大的灵活性,但学习和使用它可能会比较繁琐。为了简化场景设计,Orbit在USD API的基础上构建,提供了一个配置驱动的接口来将原始对象生成到场景中。这些功能包含在sim.spawners模块中。

在场景中生成原始对象时,每个原始对象需要一个定义了原始对象属性和关系(通过材料和阴影区信息)的配置类实例。然后,指定了原始对象的名称和变换的配置类,被传递给其相应的函数。函数随后将原始对象生成到场景中。

抽象的来看,一般是这样的

# Create a configuration class instance
cfg = MyPrimCfg()
prim_path = "/path/to/prim"

# Spawn the prim into the scene using the corresponding spawner function
spawn_my_prim(prim_path, cfg, translation=[0, 0, 0], orientation=[1, 0, 0, 0], scale=[1, 1, 1])
# OR
# Use the spawner function directly from the configuration class
cfg.func(prim_path, cfg, translation=[0, 0, 0], orientation=[1, 0, 0, 0], scale=[1, 1, 1])

在这里,我们展示如何在场景中生成各种不同的原始对象。想要了解更多可用的生成器(spawners),请参考Orbit中的sim.spawners模块。

生成一个地面平面

sim.spawners.GroundPlaneCfg用于配置一个网格状的地面平面,并且可以修改其属性,比如外观和大小。

    # Ground-plane
    cfg_ground = sim_utils.GroundPlaneCfg()
    cfg_ground.func("/World/defaultGroundPlane", cfg_ground)

生成灯光

可以在展台上生成不同类型的灯光原始对象,包括远光、球形灯、圆盘灯和圆柱灯。在这里,我们生成一个远光,这是一种来自无限远处、只向一个方向照射的灯光。

    # spawn distant light
    cfg_light_distant = sim_utils.DistantLightCfg(
        intensity=3000.0,
        color=(0.75, 0.75, 0.75),
    )
    cfg_light_distant.func("/World/lightDistant", cfg_light_distant, translation=(1, 0, 10))

生成基本图形(primitive shapes)

在介绍如何生成基本形状之前,我们先介绍一个名为变换原始对象(或Xform)的概念。变换原始对象是一种只包含变换属性的原始对象。它用于将其他原始对象分组并作为一个整体进行变换。在这里,我们创建一个Xform原始对象,将所有基本图形分组在其下。

    # create a new xform prim for all objects to be spawned under
    prim_utils.create_prim("/World/Objects", "Xform")

接下来,使用sim.spawners.ConeCfg类生成一个圆锥。我们可以指定圆锥的半径、高度、物理属性和材质属性。默认情况下,物理和材质属性是禁用的。

我们生成的前两个圆锥Cone1Cone2是视觉元素,没有启用物理效果。

    # spawn a red cone
    cfg_cone = sim_utils.ConeCfg(
        radius=0.15,
        height=0.5,
        visual_material=sim_utils.PreviewSurfaceCfg(diffuse_color=(1.0, 0.0, 0.0)),
    )
    cfg_cone.func("/World/Objects/Cone1", cfg_cone, translation=(-1.0, 1.0, 1.0))
    cfg_cone.func("/World/Objects/Cone2", cfg_cone, translation=(-1.0, -1.0, 1.0))

对于第三个圆锥ConeRigid,我们通过在配置类中设置属性,为其添加了刚体物理效果。通过这些属性,我们可以指定圆锥的质量、摩擦力系数和弹性系数。如果不指定,它们将默认使用USD物理设置的默认值。

    # spawn a red cone
    cfg_cone = sim_utils.ConeCfg(
        radius=0.15,
        height=0.5,
        visual_material=sim_utils.PreviewSurfaceCfg(diffuse_color=(1.0, 0.0, 0.0)),
    )
    cfg_cone.func("/World/Objects/Cone1", cfg_cone, translation=(-1.0, 1.0, 1.0))
    cfg_cone.func("/World/Objects/Cone2", cfg_cone, translation=(-1.0, -1.0, 1.0))

通过其他文件生成

最后,还可以从其他文件格式中生成原始对象,如其他USD、URDF或OBJ文件。在这里,我们将一个桌子的USD文件生成到场景中。桌子是一个网格原始对象,并且有一个与之关联的材质原始对象。所有这些信息都存储在其USD文件中。

    # spawn a usd file of a table into the scene
    cfg = sim_utils.UsdFileCfg(usd_path=f"{ISAAC_NUCLEUS_DIR}/Props/Mounts/SeattleLabTable/table_instanceable.usd")
    cfg.func("/World/Objects/Table", cfg, translation=(0.0, 0.0, 1.05))

上述的桌子实际上是作为一个引用被添加到场景中。用通俗的话来说,这意味着桌子实际上没有被直接添加到场景中,而是添加了一个指向桌子的指针。这允许我们以非破坏性的方式对桌子做出修改并在场景中反映出其变化。例如,我们可以改变桌子的材质,而无需直接修改桌子的底层文件。只有变化会被存储在USD展台中。

运行脚本

我们通过在命令行输入以下命令来运行脚本

./orbit.sh -p source/standalone/tutorials/00_sim/spawn_prims.py

模拟开始,应该能看到一个窗口,里面有一个地面平面、灯光、一些圆锥和一个桌子。启用了刚体物理的绿色圆锥应该会掉落并与桌子及地面平面发生碰撞。其他的圆锥是视觉元素,应该保持静止。要停止模拟,你可以关闭窗口,或在终端中按Ctrl+C。
在这里插入图片描述

指南02为在Orbit中,向场景生成各种原始对象提供了基础,展示了Orbit场景设计的基本概念以及如何使用生成器(spawners)。在接下来的指南中,我们将探讨如何与场景和模拟进行交互。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/426792.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

VUE实现Office文档在线编辑,支持doc/docx、xls/xlsx、ppt/pptx、pdf等

1.微软提供的在线Office预览(只能预览,不能编辑) https://view.officeapps.live.com/op/view.aspx?src服务器上文档地址(http开头) 2.国内在线Office方案: 腾讯文档、石墨文档、飞书 优势:跨…

paimon取消hive转filesystem

目录 概述实践关键配置spark sql 结束 概述 公司上一版本保留了 hive ,此版优化升级后,取消 hive。 实践 关键配置 同步数据时,配置如下,将形成两个库 # ods库 CREATE CATALOG paimon WITH (type paimon,warehouse hdfs:///d…

CentOS配网报错:network is unreachable

常用命令: 打开: cd /etc/sysconfig/network-scripts/ 修改: vim ifcfg-ens33 打开修改: vim /etc/sysconfig/network-scripts/ifcfg-ens33 保存: 方法1:ESCZZ(Z要大写) 方…

熔断降级 spring事务

如果有事务处理,会先把事务的自动提交给关闭

Apache Flink连载(三十七):Flink基于Kubernetes部署(7)-Kubernetes 集群搭建-3

🏡 个人主页:IT贫道-CSDN博客 🚩 私聊博主:私聊博主加WX好友,获取更多资料哦~ 🔔 博主个人B栈地址:豹哥教你学编程的个人空间-豹哥教你学编程个人主页-哔哩哔哩视频 目录

32单片机基础:PWM驱动舵机,直流电机

PWM驱动舵机 接线图如上图所示。注意,舵机的5V 线不能接到面包板上的正极,面包板上的正极只有3.3V,是STM32提供的,所以要接到STLINK的5V, 我们如何驱动舵机呢?由之前我们介绍原理知道,要输出如下图对应的PWM波形才行…

202209 青少年软件编程等级考试Scratch二级真题

第 1 题 【 单选题 】 数字:1,2,3,4,6,9,13,19,28,...的下一项是多少? A:37 B:39 C:41 D:47 …

爱奇艺2023年营收319亿元:完善服务价值感知,重构影视新生态

近日,爱奇艺(NASDAQ:IQ)发布截至2023年12月31日未经审计的第四季度和全年财报,这份财报被外界评价为“爱奇艺交出的年度最佳业绩”。 财报显示,爱奇艺全年总营收319亿元,同比增长10%;非美国通用…

模拟器抓HTTP/S的包时如何绕过单向证书校验(XP框架)

模拟器抓HTTP/S的包时如何绕过单向证书校验(XP框架) 逍遥模拟器无法激活XP框架来绕过单向的证书校验,如下图: ​​ 解决办法: 安装JustMePlush.apk安装Just Trust Me.apk安装RE管理器.apk安装Xposedinstaller_逍遥64位…

Java SE:反射

反射作用 获取字节码文件里面的所有信息,包括构造方法、成员、成员方法,以及修饰他们的修饰符、类型和方法的返回值等等,只要是类里面的内容都能获取,获取之后可以动态的调用方法,动态的创建对象 获取类字节码文件对象…

vue3中的基本语法

目录 基础素材 vue3的优化 使用CompositionAPI理由 1. reactive() 函数 2. ref() 函数 2.1. ref的使用 2.2. 在 reactive 对象中访问 ref 创建的响应式数据 3. isRef() 函数 4. toRefs() 函数 5. computed() 5.1. 通过 set()、get()方法创建一个可读可写的计算属性 …

“耳机党”注意了!你的耳机,用对了吗?

文章目录 📖 介绍 📖🏡 什么是“3个60”原则? 🏡📒 如何遵循“3个60”原则? 📒📝 控制音量📝 适时休息📝 关注外界声音 📖 介绍 &…

深度学习目标检测】二十二、基于深度学习的肺炎检测系统-含数据集、GUI和源码(python,yolov8)

肺炎尽管很常见,但准确诊断是一项困难的任务。它要求训练有素的专家对胸部X光片进行检查,并通过临床病史,生命体征和实验室检查进行确认。肺炎通常表现为胸部X光片上一个或多个区域的阴影(opacity)增加。但是,由于肺部有许多其他状…

足球青训俱乐部|基于Springboot的足球青训俱乐部管理系统设计与实现(源码+数据库+文档)

足球青训俱乐部管理系统目录 目录 基于Springboot的足球青训俱乐部管理系统设计与实现 一、前言 二、系统设计 1、系统架构设计 三、系统功能设计 1、管理员登录界面 2、公告信息管理界面 3、学员管理界面 4、商品信息管理界面 5、课程安排管理界面 四、数据库设计…

机器学习:主成分分析笔记

主成分分析(Principal Component Analysis,PCA)是一种无监督的机器学习算法,通常用于高维数据的降维、提取主要特征、数据降噪和可视化。PCA的基本思想是将原始数据的多个变量转换为少数几个相互独立的变量(即主成分&a…

上海亚商投顾:深成指震荡涨超1% 两市成交连续破万亿

上海亚商投顾前言:无惧大盘涨跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。 一.市场情绪 沪指3月1日震荡反弹,深成指、创业板指午后涨超1%。充电桩概念股集体走强,英可瑞、欧陆…

Stable Video文本生成视频公测地址——Scaling Latent Video Diffusion Models to Large Datasets

近期,Stability AI发布了首个开放视频模型——"Stable Video",该创新工具能够将文本和图像输入转化为生动的场景,将概念转换成动态影像,生成出电影级别的作品,旨在满足广泛的视频应用需求,包括媒…

leetcode10正则表达式匹配

leetcode10正则表达式匹配 思路python 思路 难点1 如何理解特殊字符 ’ * ’ 的作用? 如何正确的利用特殊字符 ’ . ’ 和 ’ * ’ ? * 匹配零个或多个前面的那一个元素 "a*" 可表示的字符为不同数目的 a,包括: "…

二维码门楼牌管理系统技术服务:制作详解

文章目录 前言一、二维码门楼牌制作技术要求二、二维码门楼牌管理系统的优势与应用 前言 随着信息化时代的到来,二维码技术已广泛应用于各个领域。在城市管理中,二维码门楼牌管理系统的应用为城市管理带来了极大的便利。本文将详细探讨二维码门楼牌管理…

绝地求生:【2024PGC之路——PUBG电竞积分分布】

亲爱的PUBG电竞爱好者, 你们好! 2024年PUBG电竞即将开始,让我们一起深入了解下今年令人激动的PGS 和 PGC赛事积分分配情况。 PUBG GLOBAL SERIES(PGS全球系列赛): 积分分布 根据我们之前概述的《PUBG 2024电竞计划》…
最新文章