浅浅尝试Numpy的函数:

1.numpy.empty:

numpy.empty方法用来创建一个指定形状(shape),数据类型(dtype)且未被初始化的数组:

numpy.empty(shape,dtype = float,order = 'C')

参数说明: 

shape:数组形状。

dtype:数据类型,可选。

order:有C和F两个选项,分别代表行优先和列优先,是计算机内存中存储元素的顺序。

import numpy as np# 1、numpy.empty
s = np.empty([4, 6], dtype=int)
print(s)

2.numpy.zeros:

创建指定大小的组数,数组元素用0来填充:

numpy.zeros(shape, dtype = float,order = 'C')

参数说明:

shape:数组形状。

dtype:数据类型,可选。

order:有C和F两个选项,分别代表行优先和列优先,是计算机内存中存储元素的顺序。

import numpy as np# 默认为浮点数
x = np.zeros(5)
print(x)# 设置类型为整数
y = np.zeros((5, 2), dtype=np.int32)
print(y)# 自定义类型
z = np.zeros((3, 2), dtype=[('x', 'i4'), ('y', 'i4')])
print(z)

numpy.ones:

创建指定形状的数组,用数组元素1来填充:

numpty.ones(shape, dtype = None,order = 'C')

参数说明:

shape:数组形状。

dtype:数据类型,可选。

order:有C和F两个选项,分别代表行优先和列优先,是计算机内存中存储元素的顺序。

import numpy as np# 默认为浮点数:
x = np.ones(5)
print(x)
# 自定义类型
x = np.ones([3, 3], dtype=int)
print(x)

还可以从已有数组创建数组。

(1)numpy.asarray:

numpy.asarray类似于numpy.array,但numpy.asarray的参数只有3个,比numpy.array少两个。

numpy.asarray(a, dtype = None, order = Npne)

参数说明如下:

a:任意形式的输入参数,可以是列表、列表的元组,元组、元组的元组,元组的列表。多维数组。

dtype:数据类型,可选。

order:可选,有C和F两个选项,分别代表行优先和列优先,是计算机内存中存储元素的顺序。 

 将列表转为ndarray:

import numpy as npx = [4, 5, 6, 10000]
print(x)
a = np.asarray(x)
print(a)
# [4, 5, 6, 10000]
# [    4     5     6 10000]

  将元组转为ndarray:

import numpy as npx = (100, 2000, 300000)
print(x)
a = np.asarray(x)
print(a)
# (100, 2000, 300000)
# [   100   2000 300000]

元组列表转为ndarray:

import numpy as npx = [(1, 2, 3), (4, 5, 6)]  # 确保所有元组长度一致
a = np.asarray(x)
print(a)
print('-'*15)# 定义dtype
y = [1, 2, 3]
b = np.asarray(y, dtype=float)
print(b)

(2)numpy.frombuffer:

numpy.frombuffer用于实现动态数组。

numpy.frombuffer接收buffer输入的参数,以流的形式读入转化成ndarray对象。

buffer是字符串的时候,Python3默认str是Unicode类型,所以要转为bytestring需在原str前加上b。

numpy.frombutter(buffer, dtype = float, count = -1, offset = 0)

 参数说明如下:

buffer:可以是任意对象,会以流的形式读入。

dtype:返回数组的数据类型,可选。

count:读取的数据数量,默认为-1,读取所有数据。

offset:读取的起始位置,默认为0。

 numpy.frombuffer实例应用:

import numpy as nps = b"Hello World!"
s1 = np.frombuffer(s, dtype='S1')
# [b'H' b'e' b'l' b'l' b'o' b' ' b'W' b'o' b'r' b'l' b'd']
print(s1)

(2)numpy.fromiter:

numpy.fromiter方法从可迭代对象中建立ndarray对象,返回一维数组。

numpy.fromiter(iterable,dtype,count = -1)

 参数说明如下:

iterable:可迭代对象。

dtype:返回数组的数据类型。

count:读取的数据数量,默认为-1,读取所有数据。

numpy.fromiter应用实例:

import numpy as npList = range(15)
it = iter(List)
x = np.fromiter(it, dtype=float)
print(x)
# [ 0.  1.  2.  3.  4.  5.  6.  7.  8.  9. 10. 11. 12. 13. 14.]

数学运算:

算术函数:

1.加、减、乘、除函数

import numpy as npa = np.arange(0, 27, 3, dtype=np.float_).reshape(3, 3)
print('第一个数组:')
print(a)
print('~' * 15)
print("第二个数组:")
b = np.array([3, 6, 9])
print(b)
print('~' * 15)
print("第三个数组:")
c = np.arange(0, 20, 5,dtype=np.int32).reshape(2,2)
print(c)print(np.add(a, b))
print(np.subtract(a, b))
print(np.multiply(a, b))
print(np.divide(a, b))

1.numpy.reciprocal()函数: (求倒数)

