4 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
20 #include <fusion_util.h>
24 int quat_to_matrix(const float *quat, float *R)
26 if(quat == NULL || R == NULL)
34 float sq_q1 = 2 * q1 * q1;
35 float sq_q2 = 2 * q2 * q2;
36 float sq_q3 = 2 * q3 * q3;
37 float q1_q2 = 2 * q1 * q2;
38 float q3_q0 = 2 * q3 * q0;
39 float q1_q3 = 2 * q1 * q3;
40 float q2_q0 = 2 * q2 * q0;
41 float q2_q3 = 2 * q2 * q3;
42 float q1_q0 = 2 * q1 * q0;
44 R[0] = 1 - sq_q2 - sq_q3;
48 R[4] = 1 - sq_q1 - sq_q3;
52 R[8] = 1 - sq_q1 - sq_q2;