TPYBoard MircoPython 外接SPI AD7705
来源:互联网 发布:哪有学java的学校 编辑:程序博客网 时间:2024/06/05 11:26
硬件:TPYboard一块,STM32F405,168MHz,Micropython
外设:AD7705,TM7705,16位AD,SPI接口
原因:由于STM32F405内置ADC精度不够,满足不了项目需求,故外置AD7705(淘宝,买现成的电路板),ADS1256(24位)。乘着国庆大假期间,先把AD7705的驱动编号。ADS1256还没有到货。
历时48小时,熟读AD7705 pdf,参考AD7705的C版本程序,改编,用python实现驱动,TPYBoard给出的SPI驱动有OLED,5110显示例程,可以参考。
代码(部分):如有需要,请email:ra00103@163.com,QQ:16183870
importpyb
import time
from pyb import SPI,Pin
class ADS7705:
#/* 寄存器选择 RS2 RS1 RS0 */
REG_COMM= 0x00 #,/* 通信寄存器 */
REG_SETUP= 0x10 #,/* 设置寄存器 */
REG_CLOCK= 0x20 #,/* 时钟寄存器 */
REG_DATA= 0x30 #,/* 数据寄存器 */
REG_ZERO_CH1= 0x60 #,/* CH1 偏移寄存器 */
REG_FULL_CH1= 0x70 #,/* CH1 满量程寄存器 */
REG_ZERO_CH2= 0x61 #,/* CH2 偏移寄存器 */
REG_FULL_CH2= 0x71 #,/* CH2 满量程寄存器 */
#/* 读写操作 */
WRITE = 0x00 #,/* 写操作 */
READ = 0x08#,/* 读操作 */
#/* 通道 */
CH_1= 0#,/* AIN1+ AIN1- */
CH_2= 1#,/* AIN2+ AIN2- */
CH_3= 2#,/* AIN1- AIN1- */
CH_4= 3#/* AIN1- AIN2- */
MD_NORMAL= (0 << 6)#,/* 正常模式 */
MD_CAL_SELF= (1 << 6)#,/* 自校准模式 */
MD_CAL_ZERO= (2 << 6)#,/* 校准0刻度模式 */
MD_CAL_FULL= (3 << 6)#,/* 校准满刻度模式 */
GAIN_1= (0 << 3)#,/* 增益 */
#GAIN_2= (1 << 3),/* 增益 */
#GAIN_4= (2 << 3),/* 增益 */
#GAIN_8= (3 << 3),/* 增益 */
#GAIN_16= (4 << 3),/* 增益 */
#GAIN_32= (5 << 3),/* 增益 */
#GAIN_64= (6 << 3),/* 增益 */
#GAIN_128= (7 << 3),/* 增益 */
#/* 无论双极性还是单极性都不改变任何输入信号的状态,它只改变输出数据的代码和转换函数上的校准点 */
BIPOLAR= (0 << 2)#,/* 双极性输入 */
UNIPOLAR= (1 << 2)#,/* 单极性输入 */
BUF_NO= (0 << 1)#,/* 输入无缓冲(内部缓冲器不启用) */
BUF_EN= (1 << 1)#,/* 输入有缓冲 (启用内部缓冲器) */
FSYNC_0= 0#,
FSYNC_1= 1#/* 不启用 */
CLKDIS_0= 0x00#,/* 时钟输出使能 (当外接晶振时,必须使能才能振荡) */
CLKDIS_1= 0x10#,/* 时钟禁止 (当外部提供时钟时,设置该位可以禁止MCK_OUT引脚输出时钟以省电 */
#/*
#2.4576MHz(CLKDIV=0 )或为 4.9152MHz (CLKDIV=1 ),CLK 应置 “0”。
#1MHz (CLKDIV=0 )或 2MHz (CLKDIV=1 ),CLK 该位应置 “1”
#*/
CLK_4_9152M = 0x08 #,
CLK_2_4576M = 0x00 #,
CLK_1M = 0x04 #,
CLK_2M = 0x0C #,
FS_50HZ= 0x00 #,
FS_60HZ= 0x01 #,
FS_250HZ= 0x02 #,
FS_500HZ= 0x04 #,
ZERO_0= 0x00#
ZERO_1= 0x80
def __init__(self,drdy,ce,rst,sck,di,do,softspi):
# init the SPI bus and pins
#spi.init(spi.MASTER, baudrate=328125,prescaler=32,bits=8, polarity=0, phase=1, firstbit=spi.MSB)
#self.spi=spi
if(softspi==1):
drdy.init(drdy.IN, drdy.PULL_UP) # Data ready
ce.init(ce.OUT_PP,ce.PULL_NONE) #chip enable pin
rst.init(rst.OUT_PP,rst.PULL_NONE)
sck.init(sck.OUT_PP,sck.PULL_NONE)
di.init(di.OUT_PP,di.PULL_NONE)
do.init(do.IN, do.PULL_NONE) # Data ready
rst.value(1)
ce.value(1)
sck.value(1)
di.value(1)
self.sck=sck
self.di=di
self.do=do
self.softspi=softspi
self.ce=ce
self.drdy=drdy
self.rst=rst
self.sodtspi=softspi
else:
drdy.init(drdy.IN, drdy.PULL_UP) # Data ready
ce.init(ce.OUT_PP,ce.PULL_NONE) #chip enable pin
rst.init(rst.OUT_PP,rst.PULL_NONE)
rst.value(1)
ce.value(1)
SPI = pyb.SPI(1) #DIN=>X8-MOSI/CLK=>X6-SCK/DO=>X7
SPI.init(SPI.MASTER,prescaler=64,bits=8, polarity=1, phase=1, firstbit=SPI.MSB)
self.spi=SPI
self.ce=ce
self.drdy=drdy
self.rst=rst
self.softspi=softspi
self.sleep_ms(10)
self.AD7705_ResetHard()
self.sleep_ms(10)
self.AD7705_SyncSPI()
self.AD7705_IntiCh()
#self.AD7705_CalibSelf(1)
#self.sleep_ms(5)
#/* 配置时钟寄存器 */
#self.AD7705_WriteByte(self.REG_CLOCK | self.WRITE | self.CH_1)#;/* 先写通信寄存器,下一步是写时钟寄存器 */
#self.AD7705_WriteByte(self.CLKDIS_0 | self.CLK_4_9152M | self.FS_50HZ);/* 刷新速率50Hz */
#//TM7705_WriteByte(CLKDIS_0 | CLK_4_9152M | FS_500HZ);/* 刷新速率500Hz */
#/* 每次上电进行一次自校准 */
#TM7705_CalibSelf(1);/* 内部自校准 CH1 */
self.sleep_ms(5);
def sleep_ms(self, mseconds):
try:
time.sleep_ms(mseconds)
except AttributeError:
machine.delay(mseconds)
def sleep_us(self, useconds):
try:
time.sleep_us(useconds)
except AttributeError:
machine.udelay(useconds)
#**************************************************************************************
#*
def AD7705_IntiCh(self):
self.AD7705_WriteByte(self.REG_CLOCK | self.WRITE | self.CH_1)# 先写通信寄存器,下一步是写时钟寄存器 */
self.AD7705_WriteByte(self.CLKDIS_0 | self.CLK_4_9152M | self.FS_50HZ)#刷新速率50Hz */
self.AD7705_WriteByte(0x10)#; /*选择设置寄存器,使用chnanel 1*/
self.AD7705_WriteByte(0x44)#; //写设置寄存器 ,设置成单极性、无缓冲、增益为1、滤波器工作、自校准
# if(_ch==1):
# self.AD7705_Send8Bit(0x20)#; /* 写通讯寄存器选中ch1*/
#self.AD7705_Send8Bit(self.CLKDIS_0 | self.CLK_4_9152M | self.FS_50HZ);#/* 刷新速率50Hz */)# /*4.9152MHz,
# self.AD7705_Send8Bit(0x0C)
# self.AD7705_Send8Bit(0x10)#; /*选择设置寄存器,使用chnanel 1*/
# self.AD7705_Send8Bit(0x40)#; //写设置寄存器 ,设置成单极性、无缓冲、增益为1、滤波器工作、自校准
#else:
# self.AD7705_Send8Bit(0x21)#; /* 写通讯寄存器选中ch2 */
# self.AD7705_Send8Bit(0x06)#; /* 2.4576MHz时钟,50Hz数据更新速率 */
#self.AD7705_Send8Bit(0x11)#; /*选择设置寄存器,使用chnane 2*/
#self.AD7705_Send8Bit(0x44)#; //写设置寄存器,设置成单极性、无缓冲、增益为1、滤波器工作、自校准
#*********************************************************************************************************
#*函 数 名: AD7705_ResetHard
#*功能说明: 硬件复位 TM7705芯片
#*形 参: 无
#*返 回 值: 无
#********************************************************************************************************
def AD7705_ResetHard(self):
self.rst.value(1)#RESET_1()
self.sleep_ms(1) #bsp_DelayMS(1)
self.rst.value(0)#RESET_0()
self.sleep_ms(2) #bsp_DelayMS(2)
self.rst.value(1)#RESET_1()
self.sleep_ms(1) #bsp_DelayMS(1)
print("Rest OK")
# self.sleep_ms(2000)
#*************************************************************
#SPI = pyb.SPI(1) #DIN=>X8-MOSI/CLK=>X6-SCK
#DIN =>SPI(1).MOSI 'X8' data flow (Master out, Slave in)
#CLK =>SPI(1).SCK 'X6' SPI clock
CE = pyb.Pin('X2')
DRDY = pyb.Pin('X4')
RST = pyb.Pin('X3')
SCK = pyb.Pin('X6')
DI = pyb.Pin('X8')
DO = pyb.Pin('X7')
ads7705 =ADS7705(DRDY,CE,RST,SCK,DI,DO,0)
print("Init OK")
#print(ads7705.drdy,ads7705.drdy.value())
#print(ads7705.ce,ads7705.ce.value())
while(1):
v=ads7705.AD7705_Average(1,10)
print(v)
#ads7705.sleep_ms(10)
#ads1256.AD7705_ReAD7705hipID()
阅读全文
0 0
- TPYBoard MircoPython 外接SPI AD7705
- AD7705在STM32F103RBT6上的移植[硬件SPI]
- HR8P506芯片利用SPI外接flash
- AD7705测试问题
- MSP430的AD7705驱动程序
- tpyboard开发板之按键
- tpyboard开发板之定时器
- 五分种学会用TPYBoard
- SPI
- SPI
- SPI
- SPI
- SPI
- SPI
- SPI
- spi
- spi
- SPI
- 2.图层
- java鬼混笔记:lucene 5、index基本的增删查改
- POJ 2763 Housewife Wind 笔记
- *TEST 2 for NOIP 妈的智障
- 联网请求工具类
- TPYBoard MircoPython 外接SPI AD7705
- 二维树状数组模板
- 异步加载
- media 属性的使用
- 合并两个排序链表
- Java 基础(4) —— 方法的重载 与 方法的重写
- 贪心G 商人的诀窍
- 解决搜狗输入法输入英文,切换不到中文问题
- 继承