1d0f13633SDavid Schultz /*- 2d0f13633SDavid Schultz * Copyright (c) 2003, Steven G. Kargl 3d0f13633SDavid Schultz * All rights reserved. 4d0f13633SDavid Schultz * 5d0f13633SDavid Schultz * Redistribution and use in source and binary forms, with or without 6d0f13633SDavid Schultz * modification, are permitted provided that the following conditions 7d0f13633SDavid Schultz * are met: 8d0f13633SDavid Schultz * 1. Redistributions of source code must retain the above copyright 9d0f13633SDavid Schultz * notice unmodified, this list of conditions, and the following 10d0f13633SDavid Schultz * disclaimer. 11d0f13633SDavid Schultz * 2. Redistributions in binary form must reproduce the above copyright 12d0f13633SDavid Schultz * notice, this list of conditions and the following disclaimer in the 13d0f13633SDavid Schultz * documentation and/or other materials provided with the distribution. 14d0f13633SDavid Schultz * 15d0f13633SDavid Schultz * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 16d0f13633SDavid Schultz * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 17d0f13633SDavid Schultz * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 18d0f13633SDavid Schultz * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 19d0f13633SDavid Schultz * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 20d0f13633SDavid Schultz * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 21d0f13633SDavid Schultz * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 22d0f13633SDavid Schultz * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 23d0f13633SDavid Schultz * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 24d0f13633SDavid Schultz * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 25d0f13633SDavid Schultz */ 26d0f13633SDavid Schultz 27d0f13633SDavid Schultz #include <sys/cdefs.h> 28d0f13633SDavid Schultz __FBSDID("$FreeBSD$"); 29d0f13633SDavid Schultz 30d0f13633SDavid Schultz #include <math.h> 31d0f13633SDavid Schultz 32d0f13633SDavid Schultz float 33d0f13633SDavid Schultz roundf(float x) 34d0f13633SDavid Schultz { 35d0f13633SDavid Schultz float t; 36d0f13633SDavid Schultz int i; 37d0f13633SDavid Schultz 38d0f13633SDavid Schultz i = fpclassify(x); 39d0f13633SDavid Schultz if (i == FP_INFINITE || i == FP_NAN) 40d0f13633SDavid Schultz return (x); 41d0f13633SDavid Schultz 42d0f13633SDavid Schultz if (x >= 0.0) { 43d0f13633SDavid Schultz t = ceilf(x); 44d0f13633SDavid Schultz if (t - x > 0.5) 45d0f13633SDavid Schultz t -= 1.0; 46d0f13633SDavid Schultz return (t); 47d0f13633SDavid Schultz } else { 48d0f13633SDavid Schultz t = ceilf(-x); 49d0f13633SDavid Schultz if (t + x > 0.5) 50d0f13633SDavid Schultz t -= 1.0; 51d0f13633SDavid Schultz return (-t); 52d0f13633SDavid Schultz } 53d0f13633SDavid Schultz } 54