All Downloads are FREE. Search and download functionalities are using the official Maven repository.

native-prism-sw.PiscesTransform.c Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

/**
 * @file PiscesTransform.c
 * Basic matrix algebra.
 */

#include 
#include 

/**
 * This function simply copies data from source transformation matrix pointed to 
 * by transformS to destination pointed to by transformD.
 */  
void
pisces_transform_assign(Transform6* transformD, const Transform6* transformS) {
    memcpy(transformD, transformS, sizeof(Transform6));
}

/**
 * This function computes inverse transformation matrix of *transform. Result is
 * stored in structure pointed to by transform. 
 */ 
void
pisces_transform_invert(Transform6* transform) {
    jfloat fm00 = transform->m00/65536.0f;
    jfloat fm01 = transform->m01/65536.0f;
    jfloat fm02 = transform->m02/65536.0f;
    jfloat fm10 = transform->m10/65536.0f;
    jfloat fm11 = transform->m11/65536.0f;
    jfloat fm12 = transform->m12/65536.0f;
    jfloat fdet = fm00*fm11 - fm01*fm10;

    jfloat fa00 =  fm11/fdet;
    jfloat fa01 = -fm01/fdet;
    jfloat fa10 = -fm10/fdet;
    jfloat fa11 =  fm00/fdet;
    jfloat fa02 = (fm01*fm12 - fm02*fm11)/fdet;
    jfloat fa12 = (fm02*fm10 - fm00*fm12)/fdet;

    transform->m00 = (jint)(fa00*65536.0f);
    transform->m01 = (jint)(fa01*65536.0f);
    transform->m10 = (jint)(fa10*65536.0f);
    transform->m11 = (jint)(fa11*65536.0f);
    transform->m02 = (jint)(fa02*65536.0f);
    transform->m12 = (jint)(fa12*65536.0f);
}

/**
 * Multiplicates transformation matrixes *transformD and *transformS. Result is
 * stored in *transformD. Matrix *transformD is multiplied by matrix *transformS
 * from right (*transformD = *transformD.*transformS).
 */   
void
pisces_transform_multiply(Transform6* transformD, 
                          const Transform6* transformS) {
    jlong _m00 = ((jlong)transformD->m00*transformS->m00 +
                  (jlong)transformD->m01*transformS->m10) >> 16;
    jlong _m01 = ((jlong)transformD->m00*transformS->m01 +
                  (jlong)transformD->m01*transformS->m11) >> 16;
    jlong _m10 = ((jlong)transformD->m10*transformS->m00 +
                  (jlong)transformD->m11*transformS->m10) >> 16;
    jlong _m11 = ((jlong)transformD->m10*transformS->m01 +
                  (jlong)transformD->m11*transformS->m11) >> 16;
    jlong _m02 = (((jlong)transformD->m02 << 16) +
                  (jlong)transformD->m00*transformS->m02 +
                  (jlong)transformD->m01*transformS->m12) >> 16;
    jlong _m12 = (((jlong)transformD->m12 << 16) +
                  (jlong)transformD->m10*transformS->m02 +
                  (jlong)transformD->m11*transformS->m12) >> 16;

    transformD->m00 = (jint)_m00;
    transformD->m01 = (jint)_m01;
    transformD->m02 = (jint)_m02;
    transformD->m10 = (jint)_m10;
    transformD->m11 = (jint)_m11;
    transformD->m12 = (jint)_m12;
}

jboolean pisces_transform_equals(const Transform6* tr1, const Transform6* tr2) {
    if(tr1 == tr2) {
        return XNI_TRUE;
    } else if (tr1 != NULL && tr2 != NULL) {
        return (tr1->m00 == tr2->m00 &&
                tr1->m01 == tr2->m01 &&
                tr1->m02 == tr2->m02 &&
                tr1->m10 == tr2->m10 &&
                tr1->m11 == tr2->m11 &&
                tr1->m12 == tr2->m12);
    }
    return XNI_FALSE;
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy