返回顶部
首页 > 资讯 > 后端开发 > Python >Python NumPy教程之二元计算详解
  • 350
分享到

Python NumPy教程之二元计算详解

2024-04-02 19:04:59 350人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

二元运算符作用于位,进行逐位运算。二元运算只是组合两个值以创建新值的规则。 numpy.bitwise_and(): 此函数用于计算两个数组元素的按位与。 此函数计算输入数组中整数的

二元运算符作用于位,进行逐位运算。二元运算只是组合两个值以创建新值的规则。

numpy.bitwise_and(): 此函数用于计算两个数组元素的按位与。 此函数计算输入数组中整数的底层二进制表示的按位与。

代码#1:

# 解释 bitwise_and() 函数的 python 程序
 
import numpy as geek
in_num1 = 10
in_num2 = 11
 
print ("Input  number1 : ", in_num1)
print ("Input  number2 : ", in_num2) 
   
out_num = geek.bitwise_and(in_num1, in_num2) 
print ("bitwise_and of 10 and 11 : ", out_num) 

在 IDE 上运行

输出 :

Input  number1 :  10
Input  number2 :  11
bitwise_and of 10 and 11 :  10

代码#2:

# 解释 bitwise_and() 函数的 Python 程序
 
import numpy as geek
 
in_arr1 = [2, 8, 125]
in_arr2 = [3, 3, 115]
  
print ("Input array1 : ", in_arr1) 
print ("Input array2 : ", in_arr2)
   
out_arr = geek.bitwise_and(in_arr1, in_arr2) 
print ("Output array after bitwise_and: ", out_arr) 

在 IDE 上运行

输出 :

Input array1 :  [2, 8, 125]
Input array2 :  [3, 3, 115]
Output array after bitwise_and:  [  2   0 113]

numpy.bitwise_or(): 此函数用于计算两个数组元素的按位或。 此函数计算输入数组中整数的底层二进制表示的按位或。

代码#1:

# 解释 bitwise_or() 函数的 Python 程序
 
import numpy as geek
in_num1 = 10
in_num2 = 11
 
print ("Input  number1 : ", in_num1)
print ("Input  number2 : ", in_num2) 
   
out_num = geek.bitwise_or(in_num1, in_num2) 
print ("bitwise_or of 10 and 11 : ", out_num) 

在 IDE 上运行

输出 :

Input  number1 :  10
Input  number2 :  11
bitwise_or of 10 and 11 :  11

代码#2:

# 解释 bitwise_or() 函数的 Python 程序
 
import numpy as geek
 
in_arr1 = [2, 8, 125]
in_arr2 = [3, 3, 115]
  
print ("Input array1 : ", in_arr1) 
print ("Input array2 : ", in_arr2)
   
out_arr = geek.bitwise_or(in_arr1, in_arr2) 
print ("Output array after bitwise_or: ", out_arr) 

在 IDE 上运行

输出 :

Input array1 :  [2, 8, 125]
Input array2 :  [3, 3, 115]
Output array after bitwise_or:  [  3  11 127]

numpy.bitwise_xor(): 此函数用于计算两个数组元素的按位异或。 此函数计算输入数组中整数的底层二进制表示的按位异或。

代码#1:

# 解释 bitwise_xor() 函数的 Python 程序
 
import numpy as geek
in_num1 = 10
in_num2 = 11
 
print ("Input  number1 : ", in_num1)
print ("Input  number2 : ", in_num2) 
   
out_num = geek.bitwise_xor(in_num1, in_num2) 
print ("bitwise_xor of 10 and 11 : ", out_num) 

在 IDE 上运行

输出 :

Input  number1 :  10
Input  number2 :  11
bitwise_xor of 10 and 11 :  1

代码#2:

# 解释 bitwise_xor() 函数的 Python 程序
 
import numpy as geek
 
in_arr1 = [2, 8, 125]
in_arr2 = [3, 3, 115]
  
print ("Input array1 : ", in_arr1) 
print ("Input array2 : ", in_arr2)
   
out_arr = geek.bitwise_xor(in_arr1, in_arr2) 
print ("Output array after bitwise_xor: ", out_arr) 

在 IDE 上运行

输出 :

Input array1 :  [2, 8, 125]
Input array2 :  [3, 3, 115]
Output array after bitwise_xor:  [ 1 11 14]

numpy.invert(): 此函数用于计算数组元素的按位反转。 它计算输入数组中整数的底层二进制表示的按位 NOT。

