WorldViz User Forum  

Go Back   WorldViz User Forum > Vizard

Reply
 
Thread Tools Rate Thread Display Modes
  #1  
Old 02-13-2007, 12:21 PM
astull astull is offline
Member
 
Join Date: Dec 2005
Posts: 9
Question (beginner) calculating orientation change with eulers

I'm capturing Euler angles before and after a user manipulation. The object is fixed in location and only changes in orientation. What I want to measure is the error between a target orientation and the user's response orientation for the object. I've calculated the difference for each of the 3 axis but, if I understand correctly, this doesn't give a measure of the orientation change in 3D space. What is the proper method/strategy to attack this question? I'd like one measure of orientation error but I'm not sure how to get it.
Reply With Quote
  #2  
Old 02-13-2007, 12:35 PM
farshizzo farshizzo is offline
WorldViz Team Member
 
Join Date: Mar 2003
Posts: 2,849
Using the euler angles, you can find the look vector of each orientation, then compute the angle difference between these vectors. However, this method will not take roll into account. For example, if both orientations are looking straight ahead, but one has the head rolled 90 degrees, the difference will still be 0 degrees. If you are interested in the roll, then you can also extract the up vector of each orientation and compute the angle difference between these. It would then be up to you to figure out how to convert these two angle differences into some orientation error metric.

Let me know if you are interested in this method and I will supply you with some sample code.
Reply With Quote
  #3  
Old 02-13-2007, 03:22 PM
astull astull is offline
Member
 
Join Date: Dec 2005
Posts: 9
Smile Thank you

Yes, this method makes sense and sample code would be welcomed.
Reply With Quote
  #4  
Old 02-13-2007, 03:33 PM
farshizzo farshizzo is offline
WorldViz Team Member
 
Join Date: Mar 2003
Posts: 2,849
Here you go
Code:
import viz
viz.go()

euler1 = [90,0,0]
euler2 = [91,0,5]

def ComputeAngleDifference(euler1, euler2):
	m = viz.Transform()
	
	#Extract forward/up vector from euler1
	m.setRot( vizmat.EulerToAxisAngle(euler1) )
	d = m.get()
	forward1 = d[8:11]
	up1 = d[4:7]
	
	#Extract forward/up vector from euler2
	m.setRot( vizmat.EulerToAxisAngle(euler2) )
	d = m.get()
	forward2 = d[8:11]
	up2 = d[4:7]

	#Compute angle difference between forward/up vectors
	forward_diff = vizmat.AngleBetweenVector(forward1,forward2)
	up_diff = vizmat.AngleBetweenVector(up1,up2)

	return forward_diff,up_diff
	
print ComputeAngleDifference(euler1,euler2)
Reply With Quote
  #5  
Old 02-15-2007, 10:35 PM
astull astull is offline
Member
 
Join Date: Dec 2005
Posts: 9
non-unique solution

Jerry pointed out that the script doesn't always give a unique solution. For example, both of the following sets of eulers give the same forward_diff and up_diff solution, which is (90, 90).

euler1 [0, 90, 0]
euler2 [0, 0, 0]

and

euler1 [0, 90, 30]
euler2 [0, 0, 0]

Is there a way to address this?
Reply With Quote
  #6  
Old 02-16-2007, 09:20 AM
farshizzo farshizzo is offline
WorldViz Team Member
 
Join Date: Mar 2003
Posts: 2,849
I'm not sure what the problem is. The solution you are getting for those sets of euler angles is correct. The problem with getting non-unique solutions is when extracting euler angles from a matrix. In this example we are creating a matrix from euler angles, so there should be no problem.
Reply With Quote
  #7  
Old 02-20-2007, 12:37 PM
astull astull is offline
Member
 
Join Date: Dec 2005
Posts: 9
quatdiff c code?

I met with Andy B. today and he pointed me to the quatdiff function as a potential single metric solution to the error calculation. I know the function is available through Vizard but I'd like to verify it on paper. He said that you might be able to send me the C code.

Thanks again!
Reply With Quote
  #8  
Old 02-20-2007, 12:53 PM
farshizzo farshizzo is offline
WorldViz Team Member
 
Join Date: Mar 2003
Posts: 2,849
The QuatDiff function simply uses the above method of computing the angle difference between the forward and up vectors, and returns the maximum of those two values.

You can modify the sample code I gave you to replicate this behavior.
Reply With Quote
  #9  
Old 02-22-2007, 09:45 AM
farshizzo farshizzo is offline
WorldViz Team Member
 
Join Date: Mar 2003
Posts: 2,849
Here is some code that calculates the difference between two angles based on the method steve described:
Code:
import viz
import math
viz.go()

euler1 = [90,0,0]
euler2 = [0,0,90]

def ComputeAngleDifference(euler1, euler2):
       q1 = viz.Quat( vizmat.EulerToQuat(euler1) )
       q2 = viz.Quat( vizmat.EulerToQuat(euler2) )

       delta = q1 * q2.inverse()

       return viz.degrees( math.acos( delta.w ) ) * 2.0

print ComputeAngleDifference(euler1,euler2)
I'll updated Vizard's QuatDiff function to use this method in the next release.
Reply With Quote
Reply


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump


All times are GMT -7. The time now is 11:55 AM.


Powered by vBulletin® Version 3.8.7
Copyright ©2000 - 2024, vBulletin Solutions, Inc.
Copyright 2002-2023 WorldViz LLC