| /* | 
 |  This Software is provided under the Zope Public License (ZPL) Version 2.1. | 
 |  | 
 |  Copyright (c) 2009, 2010 by the mingw-w64 project | 
 |  | 
 |  See the AUTHORS file for the list of contributors to the mingw-w64 project. | 
 |  | 
 |  This license has been certified as open source. It has also been designated | 
 |  as GPL compatible by the Free Software Foundation (FSF). | 
 |  | 
 |  Redistribution and use in source and binary forms, with or without | 
 |  modification, are permitted provided that the following conditions are met: | 
 |  | 
 |    1. Redistributions in source code must retain the accompanying copyright | 
 |       notice, this list of conditions, and the following disclaimer. | 
 |    2. Redistributions in binary form must reproduce the accompanying | 
 |       copyright notice, this list of conditions, and the following disclaimer | 
 |       in the documentation and/or other materials provided with the | 
 |       distribution. | 
 |    3. Names of the copyright holders must not be used to endorse or promote | 
 |       products derived from this software without prior written permission | 
 |       from the copyright holders. | 
 |    4. The right to distribute this software or to use it for any purpose does | 
 |       not give you the right to use Servicemarks (sm) or Trademarks (tm) of | 
 |       the copyright holders.  Use of them is covered by separate agreement | 
 |       with the copyright holders. | 
 |    5. If any files are modified, you must cause the modified files to carry | 
 |       prominent notices stating that you changed the files and the date of | 
 |       any change. | 
 |  | 
 |  Disclaimer | 
 |  | 
 |  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY EXPRESSED | 
 |  OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | 
 |  OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO | 
 |  EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY DIRECT, INDIRECT, | 
 |  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 
 |  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,  | 
 |  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF | 
 |  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | 
 |  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, | 
 |  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
 | */ | 
 |  | 
 | #include "complex_test.h" | 
 |  | 
 | /** | 
 |  * Annex G.6 csin(z) = -i csinh (iz) | 
 |  * Reference: Annex G.6.2.5 The csinh functions | 
 |  * csinh(conj(z)) = conj(csinh(z)) and csinh is odd. | 
 |  * csinh(+0 + i0) returns +0 + i0. | 
 |  * csinh(+0 + i inf) returns +/-0 + iNaN (where the sign of the real part of the result is unspecified) and raises the invalid floating-point exception. | 
 |  * csinh(+0 + iNaN) returns +/-0 + iNaN (where the sign of the real part of the result is unspecified). | 
 |  * csinh(x + i inf) returns NaN + iNaN and raises the invalid floating-point exception, for positive finite x. | 
 |  * csinh(x + iNaN) returns NaN + iNaN and optionally raises the invalid floating-point exception, for finite nonzero x. | 
 |  * csinh(+inf + i0) returns +inf + i0. | 
 |  * csinh(+inf + iy) returns +inf cis(y), for positive finite y. | 
 |  * csinh(+inf + i inf) returns +/-inf + iNaN (where the sign of the real part of the result is unspecified) and raises the invalid floating-point exception. | 
 |  * csinh(+inf + iNaN) returns +/-inf + iNaN (where the sign of the real part of the result is unspecified). | 
 |  * csinh(NaN + i0) returns NaN + i0. | 
 |  * csinh(NaN + iy) returns NaN + iNaN and optionally raises the invalid floating-point exception, for all nonzero numbers y. | 
 |  * csinh(NaN + iNaN) returns NaN + iNaN. | 
 |  */ | 
 |  | 
 | int __FLT_ABI(test_function_csin) () | 
 | { | 
 |   /* cos(42.42) is positive, sin(42.42) is negative */ | 
 |   _DEFINE_DEFAULT_TEST_FUNCTION (csin, FUNC_BEHAVIOR_CONJ | FUNC_BEHAVIOR_ODD); | 
 |  | 
 |   DEFAULT_TESTS_START | 
 |  | 
 |   DEFINE_TEST (  __FLT_CST(0.0),   __FLT_CST(0.0), __FLT_CST(0.0), __FLT_CST(0.0), 0, 0) | 
 |   DEFINE_TEST (  __FLT_CST(0.0),         INFINITY, __FLT_CST(0.0),       INFINITY, 0, 0) | 
 |   DEFINE_TEST (  __FLT_CST(0.0),        __FLT_NAN, __FLT_CST(0.0),      __FLT_NAN, 0, 0) | 
 |   DEFINE_TEST (__FLT_CST(42.42),         INFINITY,      -INFINITY,       INFINITY, 0, 0) | 
 |   DEFINE_TEST (__FLT_CST(42.42),        __FLT_NAN,      __FLT_NAN,      __FLT_NAN, 0, 0) | 
 |   DEFINE_TEST (       -INFINITY,  __FLT_CST( 0.0),      __FLT_NAN, __FLT_CST(0.0), 0, 1) | 
 |   DEFINE_TEST (       -INFINITY, __FLT_CST(42.42),      __FLT_NAN,      __FLT_NAN, 0, 0) | 
 |   DEFINE_TEST (       -INFINITY,         INFINITY,      __FLT_NAN,       INFINITY, 0, 1) | 
 |   DEFINE_TEST (       -INFINITY,        __FLT_NAN,      __FLT_NAN,      __FLT_NAN, 0, 0) | 
 |   DEFINE_TEST (       __FLT_NAN,  __FLT_CST( 0.0),      __FLT_NAN, __FLT_CST(0.0), 0, 1) | 
 |   DEFINE_TEST (       __FLT_NAN, __FLT_CST(42.42),      __FLT_NAN,      __FLT_NAN, 0, 0) | 
 |   DEFINE_TEST (       __FLT_NAN,         INFINITY,      __FLT_NAN,       INFINITY, 0, 1) | 
 |   DEFINE_TEST (       __FLT_NAN,        __FLT_NAN,      __FLT_NAN,      __FLT_NAN, 0, 0) | 
 |  | 
 |   TESTS_END | 
 |  | 
 |   return RUN_DEFAULT_TESTS(csin); | 
 | } |