对于有符号整数输入,返回二进制补码。在二进制补码系统中,负数由绝对值的二进制补码表示。

代码#1:

# 解释 invert() 函数的 Python 程序
 
import numpy as geek
in_num = 10
print ("Input  number : ", in_num)
   
out_num = geek.invert(in_num) 
print ("inversion of 10 : ", out_num) 

在 IDE 上运行

输出 :

Input  number :  10
inversion of 10 :  -11

代码#2:

# 解释 invert() 函数的 Python 程序
 
import numpy as geek
 
in_arr = [2, 0, 25]
print ("Input array : ", in_arr)
   
out_arr = geek.invert(in_arr) 
print ("Output array after inversion: ", out_arr) 

在 IDE 上运行

输出 :

Input array :  [2, 0, 25]
Output array after inversion:  [ -3  -1 -26]

numpy.left_shift(): 此函数用于将整数的位向左移动。通过在 arr1 的右侧附加 arr2 0s(零)来向左移动位。由于数字的内部表示是二进制格式,所以这个操作相当于 arr1 乘以 2**arr2。例如,如果数字是 5,我们想要左移 2 位,那么在左移 2 位之后,结果将是 5*(2^2) = 20

代码#1:

# 解释 left_shift() 函数的 Python 程序
 
import numpy as geek
in_num = 5
bit_shift = 2
 
print ("Input  number : ", in_num)
print ("Number of bit shift : ", bit_shift ) 
   
out_num = geek.left_shift(in_num, bit_shift) 
print ("After left shifting 2 bit  : ", out_num) 

在 IDE 上运行

输出 :

Input  number :  5
Number of bit shift :  2
After left shifting 2 bit  :  20

代码#2:

# 解释 left_shift() 函数的 Python 程序
 
import numpy as geek
 
in_arr = [2, 8, 15]
bit_shift =[3, 4, 5]
  
print ("Input array : ", in_arr) 
print ("Number of bit shift : ", bit_shift)
   
out_arr = geek.left_shift(in_arr, bit_shift) 
print ("Output array after left shifting: ", out_arr) 

在 IDE 上运行

输出 :

Input array :  [2, 8, 15]
Number of bit shift :  [3, 4, 5]
Output array after left shifting:  [ 16 128 480]

numpy.right_shift(): 该函数用于将整数的位右移。由于数字的内部表示是二进制格式,因此该操作相当于将 arr1 除以 2**arr2。例如,如果数字是 20,我们想要右移 2 位,那么在右移 2 位之后,结果将是 20/(2^2) = 5。

代码#1:

# 解释 right_shift() 函数的 Python 程序
 
import numpy as geek
in_num = 20
bit_shift = 2
 
print ("Input  number : ", in_num)
print ("Number of bit shift : ", bit_shift ) 
   
out_num = geek.right_shift(in_num, bit_shift) 

在 IDE 上运行

输出 :

Input  number :  20
Number of bit shift :  2
After right shifting 2 bit  :  5

代码#2:

# 解释 right_shift() 函数的 Python 程序
 
import numpy as geek
 
in_arr = [24, 48, 16]
bit_shift =[3, 4, 2]
  
print ("Input array : ", in_arr) 
print ("Number of bit shift : ", bit_shift)
   
out_arr = geek.right_shift(in_arr, bit_shift) 
print ("Output array after right shifting: ", out_arr) 

在 IDE 上运行

输出 :

Input array :  [24, 48, 16]
Number of bit shift :  [3, 4, 2]
Output array after right shifting:  [3 3 4]

numpy.binary_repr(number, width=None): 该函数用于将输入数字的二进制形式表示为字符串。对于负数,如果未给出宽度,则在前面添加一个减号。如果给出了宽度,则返回与该宽度相关的数字的二进制补码。

在二进制补码系统中,负数由绝对值的二进制补码表示。这是在计算机上表示有符号整数的最常用方法。

代码#1:

# 解释 binary_repr() 函数的 Python 程序
 
import numpy as geek
in_num = 10
 
print ("Input  number : ", in_num)
 
out_num = geek.binary_repr(in_num) 
print ("binary representation of 10 : ", out_num) 

在 IDE 上运行

输出 :

Input  number :  10
binary representation of 10 :  1010

代码#2:

# 解释 binary_repr() 函数的 Python 程序
import numpy as geek
 
