Python 标准库解读.1(对应MicroPython)

原创 云深之无迹 2021-11-03 17:22


上篇文章我们对mpy标准微库进行了简单的方法罗列,又因为mpy是从标准的Python库中退化而来,那就先简单的学习一下Python的库。



上面的文章说了这么多,那这篇就写这些



我这里就用3.8写了,使用jupyter环境


array是一个高效的数组模块,该模块定义了一个对象类型,它可以紧凑地表示一组基本值:字符、整数、浮点数。数组是序列类型,其行为与列表非常相似,只是其中存储的对象类型受到限制。类型是在创建对象时使用类型代码指定的, 类型代码是单个字符。定义了以下类型代码:



笔记,记好了


mpy中支持的格式代码:bBhHiIlLqQfd(后 2 种取决于浮点支持)。


那这个和list有什么区别呢?首先是一种序列类型,序列方法都可以在上面使用。然后数组类型的对象是固定的,不可以混合装载



使用要先导入,然后一开始要指定存储的数据类型



后面用元组传入存储的东西



IDE可以智能的给出方法



这里使用了一个列表的转换方法


这个比较简单,实验了mpy提供的一个添加方法


请看extend的方法


array.extend(iterable)


将来自 iterable 的项添加到数组末尾。如果 iterable 是另一个数组,它必须具有 完全 相同的类型码;否则将引发 TypeError。如果 iterable 不是一个数组,则它必须为可迭代对象并且其元素必须为可添加到数组的适当类型。


限制较多,其实数据类型相同就行。其实方法这么少,正好可以去看看实现,谁说不是呢?



二进制之间的转换方法,没有什么说的


复数运算



这是完整的双端队列



mpy提供了两个方法



我这里就做简单的演示



这些方法mpy不支持而且很多方法是之后才加进来的


在看命名数组之前,需要知道一个概念,叫工厂函数:


工厂函数看上去有点像函数,实质上他们是类,当你调用它们时,实际上是生成了该类型的一个实例,就像工厂生产货物一样.

python核心编程


https://www.cr173.com/soft/10446.html


书籍的下载位置



书籍封面



当然java里面也有这样的概念,你可以看看



看这个,list这个函数本身就有工厂函数的能力


工厂函数是指这些内建函数都是类对象,当你调用它们的时候,实际上是创建了一个类实例,其实也可以理解成内建函数


https://www.zhihu.com/question/20670869


归根结底,它源于设计模式中的一种说法,就是指你不通过类来直接构造对象,而是通过一个函数来构造对象,这样允许你在函数中加入更多的控制。


懵了吗?要是就这就懵了,那别看了~


其中命名元组赋予每个位置一个含义,提供可读性和自文档性。它们可以用于任何普通元组,并添加了通过名字获取值的能力,通过索引值也是可以的。



我觉得你看例子就能看懂


其中有使用位置和关键字实参,可以像普通元组一样去索引,字段可以用命去访问,加入了__repr__的值方法。


在mpy里面是这样使用的:


from collections import namedtuple
MyTuple = namedtuple("MyTuple", ("id", "name"))t1 = MyTuple(1, "foo")t2 = MyTuple(2, "bar")print(t1.name)assert t2.name == t2[1]


命名元组实例没有字典,所以它们要更轻量,并且占用更小内存。


我这个ordereddict真的不知道怎么翻译了,反正就是可以迭代的时候(就是打印的时候可以按照你加进去的顺序打印)


它会返回一个 dict 子类的实例,支持常用的 dict 方法。Ordered Dict 是一种记录键首次插入顺序的 dict 。如果新条目覆盖现有条目,则原始插入位置保持不变。删除一个条目并重新插入它将把它移到末尾。




这是标准Python库


from collections import OrderedDict
d = OrderedDict([("z"1), ("a"2)])# More items can be added as usuald["w"] = 5d["b"] = 3for k, v in d.items(): print(k, v)


使用前记得初始化,以上为mpy


z 1a 2w 5b 3


输出


接下来是文章中最有技术含量的东西,堆队列算法,这个东西讲起来就有学术味道了,而且还需要补充一些知识才可以。


容器:

在计算机科学中,容器是一个类或数据结构,其实例(运行实体)是其他对象的集合。换句话说,它们以遵循特定访问规则的有组织的方式存储对象。容器的大小取决于它包含的对象(元素)的数量。各种容器类型的底层(继承)实现的大小和复杂性可能不同,并为任何给定场景选择正确的实现提供了灵活性。


