1*e1eccf28SAndroid Build Coastguard Worker /*
2*e1eccf28SAndroid Build Coastguard Worker * Copyright (C) 2011 The Android Open Source Project
3*e1eccf28SAndroid Build Coastguard Worker *
4*e1eccf28SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*e1eccf28SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*e1eccf28SAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*e1eccf28SAndroid Build Coastguard Worker *
8*e1eccf28SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
9*e1eccf28SAndroid Build Coastguard Worker *
10*e1eccf28SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*e1eccf28SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*e1eccf28SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*e1eccf28SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*e1eccf28SAndroid Build Coastguard Worker * limitations under the License.
15*e1eccf28SAndroid Build Coastguard Worker */
16*e1eccf28SAndroid Build Coastguard Worker
17*e1eccf28SAndroid Build Coastguard Worker #include "rsMatrix2x2.h"
18*e1eccf28SAndroid Build Coastguard Worker #include "rsMatrix3x3.h"
19*e1eccf28SAndroid Build Coastguard Worker #include "rsMatrix4x4.h"
20*e1eccf28SAndroid Build Coastguard Worker
21*e1eccf28SAndroid Build Coastguard Worker #include "stdlib.h"
22*e1eccf28SAndroid Build Coastguard Worker #include "string.h"
23*e1eccf28SAndroid Build Coastguard Worker #include "math.h"
24*e1eccf28SAndroid Build Coastguard Worker
25*e1eccf28SAndroid Build Coastguard Worker namespace android {
26*e1eccf28SAndroid Build Coastguard Worker namespace renderscript {
27*e1eccf28SAndroid Build Coastguard Worker
loadIdentity()28*e1eccf28SAndroid Build Coastguard Worker void Matrix2x2::loadIdentity() {
29*e1eccf28SAndroid Build Coastguard Worker m[0] = 1.f;
30*e1eccf28SAndroid Build Coastguard Worker m[1] = 0.f;
31*e1eccf28SAndroid Build Coastguard Worker m[2] = 0.f;
32*e1eccf28SAndroid Build Coastguard Worker m[3] = 1.f;
33*e1eccf28SAndroid Build Coastguard Worker }
34*e1eccf28SAndroid Build Coastguard Worker
load(const float * v)35*e1eccf28SAndroid Build Coastguard Worker void Matrix2x2::load(const float *v) {
36*e1eccf28SAndroid Build Coastguard Worker memcpy(m, v, sizeof(m));
37*e1eccf28SAndroid Build Coastguard Worker }
38*e1eccf28SAndroid Build Coastguard Worker
load(const rs_matrix2x2 * v)39*e1eccf28SAndroid Build Coastguard Worker void Matrix2x2::load(const rs_matrix2x2 *v) {
40*e1eccf28SAndroid Build Coastguard Worker memcpy(m, v->m, sizeof(m));
41*e1eccf28SAndroid Build Coastguard Worker }
42*e1eccf28SAndroid Build Coastguard Worker
loadMultiply(const rs_matrix2x2 * lhs,const rs_matrix2x2 * rhs)43*e1eccf28SAndroid Build Coastguard Worker void Matrix2x2::loadMultiply(const rs_matrix2x2 *lhs, const rs_matrix2x2 *rhs) {
44*e1eccf28SAndroid Build Coastguard Worker // Use a temporary variable to support the case where one of the inputs
45*e1eccf28SAndroid Build Coastguard Worker // is also the destination, e.g. left.loadMultiply(left, right);
46*e1eccf28SAndroid Build Coastguard Worker Matrix2x2 temp;
47*e1eccf28SAndroid Build Coastguard Worker for (int i=0 ; i<2 ; i++) {
48*e1eccf28SAndroid Build Coastguard Worker float ri0 = 0;
49*e1eccf28SAndroid Build Coastguard Worker float ri1 = 0;
50*e1eccf28SAndroid Build Coastguard Worker for (int j=0 ; j<2 ; j++) {
51*e1eccf28SAndroid Build Coastguard Worker const float rhs_ij = ((const Matrix2x2 *)rhs)->get(i, j);
52*e1eccf28SAndroid Build Coastguard Worker ri0 += ((const Matrix2x2 *)lhs)->get(j, 0) * rhs_ij;
53*e1eccf28SAndroid Build Coastguard Worker ri1 += ((const Matrix2x2 *)lhs)->get(j, 1) * rhs_ij;
54*e1eccf28SAndroid Build Coastguard Worker }
55*e1eccf28SAndroid Build Coastguard Worker temp.set(i, 0, ri0);
56*e1eccf28SAndroid Build Coastguard Worker temp.set(i, 1, ri1);
57*e1eccf28SAndroid Build Coastguard Worker }
58*e1eccf28SAndroid Build Coastguard Worker load(&temp);
59*e1eccf28SAndroid Build Coastguard Worker }
60*e1eccf28SAndroid Build Coastguard Worker
transpose()61*e1eccf28SAndroid Build Coastguard Worker void Matrix2x2::transpose() {
62*e1eccf28SAndroid Build Coastguard Worker float temp = m[1];
63*e1eccf28SAndroid Build Coastguard Worker m[1] = m[2];
64*e1eccf28SAndroid Build Coastguard Worker m[2] = temp;
65*e1eccf28SAndroid Build Coastguard Worker }
66*e1eccf28SAndroid Build Coastguard Worker
67*e1eccf28SAndroid Build Coastguard Worker } // namespace renderscript
68*e1eccf28SAndroid Build Coastguard Worker } // namespace android
69