in_arr = [5, -8 ]
  
print ("Input array : ", in_arr) 
 
# 不使用宽度参数的第一个数组元素的二进制表示
out_num = geek.binary_repr(in_arr[0])
print("Binary representation of 5")
print ("Without using width parameter : ", out_num) 
 
# 使用宽度参数的第一个数组元素的二进制表示
out_num = geek.binary_repr(in_arr[0], width = 5)
print ("Using width parameter: ", out_num) 
 
print("\nBinary representation of -8")
 
# 不使用宽度参数的第二个数组元素的二进制表示
out_num = geek.binary_repr(in_arr[1])
print ("Without using width parameter : ", out_num) 
 
# 使用宽度参数的第二个数组元素的二进制表示
out_num = geek.binary_repr(in_arr[1], width = 5)
print ("Using width parameter : ", out_num) 

在 IDE 上运行

输出 :

Input array :  [5, -8]
Binary representation of 5 
Without using width parameter :  101
Using width parameter:  00101

Binary representation of -8  
Without using width parameter :  -1000
Using width parameter :  11000

numpy.packbits(myarray, axis=None) : 此函数用于将二进制值数组的元素打包成 uint8 数组中的位。通过在末尾插入零位将结果填充到完整字节。

代码#1:

# 解释 packbits() 函数的 Python 程序
import numpy as np
 
# 使用数组函数创建数组
a = np.array([[[1,0,1],
             [0,1,0]],
             [[1,1,0],
             [0,0,1]]])
 
# 使用 packbits() 函数打包数组的元素
b = np.packbits(a, axis=-1)
 
print(b)

在 IDE 上运行

输出 :

[[[160],[64]],[[192],[32]]]

numpy.unpackbits(myarray, axis=None) : 此函数用于将 uint8 数组的元素解包为二进制值输出数组。 myarray 的每个元素表示应解包为二进制值输出数组的位字段. 输出数组的形状是一维的(如果轴为无)或与输入数组的形状相同,并沿指定的轴进行解包。

代码#1:

# 解释 unpackbits() 函数的 Python 程序
import numpy as np
 
# 使用数组函数创建数组
a = np.array([[2], [7], [23]], dtype=np.uint8)
 
# 使用 packbits() 函数打包数组的元素
b = np.unpackbits(a, axis = 1)
 
print(b)

在 IDE 上运行

输出 :

[[0, 0, 0, 0, 0, 0, 1, 0],
 [0, 0, 0, 0, 0, 1, 1, 1],
 [0, 0, 0, 1, 0, 1, 1, 1]]

到此这篇关于Python NumPy教程之二元计算详解的文章就介绍到这了,更多相关Python NumPy二元计算内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Python NumPy教程之二元计算详解

