解决rotationtransform

时间:2012-08-29 22:35:39

标签: wolfram-mathematica

我对重建仿射变换矩阵存在问题。 翻译矩阵重建工作得很好,但不是旋转。

谢谢你们!

(*Works just fine*)
Clear["Global`*"]
data = RandomReal[10, {100, 3}];
data0 = TranslationTransform[{1, -1, 1}]@data;
{dX0, dY0, dZ0} /. 
 Solve[data0 == TranslationTransform[{dX0, dY0, dZ0}]@data, {dX0, dY0,
    dZ0}]


(*Yields {} ????*)
Clear["Global`*"]
data = RandomReal[10, {10, 3}];
data0 = RotationTransform[10 , {1, 0, 0}]@data;
Solve[data0 == RotationTransform[aZ0 Degree, {0, 0, 1}]@data, {aZ0}]

1 个答案:

答案 0 :(得分:0)

对于一个var,你有太多的方程式。

data = RandomReal[1, {10, 3}];
data0 = RotationMatrix[1/2, {1, 0, 0}].# & /@ data;
Solve[Thread[data[[1]] == RotationMatrix[aZ0, {1, 0, 0}].data0[[1]]][[2]], {aZ0}]
(*
-> -0.5
*)