亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? inverse.cpp

?? Windows上的MUD客戶端程序
?? CPP
字號:
/*----------------------------------------------------------------------------
                        _                              _ _       
        /\             | |                            | (_)      
       /  \   _ __   __| |_ __ ___  _ __ ___   ___  __| |_  __ _ 
      / /\ \ | '_ \ / _` | '__/ _ \| '_ ` _ \ / _ \/ _` | |/ _` |
     / ____ \| | | | (_| | | | (_) | | | | | |  __/ (_| | | (_| |
    /_/    \_\_| |_|\__,_|_|  \___/|_| |_| |_|\___|\__,_|_|\__,_|

    The contents of this file are subject to the Andromedia Public
	License Version 1.0 (the "License"); you may not use this file
	except in compliance with the License. You may obtain a copy of
	the License at http://www.andromedia.com/APL/

    Software distributed under the License is distributed on an
	"AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
	implied. See the License for the specific language governing
	rights and limitations under the License.

    The Original Code is Pueblo client code, released November 4, 1998.

    The Initial Developer of the Original Code is Andromedia Incorporated.
	Portions created by Andromedia are Copyright (C) 1998 Andromedia
	Incorporated.  All Rights Reserved.

	Andromedia Incorporated                         415.365.6700
	818 Mission Street - 2nd Floor                  415.365.6701 fax
	San Francisco, CA 94103

    Contributor(s):
	--------------------------------------------------------------------------
	   Chaco team:  Dan Greening, Glenn Crocker, Jim Doubek,
	                Coyote Lussier, Pritham Shetty.

					Wrote and designed original codebase.

------------------------------------------------------------------------------

----------------------------------------------------------------------------*/

#if ( _MSC_VER > 900	 )
#pragma warning( disable: 4237 )
#endif
#include <ChTypes.h>
#include "GxTypes.h"
#include "GxTrnsfm.h"
#include <stdio.h>

/****
 *
 * affine_matrix4_inverse
 *
 * Computes the inverse of a 3D affine matrix; i.e. a matrix with a dimen-
 * sionality of 4 where the right column has the entries (0, 0, 0, 1).
 *
 * This procedure treats the 4 by 4 matrix as a block matrix and
 * calculates the inverse of one submatrix for a significant perform-
 * ance improvement over a general procedure that can invert any non-
 * singular matrix:
 *          --        --          --          --
 *          |          | -1       |    -1      |
 *          | A      0 |          |   A      0 |
 *    -1    |          |          |            |
 *   M   =  |          |     =    |     -1     |
 *          | C      1 |          | -C A     1 |
 *          |          |          |            |
 *          --        --          --          --
 *
 *  where     M is a 4 by 4 matrix,
 *            A is the 3 by 3 upper left submatrix of M,
 *            C is the 1 by 3 lower left submatrix of M.
 *
 * Input:
 *   in   - 3D affine matrix
 *
 * Output:
 *   out  - inverse of 3D affine matrix
 *
 * Returned value:
 *   TRUE   if input matrix is nonsingular
 *   FALSE  otherwise
 *
 ***/

