Gyro Sensor Library
util.c
- Committer:
- bant62
- Date:
- 2012-07-16
- Revision:
- 0:da10b9c9db7a
File content as of revision 0:da10b9c9db7a:
/** ***************************************************************************** * File Name : util.c * * Title : Utility functions Source File * Revision : 0.1 * Notes : * Target Board : mbed NXP LPC1768 * Tool Chain : ???? * * Revision History: * When Who Description of change * ----------- ----------- ----------------------- * 2012/07/10 Hiroshi M init ***************************************************************************** * * Copyright (C) 2012 Hiroshi M, MIT License * * Permission is hereby granted, free of charge, to any person obtaining a copy of this software * and associated documentation files (the "Software"), to deal in the Software without restriction, * including without limitation the rights to use, copy, modify, merge, publish, distribute, * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all copies or * substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * **/ /* Includes ----------------------------------------------------------------- */ #include "util.h" /* Private typedef ---------------------------------------------------------- */ /* Private define ----------------------------------------------------------- */ /* Private macro ------------------------------------------------------------ */ /* Private variables -------------------------------------------------------- */ /* Private function prototypes -----------------------------------------------*/ /** * least squares method * */ int lsm(int *y, int x) { int n; static long a0, a1, a2; long s01 = 0, s02 = 0, s11 = 0, s12 = 0; if (x == 0) { for (n = 0; n < N; n++) { s01 += n; s02 += (long)y[n]; s11 += n * n; s12 += n * (long)y[n]; } a0 = (s02 * s11 - s01 * s12) / (N * s11 - s01 * s01); a1 = (N * s12 - s01 * s02); a2 = (N * s11 - s01 * s01 * 2); } return (int)(a0 + a1 * (N + x) / a2); } int xabs(int x,int y) { if(x >= y) { return (x - y); } else { return (y - x); } }