/*
 *  Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
 *  Copyright (C) 2006-2008 - INRIA - Bruno JOFRET
 *
 *  This file must be used under the terms of the CeCILL.
 *  This source file is licensed as described in the file COPYING, which
 *  you should have received as part of this distribution.  The terms
 *  are also available at
 *  http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
 *
 */

#ifndef __TANH_H__
#define __TANH_H__

#include "dynlib_elementaryfunctions.h"
#include "floatComplex.h"
#include "doubleComplex.h"
#include "sinh.h"

#ifdef  __cplusplus
extern "C" {
#endif
/*
** Compute Hyperbolic Tangeant for different types .
*/

/*
** \brief Float Hyperbolic Tangeant function
** \param in : input value.
*/
EXTERN_ELEMFUNCT float		stanhs(float in);

/*
** \brief Double Hyperbolic Tangeant function
** \param in : input value.
*/
EXTERN_ELEMFUNCT double		dtanhs(double in);

/*
** \brief Float Complex Hyperbolic Tangeant function
** \param in : input value.
*/
EXTERN_ELEMFUNCT floatComplex	ctanhs(floatComplex in);

/*
** \brief Double Complex Hyperbolic Tangeant function
** \param in : input value.
*/
EXTERN_ELEMFUNCT doubleComplex	ztanhs(doubleComplex in);

/*
** \brief Uint8 Hyperbolic Tangeant function
** \param in : input value.
*/
EXTERN_ELEMFUNCT float		u8tanhs(uint8 in);

/*
** \brief Int8 Hyperbolic Tangeant function
** \param in : input value.
*/
EXTERN_ELEMFUNCT float		i8tanhs(int8 in);

/*
** \brief Uint16 Hyperbolic Tangeant function
** \param in : input value.
*/
EXTERN_ELEMFUNCT float		u16tanhs(uint16 in);

/*
** \brief Int16 Hyperbolic Tangeant function
** \param in : input value.
*/
EXTERN_ELEMFUNCT float		i16tanhs(int16 in);

/*
** \brief Float Matrix Hyperbolic Tangeant function
** \param in : input array value.
** \param out : output array value.
** \param size : the size of in and out arrays.
*/
EXTERN_ELEMFUNCT void		stanha(float* in, int size, float* out);

/*
** \brief Double Matrix Hyperbolic Tangeant function
** \param in : input array value.
** \param out : output array value.
** \param size : the size of in and out arrays.
*/
EXTERN_ELEMFUNCT void		dtanha(double* in, int size, double* out);

/*
** \brief Float Complex Matrix Hyperbolic Tangeant function
** \param in : input array value.
** \param out : output array value.
** \param size : the size of in and out arrays.
*/
EXTERN_ELEMFUNCT void		ctanha(floatComplex* in, int size, floatComplex* out);

/*
** \brief Double Complex Matrix Hyperbolic Tangeant function
** \param in : input array value.
** \param out : output array value.
** \param size : the size of in and out arrays.
*/
EXTERN_ELEMFUNCT void		ztanha(doubleComplex* in, int size, doubleComplex* out);

/*
** \brief Uint8 Matrix Hyperbolic Tangeant function
** \param in : input array value.
** \param out : output array value.
** \param size : the size of in and out arrays.
*/
EXTERN_ELEMFUNCT void		u8tanha(uint8* in, int size, float* out);

/*
** \brief Int8 Matrix Hyperbolic Tangeant function
** \param in : input array value.
** \param out : output array value.
** \param size : the size of in and out arrays.
*/
EXTERN_ELEMFUNCT void		i8tanha(int8* in, int size, float* out);

/*
** \brief Uint16 Matrix Hyperbolic Tangeant function
** \param in : input array value.
** \param out : output array value.
** \param size : the size of in and out arrays.
*/
EXTERN_ELEMFUNCT void		u16tanha(uint16* in, int size, float* out);

/*
** \brief Int16 Matrix Hyperbolic Tangeant function
** \param in : input array value.
** \param out : output array value.
** \param size : the size of in and out arrays.
*/
EXTERN_ELEMFUNCT void		i16tanha(int16* in, int size, float* out);

#ifdef  __cplusplus
} /* extern "C" */
#endif


#endif /* !__TANH_H__ */