bool
affine_matrix4_inverse (GxTransformF_t &in, GxTransformF_t &out)
{
    register  double    det_1;
    double    pos, neg, temp;

#define ACCUMULATE    \
    if (temp >= 0.0)  \
        pos += temp;  \
    else              \
        neg += temp;

//#define PRECISION_LIMIT (1.0e-15)
#define PRECISION_LIMIT (1.0e-7)

    /*
     * Calculate the determinant of submatrix A and determine if the
     * the matrix is singular as limited by the single (or double) precision
     * floating-point data representation.
     */
    pos = neg = 0.0;
    temp =  in[0][0] * in[1][1] * in[2][2];
    ACCUMULATE
    temp =  in[0][1] * in[1][2] * in[2][0];
    ACCUMULATE
    temp =  in[0][2] * in[1][0] * in[2][1];
    ACCUMULATE
    temp = -in[0][2] * in[1][1] * in[2][0];
    ACCUMULATE
    temp = -in[0][1] * in[1][0] * in[2][2];
    ACCUMULATE
    temp = -in[0][0] * in[1][2] * in[2][1];
    ACCUMULATE
    det_1 = pos + neg;

    /* Is the submatrix A singular? */
    if ((det_1 == 0.0) || (fabs(det_1 / (pos - neg)) < PRECISION_LIMIT)) {

        /* Matrix M has no inverse */
        fprintf (stderr, "affine_matrix4_inverse: singular matrix\n");
        return FALSE;
    }

    else {

        /* Calculate inverse(A) = adj(A) / det(A) */
        det_1 = 1.0 / det_1;
        out[0][0] =   ( in[1][1] * in[2][2] -
                                 in[1][2] * in[2][1] )
                               * det_1;
        out[1][0] = - ( in[1][0] * in[2][2] -
                                 in[1][2] * in[2][0] )
                               * det_1;
        out[2][0] =   ( in[1][0] * in[2][1] -
                                 in[1][1] * in[2][0] )
                               * det_1;
        out[0][1] = - ( in[0][1] * in[2][2] -
                                 in[0][2] * in[2][1] )
                               * det_1;
        out[1][1] =   ( in[0][0] * in[2][2] -
                                 in[0][2] * in[2][0] )
                               * det_1;
        out[2][1] = - ( in[0][0] * in[2][1] -
                                 in[0][1] * in[2][0] )
                               * det_1;
        out[0][2] =   ( in[0][1] * in[1][2] -
                                 in[0][2] * in[1][1] )
                               * det_1;
        out[1][2] = - ( in[0][0] * in[1][2] -
                                 in[0][2] * in[1][0] )
                               * det_1;
        out[2][2] =   ( in[0][0] * in[1][1] -
                                 in[0][1] * in[1][0] )
                               * det_1;

        /* Calculate -C * inverse(A) */
        out[3][0] = - ( in[3][0] * out[0][0] +
                                 in[3][1] * out[1][0] +
                                 in[3][2] * out[2][0] );
        out[3][1] = - ( in[3][0] * out[0][1] +
                                 in[3][1] * out[1][1] +
                                 in[3][2] * out[2][1] );
        out[3][2] = - ( in[3][0] * out[0][2] +
                                 in[3][1] * out[1][2] +
                                 in[3][2] * out[2][2] );

        /* Fill in last column */
        out[0][3] = out[1][3] = out[2][3] = 0.0;
        out[3][3] = 1.0;

        return TRUE;
    }
}








