Skip to content

Commit

Permalink
renaming some scripts, updating the third party references (#6)
Browse files Browse the repository at this point in the history
  • Loading branch information
Paweł Budzianowski authored Apr 29, 2024
1 parent 1c5698e commit 7bb19f2
Show file tree
Hide file tree
Showing 9 changed files with 153 additions and 99 deletions.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,10 +37,10 @@ make install-third-party-external
```

### Running Stompy experiments
1. Download our model from
1. Download our URDF model from
```bash
wget https://media.kscale.dev/stompy.tar.gz && tar -xzvf stompy.tar.gz
python sim/scripts/create_fixed_urdf.py
python sim/scripts/create_fixed_torso.py
export MODEL_DIR=stompy
```

Expand Down
1 change: 1 addition & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ namespace_packages = false
module = [
"isaacgym.*",
"humanoid.*",
"IsaacGymEnvs.*",
]

ignore_missing_imports = true
Expand Down
9 changes: 9 additions & 0 deletions sim/env.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,12 @@ def stompy_urdf_path(legs_only: bool = False) -> Path:
raise FileNotFoundError(f"URDF file not found: {stompy_path}")

return stompy_path.resolve()


def stompy_mjcf_path() -> Path:
stompy_path = model_dir() / "robot.xml"

if not stompy_path.exists():
raise FileNotFoundError(f"MJCF file not found: {stompy_path}")

return stompy_path.resolve()
36 changes: 36 additions & 0 deletions sim/scripts/create_fixed_torso.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
# mypy: disable-error-code="valid-newtype"
"""This script updates the URDF file to fix the joints of the robot."""

import xml.etree.ElementTree as ET
from sim.stompy.joints import StompyFixed

STOMPY_URDF = "stompy/robot.urdf"


def update_urdf():
tree = ET.parse(STOMPY_URDF)
root = tree.getroot()
stompy = StompyFixed()

revolute_joints = set(stompy.default_standing().keys())
joint_limits = stompy.default_limits()

for joint in root.findall("joint"):
joint_name = joint.get("name")
if joint_name not in revolute_joints:
joint.set("type", "fixed")
else:
limit = joint.find("limit")
if limit is not None:
limits = joint_limits.get(joint_name, {})
lower = str(limits.get("lower", 0.0))
upper = str(limits.get("upper", 0.0))
limit.set("lower", lower)
limit.set("upper", upper)

# Save the modified URDF to a new file
tree.write("stompy/robot_fixed.urdf")


if __name__ == "__main__":
update_urdf()
96 changes: 0 additions & 96 deletions sim/scripts/create_fixed_urdf.py

This file was deleted.

77 changes: 77 additions & 0 deletions sim/scripts/create_mjcf.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
# mypy: disable-error-code="valid-newtype"
"""This script updates the MJCF version for proper rendering.
The mcf format can be created by loading URDF file to the viewer and saving as xml.
"""
import xml.etree.ElementTree as ET

STOMPY_MJCF = "stompy/robot.xml"


def update_mjcf():
tree = ET.parse(STOMPY_MJCF)
root = tree.getroot()
# Create light element
light = ET.Element(
"light",
{
"cutoff": "100",
"diffuse": "1 1 1",
"dir": "-0 0 -1.3",
"directional": "true",
"exponent": "1",
"pos": "0 0 1.3",
"specular": ".1 .1 .1",
},
)

# Create floor geometry element
floor = ET.Element(
"geom",
{
"conaffinity": "1",
"condim": "3",
"name": "floor",
"pos": "0 0 -1.5",
"rgba": "0.8 0.9 0.8 1",
"size": "40 40 40",
"type": "plane",
"material": "MatPlane",
},
)
# Access the <worldbody> element
worldbody = root.find("worldbody")
# Insert new elements at the beginning of the worldbody
worldbody.insert(0, floor)
worldbody.insert(0, light)

new_root_body = ET.Element("body", name="root", pos="-1.4 0 -0.3", quat="1 0 0 1")

# List to store items to be moved to the new root body
items_to_move = []
# Gather all children (geoms and bodies) that need to be moved under the new root body
for element in worldbody:
items_to_move.append(element)
# Move gathered elements to the new root body
for item in items_to_move:
worldbody.remove(item)
new_root_body.append(item)
# Add the new root body to the worldbody
worldbody.append(new_root_body)
worldbody2 = worldbody
# # Create a new root worldbody and add the new root body to it
# new_worldbody = ET.Element("worldbody", name="new_root")
index = list(root).index(worldbody)

# # Remove the old <worldbody> and insert the new one at the same index
root.remove(worldbody)
root.insert(index, worldbody2)
modified_xml = ET.tostring(root, encoding="unicode")

with open(STOMPY_MJCF, "w") as f:
f.write(modified_xml)


if __name__ == "__main__":
# update_urdf()
update_mjcf()
27 changes: 27 additions & 0 deletions sim/scripts/simulate_mjcf.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# mypy: disable-error-code="valid-newtype"
"""Defines a simple demo script for simulating a MJCF to observe the physics.
Run with mjpython:
mjpython mjpython sim/scripts/simulate_mjcf.py
"""
import time
import mujoco
import mujoco.viewer

from sim.env import stompy_mjcf_path


model = mujoco.MjModel.from_xml_path(stompy_mjcf_path())
data = mujoco.MjData(model)


with mujoco.viewer.launch_passive(model, data) as viewer:
start = time.time()
while viewer.is_running():
step_start = time.time()
mujoco.mj_step(model, data)
viewer.sync()

time_until_next_step = model.opt.timestep - (time.time() - step_start)
if time_until_next_step > 0:
time.sleep(time_until_next_step)
File renamed without changes.
2 changes: 1 addition & 1 deletion third_party/IsaacGymEnvs

0 comments on commit 7bb19f2

Please sign in to comment.