1 1.15 martin /* $NetBSD: t_atan.c,v 1.15 2014/03/17 11:08:11 martin Exp $ */ 2 1.1 jruoho 3 1.1 jruoho /*- 4 1.1 jruoho * Copyright (c) 2011 The NetBSD Foundation, Inc. 5 1.1 jruoho * All rights reserved. 6 1.1 jruoho * 7 1.1 jruoho * This code is derived from software contributed to The NetBSD Foundation 8 1.1 jruoho * by Jukka Ruohonen. 9 1.1 jruoho * 10 1.1 jruoho * Redistribution and use in source and binary forms, with or without 11 1.1 jruoho * modification, are permitted provided that the following conditions 12 1.1 jruoho * are met: 13 1.1 jruoho * 1. Redistributions of source code must retain the above copyright 14 1.1 jruoho * notice, this list of conditions and the following disclaimer. 15 1.1 jruoho * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 jruoho * notice, this list of conditions and the following disclaimer in the 17 1.1 jruoho * documentation and/or other materials provided with the distribution. 18 1.1 jruoho * 19 1.1 jruoho * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 jruoho * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 jruoho * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 jruoho * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 jruoho * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 jruoho * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 jruoho * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 jruoho * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 jruoho * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 jruoho * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 jruoho * POSSIBILITY OF SUCH DAMAGE. 30 1.1 jruoho */ 31 1.1 jruoho 32 1.1 jruoho #include <atf-c.h> 33 1.1 jruoho #include <math.h> 34 1.12 dsl #include "t_libm.h" 35 1.1 jruoho 36 1.8 isaki static const struct { 37 1.8 isaki double x; 38 1.8 isaki double y; 39 1.8 isaki } values[] = { 40 1.13 martin #ifndef __vax__ 41 1.13 martin /* vax has no +/- INF */ 42 1.12 dsl { T_LIBM_MINUS_INF, -M_PI / 2 }, 43 1.12 dsl { T_LIBM_PLUS_INF, M_PI / 2 }, 44 1.13 martin #endif 45 1.8 isaki { -100, -1.560796660108231, }, 46 1.8 isaki { -10, -1.471127674303735, }, 47 1.8 isaki { -1, -M_PI / 4, }, 48 1.8 isaki { -0.1, -0.09966865249116204, }, 49 1.8 isaki { 0.1, 0.09966865249116204, }, 50 1.8 isaki { 1, M_PI / 4, }, 51 1.8 isaki { 10, 1.471127674303735, }, 52 1.8 isaki { 100, 1.560796660108231, }, 53 1.8 isaki }; 54 1.8 isaki 55 1.1 jruoho /* 56 1.1 jruoho * atan(3) 57 1.1 jruoho */ 58 1.12 dsl ATF_LIBM_TEST(atan_nan, "Test atan/atanf(NaN) == NaN") 59 1.1 jruoho { 60 1.15 martin #ifdef T_LIBM_NAN 61 1.12 dsl T_LIBM_CHECK_NAN(0, atan, T_LIBM_NAN); 62 1.12 dsl T_LIBM_CHECK_NAN(0, atanf, T_LIBM_NAN); 63 1.15 martin #else 64 1.15 martin atf_tc_skip("no NaN on this machine"); 65 1.14 martin #endif 66 1.1 jruoho } 67 1.1 jruoho 68 1.12 dsl ATF_LIBM_TEST(atan_inrange, "Test atan/atanf(x) for some values") 69 1.1 jruoho { 70 1.12 dsl unsigned int i; 71 1.1 jruoho 72 1.8 isaki for (i = 0; i < __arraycount(values); i++) { 73 1.12 dsl T_LIBM_CHECK(i, atan, values[i].x, values[i].y, 1.0e-15); 74 1.12 dsl T_LIBM_CHECK(i, atanf, values[i].x, values[i].y, 1.0e-7); 75 1.1 jruoho } 76 1.1 jruoho } 77 1.1 jruoho 78 1.12 dsl ATF_LIBM_TEST(atan_zero_neg, "Test atan/atanf(-0.0) == -0.0") 79 1.1 jruoho { 80 1.1 jruoho 81 1.12 dsl T_LIBM_CHECK_MINUS_ZERO(0, atan, -0.0); 82 1.12 dsl T_LIBM_CHECK_MINUS_ZERO(0, atanf, -0.0); 83 1.1 jruoho } 84 1.1 jruoho 85 1.12 dsl ATF_LIBM_TEST(atan_zero_pos, "Test atan/atanf(+0.0) == +0.0") 86 1.1 jruoho { 87 1.1 jruoho 88 1.12 dsl T_LIBM_CHECK_PLUS_ZERO(0, atan, +0.0); 89 1.12 dsl T_LIBM_CHECK_PLUS_ZERO(0, atanf, +0.0); 90 1.1 jruoho } 91 1.1 jruoho 92 1.1 jruoho ATF_TP_ADD_TCS(tp) 93 1.1 jruoho { 94 1.1 jruoho 95 1.1 jruoho ATF_TP_ADD_TC(tp, atan_nan); 96 1.8 isaki ATF_TP_ADD_TC(tp, atan_inrange); 97 1.1 jruoho ATF_TP_ADD_TC(tp, atan_zero_neg); 98 1.1 jruoho ATF_TP_ADD_TC(tp, atan_zero_pos); 99 1.1 jruoho 100 1.1 jruoho return atf_no_error(); 101 1.1 jruoho } 102