?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩av不卡一区二区| 欧美不卡123| 国产欧美日韩麻豆91| 成人网页在线观看| 国产精品久久国产精麻豆99网站| 成人午夜av电影| 成人免费视频一区| 国产伦精品一区二区三区免费迷 | 欧美激情资源网| 欧美丝袜丝交足nylons| 亚洲成人自拍偷拍| 精品人在线二区三区| 精品美女在线播放| 国产性天天综合网| 欧美丰满少妇xxxxx高潮对白| 精品在线免费观看| 亚洲人成伊人成综合网小说| 欧美肥胖老妇做爰| 欧美不卡视频一区| 中文字幕中文字幕中文字幕亚洲无线| 中文字幕中文字幕一区二区| 伊人夜夜躁av伊人久久| 国产欧美一区二区精品秋霞影院| 欧美国产综合色视频| 一区二区三区不卡在线观看 | 91免费在线视频观看| 日本成人在线视频网站| 国产一区福利在线| 日本道免费精品一区二区三区| 久久精品免费看| 日韩高清不卡一区二区| 国产麻豆一精品一av一免费| 99精品国产视频| 色综合久久综合中文综合网| 国产成人自拍网| 国产综合成人久久大片91| 日韩影视精彩在线| 亚洲v精品v日韩v欧美v专区 | 波多野结衣中文字幕一区| 极品少妇xxxx偷拍精品少妇| 99久久免费视频.com| 日韩精品一区二区三区蜜臀| 6080日韩午夜伦伦午夜伦| 欧美日韩大陆在线| 欧美性高清videossexo| 欧美精品一区二区三区在线| 日韩丝袜美女视频| 精品久久人人做人人爽| 亚洲自拍都市欧美小说| 婷婷一区二区三区| 免费成人在线观看视频| 国产一区二区三区在线看麻豆 | 男人的j进女人的j一区| 91麻豆国产福利在线观看| 精品国产一区二区三区久久久蜜月| 亚洲欧洲综合另类| proumb性欧美在线观看| 色婷婷久久99综合精品jk白丝| 欧美精品一区二区三区在线播放| 香蕉影视欧美成人| 91国模大尺度私拍在线视频| 国产精品卡一卡二| 极品少妇xxxx精品少妇偷拍| 日韩美女视频一区二区在线观看| 五月开心婷婷久久| 在线亚洲一区二区| 色8久久精品久久久久久蜜| 中文一区二区完整视频在线观看| 国产自产2019最新不卡| 欧美mv日韩mv| 国内外成人在线视频| 欧美tk丨vk视频| 麻豆精品在线播放| www.色综合.com| 国产精品久久久久影视| 成人午夜看片网址| 国产精品毛片无遮挡高清| 亚洲一区二区五区| 欧美丝袜丝交足nylons图片| 亚洲国产aⅴ天堂久久| 国产精品亚洲专一区二区三区 | 日韩欧美成人一区二区| 免费成人在线影院| 国产亚洲欧洲997久久综合| 国产精品一二三四| 日韩毛片视频在线看| 日韩精品免费视频人成| 日韩精品在线网站| 国产成人免费视频网站| 欧美国产一区二区| 欧洲另类一二三四区| 日韩—二三区免费观看av| 精品日韩一区二区三区免费视频| 国产精品亚洲综合一区在线观看| 国产精品入口麻豆原神| 在线视频国内自拍亚洲视频| 日本美女一区二区| 中文字幕免费不卡| 欧美日韩黄色影视| 国产一区二三区| 亚洲欧美激情插| 欧美一区二区在线看| 午夜欧美在线一二页| 日韩欧美一区二区三区在线| 成人美女视频在线看| 亚洲第一在线综合网站| 久久久欧美精品sm网站| 韩国v欧美v亚洲v日本v| 中文字幕日本乱码精品影院| 高清成人免费视频| 国产日韩欧美高清在线| 欧美在线免费观看视频| 国产一区二区三区在线看麻豆| 亚洲男女一区二区三区| 久久综合九色综合97_久久久| 麻豆国产欧美日韩综合精品二区| 国产精品天美传媒沈樵| 欧美精品在线一区二区三区| 国产suv精品一区二区6| 日韩av中文字幕一区二区 | 欧美疯狂性受xxxxx喷水图片| 国产91精品久久久久久久网曝门| 一区二区三区四区乱视频| 国产亚洲精品bt天堂精选| 欧美日韩免费不卡视频一区二区三区| 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品你懂的在线| 91精品国产乱码| 欧洲人成人精品| av不卡在线观看| 国产一区视频网站| 精品一区二区三区在线播放| 亚洲国产精品久久久久婷婷884| 国产精品色呦呦| 国产调教视频一区| 精品国产乱码久久久久久蜜臀| 欧美日韩国产乱码电影| 色婷婷av一区| 91网站最新网址| 91在线免费播放| 高清免费成人av| 国产成人综合网| 国产成a人亚洲精| 国产伦精品一区二区三区在线观看 | 日韩有码一区二区三区| 亚洲国产cao| 午夜精品久久久久| 亚洲在线视频网站| 亚洲一区二区在线免费观看视频| 亚洲激情校园春色| 亚洲一区二区免费视频| 亚洲宅男天堂在线观看无病毒| 亚洲激情av在线| 亚洲国产一区二区在线播放| 夜夜爽夜夜爽精品视频| 亚洲成a人v欧美综合天堂| 日韩中文字幕不卡| 美女尤物国产一区| 国内成+人亚洲+欧美+综合在线 | 欧美一区二区美女| 欧美xxxxxxxxx| 久久精品一级爱片| 国产精品麻豆欧美日韩ww| 亚洲欧美综合在线精品| 亚洲国产视频a| 蜜臀av在线播放一区二区三区| 免费高清在线视频一区·| 韩国成人在线视频| 91网页版在线| 4438x亚洲最大成人网| xfplay精品久久| 国产精品嫩草影院av蜜臀| 亚洲成人免费观看| 狠狠色狠狠色综合日日91app| 成人毛片老司机大片| 欧美在线免费观看亚洲| 精品少妇一区二区三区在线播放| 中文字幕欧美日韩一区| 午夜电影久久久| 国产成人在线视频网站| 在线中文字幕不卡| 欧美电影免费观看完整版| 国产精品对白交换视频| 天天射综合影视| 成人精品鲁一区一区二区| 欧美三级在线播放| 欧美色图12p| 久久品道一品道久久精品| 亚洲激情成人在线| 国产精品自拍在线| 欧美精品 国产精品| 欧美精彩视频一区二区三区| 亚洲成a人v欧美综合天堂| 国产a精品视频| 777午夜精品免费视频| 综合中文字幕亚洲| 国产一区二区在线电影| 欧美日韩三级视频| 亚洲男人都懂的| 成人av在线电影|