Comments (5)
If you simply want to run the policy without modifications, follow the Sim2Real section in the README. The instructions should be pretty straightforward if you have already setup Isaac Sim and the real-world Dofbot.
from omniisaacgymenvs-dofbotreacher.
Well, what I want to do is get the policy deployed out of Isaac Sim and into a jetson Nano in the real world. Basically after training a policy in Isaac Sim, then use it on a Nano.
I've figured out how to that with RL Game's notebook here:
However, now I need to know what the outputs of the model are, I'm assuming it's the mu tensor. what order of joints is the a2c model providing? Is it 1,2,3,4,5,6?
from omniisaacgymenvs-dofbotreacher.
I'd also like to ask if the form linked with exporting ONNX looks correct, and how the ONNX model would be used.
I'm currently trying to export it and use it like this:
import onnxruntime as ort
import numpy as np
# Load the ONNX model
sess = ort.InferenceSession('/home/jetson/Excolligere/dofbotreacherDefault.onnx')
# Get the input and output names of the model
input_name = sess.get_inputs()[0].name
output_name = sess.get_outputs()[0].name
# Get the input names and shapes
input_info = sess.get_inputs()
output_info = sess.get_outputs()a
for i in input_info:
print("Input name:", i.name)
print("Input shape:", i.shape)
for i in output_info:
print("Output name:", i.name)
print("Output shape:", i.shape)
import numpy as np
print(np.__version__)
# Create the individual arrays
jointPos = np.zeros(6, dtype=np.float32)
jointVel = np.zeros(6, dtype=np.float32)
#put in coordinates here
goalPos = np.array([0.2, .07, .1], dtype=np.float32)
goalRot = np.zeros(4, dtype=np.float32)
goalRotRel = np.zeros(4, dtype=np.float32)
prevAct = np.full(6, 0, dtype=np.float32)
# Concatenate the arrays into a single array
input_data = np.concatenate((jointPos, jointVel, goalPos, goalRot, goalRotRel, prevAct))
input_dict = {input_name: input_data.reshape(1, -1)}
# Run the model on the input data
output = sess.run(None, input_dict)
import math
import numpy as np
pi = math.pi
dof_angle_limits = [
(-90, 90, False),
(-90, 90, False),
(-90, 90, False),
(-90, 90, False),
(-90, 180, False),
(-30, 60, True),
]
servo_angle_limits = [
(0, 90),
(45, 90),
(45, 90),
(45, 90),
(45, 90),
(45, 180),
]
servo_angles = [90] * 6
for i, pos in enumerate(output[0][0]):
if i == 5:
# Ignore the gripper joints for Reacher task
continue
# Map [L, U] to [A, B]
L, U, inversed= dof_angle_limits[i]
A, B = servo_angle_limits[i]
angle = np.rad2deg(float(pos))
if not L <= angle <= U:
print("The {}-th simulation joint angle ({}) is out of range! Should be in [{}, {}]".format(i, angle, L, U))
angle = np.clip(angle, L, U)
servo_angles[i] = (angle - L) * ((B-A)/(U-L)) + A # Map [L, U] to [A, B]
if inversed:
servo_angles[i] = (B-A) - (servo_angles[i] - A) + A # Map [A, B] to [B, A]
if not A <= servo_angles[i] <= B:
raise Exception("(Should Not Happen) The {}-th real world joint angle ({}) is out of range! Should be in [{}, {}]".format(i, servo_angles[i], A, B))
print(servo_angles)
Arm.Arm_serial_servo_write6(servo_angles[0], servo_angles[1], servo_angles[3], servo_angles[5], servo_angles[4], servo_angles[5], 500)
However, the model is not correctly reaching. What information would I need about using the model in order to export it and use it like this?
from omniisaacgymenvs-dofbotreacher.
I'd also like to ask where in the code can I see how predictions are being made. I've updated my code to use the mean and std. deviation calculated from the exported model, but my predictions are still not the same as the simulations:
import numpy as np
# Create the individual arrays
jointPos = np.zeros(6)
jointVel = np.zeros(6)
goalPos = np.array([-.1949, .1820, .2187])
goalRot = np.zeros(4)
goalRotRel = np.zeros(4)
prevAct = np.full(6, 0)
# Define a function to clip the actions
def clip_actions(actions):
return np.clip(actions, -1.0, 1.0)
# Concatenate the arrays into a single array
input_data = np.concatenate((jointPos, jointVel, goalPos, goalRot, goalRotRel, prevAct), dtype=np.float32)
input_dict = {input_name: input_data.reshape(1, -1)}
while True:
input_data = np.concatenate((jointPos, jointVel, goalPos, goalRot, goalRotRel, prevAct), dtype=np.float32)
input_dict = {input_name: input_data.reshape(1, -1)}
actions = []
output = sess.run(None, input_dict)
# Run the model on the input data
mus = output[0][0]
sigmas = output[1][0]
for mu, sigma in zip(mus, sigmas):
#print("mu is " + str(mu))
#print("sigma is " + str(sigma))
sigma = np.exp(sigma)
action = np.random.normal(mu, sigma)
action = clip_actions(action)
#print(str(action))
actions.append(action)
# Print the output
prevAct = np.array(actions, dtype=np.float32)
joinPos = prevAct
print(str(actions)+"\n")
from omniisaacgymenvs-dofbotreacher.
Solved
from omniisaacgymenvs-dofbotreacher.
Related Issues (6)
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from omniisaacgymenvs-dofbotreacher.