MAV'RIC
|
00001 /******************************************************************************* 00002 * Copyright (c) 2009-2016, MAV'RIC Development Team 00003 * All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions are met: 00007 * 00008 * 1. Redistributions of source code must retain the above copyright notice, 00009 * this list of conditions and the following disclaimer. 00010 * 00011 * 2. Redistributions in binary form must reproduce the above copyright notice, 00012 * this list of conditions and the following disclaimer in the documentation 00013 * and/or other materials provided with the distribution. 00014 * 00015 * 3. Neither the name of the copyright holder nor the names of its contributors 00016 * may be used to endorse or promote products derived from this software without 00017 * specific prior written permission. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00029 * POSSIBILITY OF SUCH DAMAGE. 00030 ******************************************************************************/ 00031 00032 /******************************************************************************* 00033 * \file quick_trig.h 00034 * 00035 * \author MAV'RIC Team 00036 * \author Julien Lecoeur 00037 * 00038 * \brief Quick implementation of trigonometric functions 00039 * 00040 ******************************************************************************/ 00041 00042 00043 #ifndef QUICK_TRIG_H_ 00044 #define QUICK_TRIG_H_ 00045 00046 #ifdef __cplusplus 00047 extern "C" 00048 { 00049 #endif 00050 00051 #include "util/maths.h" 00052 00053 00054 #define INTERP_POINTS 50 00055 00056 00064 float quick_trig_sin(float x); 00065 00066 00074 float quick_trig_cos(float x); 00075 00076 00084 float quick_trig_acos(float x); 00085 00086 00094 float quick_trig_asin(float x); 00095 00096 00104 float quick_trig_tan(float x); 00105 00106 00114 float quick_trig_atan(float x); 00115 00116 00128 static inline float quick_trig_func(float x, const float func_x_min, const float func_x_max, float func_x_step, const float func_y[]) 00129 { 00130 float y; 00131 int32_t i; 00132 00133 if (x <= func_x_min) 00134 { 00135 y = func_y[0]; 00136 } 00137 else if (x >= func_x_max) 00138 { 00139 y = func_y[INTERP_POINTS - 1]; 00140 } 00141 else 00142 { 00143 i = (int32_t)((x - func_x_min) / func_x_step); 00144 y = maths_interpolate(x, 00145 func_x_min + i * func_x_step, 00146 func_x_min + (i + 1) * func_x_step, 00147 func_y[i], 00148 func_y[i + 1]); 00149 } 00150 return y; 00151 } 00152 00153 #ifdef __cplusplus 00154 } 00155 #endif 00156 00157 #endif /* QUICK_TRIG_H_ */