闲聊js17: 动画、数学与碰撞检测3(介绍一个支持simd,消除装箱拆箱的js数学库)

本篇目的:

  • gl-matrix库介绍
  • GPU为什么这么快
  • js新增的基本数据类型数组
  • 简单了解simd
  • 解释gl-matrix中各个数学类的用途以及2d中需要使用哪些类

gl-matrix简介:

  • gl-matrix github

  • gl-matrix官网文档

  • 介绍:
    Javascript has evolved into a language capable of handling realtime 3D graphics, via WebGL, and computationally intensive tasks such as physics simulations. These types of applications demand high performance vector and matrix math, which is something that Javascript doesn't provide by default. glMatrix to the rescue!

    glMatrix is designed to perform vector and matrix operations stupidly fast! By hand-tuning each function for maximum performance and encouraging efficient usage patterns through API conventions, glMatrix will help you get the most out of your browsers Javascript engine.

  • 从名称gl开头,就知道gl-matrix支持的是opengl风格的矩阵表示,这个以后在3D时候在讲吧。目前,了解一下就可以了,或者参考我写的Unity3D数学库的几个关键点这篇文章吧,不过也不详细,只是我对unity3d系统的数学库的总结。
    当你使用一个新的游戏引擎的时候,第一件事情就是了解坐标系,及数学系统是如何表示的。

  • 看一下gl-matrix中common.js源码:

var glMatrix = {};

// Configuration Constants
glMatrix.EPSILON = 0.000001;
glMatrix.ARRAY_TYPE = (typeof Float32Array !== 'undefined') ? Float32Array : Array;
glMatrix.RANDOM = Math.random;
glMatrix.ENABLE_SIMD = false;

// Capability detection
glMatrix.SIMD_AVAILABLE = (glMatrix.ARRAY_TYPE === this.Float32Array) && ('SIMD' in this);
glMatrix.USE_SIMD = glMatrix.ENABLE_SIMD && glMatrix.SIMD_AVAILABLE;

如果js引擎支持内置对象Float32Array的话,则使用Float32Array,否则,使用Array对象

这是为了避免装箱拆箱(在2d 3d中,顶点变换是极其多的,可能会上万顶点数据进行矩阵变换,上万次的内存分配,复制,析构,好可怕!)

关于基本数据类型的装箱拆箱,可以参考我写的闲聊c/c++: 再谈内存(c/c++,java,c#,js,objc中的大小端以及装箱拆箱和统一类型系统)

关于SIMD,目前基本没有浏览器支持,属于实验性质的js库。

为什么GPU速度这么快:

  1. 是因为其流水线设计是专门针对3D变换,像素操作等功能,可以进行高度优化。而cpu必须要通用性,其流水线设计无法像GPU那样有针对性

  2. simd(cpu也支持,需要16byte对齐,高效利用cpu缓存)。整个GPU操作的数据类型,你会发现只有浮点数,而且都可以看成128bit数据(324):
    矢量 vector [x,y,z,w]
    四元数 quaternion [x,y,z,q]
    RGBA [r,g,b,a]
    plane [a,b,c,d]
    matrix 3行4列,相当于3个vector4
    GPU操作的数据类型都是128位对齐的浮点数。
    SIMD就是
    单指令多数据流*,一个add指令,将x,y,z,w同时做加法(一个add指令,同时做四次加法运算),而没有simd时候,必须x+x1,y+y1,z+z1,w+w1,简单形象理解就是如此而已!其实GPU还有很多重要的指标,例如位宽之类的,寄存器数量.....,以后我会专门写一片关于GPU以及高到18级以上的流水线相关文章,来介绍GPU编程方面的基础理论知识

  3. GPU的输入是顶点数据(位置,纹理坐标,输入颜色,.....,gl中称为vertex attributes,表示的是矢量信息),经过漫长的变换流水线,输出为RBGA颜色值(图像)。输出的目标可以是帧缓存(显示到电脑屏幕),也可以是纹理(渲染到纹理,然后再给纹理做各种特效,例如模糊,高光....等数字图像处理,视频也可以输出到纹理,进行播放)。

  4. 目前的超级计算机很多都是使用GPU集群进行计算,使用的是GPGPU(General Purpose GPU),原理和渲染流水线是一样的,将输入数据以顶点或像素方式表示,经过计算,输出到纹理中,然后从纹理读取计算后的结果。充分利用GPU强大的计算能力,实现通用计算。目前opencl标准就是该目的(opencv/opencl/opengl/openal这些都是很强大的库,搞图形图像音频GPU通用计算,还是需要了解或掌握的.而搞游戏引擎开发,那一定要深入了解。) 现在知道挖矿为什么要用顶级的GPU了吧。

  5. simd在cpu中也是长久的存在,intel 从mmx(1997年)到sse5,持续对simd进行支持(加速内存memcpy,图像处理,3D数学计算,音频视频编码解码.....,很多指令有专门用途)。各个平台,例如amd,arm都有对simd提供支持,具体查文档吧!

  6. 测试了一下,目前所有浏览器还没支持simd功能

gl-matrix中的类的作用:

  • mat2.js 表示2D旋转或缩放矩阵(无平移效果)
  • mat2d.js 表示2D仿射矩阵
  • mat3,js 表示3D旋转或缩放矩阵(无平移效果)
  • mat4.js 通用表示,支持仿射变换,投影变换,view摄像机矩阵等等
  • quat.js 四元数,表示物体旋转或朝向
  • vec2.js 2维矢量
  • vec3.js 3维矢量
  • vec4.js 4维矢量(齐次坐标)可以兼容表示plane(平面)数据,依赖你的操作

对于我们的2D引擎来说,只需要vec2.js 和 mat2d.js就能解决数学相关问题,mat2.js基本没啥用。其他的几个类用于3D操作。

下一篇,我们就来了解gl-matrix中的vec2.js

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容

  • 1 前言 一直想沿着图像处理这条线建立一套完整的理论知识体系,同时积累实际应用经验。因此有了从使用AVFounda...
    RichardJieChen阅读 5,651评论 5 12
  • 看了很多视频、文章,最后却通通忘记了,别人的知识依旧是别人的,自己却什么都没获得。此系列文章旨在加深自己的印象,因...
    DCbryant阅读 1,857评论 0 4
  • Android平台下OpenGL初步 Android OpenGL ES 开发教程 从入门到精通http://bl...
    garyhu1阅读 1,488评论 1 2
  • 本篇主要讲解GPUImage底层是如何渲染的,GPUImage底层使用的是OPENGL,操控GPU来实现屏幕展示 ...
    wo不懂阅读 2,233评论 4 4
  • lua编程中,经常遇到函数的定义和调用,有时候用点号调用,有时候用冒号调用,这里简单的说明一下原理。 girl={...
    Lee坚武阅读 5,230评论 0 52