fmod¶
The fmod function performs element by element computation of the
modulus function of vector a with respect to vector b.
Syntax
Buffer API:
-
void
fmod(queue &exec_queue, int64_t n, buffer<T, 1> &a, buffer<T, 1> &b, buffer<T, 1> &y, uint64_t mode = mode::not_defined, error_handler<T> errhandler = {})¶
USM API:
-
event
fmod(queue &exec_queue, int64_t n, T *a, T *b, T *y, uint64_t mode = mode::not_defined, error_handler<T> errhandler = {})¶
fmod supports the following precisions.
T |
|---|
|
|
Description
The fmod (a,b) function computes the modulus function of each element
of vector a, with respect to the corresponding elements of vector
b:
ai - bi*trunc(ai/bi)
In general, the modulus function fmod (ai, bi) returns the value
ai - n*bi for some integer n such that if bi is
nonzero, the result has the same sign as ai and a
magnitude less than the magnitude of bi.
Argument 1 |
Argument 2 |
Result |
Error Code |
|---|---|---|---|
|
±0 |
NAN |
|
±∞ |
|
NAN |
|
±0 |
|
±0 |
|
|
±∞ |
|
|
NAN |
|
||
|
NAN |
NAN |
Input Parameters
Buffer API:
- exec_queue
The queue where the routine should be executed.
- n
Specifies the number of elements to be calculated.
- a
The buffer
acontaining 1st input vector of sizen.- b
The buffer
bcontaining 2nd input vector of sizen.- mode
Overrides the global VM mode setting for this function call. See set_mode function for possible values and their description. This is an optional parameter. The default value is
mode::not_defined.- errhandler
Sets local error handling mode for this function call. See the create_error_handler function for arguments and their descriptions. This is an optional parameter. The local error handler is disabled by default.
USM API:
- exec_queue
The queue where the routine should be executed.
- n
Specifies the number of elements to be calculated.
- a
Pointer
ato the 1st input vector of sizen.- b
Pointer
bto the 2nd input vector of sizen.- depends
Vector of dependent events (to wait for input data to be ready).
- mode
Overrides the global VM mode setting for this function call. See the set_mode function for possible values and their description. This is an optional parameter. The default value is
mode::not_defined.- errhandler
Sets local error handling mode for this function call. See the create_error_handler function for arguments and their descriptions. This is an optional parameter. The local error handler is disabled by default.
Output Parameters
Buffer API:
- y
The buffer
ycontaining the output vector of sizen.
USM API:
- y
Pointer
yto the output vector of sizen.- return value (event)
Function end event.
Example
An example of how to use fmod can be found in the oneMKL installation directory, under:
examples/sycl/vml/vfmod.cpp
Parent topic: Arithmetic Functions