xref: /aosp_15_r20/frameworks/rs/rsMatrix2x2.cpp (revision e1eccf28f96817838ad6867f7f39d2351ec11f56)
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