关键词不能为空

当前您在: 主页 > 高中公式大全 >

高三三角函数公式根据旋转前后的向量值求旋转矩阵

作者:高考题库网
来源:https://www.bjmy2z.cn/gaokao
2020-10-15 11:22
tags:旋转角公式

英语一题型-适合女生创业的项目

2020年10月15日发(作者:宦廷铨)
根据旋转前后的向量值求旋转矩阵

如果已知旋转前后的一向量的变化,那么该如何求这个旋转矩阵呢?本篇结合Rodrigues' rotation formula,
介绍一下该旋转矩阵的求法。
1.旋转角度
已知旋转前向量为P, 旋转后变为Q。由点积定义可知:
可推出P,Q之间的夹角为:
2. 旋转轴
由1中可知,旋转角所在的平面为有P和Q所构成的平面,那么旋转轴必垂直该平面。
假定旋转前向量为a(a1, a2, a3), 旋转后向量为b(b1, b2, b3)。由叉乘定义得:

所以旋转轴c(c1, c2, c3)为:
3. 罗德里格旋转公式(Rodrigues' rotation formula)
3.1 公式
已知单位向量

, 将它旋转θ角。由罗德里格旋转公式,可知对应的旋转矩阵

其中I是3x3的单位矩阵,
是叉乘中的反对称矩阵r:

3.2 公式证明
假设在坐标系(x, y, z)中,向量v=ax+by+cz,v绕z轴逆时针旋转θ角后得到新的向量v’。

根据2维(x,y)面上的旋转公式可得:

推出:
已知:
将上式带入v’的公式:
将cz替换掉,可得:

将上式中的叉乘表示为反对称矩阵得:

另外:

最终可以推出:

上式即为罗德里格旋转公式。
4. 求旋转矩阵 根据旋转前后的两个向量值,使用上面的方法,先求出旋转角度和旋转轴,然后用罗德里格旋转公式即可求出对应的旋转矩阵。
C#的实现代码如下:

void Calculation(double[] vectorBefore, double[] vectorAfter)
{
double[] rotationAxis;
double rotationAngle;
double[,] rotationMatrix;
rotationAxis = CrossProduct(vectorBefore, vectorAfter);
rotationAngle = (DotProduct(vectorBefore, vectorAfter) Normalize(vectorBefore)
Normalize(vectorAfter));
rotationMatrix = RotationMatrix(rotationAngle, rotationAxis);
}
double[] CrossProduct(double[] a, double[] b)
{
double[] c = new double[3];
c[0] = a[1] * b[2] - a[2] * b[1];
c[1] = a[2] * b[0] - a[0] * b[2];
c[2] = a[0] * b[1] - a[1] * b[0];
return c;
}
double DotProduct(double[] a, double[] b)
{
double result;
result = a[0] * b[0] + a[1] * b[1] + a[2] * b[2];
return result;
}
double Normalize(double[] v)
{
double result;
result = (v[0] * v[0] + v[1] * v[1] + v[2] * v[2]);
return result;
}
double[,] RotationMatrix(double angle, double[] u)
{
double norm = Normalize(u);
double[,] rotatinMatrix = new double[3,3];
u[0] = u[0] norm;
u[1] = u[1] norm;
u[2] = u[2] norm;
rotatinMatrix[0, 0] = (angle) + u[0] * u[0] * (1 - (angle));
rotatinMatrix[0, 0] = u[0] * u[1] * (1 - (angle) - u[2] * (angle));
rotatinMatrix[0, 0] = u[1] * (angle) + u[0] * u[2] * (1 - (angle));
rotatinMatrix[0, 0] = u[2] * (angle) + u[0] * u[1] * (1 - (angle));
rotatinMatrix[0, 0] = (angle) + u[1] * u[1] * (1 - (angle));
rotatinMatrix[0, 0] = -u[0] * (angle) + u[1] * u[2] * (1 - (angle));
rotatinMatrix[0, 0] = -u[1] * (angle) + u[0] * u[2] * (1 - (angle));
rotatinMatrix[0, 0] = u[0] * (angle) + u[1] * u[2] * (1 - (angle));
rotatinMatrix[0, 0] = (angle) + u[2] * u[2] * (1 - (angle));
return rotatinMatrix;
}

韦应物最著名的诗-后学


世界有几个洲-考试秘笈


clear的比较级-原画师


高中班主任寄语-男生青春期


掌门1对1-培训机构学费


湖南新高考方案-致政


26个英语字母大小写-日本留学费用


老龄化问题-指南针什么时候发明的



本文更新与2020-10-15 11:22,由作者提供,不代表本网站立场,转载请注明出处:https://www.bjmy2z.cn/gaokao/413612.html

根据旋转前后的向量值求旋转矩阵的相关文章

  • 余华爱情经典语录,余华爱情句子

    余华的经典语录——余华《第七天》40、我不怕死,一点都不怕,只怕再也不能看见你——余华《第七天》4可是我再也没遇到一个像福贵这样令我难忘的人了,对自己的经历如此清楚,

    语文
  • 心情低落的图片压抑,心情低落的图片发朋友圈

    心情压抑的图片(心太累没人理解的说说带图片)1、有时候很想找个人倾诉一下,却又不知从何说起,最终是什么也不说,只想快点睡过去,告诉自己,明天就好了。有时候,突然会觉得

    语文
  • 经典古训100句图片大全,古训名言警句

    古代经典励志名言100句译:好的药物味苦但对治病有利;忠言劝诫的话听起来不顺耳却对人的行为有利。3良言一句三冬暖,恶语伤人六月寒。喷泉的高度不会超过它的源头;一个人的事

    语文
  • 关于青春奋斗的名人名言鲁迅,关于青年奋斗的名言鲁迅

    鲁迅名言名句大全励志1、世上本没有路,走的人多了自然便成了路。下面是我整理的鲁迅先生的名言名句大全,希望对你有所帮助!当生存时,还是将遭践踏,将遭删刈,直至于死亡而

    语文
  • 三国群英单机版手游礼包码,三国群英手机单机版攻略

    三国群英传7五神兽洞有什么用那是多一个武将技能。青龙飞升召唤出东方的守护兽,神兽之一的青龙。玄武怒流召唤出北方的守护兽,神兽之一的玄武。白虎傲啸召唤出西方的守护兽,

    语文
  • 不收费的情感挽回专家电话,情感挽回免费咨询

    免费的情感挽回机构(揭秘情感挽回机构骗局)1、牛牛(化名)向上海市公安局金山分局报案,称自己为了挽回与女友的感情,被一家名为“实花教育咨询”的情感咨询机构诈骗4万余元。

    语文