01 pyBoard系统函数


pyBoard 提供了pyb.micros() 返回MCU从reset开始之后度过的时间,单位us。 相类似的还有millis()。使用elapsed_micros(start), elapsed_millis(start) 可以得到 时间流逝的长度。使用这个函数可以用于程序控制以及测量函数执行时间。

1.延时函数

(1)测试time.sleep_us()

a.测量代码
ddim = []
for i in range(100):start = pyb.micros()time.sleep_us(i)delayus = pyb.elapsed_micros(start)ddim.append(delayus)
b.测量结果

从测量结果来看,使用time.sleep_us所产生的延时有一个较为恒定的常量20us左右。延时的精度还是非常可靠的。

▲ delay_us测量曲线

(2)测量time.sleep_ms()

a.测量一百次 time.delay_ms(1)

下面显示了测量100次delay_ms(1)对应的数值,可以看到实际上的delay_ms()比起1ms实际上要端,而且还大约30usd的误差和突变。

▲ 测量结果time.delay_ms(1)

b.测量delay_ms(i)

测量delay_ms的逐步增长的延时。可以看到它在ms的级别对应的延迟的精度还是非常高的。

▲ 测量 time.delay_ms(i);i=1,..100

(3)测量pyb.delay

对应pyb.delay的功能与time.sleep_ms()功能相近。

▲ pyb.delay()的延时测量

2.随机数

使用pyb.rng()可以使用MCU的硬件产生随机数。

▲ 第一次运行所产生的随机数

▲ 第二次运行所产生的随机数

3. DAC; ADC

from pyb                    import ADC,DAC,LED,Pin
dac = DAC(Pin('X5'))
adc = ADC(Pin('X1'))
adcdim = []
for i in range(256):dac.write(i)val = adc.read()adcdim.append(val)
print(adcdim)

▲ 测量不同的DAC与ADC之间的关系

02 MicroPython语法


自制pyBoard的I2C实验,应用MicroPython 中给出了一些新的MicroPython的语法。下面进行总结。

1. const

应用于MicroPython定义常量变量,可以用于编译器的优化。根据测试,可以看到const必须是integer。所以下面声明中,PI是错误的の。

  • micropython.const(expr)
from micropython            import const
PI = const(3.1415)                  # Wrong: constant must be an integer
A =  const(1)
print(type(PI))
print(type(A))

对应常量幅值会出现错误。下面代码中在A=2时,会出现Exception。

from micropython            import const
A =  const(1)
B = 3
A = 2
B = 4

2.framebuf

framebuf用于给液晶显示屏给出一些内存缓存。参见: framebuf — frame buffer manipulation — MicroPython 1.14 documentation

使用frame.buffer访问framebuf对应的字节。

3.定义元组

下面代码显示了在定义元组,列表的过程中,可以使用条件幅值过程。

b = 1
a = (0, 1 if b > 0 else 2,100)
print(a)

执行结果: (0, 1, 100)

4.定义类

在定义类的时候,在基类中甚至可以运行将来在派生类中才存在的函数。比如在下面的代码中,基类中使用到了self.showA() 函数,而这个函数实际上在它的派生类 classA中才定义。相比与C++中的OO编程,它则需要在基类中定义虚拟函数,以便可以被未来的派生类所重载。

class basetype():def __init__(self, value):self.value = valuedef show(self, ):print(self.value)self.showA()def getvalue(self, ):return self.valueclass classA(basetype):def __init__(self, v):super().__init__(v)def show(self, b):super().show()print(b)def showA(self, ):print('Hello:%d'%super().getvalue())a = classA(3)
a.show(4)

上面代码运行结果:

3
Hello:3
4

▌附录


1.OLED SSD1306代码

(1)主程序代码

