• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天行健 君子當自強而不息

            3D中的方位和角位移(8)

            新建網頁 1

             

            從歐拉角轉換到四元數

            為了將角位移從歐拉角轉換到四元數,可以使用從歐拉角構造矩陣類似的方法。先將這三個旋轉分別轉換為四元數,這是一個簡單的運算。再將這三個四元數連接成一個四元數。和矩陣一樣,有兩種情況需要考慮,第一種是慣性 -- 物體四元數,第二種是物體-- 慣性四元數。因為它們互為共軛關系,所以我們只推導慣性--物體四元數。

            設歐拉角為變量h、p、b,設h、p、b分別繞軸yx、z旋轉的四元數。記住,使用負旋轉量,因為它們指定坐標系中的旋轉角度。

            用正確的順序連接它們得到公式10.24

            (記住,四元數乘法定義是按旋轉的順序從左向右乘。)

            物體--慣性四元數是慣性--物體四元數的共軛,見公式10.25

             

            從四元數轉換到歐拉角

            根據前面的公式發現:

            現在可以將它直接轉換到代碼中,如程序清單10.5所示,它能把慣性--物體四元數轉換成歐拉角。

                    Listing 10.5: Converting an inertial-to-object quaternion to Euler angles
                
                
                // Use global variables for input and output
                
            float w,x,y,z;
                
            float h,p,b;
                
                
            // Extract sin(pitch)
                
            float sp = –2.0f * (y*z + w*x);
                
                
            // Check for Gimbal lock, giving slight tolerance for numerical imprecision
                
            if (fabs(sp) > 0.9999f) {
                  
            // Looking straight up or down
                
              p = 1.570796f * sp; // pi/2
                
                  // Compute heading, slam bank to zero
                
                  h = atan2(–x*z – w*y, 0.5f – y*y – z*z);
                  b = 0.0f;
                } 
            else {
                  
            // Compute angles
                
              p = asin(sp);
                  h = atan2(x*z – w*y, 0.5f – x*x – y*y);
                  b = atan2(x*y – w*z, 0.5f – x*x – z*z);
                }

            將物體--慣性四元數轉換到歐拉角,所用的代碼和上面非常類似。只是將x、yz值變負,因為物體--慣性四元數是慣性--物體四元數的共軛。

                    Listing 10.6: Converting an object-to-inertial quaternion to Euler angles
                
                
            // Extract sin(pitch)
                
            float sp = –2.0f * (y*z – w*x);
                
                
            // Check for Gimbal lock, giving slight tolerance for numerical imprecision
                
            if (fabs(sp) > 0.9999f) {
                  
            // Looking straight up or down
                
              p = 1.570796f * sp; // pi/2
                
                  // Compute heading, slam bank to zero
                
                  h = atan2(–x*z + w*y, 0.5f – y*y – z*z);
                  b = 0.0f;
                } 
            else {
                  
            // Compute angles
                
              p = asin(sp);
                  h = atan2(x*z + w*y, 0.5f – x*x – y*y);
                  b = atan2(x*y + w*z, 0.5f – x*x – z*z);
                }

            posted on 2008-02-16 12:50 lovedday 閱讀(1180) 評論(3)  編輯 收藏 引用

            評論

            # re: 3D中的方位和角位移(8) 2008-04-17 15:57 miyuki

            請問你的10.23公式在哪里,還有四元數轉歐拉角里面的x,y,z,w分別是什么?  回復  更多評論   

            # re: 3D中的方位和角位移(8) 2008-04-17 15:57 miyuki

            能否將這幾個圖片的原文件給我看看,謝 謝
              回復  更多評論   

            # re: 3D中的方位和角位移(8) 2008-04-17 17:48 lovedday

            @miyuki
            圖片是從《3D Math Primer for Graphics and Game Development》電子書上截取的,公式10.23在3D中的方位和角位移(7)里,x,y,z,w就是四元數的各個分量。  回復  更多評論   

            公告

            導航

            統計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關鏈接

            搜索

            最新評論

            无码精品久久一区二区三区| 好久久免费视频高清| 中文字幕无码久久久| 久久久久久国产a免费观看黄色大片 | 婷婷久久五月天| 丁香狠狠色婷婷久久综合| 国产午夜精品久久久久九九电影| 一本色综合久久| 狠狠色婷婷综合天天久久丁香 | 欧美日韩中文字幕久久久不卡 | 久久66热人妻偷产精品9| 国产精品一区二区久久精品无码| 久久经典免费视频| 久久免费国产精品一区二区| 精品久久久中文字幕人妻 | 国产一区二区久久久| 狠狠狠色丁香婷婷综合久久五月 | 97精品久久天干天天天按摩| 久久综合视频网站| 国产亚洲成人久久| 久久久久久久尹人综合网亚洲 | 久久久精品波多野结衣| 久久99久久99精品免视看动漫| 日本亚洲色大成网站WWW久久| 久久久久久综合一区中文字幕| 免费无码国产欧美久久18| 久久久久亚洲AV无码专区网站| 亚洲精品高清国产一久久| 久久久久久九九99精品| 人妻无码久久一区二区三区免费 | 久久九九青青国产精品| 久久婷婷五月综合色高清| 久久夜色精品国产噜噜亚洲a| 久久人人爽人人精品视频| 丰满少妇人妻久久久久久4| 久久精品国产91久久综合麻豆自制| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 久久久久国产日韩精品网站| 精品久久久久久久中文字幕| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久午夜福利无码1000合集|