容器可以通过以下三个属性来表征:

    1.access,即访问容器对象的方式。在数组的情况下,访问是通过数组索引完成的。在堆栈的情况下,根据LIFO(后进先出)顺序进行访问,而在队列的情况下,根据FIFO(先进先出)顺序进行访问;


    2.storage,即容器对象的存储方式;

    3.traversal,即遍历容器对象的方式。


容器类应该实现方法来执行以下操作:


    1.创建一个空容器(构造函数);

    2.将对象插入容器;

    3.从容器中删除对象;

    4.删除容器中的所有对象(清除);

    5.访问容器中的对象;

    6.访问容器中的对象数量(计数)。

    7.容器有时与迭代器一起实现。


注意,容器其实是一种组织形式,就是特定的操作定义。它不单单是一种数据结构,它是一种更加高层的对数据结构的表达。


堆又是属于队列这种结构:


在计算机科学中,队列是按序列维护的实体集合,可以通过在序列的一端添加实体和从序列的另一端删除实体来修改。按照惯例,添加元素的序列末尾称为队列的后部、尾部或后部,删除元素的末尾称为队列的头部或前部,类似于以下使用的词人们排队等候商品或服务。


将元素添加到队列尾部的操作称为入队,而从队列中移除元素的操作称为出队。也可能允许其他操作,通常包括查看或前端操作,该操作返回下一个要出队的元素的值而不将其出队。


队列的操作使其成为先进先出 (FIFO) 数据结构。在 FIFO 数据结构中,添加到队列的第一个元素将是第一个被删除的元素。这相当于要求一旦添加了新元素,必须先删除之前添加的所有元素,然后才能删除新元素。队列是线性数据结构的一个例子,或者更抽象地说是一个顺序集合。队列在计算机程序中很常见,它们被实现为与访问例程耦合的数据结构、抽象数据结构或在面向对象的语言中作为类。常见的实现是循环缓冲区和链表。

队列在计算机科学、传输和运筹学领域提供服务,其中存储和保存各种实体(如数据、对象、人员或事件)以供以后处理。在这些上下文中,队列执行缓冲区的功能。队列的另一个用途是实现广度优先搜索。



大O表示



这个东西算是最出名的东西



那我们的堆是队列中的优先级队列:


在计算机科学中,优先级队列是一种抽象数据类型,类似于常规队列或堆栈数据结构,其中每个元素还具有与其关联的“优先级”。在优先级队列中,优先级高的元素在优先级低的元素之前被服务。在某些实现中,如果两个元素具有相同的优先级,则根据它们入队的顺序为它们提供服务,而在其他实现中,具有相同优先级的元素的排序是不确定的。

虽然优先级队列通常用堆实现,但它们在概念上与堆不同。优先级队列是一个类似于“列表”或“地图”的概念;正如列表可以用链表或数组实现一样,优先队列可以用堆或各种其他方法(例如无序数组)来实现。



上面这么多就够了,这里只说一下。堆是一种称为优先级队列的抽象数据类型的最高效率实现,实际上,优先级队列通常称为“堆”,无论它们如何实现。在堆中,最高(或最低)优先级的元素总是存储在根。但是,堆不是排序结构;它可以被认为是部分有序的。当需要重复删除具有最高(或最低)优先级的对象时,堆是一种有用的数据结构。




一个图解决战斗,看节点的数字大小



只实现了这三个


这个模块提供了堆队列算法的实现,也称为优先队列算法。


堆是一个二叉树,它的每个父节点的值都只会小于或大于所有孩子节点。它使用了数组来实现:从零开始计数,对于所有的 k ,都有``heap[k] <= heap[2*k+1]`` 和 heap[k] <= heap[2*k+2] 。为了便于比较,不存在的元素被认为是无限大。堆最有趣的特性在于最小的元素总是在根结点:heap[0] 。


这个API与教材中堆算法的实现不太一样,在于两方面:


(a)我们使用了基于零开始的索引。这使得节点和其孩子节点之间的索引关系不太直观,但是由于Python使用了从零开始的索引,所以这样做更加合适。


(b)我们的 pop 方法返回了最小的元素,而不是最大的


(这在教材中叫做 “最小堆”;而“最大堆”在课本中更加常见,因为它更加适用于原地排序)。


基于这两方面,把堆看作原生的Python list也没什么奇怪的: heap[0] 表示最小的元素,同时 heap.sort() 维护了堆的不变性!



注意堆的实现,是一个单独的模块



mpy中的堆操作,之后在使用的时候做说明

