From 89f49d2a0e6517a4c78d6e23d364e28918cf2a03 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cem=20G=C3=B6kmen?= Date: Sun, 17 Mar 2024 03:08:32 -0700 Subject: [PATCH 1/6] Add kit app definition for OmniGibson into the Isaac Sim apps directory --- omnigibson/omnigibson.kit | 630 ++++++++++++++++++++++++++++++++++++++ omnigibson/simulator.py | 3 +- scripts/setup.bat | 3 + scripts/setup.sh | 3 + 4 files changed, 638 insertions(+), 1 deletion(-) create mode 100644 omnigibson/omnigibson.kit diff --git a/omnigibson/omnigibson.kit b/omnigibson/omnigibson.kit new file mode 100644 index 000000000..8cd67e10f --- /dev/null +++ b/omnigibson/omnigibson.kit @@ -0,0 +1,630 @@ +[package] +title = "OmniGibson" +description = "A platform for accelerating Embodied AI research" +version = "2023.1.1" + +# That makes it browsable in UI with "experience" filter +keywords = ["experience", "app", "usd"] + +[dependencies] +# The Main UI App +"omni.kit.uiapp" = {} +"omni.kit.renderer.core" = {} + +# Livestream - OV Streaming Client +"omni.kit.streamsdk.plugins" = {version = "2.5.2", exact = true} + +# Status Bar +"omni.kit.window.status_bar" = {} + +"omni.stats" = {} + +"omni.kit.telemetry" = {} + +"omni.kit.menu.utils" = {} +"omni.kit.menu.file" = {} +"omni.kit.menu.edit" = {} +"omni.kit.menu.create" = {} +"omni.kit.menu.common" = {} +"omni.kit.menu.stage" = {} + +"omni.kit.window.file" = {} +"omni.kit.context_menu" = {} + +"omni.kit.selection" = {} +"omni.kit.stage_templates" = {} +# "omni.kit.stage.mdl_converter" = {} + +# Animation +# "omni.anim.skelvis" = {} + +# PhysX +"omni.physx.bundle" = {} +"omni.physx.tensors" = {} +# "omni.physx.fabric" = {} +# "omni.physx.zerogravity" = {} + +# "omni.kit.search.service" = {} +"omni.kit.primitive.mesh" = {} + +# Create Windows +"omni.kit.window.title" = {} +"omni.kit.widget.live" = {} +"omni.kit.window.stage" = {} +"omni.kit.widget.layers" = {} +"omni.kit.window.cursor" = {} +"omni.kit.window.toolbar" = {} +"omni.kit.window.commands" = {} + +# New Viewport, load the default bundle of extensions +"omni.kit.viewport.bundle" = {} +"omni.kit.viewport.menubar.lighting" = {} +# Load the rendering extensions +# "omni.renderer" = { tag = "rtx" } +# Load the RTX rendering bundle +"omni.kit.viewport.rtx" = {} +# Load the Storm rendering bundle +"omni.kit.viewport.pxr" = {} + +# Needed for Fabric delegate +"omni.resourcemonitor" = {} + +# Additional Viewport features (legacy grid etc, HUD GPU stats) +"omni.kit.viewport.legacy_gizmos" = {} +"omni.kit.viewport.ready" = {} +"omni.hydra.engine.stats" = {} + +"omni.rtx.settings.core" = {} # this is the new Render Settings 2.0 + +# "omni.kit.window.movie_capture" = { } + +"omni.kit.profiler.window" = {} + +"omni.kit.stage_column.variant" = {} +"omni.kit.stage_column.payload" = {} + +# Viewport Widgets and Collaboration +# "omni.kit.viewport_widgets_manager" = {} +"omni.kit.collaboration.channel_manager" = {} + +# "omni.kit.widgets.custom" = {} + +# utils window +# "omni.kit.window.about" = {} # Isaac Sim: disable this and replace with our own +# "omni.kit.window.privacy" = {} +# "omni.kit.window.provide_feedback" = {} # Isaac Sim: disable this and replace with our own + +# "omni.kit.material.library" = {} + +# "omni.kit.window.imageviewer" = {} + +"omni.kit.widget.filebrowser" = {} +"omni.kit.window.filepicker" = {} +"omni.kit.window.content_browser" = {} + +"omni.kit.window.stats" = { order = 1000 } + +"omni.kit.window.script_editor" = {} +"omni.kit.window.console" = {} + +"omni.kit.window.extensions" = {} + + +# browsers +"omni.kit.browser.sample" = {} +# "omni.kit.browser.asset" = {} +# "omni.kit.browser.asset_store" = {} +# "omni.kit.browser.asset_provider.local" = {} +# "omni.kit.browser.asset_provider.sketchfab" = {} +# "omni.kit.browser.asset_provider.turbosquid" = {} +# "omni.kit.browser.asset_provider.actorcore" = {} + +# "omni.kit.window.environment" = {} # potentially increases startup times + +# Material +# "omni.kit.window.material" = { } +# "omni.kit.graph.delegate.default" = { } +# "omni.kit.window.material_graph" = { } + +# "omni.kit.window.usd_paths" = {} +# "omni.kit.window.preferences" = { order = 1000 } # so the menu is in the correct place + +# "omni.kit.renderer.capture" = {} +# "omni.kit.thumbnails.usd" = {} +# "omni.kit.thumbnails.images" = {} + +# bring all the property Widgets and Window +"omni.kit.window.property" = {} +"omni.kit.property.bundle" = {} +"omni.kit.property.layer" = {} + +# tool +# "omni.kit.asset_converter" = {} +# "omni.kit.tool.asset_importer" = {} +# "omni.kit.tool.asset_exporter" = {} +# "omni.kit.tool.collect" = {} +# "omni.kit.tool.remove_unused.core" = {} +# "omni.kit.tool.remove_unused.controller" = {} + +# Iray +# "omni.iray.settings.core" = {} +# "omni.hydra.iray" = { order = -1000 } + +#Particle/PointCloud FileFormat +# "omni.usd.fileformat.e57" = { } +# "omni.kit.pointclouds" = {} + +# External Scene +# "omni.geo.streaming.bundle" = {} + +# All QuickSearch +# "omni.kit.window.quicksearch" = {} + +# "omni.kit.quicksearch.actions" = {} +# "omni.kit.quicksearch.settings" = {} + +# "omni.kit.quicksearch.select" = {} +# "omni.kit.quicksearch.commands" = {} +# "omni.kit.quicksearch.menu" = {} +# "omni.kit.quicksearch.material" = {} +# "omni.kit.quicksearch.hdri" = {} +# "omni.kit.quicksearch.props" = {} + +# "omni.kit.search.files" = {} + +# Compatibility Checker +# "omni.kit.compatibility_checker" = {} + +# VERSIONING +# "omni.kit.widget.versioning" = {} + +# Paint Default now +# "omni.paint.system.bundle" = {} + +# Manipulator +"omni.kit.manipulator.prim" = {} +"omni.kit.manipulator.transform" = {} +"omni.kit.manipulator.viewport" = {} +# "omni.kit.manipulator.tool.mesh_snap" = {} + +# Destruction schema +# "omni.usd.schema.destruction" = {} + +# Animation +# "omni.anim.skelJoint" = { } +# "omni.anim.curve" = { } +# "omni.kit.widget.timeline" = { } +# "omni.anim.curve_editor" = { } +# "omni.anim.window.timeline" = { } +# "omni.anim.shared.core" = {} +# "omni.anim.timeline" = { } +# "omni.anim.graph.bundle" = {} +# "omni.anim.graph.core" = {} +# "omni.anim.graph.ui" = {} +# "omni.anim.retarget.bundle" = {} +# "omni.anim.retarget.core" = {} +# "omni.anim.retarget.ui" = {} +#"omni.anim.camera_tool" = {} +# Needed to properly load navigation mesh +"omni.anim.graph.schema" = {} +"omni.anim.navigation.schema" = {} + +# OmniGraph +"omni.graph.bundle.action" = {} +"omni.graph.window.action" = {} +"omni.graph.window.generic" = {} +"omni.graph.visualization.nodes" = {} + +# Python Scripting Component +# "omni.kit.scripting" = {} + +# kit-testing +# "omni.kit.tests.usd_stress" = {} + +# Curves +# "omni.curve.manipulator" = {} + +# General Proceduralism +# "omni.genproc.bundle" = {} + +# Sequencer +# "omni.kit.window.sequencer" = {} + +# "omni.services.usd" = {} + +# SBSAR +# "omni.kit.property.sbsar" = {} +# "omni.usd.fileformat.sbsar" = {} + +# Thumbnails +# "omni.kit.thumbnails.mdl" = {} + +# Quicklayout +# "omni.kit.quicklayout" = {} + +# AOV +# "omni.kit.menu.aov" = {} +# "omni.graph.examples.cpp" = {} + +# Collections +# "omni.kit.window.collection" = {} +# "omni.kit.widget.collection" = {} +# "omni.kit.property.collection" = {} + +# Extended Searchfield +# "omni.kit.widget.extended_searchfield" = {} + +# Particle +# "omni.particle.system.bundle" = {} + +# Scene Visualization +"omni.usd.schema.scene.visualization" = {} +# "omni.scene.visualization.bundle" = {} + +#Section Tool +# "omni.kit.window.section" = {} + +# startfleet auth enabled for cloud_share to work on the receiver +# "omni.services.starfleet.auth" = {} + +# Array Tool +# "omni.tools.array" = {} +# "omni.tools.pivot" = {} + +# Randomizer +# "omni.tools.randomizer" = {} + +# Deepsearch +# "omni.kit.browser.deepsearch" = {} + +# Actions +# "omni.kit.actions.window" = {} +# "omni.kit.viewport.actions" = {} + +# Scene Optimizer (formerly Data Adapter) +# "omni.scene.optimizer.bundle" = {} + +# Hotkeys +"omni.kit.hotkeys.window" = {} + +# USDA +# "omni.kit.usda_edit" = {} + +# "omni.rakis" = {} + +"omni.warp" = {} + +# needed for omni.kit.viewport.ready.viewport_ready +"omni.activity.profiler" = {} +"omni.activity.pump" = {} + +"omni.kit.widget.cache_indicator" = {} + + +[settings] +renderer.active = "rtx" +exts."omni.kit.viewport.menubar.camera".expand = true # Expand the extra-camera settings by default +exts."omni.kit.window.file".useNewFilePicker = true +exts."omni.kit.tool.asset_importer".useNewFilePicker = true +exts."omni.kit.tool.collect".useNewFilePicker = true +exts."omni.kit.widget.layers".useNewFilePicker = true +exts."omni.kit.renderer.core".imgui.enableMips = true +exts."omni.kit.browser.material".enabled = false +exts."omni.kit.browser.asset".visible_after_startup = false +exts."omni.kit.window.material".load_after_startup = true +exts."omni.kit.widget.cloud_share".require_access_code = false +exts."omni.kit.pipapi".installCheckIgnoreVersion = true +exts."omni.kit.viewport.window".startup.windowName="Viewport" # Rename from Viewport Next +exts."omni.kit.menu.utils".logDeprecated = false + +# app.content.emptyStageOnStart = false +app.file.ignoreUnsavedOnExit = true # prevents save dialog when exiting + +# deprecate support for old kit.ui.menu +app.menu.legacy_mode = false +# use omni.ui.Menu for the MenuBar +app.menu.compatibility_mode = false +# Setting the port for the embedded http server +exts."omni.services.transport.server.http".port = 8211 + +# default viewport is fill +app.runLoops.rendering_0.fillResolution = false +exts."omni.kit.window.viewport".blockingGetViewportDrawable = false + +exts."omni.kit.test".includeTests.1 = "*isaac*" + +[settings.app.python] +# These disable the kit app from also printing out python output, which gets confusing +interceptSysStdOutput = false +logSysStdOutput = false + +[settings.app.settings] +persistent = false +dev_build = false +fabricDefaultStageFrameHistoryCount = 3 # needed for omni.syntheticdata TODO105 Still True? + +[settings.app.window] +title = "OmniGibson" +hideUi = false +_iconSize = 256 +iconPath = "${app}/../exts/omni.isaac.app.setup/data/nvidia-omniverse-isaacsim.ico" + +# width = 1700 +# height = 900 +# x = -1 +# y = -1 + +# Fonts +[setting.app.font] +file = "${fonts}/OpenSans-SemiBold.ttf" +size = 16 + +# [setting.app.runLoops] +# main.rateLimitEnabled = false +# main.rateLimitFrequency = 60 +# main.rateLimitUseBusyLoop = false +# rendering_0.rateLimitEnabled = false + +[settings.exts.'omni.kit.window.extensions'] +# List extensions here we want to show as featured when extension manager is opened +featuredExts = [] + + +[settings] +# MGPU is always on, you can turn it from the settings, and force this off to save even more resource if you +# only want to use a single GPU on your MGPU system +# False for Isaac Sim +renderer.multiGpu.enabled = true +renderer.multiGpu.autoEnable = true +'rtx-transient'.resourcemanager.enableTextureStreaming = true +# app.hydra.aperture.conform = 4 # in 105.1 pixels are square by default +app.hydraEngine.waitIdle = false +rtx.newDenoiser.enabled = true + +# Enable Iray and pxr by setting this to "rtx,iray,pxr" +renderer.enabled = "rtx" + +physics.autoPopupSimulationOutputWindow=false + +### async rendering settings +omni.replicator.asyncRendering = false +app.asyncRendering = false +app.asyncRenderingLowLatency = false + +### Render thread settings +app.runLoops.main.rateLimitEnabled = false +app.runLoops.main.rateLimitFrequency = 120 +app.runLoops.main.rateLimitUsePrecisionSleep = true +app.runLoops.main.syncToPresent = false +app.runLoops.present.rateLimitFrequency = 120 +app.runLoops.present.rateLimitUsePrecisionSleep = true +app.runLoops.rendering_0.rateLimitFrequency = 120 +app.runLoops.rendering_0.rateLimitUsePrecisionSleep = true +app.runLoops.rendering_0.syncToPresent = false +app.runLoops.rendering_1.rateLimitFrequency = 120 +app.runLoops.rendering_1.rateLimitUsePrecisionSleep = true +app.runLoops.rendering_1.syncToPresent = false +app.runLoopsGlobal.syncToPresent = false +app.vsync = false +exts.omni.kit.renderer.core.present.enabled = false +exts.omni.kit.renderer.core.present.presentAfterRendering = false +persistent.app.viewport.defaults.tickRate = 120 +rtx-transient.dlssg.enabled = false + +privacy.externalBuild = true + +# Basic Kit App +################################ +app.versionFile = "${app}/../VERSION" +app.name = "Isaac-Sim" +app.version = "2023.1.1" + +# hide NonToggleable Exts +exts."omni.kit.window.extensions".hideNonToggleableExts = true +exts."omni.kit.window.extensions".showFeatureOnly = false + +# Hang Detector +################################ +# app.hangDetector.enabled = false +# app.hangDetector.timeout = 120 + + +# Browsers +exts."omni.kit.browser.material".folders = [ + "Base::http://omniverse-content-production.s3-us-west-2.amazonaws.com/Materials/Base", + "vMaterials::http://omniverse-content-production.s3.us-west-2.amazonaws.com/Materials/vMaterials_2/", + "Twinbru Fabrics::https://twinbru.s3.eu-west-1.amazonaws.com/omniverse/Twinbru Fabrics/" +] + +exts."omni.kit.window.environment".folders = [ + "https://omniverse-content-production.s3.us-west-2.amazonaws.com/Assets/Skies/2022_1/Skies", + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/Scenes/Templates", +] + +exts."omni.kit.browser.sample".folders = [ "http://omniverse-content-production.s3-us-west-2.amazonaws.com//Samples" ] + +exts."omni.kit.browser.asset".folders = [ + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/Vegetation", + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/ArchVis/Commercial", + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/ArchVis/Industrial", + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/ArchVis/Residential", + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/DigitalTwin/Assets/Warehouse/Equipment", + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/DigitalTwin/Assets/Warehouse/Safety", + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/DigitalTwin/Assets/Warehouse/Shipping", + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/DigitalTwin/Assets/Warehouse/Storage", + ] + +exts."omni.kit.browser.texture".folders = [ + "http://omniverse-content-production.s3-us-west-2.amazonaws.com/Assets/Vegetation", + ] + +#RTX Settings +[settings.rtx] +translucency.worldEps = 0.005 + +# Content Browser +############################### +[settings.exts."omni.kit.window.content_browser"] +enable_thumbnail_generation_images = false # temp fix to avoid leaking python processes + +# Extensions +############################### +[settings.exts."omni.kit.registry.nucleus"] +registries = [ + { name = "kit/default", url = "https://ovextensionsprod.blob.core.windows.net/exts/kit/prod/shared" }, + { name = "kit/sdk", url = "https://ovextensionsprod.blob.core.windows.net/exts/kit/prod/sdk/${kit_version_short}/${kit_git_hash}" }, + { name = "kit/community", url = "https://dw290v42wisod.cloudfront.net/exts/kit/community" }, +] + +[settings.app.extensions] +skipPublishVerification = false +registryEnabled = true + +[settings.exts."omni.kit.window.modifier.titlebar"] +titleFormatString = " Isaac Sim {version:${app}/../SHORT_VERSION,font_color=0x909090,font_size=16} {separator} {file, board=true}" +showFileFullPath = true +icon.file = "${app}/../exts/omni.isaac.app.setup/data/nvidia-omniverse-isaacsim.ico" +icon.size = 256 +defaultFont.name = "Arial" +defaultFont.size = 16 +defaultFont.color = 0xD0D0D0 +separator.color = 0x00B976 +separator.width = 1 +windowBorder.color = 0x0F0F0F +windowBorder.width = 2 +colors.caption = 0x0F0F0F +colors.client = 0x0F0F0F +respondOnMouseUp = true +changeWindowRegion = true + + +# Register extension folder from this repo in kit +[settings.app.exts] +folders = ["${app}/../exts", "${app}/../extscache", "${app}/../extsPhysics"] + +[settings.crashreporter.data] +experience = "Isaac Sim Python" + +# Isaac Sim Settings +############################### +[settings.app.renderer] +skipWhileMinimized = false +sleepMsOnFocus = 0 +sleepMsOutOfFocus = 0 +resolution.width=1280 +resolution.height=720 + +[settings.app.livestream] +proto = "ws" +allowResize = true +outDirectory = "${data}" + +# default camera position in meters +[settings.app.viewport] +defaultCamPos.x = 5 +defaultCamPos.y = 5 +defaultCamPos.z = 5 + +[settings.rtx] +raytracing.fractionalCutoutOpacity = false +hydra.enableSemanticSchema = true +# descriptorSets=60000 +# reservedDescriptors=500000 +# sceneDb.maxInstances=1000000 +# Enable this for static scenes, improves visual quality +# directLighting.sampledLighting.enabled = true + +[settings.persistent] +app.file.recentFiles = [] +app.stage.upAxis = "Z" +app.stage.movePrimInPlace = false +app.stage.instanceableOnCreatingReference = false +app.stage.materialStrength = "weakerThanDescendants" + +app.transform.gizmoUseSRT = true +app.viewport.grid.scale = 1.0 +app.viewport.pickingMode = "kind:model.ALL" +app.viewport.camMoveVelocity = 0.05 # 5 m/s +app.viewport.gizmo.scale = 0.01 # scaled to meters +app.viewport.previewOnPeek = false +app.viewport.snapToSurface = false +app.viewport.displayOptions = 31887 # Disable Frame Rate and Resolution by default +app.window.uiStyle = "NvidiaDark" +app.primCreation.DefaultXformOpType = "Scale, Orient, Translate" +app.primCreation.DefaultXformOpOrder="xformOp:translate, xformOp:orient, xformOp:scale" +app.primCreation.typedDefaults.camera.clippingRange = [0.01, 10000000.0] +simulation.minFrameRate = 15 +simulation.defaultMetersPerUnit = 1.0 +omnigraph.updateToUsd = false +omnigraph.useSchemaPrims = true +omnigraph.disablePrimNodes = true +physics.updateToUsd = true +physics.updateVelocitiesToUsd = true +physics.useFastCache = false +physics.visualizationDisplayJoints = false +physics.visualizationSimulationOutput = false +omni.replicator.captureOnPlay = true +exts."omni.anim.navigation.core".navMesh.viewNavMesh = false + +renderer.startupMessageDisplayed = true # hides the IOMMU popup window + +# Make Detail panel visible by default +app.omniverse.content_browser.options_menu.show_details = true +app.omniverse.filepicker.options_menu.show_details = true + + +[settings.ngx] +enabled=true # Enable this for DLSS + +# Isaac Sim Extensions +############################### +[dependencies] +"omni.isaac.core_archive" = {} +"omni.pip.compute" = {} +"omni.pip.cloud" = {} +"omni.isaac.ml_archive" = {} +"omni.isaac.urdf" = {} +"omni.isaac.mjcf" = {} +"omni.isaac.utils" = {} +"omni.isaac.range_sensor" = {} +"omni.isaac.dynamic_control" = {} +"omni.isaac.kit" = {} +"omni.isaac.core" = {} +"omni.isaac.core_nodes" = {} +"omni.isaac.cloner" = {} +"omni.isaac.cortex" = {} +"omni.isaac.cortex.sample_behaviors" = {} +"omni.isaac.dofbot" = {} +"omni.isaac.surface_gripper" = {} +# "omni.kit.property.isaac" = {} +"omni.isaac.scene_blox" = {} +"omni.isaac.sensor" = {} +"omni.isaac.debug_draw" = {} +"omni.isaac.gym" = {} + +"omni.isaac.franka" = {} +"omni.isaac.manipulators" = {} +"omni.isaac.quadruped" = {} +"omni.isaac.wheeled_robots" = {} +"omni.isaac.lula" = {} +"omni.isaac.motion_generation" = {} +"omni.isaac.universal_robots" = {} +"omni.isaac.occupancy_map" = {} +"omni.replicator.isaac" = {} +"omni.kit.loop-isaac" = {} + +#linux only extensions +[dependencies."filter:platform"."linux-x86_64"] +# "omni.isaac.ocs2" = {} + +# Non Isaac Sim Extensions +###################### +[dependencies] +"omni.syntheticdata" = {} +"semantics.schema.editor" = {} +"semantics.schema.property" = {} +"omni.replicator.core" = {} +"omni.replicator.replicator_yaml" = {} +"omni.replicator.composer" = {} +"omni.importer.mjcf" = {} +"omni.importer.urdf" = {} diff --git a/omnigibson/simulator.py b/omnigibson/simulator.py index 0d11509ae..4ce66f832 100644 --- a/omnigibson/simulator.py +++ b/omnigibson/simulator.py @@ -45,6 +45,7 @@ m.OBJECT_GRAVEYARD_POS = (100.0, 100.0, 100.0) + # Helper functions for starting omnigibson def print_save_usd_warning(_): log.warning("Exporting individual USDs has been disabled in OG due to copyrights.") @@ -74,7 +75,7 @@ def _launch_app(): launch_context = nullcontext if gm.DEBUG else suppress_omni_log with launch_context(None): - app = lazy.omni.isaac.kit.SimulationApp(config_kwargs) + app = lazy.omni.isaac.kit.SimulationApp(config_kwargs, experience=f'{os.environ["EXP_PATH"]}/omnigibson.kit') assert meets_minimum_isaac_version("2023.1.1"), "This version of OmniGibson supports Isaac Sim 2023.1.1 and above. Please update Isaac Sim." diff --git a/scripts/setup.bat b/scripts/setup.bat index 7e50e3eda..7efd83d79 100644 --- a/scripts/setup.bat +++ b/scripts/setup.bat @@ -33,6 +33,9 @@ echo: FOR /F "tokens=*" %%g IN ('%ISAAC_SIM_PATH%\python.bat -c "import platform; print(platform.python_version())"') do (SET ISAAC_PYTHON_VERSION=%%g) echo Using Python version %ISAAC_PYTHON_VERSION% matching your current Isaac Sim version +:: Install the OmniGibson kit file +copy omnigibson\omnigibson.kit %ISAAC_SIM_PATH%\apps\omnigibson.kit || goto :error + :: Create a conda environment with the appropriate python version call conda create -y -n %conda_name% python=%ISAAC_PYTHON_VERSION% || goto :error call conda activate %conda_name% || goto :error diff --git a/scripts/setup.sh b/scripts/setup.sh index 0c6474f2b..2e0dbfac2 100755 --- a/scripts/setup.sh +++ b/scripts/setup.sh @@ -31,6 +31,9 @@ ISAAC_PYTHON_VERSION=$(${ISAAC_SIM_PATH}/python.sh -c "import platform; print(pl ISAAC_PYTHON_VERSION="${ISAAC_PYTHON_VERSION##*$'\n'}" # get rid of conda activation warnings echo Using Python version $ISAAC_PYTHON_VERSION matching your current Isaac Sim version +# Install the OmniGibson kit file +cp omnigibson/omnigibson.kit ${ISAAC_SIM_PATH}/apps/omnigibson.kit + # Create a conda environment with the appropriate python version source $(conda info --base)/etc/profile.d/conda.sh conda create -y -n $conda_name python=${ISAAC_PYTHON_VERSION} From 673dd88fc23006f89f138164b41249e584cc46ba Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cem=20G=C3=B6kmen?= Date: Sun, 17 Mar 2024 03:10:51 -0700 Subject: [PATCH 2/6] Add kit file rule into Docker --- docker/prod.Dockerfile | 3 +++ 1 file changed, 3 insertions(+) diff --git a/docker/prod.Dockerfile b/docker/prod.Dockerfile index 9feb45495..fc598e07b 100644 --- a/docker/prod.Dockerfile +++ b/docker/prod.Dockerfile @@ -4,6 +4,9 @@ FROM stanfordvl/omnigibson-dev:latest ADD . /omnigibson-src WORKDIR /omnigibson-src +# Copy over the kit file +COPY /omnigibson-src/omnigibson/omnigibson.kit /isaac-sim/apps/omnigibson.kit + SHELL ["micromamba", "run", "-n", "omnigibson", "/bin/bash", "--login", "-c"] # Install OmniGibson From 83ef7e9ce54f064a9a619bdc20113ab22cfa1bfa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cem=20G=C3=B6kmen?= Date: Sun, 17 Mar 2024 12:48:31 -0700 Subject: [PATCH 3/6] Revert "Add kit file rule into Docker" This reverts commit 673dd88fc23006f89f138164b41249e584cc46ba. --- docker/prod.Dockerfile | 3 --- 1 file changed, 3 deletions(-) diff --git a/docker/prod.Dockerfile b/docker/prod.Dockerfile index fc598e07b..9feb45495 100644 --- a/docker/prod.Dockerfile +++ b/docker/prod.Dockerfile @@ -4,9 +4,6 @@ FROM stanfordvl/omnigibson-dev:latest ADD . /omnigibson-src WORKDIR /omnigibson-src -# Copy over the kit file -COPY /omnigibson-src/omnigibson/omnigibson.kit /isaac-sim/apps/omnigibson.kit - SHELL ["micromamba", "run", "-n", "omnigibson", "/bin/bash", "--login", "-c"] # Install OmniGibson From 195e3d9d309789c72cc133f2566c6f54d7e83869 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cem=20G=C3=B6kmen?= Date: Sun, 17 Mar 2024 12:50:07 -0700 Subject: [PATCH 4/6] Undo kit file distribution at load time --- scripts/setup.bat | 3 --- scripts/setup.sh | 3 --- 2 files changed, 6 deletions(-) diff --git a/scripts/setup.bat b/scripts/setup.bat index 7efd83d79..7e50e3eda 100644 --- a/scripts/setup.bat +++ b/scripts/setup.bat @@ -33,9 +33,6 @@ echo: FOR /F "tokens=*" %%g IN ('%ISAAC_SIM_PATH%\python.bat -c "import platform; print(platform.python_version())"') do (SET ISAAC_PYTHON_VERSION=%%g) echo Using Python version %ISAAC_PYTHON_VERSION% matching your current Isaac Sim version -:: Install the OmniGibson kit file -copy omnigibson\omnigibson.kit %ISAAC_SIM_PATH%\apps\omnigibson.kit || goto :error - :: Create a conda environment with the appropriate python version call conda create -y -n %conda_name% python=%ISAAC_PYTHON_VERSION% || goto :error call conda activate %conda_name% || goto :error diff --git a/scripts/setup.sh b/scripts/setup.sh index 2e0dbfac2..0c6474f2b 100755 --- a/scripts/setup.sh +++ b/scripts/setup.sh @@ -31,9 +31,6 @@ ISAAC_PYTHON_VERSION=$(${ISAAC_SIM_PATH}/python.sh -c "import platform; print(pl ISAAC_PYTHON_VERSION="${ISAAC_PYTHON_VERSION##*$'\n'}" # get rid of conda activation warnings echo Using Python version $ISAAC_PYTHON_VERSION matching your current Isaac Sim version -# Install the OmniGibson kit file -cp omnigibson/omnigibson.kit ${ISAAC_SIM_PATH}/apps/omnigibson.kit - # Create a conda environment with the appropriate python version source $(conda info --base)/etc/profile.d/conda.sh conda create -y -n $conda_name python=${ISAAC_PYTHON_VERSION} From 9de9ddb2528c1fb8b409751f3a2fe84b558e175b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cem=20G=C3=B6kmen?= Date: Sun, 17 Mar 2024 12:54:09 -0700 Subject: [PATCH 5/6] Copy over the kit file on every launch --- omnigibson/simulator.py | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/omnigibson/simulator.py b/omnigibson/simulator.py index 4ce66f832..25bbf4f0f 100644 --- a/omnigibson/simulator.py +++ b/omnigibson/simulator.py @@ -3,6 +3,7 @@ import contextlib import logging import os +import shutil import socket from pathlib import Path import atexit @@ -73,6 +74,17 @@ def _launch_app(): # sys.argv.append("--/log/outputStreamLevel=error") warnings.simplefilter("ignore", category=NumbaPerformanceWarning) + # Copy the OmniGibson kit file to the Isaac Sim apps directory. This is necessary because the Isaac Sim app + # expects the extensions to be reachable in the parent directory of the kit file. We copy on every launch to + # ensure that the kit file is always up to date. + assert "EXP_PATH" in os.environ, "The EXP_PATH variable is not set. Are you in an Isaac Sim installed environment?" + kit_file = Path(__file__).parent / "omnigibson.kit" + kit_file_target = Path(os.environ["EXP_PATH"]) / "omnigibson.kit" + try: + shutil.copy(kit_file, kit_file_target) + except Exception as e: + raise e from ValueError("Failed to copy omnigibson.kit to Isaac Sim apps directory.") + launch_context = nullcontext if gm.DEBUG else suppress_omni_log with launch_context(None): app = lazy.omni.isaac.kit.SimulationApp(config_kwargs, experience=f'{os.environ["EXP_PATH"]}/omnigibson.kit') From 361aec4241c34e4869e9b183add06b1b21bf2e4c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cem=20G=C3=B6kmen?= Date: Sun, 17 Mar 2024 12:56:19 -0700 Subject: [PATCH 6/6] Update simulator.py --- omnigibson/simulator.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/omnigibson/simulator.py b/omnigibson/simulator.py index 25bbf4f0f..9238c1284 100644 --- a/omnigibson/simulator.py +++ b/omnigibson/simulator.py @@ -87,7 +87,7 @@ def _launch_app(): launch_context = nullcontext if gm.DEBUG else suppress_omni_log with launch_context(None): - app = lazy.omni.isaac.kit.SimulationApp(config_kwargs, experience=f'{os.environ["EXP_PATH"]}/omnigibson.kit') + app = lazy.omni.isaac.kit.SimulationApp(config_kwargs, experience=str(kit_file_target.resolve(strict=True))) assert meets_minimum_isaac_version("2023.1.1"), "This version of OmniGibson supports Isaac Sim 2023.1.1 and above. Please update Isaac Sim."