参考

三维旋转矩阵 + 矩阵加速

这个还要用到仿射变换。

平移

translate tx ty tz
1 0 0 tx
0 1 0 ty
0 0 1 tz
0 0 0 1
缩放
scale kx ky kz
kx 0  0  0
0  ky 0  0
0  0  kz 0
0  0  0  1
绕任意轴(过原点)旋转(注意要把轴向量归一化,不然会在“点在轴上”这个情况下出问题)
rotate x y z d
(1-cos(d))*x*x+cos(d)     (1-cos(d))*x*y-sin(d)*z   (1-cos(d))*x*z+sin(d)*y   0
(1-cos(d))*y*x+sin(d)*z   (1-cos(d))*y*y+cos(d)     (1-cos(d))*y*z-sin(d)*x   0
(1-cos(d))*z*x-sin(d)*y   (1-cos(d))*z*y+sin(d)*x   (1-cos(d))*z*z+cos(d)     0
                 0                                     0                                      0                       1
 
类似于一种构造矩阵的方式,每一种操作都相当于乘一次矩阵,具体第三个怎么推出来的没看懂。。。
 
矩阵乘法不支持交换律,一定要看好顺序。。debug了一天。。
据说会有-0.00这种答案不通过的坑,不过下面的代码加了eps..
 
 #include <iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<stdlib.h>
