Source code for dpnp.dpnp_iface_bitwise

# cython: language_level=3
# distutils: language = c++
# -*- coding: utf-8 -*-
# *****************************************************************************
# Copyright (c) 2016-2020, Intel Corporation
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
# - Redistributions of source code must retain the above copyright notice,
#   this list of conditions and the following disclaimer.
# - Redistributions in binary form must reproduce the above copyright notice,
#   this list of conditions and the following disclaimer in the documentation
#   and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
# THE POSSIBILITY OF SUCH DAMAGE.
# *****************************************************************************

"""
Interface of the Binary operations of the DPNP

Notes
-----
This module is a face or public interface file for the library
it contains:
 - Interface functions
 - documentation for the functions
 - The functions parameters check

"""


import numpy


from dpnp.dpnp_algo import *
from dpnp.dpnp_utils import *
import dpnp

__all__ = [
    'bitwise_and',
    'bitwise_or',
    'bitwise_xor',
    'invert',
    'bitwise_not',
    'left_shift',
    'right_shift',
]


def _check_nd_call(origin_func, dpnp_func, x1, x2, dtype=None, out=None, where=True, **kwargs):
    """Choose function to call based on input and call chosen fucntion."""

    x1_is_scalar = dpnp.isscalar(x1)
    x2_is_scalar = dpnp.isscalar(x2)
    x1_desc = dpnp.get_dpnp_descriptor(x1)
    x2_desc = dpnp.get_dpnp_descriptor(x2)
    x1_desc = dpnp.get_dpnp_descriptor(x1, copy_when_strides=False)
    x2_desc = dpnp.get_dpnp_descriptor(x2, copy_when_strides=False)

    if x1_desc and x2_desc and not kwargs:
        if not x1_desc and not x1_is_scalar:
            pass
        elif not x2_desc and not x2_is_scalar:
            pass
        elif x1_is_scalar and x2_is_scalar:
            pass
        elif x1_desc and x1_desc.ndim == 0:
            pass
        elif x2_desc and x2_desc.ndim == 0:
            pass
        elif x1_desc and x2_desc and x1_desc.size != x2_desc.size:
            pass
        elif x1_desc and x2_desc and x1_desc.shape != x2_desc.shape:
            pass
        elif dtype is not None:
            pass
        elif out is not None:
            pass
        elif not where:
            pass
        else:
            out_desc = dpnp.get_dpnp_descriptor(out) if out is not None else None
            return dpnp_func(x1_desc, x2_desc, dtype, out_desc, where).get_pyobj()

    return call_origin(origin_func, x1, x2, dtype=dtype, out=out, where=where, **kwargs)


