我要评分
获取效率
正确性
完整性
易理解

v?tanh

Compute the input hyperbolic tangent value. The input is a vector.

Interface Definition

C interface:

void vstanh(const int len, const float* src, float* dst);

void vdtanh(const int len, const double* src, double* dst);

Fortran interface:

CALL VSTANH(LEN, SRC, DST);

CALL VDTANH(LEN, SRC, DST);

Parameters

Parameter

Type

Description

Input/Output

len

Integer

Number of elements in the input vector.

If len ≤ 0, the system displays a message indicating that the value of len is invalid.

Input

src

  • For vstanh, src is of single-precision floating-point type.
  • For vdtanh, src is of double-precision floating-point type.

Input vector src with length len.

If the pointer is null, the system prompts a null pointer error.

Input

dst

  • For vstanh, dst is of single-precision floating-point type.
  • For vdtanh, dst is of double-precision floating-point type.

Output vector dst with length len.

If the pointer is null, the system prompts a null pointer error.

Output

Return Value

  • Each operation value returns the hyperbolic tangent function value y of the radian angle x. y ∈ [-1, +1].
  • If the input is +0, the return value is +0.
  • If the input is -0, the return value is -0.
  • If the input is +∞, the return value is +1.
  • If the input is -∞, the return value is -1.
  • If the input is NaN, the return value is NaN.

Dependencies

C: "kvml.h"

Fortran: "kvml.f03"

Examples

C interface:

    int i, len = 4; 
    float src[len] = {0.0f, 2.0f, inf, nan}; 
    float* dst = (float*)malloc(sizeof(float) * len); 
    if (dst == NULL) { 
        printf("Malloc Failed!\n"); 
        return 0; 
    } 
    vstanh(len, src, dst); 
    /** 
     *  Output dst: 
     *     0.0  0.964027580  1.0  nan 
     * 
     */

Fortran interface:

    INTEGER :: LEN = 4 
    REAL(4) SRC(4)  
    REAL(4) DST(4) 
    DATA SRC /1, 2, 3, 4/ 
    CALL VSTANH(LEN, SRC, DST) 
    !  
    ! OUTPUT DST: 
    !     0.761594156, 0.964027580, 0.995054754, 0.9993292997
    !