copysign#
Returns vector of elements of one argument with signs changed to match other argument elements.
Syntax
Buffer API:
namespace oneapi::math::vm {
sycl::event copysign(
        sycl::queue& exec_queue,
        std::int64_t n,
        sycl::buffer<T,1>& a,
        sycl::buffer<T,1>& b,
        sycl::buffer<T,1>& y,
        oneapi::math::vm::mode mode = oneapi::math::vm::mode::not_defined);
} // namespace oneapi::math::vm
USM API:
namespace oneapi::math::vm {
sycl::event copysign(
        sycl::queue& exec_queue,
        std::int64_t n,
        const T *a,
        const T *b,
        T* y,
        std::vector<sycl::event> const & depends = {},
        oneapi::math::vm::mode mode = oneapi::math::vm::mode::not_defined);
} // namespace oneapi::math::vm
copysign supports the following precisions.
T  | 
|---|
  | 
  | 
Description
The copysign(a, b) function returns the first vector argument elements with the sign changed to match the sign of the second vector argument’s corresponding elements.
Argument 1  | 
Argument 2  | 
Result  | 
Status code  | 
|---|---|---|---|
any value  | 
positive value  | 
+any value  | 
|
any value  | 
negative value  | 
-any value  | 
The copysign(a, b) function does not generate any errors.
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
oneapi::math::vm::mode::not_defined.
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
oneapi::math::vm::mode::not_defined.
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)
 Event, signifying availability of computed output and status code(s).
Exceptions
For list of generated exceptions please refer to Exceptions
Parent topic: VM Mathematical Functions