Rate This Document
Findability
Accuracy
Completeness
Readability

v?add

Perform element-wise addition of vectors. The sum is also a vector.

Interface Definition

C interface:

void vsadd(const int len, const float* src1, const float* src2, float* dst);

void vdadd(const int len, const double* src1, const double* src2, double* dst);

Fortran interface:

CALL VSADD(LEN, SRC1, SRC2, DST);

CALL VDADD(LEN, SRC1, SRC2, 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

src1

  • For vsadd, src1 is of single-precision floating-point type.
  • For vdadd, src1 is of double-precision floating-point type.

Input vector src1 with length len.

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

Input

src2

  • For vsadd, src2 is of single-precision floating-point type.
  • For vdadd, src2 is of double-precision floating-point type.

Input vector src2 with length len.

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

Input

dst

  • For vsadd, dst is of single-precision floating-point type.
  • For vdadd, 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

  • The sum of two numbers is returned for each operation value. The value range is [-INF, +INF].
  • If the values of src1 and src2 are –0, the value of dst is –0. If the values of src1 and src2 are ±0, the value of dst is +0.
  • If the values of src1 and src2 are -∞, the value of dst is -∞. If the values of src1 and src2 are +∞, the value of dst is +∞.
  • If the value of src1 is +∞ and the value of src2 is -∞, then the value of dst is Not a Number (NaN). If the value of src1 is -∞ and the value of src2 is +∞, then the value of dst is NaN.
  • If the value of src1 or src2 is NaN, the value of dst is NaN.

Dependencies

C: "kvml.h"

Fortran: "kvml.f03"

Examples

C interface:

    int i, len = 4; 
    float src1[len] = {0.0f, 0.5f, 1.5f, 5.5f}; 
    float src2[len] = {0.3f, 0.7f, 2.5f, 10.0f}; 
    float* dst = (float*)malloc(sizeof(float) * len); 
    if (dst == NULL) { 
        printf("Malloc Failed!\n"); 
        return 0; 
    } 
    vsadd(len, src1, src2, dst); 
    /** 
     *  Output dst: 
     *     0.3  1.2  4.0  15.5 
     * 
     */

Fortran interface:

    INTEGER :: LEN = 4 
    REAL(4) SRC1(4)  
    REAL(4) SRC2(4) 
    REAL(4) DST(4) 
    DATA SRC1 /1.2, 2.5, -2.4, 3.6/ 
    DATA SRC2 /8.6, -2.5, -12.4, 32.6/ 
    CALL VSADD(LEN, SRC1, SRC2, DST) 
    ! 
    ! OUTPUT DST 
    !     9.800000191, 0.000000000, -14.799999237, 36.199996948 
    !