评论 (0)
  • 真空容器内部并非wan全没有压强,而是压强极低,接近于零。真空状态下的压强与容器内外气体的分子数量、温度以及容器本身的性质有关。一、真空与压强的基本概念真空指的是一个空间内不存在物质或物质极少的状态,通常用于描述容器或系统中气体的稀薄程度。压强则是单位面积上所受正压力的大小,常用于描述气体、液体等流体对容器壁的作用力。二、真空状态下的压强特点在真空状态下,容器内部的气体分子数量极少,因此它们对容器壁的作用力也相应减小。这导致真空容器内部的压强远低于大气压强,甚至接近于零。然而,由于技术限制和物理
    锦正茂科技 2025-03-29 10:16 101浏览
  • 在工业控制与数据采集领域,高精度的AD采集和实时显示至关重要。今天,我们就来基于瑞芯微RK3568J + FPGA国产平台深入探讨以下,它是如何实现该功能的。适用开发环境如下:Windows开发环境:Windows 7 64bit、Windows 10 64bitLinux开发环境:Ubuntu18.04.4 64bit、VMware15.5.5U-Boot:U-Boot-2017.09Kernel:Linux-4.19.232、Linux-RT-4.19.232LinuxSDK:LinuxSD
    Tronlong 2025-03-28 10:14 103浏览
  • Shinco音响拆解 一年一次的面包板社区的拆解活动拉开帷幕了。板友们开始大显身手了,拆解各种闲置的宝贝。把各自的设计原理和拆解的感悟一一向电子爱好者展示。产品使用了什么方案,用了什么芯片,能否有更优的方案等等。不仅让拆解的人员了解和深入探索在其中。还可以让网友们学习电子方面的相关知识。今天我也向各位拆解一个产品--- Shinco音响(如下图)。 当产品连接上电脑的耳机孔和USB孔时,它会发出“开机,音频输入模式”的语音播报,。告诉用户它已经进入音响外放模式。3.5mm耳机扣接收电脑音频信号。
    zhusx123 2025-03-30 15:42 65浏览
  • 在智能家居领域,无线门铃正朝着高集成度、低功耗、强抗干扰的方向发展。 WTN6040F 和 WT588F02B 两款语音芯片,凭借其 内置EV1527编解码协议 和 免MCU设计 的独特优势,为无线门铃开发提供了革命性解决方案。本文将深入解析这两款芯片的技术特性、应用场景及落地价值。一、无线门铃市场痛点与芯片方案优势1.1 行业核心痛点系统复杂:传统方案需MCU+射频模块+语音芯片组合,BOM成本高功耗瓶颈:待机电流
    广州唯创电子 2025-03-31 09:06 56浏览
  • 一、真空容器的定义与工作原理真空容器是一种能够创造并保持一定真空度的密闭容器。其工作原理通常涉及抽气系统,该系统能够逐渐抽出容器内部的气体分子,从而降低容器内的气压,形成真空环境。在这个过程中,容器的体积并不会因抽气而改变,但容器内的压力会随着气体的抽出而逐渐降低。二、真空容器并非恒压系统真空容器并非一个恒压系统。恒压系统指的是在外部环境变化时,系统内部压力能够保持相对稳定。然而,在真空容器中,随着气体的不断抽出,内部压力会持续降低,直至达到所需的真空度。因此,真空容器内部的压力是变化的,而非恒
    锦正茂科技 2025-03-29 10:23 95浏览
  • 真空容器的材料选择取决于其应用场景(如科研、工业、医疗)、真空等级(低真空、高真空、超高真空)以及环境条件(温度、压力、化学腐蚀等)。以下是常见材料及其优缺点分析:1. 不锈钢(如304、316L)优点:耐腐蚀性强:316L含钼,耐酸碱和高温氧化,适合高真空和腐蚀性环境。高强度:机械性能稳定,可承受高压差和外部冲击。低放气率:经电解抛光或镀镍处理后,表面放气率极低,适合超高真空系统(如粒子加速器、半导体镀膜设备)。易加工:可焊接、铸造,适合复杂结构设计。缺点:重量大:大型容器运输和安装成本高。磁
    锦正茂科技 2025-03-29 10:52 40浏览
  • 文/杜杰编辑/cc孙聪颖‍3月11日,美国总统特朗普,将自费8万美元购买的特斯拉Model S,开进了白宫。特朗普此举,绝非偶然随性,而是有着鲜明的主观意图,处处彰显出一种刻意托举的姿态 。特朗普也毫不讳言,希望他的购买能推动特斯拉的发展。作为全球电动车鼻祖,特斯拉曾凭借创新理念与先进技术,开辟电动汽车新时代,引领行业发展潮流。然而当下,这家行业先驱正深陷困境,面临着前所未有的挑战。就连“钢铁侠”马斯克自己都在采访时表示“非常困难”,的确是需要美国总统伸手拉一把了。马斯克踏入白宫的那一刻,特斯拉
    华尔街科技眼 2025-03-28 20:44 140浏览
  • 3月27日,长虹中玖闪光超高剂量率电子射线放射治疗系统(e-Flash)临床试验项目在四川大学华西医院正式启动,标志着该项目正式进入临床试验阶段。这不仅是我国医学技术领域的一项重大突破,更是我国在高端医疗设备研发和应用方面的重要里程碑。e-Flash放射治疗系统适用于哪些病症,治疗周期为多久?会不会产生副作用?治疗费用高不高……随着超高剂量率电子射线放射治疗系统(e-Flash)正式进入临床试验阶段,社会各界对该项目的实施情况尤为关注。对此,中国工程院院士范国滨,以及四川大学华西医院、四川省肿瘤
    华尔街科技眼 2025-03-28 20:26 153浏览
  • 在智能语音交互设备开发中,系统响应速度直接影响用户体验。WT588F系列语音芯片凭借其灵活的架构设计,在响应效率方面表现出色。本文将深入解析该芯片从接收指令到音频输出的全过程,并揭示不同工作模式下的时间性能差异。一、核心处理流程与时序分解1.1 典型指令执行路径指令接收 → 协议解析 → 存储寻址 → 数据读取 → 数模转换 → 音频输出1.2 关键阶段时间分布(典型值)处理阶段PWM模式耗时DAC模式耗时外挂Flash模式耗时指令解析2-3ms2-3ms3-5ms存储寻址1ms1ms5-10m
    广州唯创电子 2025-03-31 09:26 82浏览
  • 本文介绍瑞芯微RK356X系列复用接口配置的方法,基于触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。复用接口介绍由下图可知,红圈内容当前引脚可配置为SPI0或者PWM0功能。由标准系统固件以及相关系统手册可得,当前接口默认配置为SPI0功能:console:/ # ls dev/spidev0.0dev/spidev0.0再由原理图可知当前GPIO为GPIO0_C3
    Industio_触觉智能 2025-03-28 18:14 81浏览
  •        随着智能驾驶向L3级及以上迈进,系统对实时性的要求已逼近极限。例如,自动紧急制动(AEB)需在50毫秒内完成感知、决策到执行的全链路响应,多传感器数据同步误差需小于10微秒。然而,传统基于Linux-RT的方案在混合任务处理中存在天然缺陷——其最大中断延迟高达200微秒,且多任务并发时易引发优先级反转问题。据《2024年智能汽车电子架构白皮书》统计,超60%的车企因实时性不足被迫推迟舱驾一体化项目落地。为旌电子给出的破局之道,是采用R5F(实
    中科领创 2025-03-29 11:55 146浏览
  • 语音芯片在播放音频时出现电流声是嵌入式音频系统开发中的常见问题,直接影响用户体验。唯创电子WT系列语音芯片在智能家居、工业控制等领域广泛应用,本文将从PWM直推输出与DAC+功放输出两类典型电路架构出发,系统化分析电流声成因并提供工程级解决方案。一、PWM直推输出电路电流声诊断1.1 现象特征高频"滋滋"声(8kHz-20kHz)声音随系统负载变化波动静音状态下仍存在底噪1.2 核心成因分析(1) 电源干扰开关电源纹波超标:实测案例显示,当12V转3.3V的DC-DC电源纹波>80mVpp时,P
    广州唯创电子 2025-03-28 08:47 71浏览
  • 在智能语音设备开发中,高音量输出是许多场景的核心需求,例如安防警报、工业设备提示、户外广播等。 WT588F02BP-14S 和 WTN6040FP-14S 两款语音芯片,凭借其内置的 D类功放 和 3W大功率输出 能力,成为高音量场景的理想选择。本文将从 性能参数、应用场景、设计要点 三大维度,全面解析这两款芯片的选型策略。一、核心参数对比与选型决策参数WT588F02BP-14SWTN6040FP-14S输出功率3W@4Ω(THD<1%)3W@4Ω(THD<0.8%)功
    广州唯创电子 2025-03-28 09:15 63浏览
  • 本文介绍OpenHarmony5.0 DevEco Studio开发工具安装与配置,鸿蒙北向开发入门必备!鸿蒙北向开发主要侧重于应用层的开发,如APP开发、用户界面设计等,更多地关注用户体验、应用性能优化、上层业务逻辑的实现,需要开发者具备基本的编程知识、对操作系统原理的简单理解,以及一定的UI设计感。由触觉智能Purple Pi OH鸿蒙开发板演示。搭载了瑞芯微RK3566四核处理器,支持开源鸿蒙OpenHarmony3.2至5.0系统,适合鸿蒙开发入门学习。下载与安装开发工具点下面链接下载:
    Industio_触觉智能 2025-03-28 18:16 125浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