本文链接: https://lsjlt.com/news/120241.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python NumPy教程之二元计算详解
    二元运算符作用于位,进行逐位运算。二元运算只是组合两个值以创建新值的规则。 numpy.bitwise_and(): 此函数用于计算两个数组元素的按位与。 此函数计算输入数组中整数的...
    99+
    2024-04-02
  • Python科学计算之NumPy入门教程
    前言 NumPy是Python用于处理大型矩阵的一个速度极快的数学库。它允许你在Python中做向量和矩阵的运算,而且很多底层的函数都是用C写的,你将获得在普通Python中无法达到的运行速度。这是由于矩...
    99+
    2022-06-04
    入门教程 科学 Python
  • Python NumPy教程之索引详解
    目录为什么我们需要 NumPy 使用索引数组进行索引索引类型基本切片和索引高级索引NumPy 或 Numeric Python 是一个用于计算同质 n 维数组的包。在 nu...
    99+
    2024-04-02
  • Python Pandas学习之series的二元运算详解
    目录二元运算series 的二元运算series 上的二元运算方法二元运算 二元运算是指由两个元素形成第三个元素的一种规则,例如数的加法及乘法;更一般地,由两个集合形成第三个集合的产...
    99+
    2024-04-02
  • 用python计算二元一次方程
    二元一次方程通常形如ax + b = 0,其中a和b是常数。要用Python计算这个方程的解,你可以使用如下代码: # 定义a和b的值a = 2b = 1# 计算方程的解x = -b / aprint(x) # 输出 -0.5 如...
    99+
    2023-10-28
  • Python入门教程之三元运算符的使用详解
    目录使用三元运算符的简单方法使用元组、字典和 lambda 的直接方法三元运算符可以写成嵌套的 if-else在三元运算符中使用打印功能要点三元运算符也称为条件表达式,是根据条件为真...
    99+
    2024-04-02
  • Python NumPy教程之数组的创建详解
    本篇文章给大家带来了关于Python的相关知识,主要为大家详细介绍了Python NumPy中数组的创建方式,文中的示例代码讲解详细,对我们学习Python有一定帮助,需要的可以参考一下。【相关推荐:Python3视频教程 】使用 List...
    99+
    2024-04-02
  • educoder之Python数值计算库Numpy图像处理详解
    目录NumPy   Python数值计算重要库读取和显示图像图像的大小调整图像的翻转图像缩放和裁剪颜色通道处理图像滤波NumPy   Pyth...
    99+
    2023-05-17
    Python 数值计算库Numpy Python Numpy图像处理
  • Python NumPy教程之数据类型对象详解
    每个 ndarray 都有一个关联的数据类型 (dtype) 对象。这个数据类型对象(dtype)告诉我们数组的布局。这意味着它为我们提供了以下信息: 数据类型(整数、浮点数、Pyt...
    99+
    2024-04-02
  • Python NumPy教程之数组的基本操作详解
    目录Numpy中的N维数组(ndarray)数组创建数组索引基本操作数据类型Numpy中的N维数组(ndarray) Numpy 中的数组是一个元素表(通常是数字),所有元素类型相同...
    99+
    2024-04-02
  • Python运算符教程之逻辑门详解
    目录1. 与门 2. 与非门 3. 或门 4. 异或 5. NOT Gate 6. NOR 门 7. XNOR 门&nbs...
    99+
    2024-04-02
  • Python科学计算之Pandas详解
    起步 Pandas最初被作为金融数据分析工具而开发出来,因此 pandas 为时间序列分析提供了很好的支持。 Pandas 的名称来自于面板数据(panel data)和python数据分析 (data ...
    99+
    2022-06-04
    详解 科学 Python
  • Python-OpenCV教程之图像的位运算详解
    1、按位取反bitwise_not() 按位取反就是将数值根据每个bit位1变0,0变1,比如0xf0按位取反就变成了0x0f,如果是uint8类型的数据,取反前...
    99+
    2024-04-02
  • Python入门教程之运算符重载详解
    目录如何重载Python中的运算符在 Python中重载比较运算符重载相等和小于运算符用于运算符重载的 Python 魔术方法或特殊函数二元运算符比较运算符赋值运算符一元运算符运算符...
    99+
    2024-04-02
  • Python中numpy数组的计算与转置详解
    目录前言1、numpy数组与数的运算2、numpy相同尺寸的数组运算3、numpy不同尺寸的数组计算4、numpy数组的转置总结:前言 本文主要讲述numpy数组的计算与转置,讲相同...
    99+
    2024-04-02
  • 千锋Linux云计算教程全套视频合集:Dockerfile详解(二)
    在本章节中将和大家讲解:Dockerfile的第二部分:DockerfileFROM 指令主要作用是指定一个镜像作为构建自定义镜像的基础镜像,在这个基础镜像之上进行修改定制。这个指令是 Dockerfile 中的必备指令,同时也必须是第一条...
    99+
    2023-06-04
  • Python详细解析之二分查找算法
    本篇文章给大家带来了关于python的相关知识,其中主要整理了二分查找算法的相关问题,包括了算法描述、算法分析、算法思路等等内容,下面一起来看一下,希望对大家有帮助。二分法是一种效率比较高的搜索方法回忆之前做过的猜数字的小游戏,预先给定一个...
    99+
    2022-06-28
    python
  • 如何理解Python的二元算术运算
    本篇内容介绍了“如何理解Python的二元算术运算”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!查看 C 代码按照惯例,我们从查看 CPyt...
    99+
    2023-06-16
  • Python生成二维码的教程详解
    目录交代背景pyqrcode 实现二维码qrcode 实现二维码MyQR 实现二维码Amazing-QR 实现二维码交代背景 作为一名合格的 Python 程序员,在工作中必然会用到...
    99+
    2024-04-02
  • Python Numpy库的超详细教程
    1、Numpy概述 1.1 概念 Python本身含有列表和数组,但对于大数据来说,这些结构是有很多不足的。由于列表的元素可以是任何对象,因此列表中所保存的是对象的指针。对于数值运算...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作