import numpy as nps = np.array([888, 1000, 20, 0.1])
print("原数组是:")
print(s)
print('*' * 20)
print("调用reciprocal函数:")
print(np.reciprocal(s))
# 原数组是:
# [8.88e+02 1.00e+03 2.00e+01 1.00e-01]
# ********************
# 调用reciprocal函数:
# [1.12612613e-03 1.00000000e-03 5.00000000e-02 1.00000000e+01]

2.numpy.reciprocal()函数:

import numpy as npbase_array = np.array([2, 4, 8])
print("底数数组是:")
print(base_array)
print('*' * 20)
print('调用power函数计算平方:')
print(np.power(base_array, 2))  # 计算每个元素的平方
print('*' * 20)
print('指数数组是:')
exponents = np.array([1, 2, 4])
print(exponents)
print('*' * 20)
print('再次调用power函数计算底数的对应指数次方:')
# 计算2^1, 4^2, 8^4
print(np.power(base_array, exponents))
# 底数数组是:
# [2 4 8]
# ********************
# 调用power函数计算平方:
# [ 4 16 64]
# ********************
# 指数数组是:
# [1 2 4]

3.numpy.mod()函数:

函数作用公式负数行为
np.mod()计算余数s - w * floor(s / w)余数符号与除数相同
np.remainder()计算余数s - w * round(s / w)余数符号与被除数相同
a = np.array([-5, 5])
b = np.array([2, -2])
print(np.mod(a, b))      # [1, -1]
print(np.remainder(a, b)) # [-1, 1]
import numpy as nps = np.array([-3, 6, 9])
w = np.array([2, 4, 8])
print('第一个数组:')
print(s)
print('*' * 20)
print('第二个数组:')
print(w)
print('*' * 20)
print('调用mod()函数')
print(np.mod(s, w))
print('*' * 20)
print('调用remainder()函数:')
print(np.remainder(s, w))

三角函数:

1.sin(),cos()和tan()函数:

import numpy as npa = np.array([0, 30, 45, 60, 90])
print('不同角度的正弦值:')
# 通过乘 pi/180 转化为弧度
print('*' * 20)
print(np.sin(a * np.pi / 180))
print('*' * 20)
print("数组中角度的余弦值:")
print(np.cos(a * np.pi / 180))
print('*' * 20)
print('数组中角度的正切值')
print(np.tan(a * np.pi / 180))

2.arcsin(),arccos()和arctan()

import numpy as npa = np.array([0, 30, 45, 60, 90])
print('含有正弦值的数组:')
sin = np.sin(a * np.pi / 180)
print(sin)
print('*' * 20)
print('计算角度的反正弦,返回值以弧度为单位:')
inv = np.arcsin(sin)
print(inv)
print('*' * 20)
print('通过转化角度制来检查结果:')
print(np.degrees(inv))
print('*' * 20)
print('arccos 和 arctan函数行为类似:')
cos = np.cos(a * np.pi / 180)
print(cos)
print('*' * 20)
print('反余弦:')
inv = np.arccos(cos)
print(inv)

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/74397.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IM基本设计思路与有序ID的重要性

文章目录 概要问题解析思考问题数据基础读取写入总结 概要 说起IM程序我们都不陌生,本篇文章我们就为如何实现一个IM做一个简单的整体方案设计以及基本的数据结构 问题解析 我们先不上一大堆牛逼哄哄的中间件。 我们先从实现角度,来讲讲设计思路。 从…

数据结构学习

链表 单链表 头插 将x插到下标是k的点后面 将下标是k的点后面的点删掉 代码 // head 表示头结点的下标 // e[i] 表示节点i的值 // ne[i] 表示节点i的next指针是多少 // idx 存储当前已经用到了哪个点// 初始化 void init() {head -1;idx 0; }// 将x插到头结点 void add_to_…

0.DJI-PSDK开发准备及资料说明(基于DJI经纬M300RTK和M350RTK无人机上使用)

0.DJI-PSDK开发准备及资料说明(基于DJI经纬M300RTK和M350RTK无人机上使用) 【资料名称】 DJI经纬M300RTK和M350RTK无人机二次开发资料包。资料包在最下方的百度网盘 一、引言 在进行大疆无人机负载开发的过程中,我整理出一系列有价值的资…

Linux内核TCP/IP协议栈中的设计模式:从面向对象到系统级软件的跨界实践

引言 设计模式(Design Patterns)自GoF(Gang of Four)在1994年提出以来,已成为软件工程领域的核心概念。尽管其经典定义基于面向对象编程(OOP),但设计模式的本质是解决复杂问题的经验总结,而非局限于特定编程范式。本文以Linux内核的TCP/IP协议栈为例,探讨设计模式在…

第十四届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(部分题解)

文章目录 前言日期统计题意: 冶炼金属题意: 岛屿个数题意: 子串简写题意: 整数删除题意: 总结 前言 一年一度的🏀杯马上就要开始了,为了取得更好的成绩,好名字写了下前年2023年蓝桥…

处理JWT Token失效需求

JWT 本身是无状态的,这意味着服务器不会保存任何关于 Token 的状态信息。但为了支持 JWT 的状态管理(例如:强制使某些 Token 失效),可以借助 Redis 这样的外部存储来维护一个黑名单或白名单。 安装必要的 NuGet 包 首…