[docs]def bitwise_and(x1, x2, dtype=None, out=None, where=True, **kwargs): """ Compute the bit-wise AND of two arrays element-wise. For full documentation refer to :obj:`numpy.bitwise_and`. Limitations ----------- Parameters ``x1`` and ``x2`` are supported as either :obj:`dpnp.ndarray` or scalar. Parameters ``dtype``, ``out`` and ``where`` are supported with their default values. Sizes, shapes and data types of input arrays are supported to be equal. Keyword arguments ``kwargs`` are currently unsupported. Otherwise the function will be executed sequentially on CPU. Input data is supported as integer only. See Also -------- :obj:`dpnp.logical_and` : Compute the truth value of ``x1`` AND ``x2`` element-wise. :obj:`dpnp.bitwise_or`: Compute the bit-wise OR of two arrays element-wise. :obj:`dpnp.bitwise_xor` : Compute the bit-wise XOR of two arrays element-wise. Examples -------- >>> import dpnp as np >>> x1 = np.array([2, 5, 255]) >>> x2 = np.array([3,14,16]) >>> out = np.bitwise_and(x1, x2) >>> [i for i in out] [2, 4, 16] """ return _check_nd_call(numpy.bitwise_and, dpnp_bitwise_and, x1, x2, dtype=dtype, out=out, where=where, **kwargs)
[docs]def bitwise_or(x1, x2, dtype=None, out=None, where=True, **kwargs): """ Compute the bit-wise OR of two arrays element-wise. For full documentation refer to :obj:`numpy.bitwise_or`. Limitations ----------- Parameters ``x1`` and ``x2`` are supported as either :obj:`dpnp.ndarray` or scalar. Parameters ``dtype``, ``out`` and ``where`` are supported with their default values. Sizes, shapes and data types of input arrays are supported to be equal. Keyword arguments ``kwargs`` are currently unsupported. Otherwise the function will be executed sequentially on CPU. Input data is supported as integer only. See Also -------- :obj:`dpnp.logical_or` : Compute the truth value of ``x1`` OR ``x2`` element-wise. :obj:`dpnp.bitwise_and`: Compute the bit-wise AND of two arrays element-wise. :obj:`dpnp.bitwise_xor` : Compute the bit-wise XOR of two arrays element-wise. Examples -------- >>> import dpnp as np >>> x1 = np.array([2, 5, 255]) >>> x2 = np.array([4, 4, 4]) >>> out = np.bitwise_or(x1, x2) >>> [i for i in out] [6, 5, 255] """ return _check_nd_call(numpy.bitwise_or, dpnp_bitwise_or, x1, x2, dtype=dtype, out=out, where=where, **kwargs)
[docs]def bitwise_xor(x1, x2, dtype=None, out=None, where=True, **kwargs): """ Compute the bit-wise XOR of two arrays element-wise. For full documentation refer to :obj:`numpy.bitwise_xor`. Limitations ----------- Parameters ``x1`` and ``x2`` are supported as either :obj:`dpnp.ndarray` or scalar. Parameters ``dtype``, ``out`` and ``where`` are supported with their default values. Sizes, shapes and data types of input arrays are supported to be equal. Keyword arguments ``kwargs`` are currently unsupported. Otherwise the function will be executed sequentially on CPU. Input data is supported as integer only. See Also -------- :obj:`dpnp.logical_xor` : Compute the truth value of ``x1`` XOR `x2`, element-wise. :obj:`dpnp.bitwise_and`: Compute the bit-wise AND of two arrays element-wise. :obj:`dpnp.bitwise_or` : Compute the bit-wise OR of two arrays element-wise. Examples -------- >>> import dpnp as np >>> x1 = np.array([31, 3]) >>> x2 = np.array([5, 6]) >>> out = np.bitwise_xor(x1, x2) >>> [i for i in out] [26, 5] """ return _check_nd_call(numpy.bitwise_xor, dpnp_bitwise_xor, x1, x2, dtype=dtype, out=out, where=where, **kwargs)
[docs]def invert(x, **kwargs): """ Compute bit-wise inversion, or bit-wise NOT, element-wise. For full documentation refer to :obj:`numpy.invert`. Limitations ----------- Parameters ``x`` is supported as :obj:`dpnp.ndarray`. Keyword arguments ``kwargs`` are currently unsupported. Otherwise the function will be executed sequentially on CPU. Input array ``x`` is supported as integer :obj:`dpnp.ndarray` only. See Also -------- :obj:`dpnp.bitwise_and`: Compute the bit-wise AND of two arrays element-wise. :obj:`dpnp.bitwise_or` : Compute the bit-wise OR of two arrays element-wise. :obj:`dpnp.bitwise_xor` : Compute the bit-wise XOR of two arrays element-wise. :obj:`dpnp.logical_not` : Compute the truth value of NOT x element-wise. Examples -------- >>> import dpnp as np >>> x = np.array([13]) >>> out = np.invert(x) >>> out[0] -14 """ x1_desc = dpnp.get_dpnp_descriptor(x) if x1_desc and not kwargs: return dpnp_invert(x1_desc).get_pyobj() return call_origin(numpy.invert, x, **kwargs)
bitwise_not = invert # bitwise_not is an alias for invert
[docs]def left_shift(x1, x2, dtype=None, out=None, where=True, **kwargs): """ Shift the bits of an integer to the left. For full documentation refer to :obj:`numpy.left_shift`. Limitations ----------- Parameters ``x1`` and ``x2`` are supported as either :obj:`dpnp.ndarray` or scalar. Parameters ``dtype``, ``out`` and ``where`` are supported with their default values. Sizes, shapes and data types of input arrays are supported to be equal. Keyword arguments ``kwargs`` are currently unsupported. Otherwise the function will be executed sequentially on CPU. Input data is supported as integer only. See Also -------- :obj:`dpnp.right_shift` : Shift the bits of an integer to the right. Examples -------- >>> import dpnp as np >>> x1 = np.array([5, 5, 5]) >>> x2 = np.array([1, 2, 3]) >>> out = np.left_shift(x1, x2) >>> [i for i in out] [10, 20, 40] """ return _check_nd_call(numpy.left_shift, dpnp_left_shift, x1, x2, dtype=dtype, out=out, where=where, **kwargs)
[docs]def right_shift(x1, x2, dtype=None, out=None, where=True, **kwargs): """ Shift the bits of an integer to the right. For full documentation refer to :obj:`numpy.right_shift`. Limitations ----------- Parameters ``x1`` and ``x2`` are supported as either :obj:`dpnp.ndarray` or scalar. Parameters ``dtype``, ``out`` and ``where`` are supported with their default values. Sizes, shapes and data types of input arrays are supported to be equal. Keyword arguments ``kwargs`` are currently unsupported. Otherwise the function will be executed sequentially on CPU. Input data is supported as integer only. See Also -------- :obj:`dpnp.left_shift` : Shift the bits of an integer to the left. Examples -------- >>> import dpnp as np >>> x1 = np.array([10, 10, 10]) >>> x2 = np.array([1, 2, 3]) >>> out = np.right_shift(x1, x2) >>> [i for i in out] [5, 2, 1] """ return _check_nd_call(numpy.right_shift, dpnp_right_shift, x1, x2, dtype=dtype, out=out, where=where, **kwargs)