/* Copyright 2012-2014 Benjamin Vedder benjamin@vedder.se This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ /* * utils.c * * Created on: 16 maj 2013 * Author: benjamin */ #include "utils.h" #include void step_towards(float *value, float goal, float step) { if (*value < goal) { if ((*value + step) < goal) { *value += step; } else { *value = goal; } } else if (*value > goal) { if ((*value - step) > goal) { *value -= step; } else { *value = goal; } } } float calc_ratio(float low, float high, float val) { return (val - low) / (high - low); } /** * Make sure that 0 <= angle < 360 * @param angle * The angle to normalize. */ void utils_norm_angle(float *angle) { *angle = fmodf(*angle, 360.0); if (*angle < 0.0) { *angle += 360.0; } }