PHP代码审计-01

🌸 连接方式 PHP Mysql连接方式: Mysql(废弃)MysqliPDO 🌸 常见过滤 intval/addslashes/mysql_real_escape mysqli_escape_string/mysqli_real_escape_string/mysqli::escape_string PDO::quote 参数化查询 a…

SpringKafka错误处理:重试机制与死信队列

文章目录 引言一、Spring Kafka错误处理基础二、配置重试机制三、死信队列实现四、特定异常的处理策略五、整合事务与错误处理总结 引言 在构建基于Kafka的消息系统时,错误处理是确保系统可靠性和稳定性的关键因素。即使设计再完善的系统,在运行过程中也…

蓝桥杯2024JavaB组的一道真题的解析

文章目录 1.问题描述2.问题描述3.思路分析4.代码分析 1.问题描述 这个是我很久之前写的一个题目,当时研究了这个题目好久,发布了一篇题解,后来很多人点赞,我都没有意识到这个问题的严重性,我甚至都在怀疑自己&#xf…

性能比拼: Go标准库 vs Python FastAPI(第二轮)

本内容是对知名性能评测博主 Anton Putra Python (FastAPI) vs Go (Golang) (Round 2) Performance Benchmark 内容的翻译与整理, 有适当删减, 相关指标和结论以原作为准 介绍 这是第二轮关于 FastAPI 和 Golang 的对比测试。我几天前运行了前一次的基准测试,到目…

DeepSeek与ChatGPT的优势对比:选择合适的工具来提升工作效率

选DeepSeek还是ChatGPT?这就像问火锅和披萨哪个香! "到底该用DeepSeek还是ChatGPT?” 这个问题最近在互联网圈吵翻天!其实这就跟选手机系统-样,安卓党iOS党都能说出一万条理由,但真正重要的是你拿它来干啥!&am…

Python爬虫第4节-请求库urllib的request模块使用

目录 前言:基本库urllib的使用 一、urlopen方法 二、Request类 三、高级用法 前言:基本库urllib的使用 开始学习爬虫时,第一步就是要模拟浏览器给服务器发送请求。这个时候,你可能会有很多问题:该从哪里开始做呢&a…

Vue3 Pinia Store使用示例

代码示例: import { defineStore } from "pinia"; // 导入 Pinia 的 defineStore 方法 import { ref } from "vue"; // 导入 Vue 的响应式 API ref import { type Menu } from "/interface"; // 导入自定义的 Menu 类型/…

JavaScript逆向魔法:Chrome开发者工具探秘之旅

在前端开发和安全研究领域,JavaScript逆向工程是一项关键技能。它涉及分析和理解代码的执行流程、数据结构和逻辑,以发现潜在的安全漏洞、提取核心算法或实现功能兼容。本文将结合Chrome开发者工具的调试功能,并通过具体示例帮助你更好地理解…

Qt基础:资源文件

资源文件 1. 资源文件2. 资源文件创建 1. 资源文件 资源文件顾名思义就是一个存储资源的文件,在Qt中引入资源文件好处在于他能提高应用程序的部署效率并且减少一些错误的发生。 在程序编译过程中, 添加到资源文件中的文件也会以二进制的形式被打包到可执…

Agent TARS与Manus的正面竞争

Agent TARS 是 Manus 的直接竞争对手,两者在 AI Agent 领域形成了显著的技术与生态对抗。 一、技术架构与功能定位的竞争 集成化架构 vs 模块化设计 Agent TARS 基于字节跳动的 UI-TARS 视觉语言模型,将视觉感知、推理、接地(grounding&#…

使用ssh连接上开发板

最后我发现了问题,我忘记指定用户名了,在mobaXterm上左上角打开会话,点击ssh,然后输入要连接的开发板主机的ip地址,关键在这里,要指定你要连接的开发板的系统中存在的用户,因为通过ssh连接一个设…

【性能优化点滴】odygrd/quill在编译期做了哪些优化

Quill 是一个高性能的 C 日志库,它在编译器层面进行了大量优化以确保极低的运行时开销。以下是 Quill 在编译器优化方面的关键技术和实现细节: 1. 编译时字符串解析与格式校验 Quill 在编译时完成格式字符串的解析和校验,避免运行时开销&…

【数据结构】排序算法(中篇)·处理大数据的精妙

前引:在进入本篇文章之前,我们经常在使用某个应用时,会出现【商品名称、最受欢迎、购买量】等等这些榜单,这里面就运用了我们的排序算法,作为刚学习数据结构的初学者,小编为各位完善了以下几种排序算法&…

混杂模式(Promiscuous Mode)与 Trunk 端口的区别详解

一、混杂模式(Promiscuous Mode) 1. 定义与工作原理 定义:混杂模式是网络接口的一种工作模式,允许接口接收通过其物理链路的所有数据包,而不仅是目标地址为本机的数据包。工作层级:OSI 数据链路层&#x…