OpenGL, GLSL, DirectX, HLSL中的矩阵存储形式
2015-09-19 12:16
836 查看
OpenGL, GLSL, DirectX, HLSL中的矩阵存储形式
OpenGL: 按列存储矩阵(column-major)。调用API形成的矩阵用来和一个列向量相乘,矩阵在左,列向量在右
GLSL: 存储方式和OpenGL相同(column-major)
DirectX: 按行存储矩阵(row-major)。调用API形成的矩阵用来和一个行向量相乘,矩阵在右,行向量在左
HLSL: 存储方式和DirectX相反(column-major)
因此,若HLSL的矩阵也是用来右乘行向量,则应将DX API构造的矩阵做Transpose,这样数学上HLSL会将Transpose后的矩阵视为 和DX API构造的矩阵是同一个矩阵,但是实际数值的存储顺序不同。若用来将矩阵左乘列向量,则可以不必做Transpose。
因此,一般的传入shader的操作是原封不动的将用来存储矩阵的array导入shader。但是如果是用的effect system里的setMatrix(), 则会先自动将矩阵由row-major改为colunn-major存储,再将其导入shader。这种情况下则无需在导入前手动Transpose 矩阵。
(原文地址:http://alvincc-tech.blogspot.com/2010/10/opengl-glsl-directx-hlsl.html)
OpenGL: 按列存储矩阵(column-major)。调用API形成的矩阵用来和一个列向量相乘,矩阵在左,列向量在右
GLSL: 存储方式和OpenGL相同(column-major)
DirectX: 按行存储矩阵(row-major)。调用API形成的矩阵用来和一个行向量相乘,矩阵在右,行向量在左
HLSL: 存储方式和DirectX相反(column-major)
因此,若HLSL的矩阵也是用来右乘行向量,则应将DX API构造的矩阵做Transpose,这样数学上HLSL会将Transpose后的矩阵视为 和DX API构造的矩阵是同一个矩阵,但是实际数值的存储顺序不同。若用来将矩阵左乘列向量,则可以不必做Transpose。
因此,一般的传入shader的操作是原封不动的将用来存储矩阵的array导入shader。但是如果是用的effect system里的setMatrix(), 则会先自动将矩阵由row-major改为colunn-major存储,再将其导入shader。这种情况下则无需在导入前手动Transpose 矩阵。
(原文地址:http://alvincc-tech.blogspot.com/2010/10/opengl-glsl-directx-hlsl.html)
相关文章推荐
- hadoop环境搭建
- Linux内核升级
- opencv特效编辑之雕刻效果
- Photoshop和WPF双剑配合,打造炫酷个性的进度条控件
- aop的概念总结
- 使用popwindows实现Actionbar右上角的小菜单
- LINK : fatal error LNK1104: cannot open file "mfc42u.lib"
- linux 信号
- Linux修改eth2到eth0
- aop的需求分析:错误异常分析
- 错误Unable to load native-hadoop library for your platform...
- WebRTC VideoEngine超详细教程(二)——集成OPENH264编解码器
- Linux系统定时任务
- 组建自己的Linux-04启动Linux并测试
- Linux初学——管理文件与目录(上)
- linux下软件安装的方法
- Linux Shell
- (转)ECSHOP给分类添加代表图
- 【转】【调试技巧】Linux环境下段错误的产生原因及调试方法小结
- 安卓PopupWindow使用详解与源码分析(附项目实例)