#include<vector>
#include<cmath>
#include<queue>
#include<set>
using namespace std;
#define N 1010
#define LL long long
#define INF 0xfffffff
#define forn(i,n) for(int i=0; i<(int)(n); i++)
const double eps = 1e-;
const double pi = acos(-1.0);
const double inf = ~0u>>; struct point3
{
double x,y,z;
} p[N];
struct Mat
{
double mat[][];
};
int n,m;
char str[];
Mat operator * (Mat a,Mat b)
{
Mat c;
memset(c.mat,,sizeof(c.mat));
int i,j,k;
for(i = ; i < n ; i++)
for(j = ; j < n ; j++)
for(k = ; k < n ; k++)
c.mat[i][j] +=a.mat[i][k]*b.mat[k][j];
return c;
}
Mat operator ^(Mat a,int k)
{
Mat c; int i,j;
for(i = ; i < n ; i++)
for(j = ; j < n ; j++)
c.mat[i][j] = (i==j);
for(; k ; k >>= )
{
if(k&) c = c*a;
a = a*a;
}
return c;
}
Mat solve(int k)
{ Mat cc;
double a[];
int i;
memset(cc.mat,,sizeof(cc.mat));
for(i = ; i < ; i++) cc.mat[i][i] = ;
while(~scanf("%s",str))
{
if(str[]=='e')
{
break;
}
Mat c;
memset(c.mat,,sizeof(c.mat));
for(i = ; i < ; i++) c.mat[i][i] = ;
if(str[]=='t')
{
forn(i,) scanf("%lf", &a[i]);
forn(i,) c.mat[i][]=a[i];
}
else if(str[]=='s')
{
for(i = ; i < ; i++)
scanf("%lf",&a[i]);
for(i = ; i < ; i++)
c.mat[i][i] = a[i];
}
else if(str[]=='r'&&str[]=='o')
{
for(i = ; i < ; i++) scanf("%lf",&a[i]);
a[] = a[]/*pi;
double mag=sqrt(a[]*a[]+a[]*a[]+a[]*a[]);
a[]/=mag;
a[]/=mag;
a[]/=mag;
c.mat[][] = (-cos(a[]))*a[]*a[]+cos(a[]);
c.mat[][] = (-cos(a[]))*a[]*a[]-sin(a[])*a[];
c.mat[][] = (-cos(a[]))*a[]*a[]+sin(a[])*a[];
c.mat[][] = (-cos(a[]))*a[]*a[]+sin(a[])*a[];
c.mat[][] = (-cos(a[]))*a[]*a[]+cos(a[]);
c.mat[][] = (-cos(a[]))*a[]*a[]-sin(a[])*a[];
c.mat[][] = (-cos(a[]))*a[]*a[]-sin(a[])*a[];
c.mat[][] = (-cos(a[]))*a[]*a[]+sin(a[])*a[];
c.mat[][] = (-cos(a[]))*a[]*a[]+cos(a[]);
}
else if(str[]=='r')
{
int kk ;
scanf("%d",&kk);
c = solve(kk);
}
cc = c*cc;
}
return cc^k;
}
int dcmp(double x)
{
if(fabs(x)<eps) return ;
return x<?-:;
}
int main()
{
int i,j;
n = ;
while(scanf("%d",&m)&&m)
{
Mat c;
memset(c.mat,,sizeof(c.mat));
for(i = ; i < n; i++) c.mat[i][i] = ;
c = solve()*c;
for(i = ; i <= m; i++)
{
Mat x,y;
memset(y.mat,,sizeof(y.mat));
for(j = ; j < ; j++)
scanf("%lf",&y.mat[j][]);
y.mat[][] = ;
x = c*y;
p[i].x = x.mat[][],p[i].y = x.mat[][],p[i].z = x.mat[][];
}
for(i = ; i <= m; i++)
{
printf("%.2f %.2f %.2f\n",p[i].x+eps,p[i].y+eps,p[i].z+eps);
}
puts("");
}
return ;
}

hdu4087ALetter to Programmers(三维旋转矩阵)的更多相关文章

  1. 三维卷积:全景图像Spherical CNNs(Code)

    卷积神经网络(CNN)可以很好的处理二维平面图像的问题.然而,对球面图像进行处理需求日益增加.例如,对无人机.机器人.自动驾驶汽车.分子回归问题.全球天气和气候模型的全方位视觉处理问题. 将球形信号的 ...

  2. 深入理解图优化与g2o:图优化篇

    前言 本节我们将深入介绍视觉slam中的主流优化方法——图优化(graph-based optimization).下一节中,介绍一下非常流行的图优化库:g2o. 关于g2o,我13年写过一个文档,然 ...

  3. 四轴飞行器1.1 Matlab 姿态显示

    四轴飞行器1.1 Matlab 姿态显示 开始做四轴了,一步一步来,东西实在很多,比较杂.先做matlab上位机,主要用来做数据分析,等板子到了可以写飞控的程序了,从底层一层一层开始写..希望能好好的 ...

  4. PostScript学习:另一种缩写为PS的技术

    1.前言 PostScript是一种编程语言,直译为"后处理脚本"[相对印刷过程而言],学名为页面描述语言.更为详细的解释见维基百科,以及其翻译版百度百科. 值得一提的是,Post ...

  5. Three.js 学习笔记(1)--坐标体系和旋转

    前言 JavaScript 3D library The aim of the project is to create an easy to use, lightweight, 3D library ...

  6. 相机标定问题-Matlab & Py-Opencv

    一.相机标定基本理论 1.相机成像系统介绍 图中总共有4个坐标系: 图像坐标系:Op    坐标表示方法(u,v)                 Unit:Dots(个) 成像坐标系:Oi      ...

  7. SLAM学习笔记 - 世界坐标系到相机坐标系的变换

    参考自: http://blog.csdn.net/yangdashi888/article/details/51356385 http://blog.csdn.net/li_007/article/ ...

  8. 高翔《视觉SLAM十四讲》从理论到实践

    目录 第1讲 前言:本书讲什么:如何使用本书: 第2讲 初始SLAM:引子-小萝卜的例子:经典视觉SLAM框架:SLAM问题的数学表述:实践-编程基础: 第3讲 三维空间刚体运动 旋转矩阵:实践-Ei ...

  9. 《SLAM十四讲》个人学习知识点梳理

    0.引言 从六月末到八月初大概一个月时间一直在啃SLAM十四讲[1]这本书,这本书把SLAM中涉及的基本知识点都涵盖了,所以在这里做一个复习,对这本书自己学到的东西做一个梳理. 书本地址:http:/ ...

随机推荐

  1. weblogic10异常:org.hibernate.hql.ast.HqlToken

    转自:http://www.programgo.com/article/68682994452/ 在做查询的时候,报出  org.hibernate.QueryException: ClassNotF ...

  2. 【皇甫】☀ 图_substring

    substring是啥?

  3. js 控制浏览器窗口大小

    //打开一个新窗口并设置其大小window.open('index.html','','width=450,height=750,location=no,menubar=no,status=no,to ...

  4. 目标检测方法——SSD

    SSD论文阅读(Wei Liu--[ECCV2016]SSD Single Shot MultiBox Detector) 目录 作者及相关链接 文章的选择原因 方法概括 方法细节 相关背景补充 实验 ...

  5. MVC 中301永久重定向

    public class PermanentRedirectResult : ViewResult { public string Url { get; set; } public Permanent ...

  6. Hdu 5489 合肥网络赛 1009 Removed Interval

    跳跃式LIS(nlogn),在普通的转移基础上增加一种可以跨越一段距离的转移,用一颗新的树状数组维护,同时,我们还要维护跨越完一次后面的转移,所以我用了3颗树状数组.. 比赛的时候一句话位置写错了,然 ...

  7. Html5的表单

    跨浏览器 https://github.com/westonruter/webforms2 https://github.com/Modernizr/Modernizr http://www.blog ...

  8. Andy - 又一款速度流畅的免费安卓 Android 模拟器 (支持手机无线控制电脑模拟器)

    随着 Genymotion.BlueStacks 等电脑上的 Android 模拟器流行起来之后,似乎很多人都发现在电脑上运行使用安卓APP软件.畅玩手机游戏确实很有乐趣. 今天我们又发现了一款全新免 ...

  9. hdu2068RPG的错排

    Problem Description 今年暑假杭电ACM集训队第一次组成女生队,其中有一队叫RPG,但做为集训队成员之一的野骆驼竟然不知道RPG三个人具体是谁谁.RPG给他机会让他猜猜,第一次猜:R ...

  10. CSS 样式优先级

    首先,选择器优先级顺序 优先级逐级增加的选择器列表: 通用选择器(*) 元素(类型)选择器 类选择器 属性选择器 伪类 ID 选择器 内联样式 !important 规则例外,该样式声明会覆盖CSS中 ...