#!/usr/local/bin/python
# -*- coding: gbk -*-
#============================================================
# TESTOLED.PY                  -- by Dr. ZhuoQing 2021-03-20
#
# Note:
#============================================================#------------------------------------------------------------'''
实验名称:OLED显示屏(I2C总线)
版本:v1.0
日期:2019.4
作者:01Studio
'''from machine import I2C,Pin         #从machine模块导入I2C、Pin子模块
import SSD1306i2c = I2C(sda=Pin("Y10"), scl=Pin("Y9"))    #pyBoard I2C初始化:sda--> Y8, scl --> Y6
oled = SSD1306.SSD1306_I2C(128, 64, i2c, addr=0x3c) #OLED显示屏初始化:128*64分辨率,OLED的I2C地址是0x3coled.text("Hello World!", 0,  0)      #写入第1行内容
oled.text("MicroPython",  0, 20)      #写入第2行内容
oled.text("By 01Studio",  0, 50)      #写入第3行内容oled.show()   #OLED执行显示#------------------------------------------------------------
#        END OF FILE : TESTOLED.PY
#============================================================

(2)底层代码

#!/usr/local/bin/python
# -*- coding: gbk -*-
#============================================================
# SSD1306.PY                   -- by Dr. ZhuoQing 2021-03-20
#
# Note:
#============================================================# MicroPython SSD1306 OLED driver, I2C and SPI interfacesfrom micropython import const
import framebuf# register definitions
SET_CONTRAST        = const(0x81)
SET_ENTIRE_ON       = const(0xa4)
SET_NORM_INV        = const(0xa6)
SET_DISP            = const(0xae)
SET_MEM_ADDR        = const(0x20)
SET_COL_ADDR        = const(0x21)
SET_PAGE_ADDR       = const(0x22)
SET_DISP_START_LINE = const(0x40)
SET_SEG_REMAP       = const(0xa0)
SET_MUX_RATIO       = const(0xa8)
SET_COM_OUT_DIR     = const(0xc0)
SET_DISP_OFFSET     = const(0xd3)
SET_COM_PIN_CFG     = const(0xda)
SET_DISP_CLK_DIV    = const(0xd5)
SET_PRECHARGE       = const(0xd9)
SET_VCOM_DESEL      = const(0xdb)
SET_CHARGE_PUMP     = const(0x8d)# Subclassing FrameBuffer provides support for graphics primitives
# http://docs.micropython.org/en/latest/pyboard/library/framebuf.html
class SSD1306(framebuf.FrameBuffer):def __init__(self, width, height, external_vcc):self.width = widthself.height = heightself.external_vcc = external_vccself.pages = self.height // 8self.buffer = bytearray(self.pages * self.width)super().__init__(self.buffer, self.width, self.height, framebuf.MONO_VLSB)self.init_display()def init_display(self):for cmd in (SET_DISP | 0x00, # off# address settingSET_MEM_ADDR, 0x00, # horizontal# resolution and layoutSET_DISP_START_LINE | 0x00,SET_SEG_REMAP | 0x01, # column addr 127 mapped to SEG0SET_MUX_RATIO, self.height - 1,SET_COM_OUT_DIR | 0x08, # scan from COM[N] to COM0SET_DISP_OFFSET, 0x00,SET_COM_PIN_CFG, 0x02 if self.height == 32 else 0x12,# timing and driving schemeSET_DISP_CLK_DIV, 0x80,SET_PRECHARGE, 0x22 if self.external_vcc else 0xf1,SET_VCOM_DESEL, 0x30, # 0.83*Vcc# displaySET_CONTRAST, 0xff, # maximumSET_ENTIRE_ON, # output follows RAM contentsSET_NORM_INV, # not inverted# charge pumpSET_CHARGE_PUMP, 0x10 if self.external_vcc else 0x14,SET_DISP | 0x01): # onself.write_cmd(cmd)self.fill(0)self.show()def poweroff(self):self.write_cmd(SET_DISP | 0x00)def poweron(self):self.write_cmd(SET_DISP | 0x01)def contrast(self, contrast):self.write_cmd(SET_CONTRAST)self.write_cmd(contrast)def invert(self, invert):self.write_cmd(SET_NORM_INV | (invert & 1))def show(self):x0 = 0x1 = self.width - 1if self.width == 64:# displays with width of 64 pixels are shifted by 32x0 += 32x1 += 32self.write_cmd(SET_COL_ADDR)self.write_cmd(x0)self.write_cmd(x1)self.write_cmd(SET_PAGE_ADDR)self.write_cmd(0)self.write_cmd(self.pages - 1)self.write_data(self.buffer)class SSD1306_I2C(SSD1306):def __init__(self, width, height, i2c, addr=0x3c, external_vcc=False):self.i2c = i2cself.addr = addrself.temp = bytearray(2)super().__init__(width, height, external_vcc)def write_cmd(self, cmd):self.temp[0] = 0x80 # Co=1, D/C#=0self.temp[1] = cmdself.i2c.writeto(self.addr, self.temp)def write_data(self, buf):self.temp[0] = self.addr << 1self.temp[1] = 0x40 # Co=0, D/C#=1self.i2c.start()self.i2c.write(self.temp)self.i2c.write(buf)self.i2c.stop()class SSD1306_SPI(SSD1306):def __init__(self, width, height, spi, dc, res, cs, external_vcc=False):self.rate = 10 * 1024 * 1024dc.init(dc.OUT, value=0)res.init(res.OUT, value=0)cs.init(cs.OUT, value=1)self.spi = spiself.dc = dcself.res = resself.cs = csimport timeself.res(1)time.sleep_ms(1)self.res(0)time.sleep_ms(10)self.res(1)super().__init__(width, height, external_vcc)def write_cmd(self, cmd):self.spi.init(baudrate=self.rate, polarity=0, phase=0)self.cs(1)self.dc(0)self.cs(0)self.spi.write(bytearray([cmd]))self.cs(1)def write_data(self, buf):self.spi.init(baudrate=self.rate, polarity=0, phase=0)self.cs(1)self.dc(1)self.cs(0)self.spi.write(buf)self.cs(1)#------------------------------------------------------------
#        END OF FILE : SSD1306.PY
#============================================================

利用pyBoard的实验来讨论部分MicroPython特性相关推荐

  1. 利用vmware虚拟机实验从SUSE SLES12sp3 升级到SLES15sp1的过程

    利用vmware虚拟机实验从SUSE SLES12sp3 升级到SLES15sp1的过程 1. 首先要给虚拟机安装两个光盘,第一个光驱装入15sp1的Installer光盘用于启动系统和选择升级选项, ...

  2. 利用计算机模拟地理实验,虚拟地理实验在中学地理教学的应用论文

    虚拟地理实验在中学地理教学的应用论文 一.虚拟地理实验的概念 虚拟地理实验属于全面开放的虚拟实验环境,首先利用大型的多种尺度所集成的相关地理数据.参数与教学模型,建立有效解决较为复杂的地理问题的虚拟地 ...

  3. XBee3 特性实验1——如何下载MicroPython代码到XBee3模块

    (http://www.bitconn.com/form_1/注册后,购买XBee模块,送USB评估底板及相关中文资料,或者免费申请借用评估套件) MicroPython是一种受Python 3.0启 ...

  4. 利用计算机模拟地理实验,安徽省淮北师范大学附属实验中学高二2018-2019学年学业水平模拟考试地理【解析】...

    6. 影响该地农业生产分布格局的主要因素是 A. 气候 B. 地形 C. 水源 D. 交通 7. 图中体现的农业生产显著特点是 A. 绿洲农业 B. 灌溉农业 C. 立体农业 D. 城郊农业 [答案] ...

  5. 大学计算机基础实践教程实验一讨论与思考,大学计算机基础实验报告手册(非艺术类).doc...

    PAGE PAGE 24 < 大学计算机基础>课程 实验报告手册 学院 农生院 年级 2015级 专业 植物科学与技术 姓名 何罗姝 学号 222015326052044 任课教师 阎桦 ...

  6. VS2013+Windows+CPU下搭建caffe框架并利用mnist数据集实验

    <李凭箜篌引>--李贺 吴丝蜀桐张高秋,空山临云颓不流: 江娥啼竹素女愁,李凭中国弹箜篌: 昆山玉碎凤凰叫,芙蓉泣露香兰笑: 十二门前融冷光,二十三丝动紫皇: 女娲炼石补天处,石破天惊逗秋 ...

  7. 太阳能电池基本特性实验报告_太阳能电池基本特性测定实验

    太阳能电池基本特性测定实验 太阳能电池基本特性测定实验 太阳能电池是一种由于光生伏特效应而将太阳光能直接转化为电能的器件,是一个半导体光电二极管,当太阳光照到光电二极管上时,光电二极管就会把太阳的光能 ...

  8. 太阳能电池基本特性实验报告_太阳能电池基本特性研究实验报告的数据处理Ini怎么?太阳能电池基 爱问知识人...

    摘要:实验结果的表示,首先取决于实验的物理模式,通过被测量之间的相互关系,考虑实验结果的表示方法.常用到数据处理方法有作图法,列表法,平均值法,最小二乘法等.在处理数据时可根据需要和方便选择任何一种方 ...

  9. 《大学“电路分析基础”课程实验合集.实验四》丨线性电路特性的研究

    实验四   线性电路特性的研究 目录 1 实验目的 2 实验仪器与设备 3 实验原理 4 实验预习 5 实验内容与步骤 6 实验要求与注意事项 7 实验报告与思考题 1 实验目的 1. 加深对线性电路 ...

最新文章

  1. 清理C盘无用的垃圾的文件,给c盘瘦身
  2. carbon 一天的开始 结束_情话文案:朋友圈背景图丨2020国庆最后一天朋友圈的说说文案 修炼七天的你,是否准备就绪?...
  3. 苹果:AMD yes!官方开售显卡模块,价格1.8万起
  4. gdb 设置一个函数, 出现4个断点的原因
  5. squid代理服务器在企业网中的应用
  6. 如何检索Python函数的源代码
  7. 机器学习与计算机视觉(被忽视的isp图像处理)
  8. 2025 年全球数据量高达175ZB,开发者如何挑战数据洪流?
  9. elcom协议_物联网@电力系统通信协议
  10. Java知识整理5-Java核心 (一)Java IO/NIO
  11. ASP.NET Core3.1 入门介绍
  12. pc端ui图片尺寸_PC网页设计尺寸规范
  13. 游戏服务器背包设计与开发
  14. 超过2T硬盘用不了,怎么办?
  15. 字节跳动正式宣布要做全网搜索,百度真正的危机来了!
  16. Redis伪集群搭建
  17. 在Excel中插入行并复制单元格格式
  18. 如何在h5页面中调用摄像头来完成拍照之类的操作
  19. 什么是人工智能?什么是机器学习?什么是深度学习?三连问
  20. 【大数据入门核心技术-Tez】(三)Tez与Hive整合

热门文章

  1. 理解AngularJS的作用域Scope
  2. python数据分析(九)-点积与线性代数
  3. Okhttp 使用与debug时留的大坑
  4. 基于sqlcmd命令行工具管理SQL server
  5. 游戏开发中的图像生成
  6. windows 2008+Oracle 11g R2 故障转移群集配置
  7. SA区坏道数据恢复的经历
  8. android闪退日志收集
  9. java socket相关的timeout
  10. 【CentOS 7MySQL常用操作3】,MySQL常用命令#180113