VHDL实现IIC通讯协议读写LM75A传感器教程

版权申诉
0 下载量 154 浏览量 更新于2024-10-23 收藏 1.6MB ZIP 举报
资源摘要信息:"iic.zip_IIC读_LM75A_iic vhdl_lm75a FP_site:***" IIC(Inter-Integrated Circuit)是一种多主机的串行计算机总线,主要用于连接低速外围设备到主板、嵌入式系统或手机内的集成电路。IIC协议是由Philips(现在的NXP)在1980年代初期开发的,现已成为电子工业中普遍采用的一种标准通信协议。 LM75A是由德州仪器(Texas Instruments)生产的一种数字温度传感器,广泛应用于系统环境温度监测。它符合I2C(IIC的一种称呼)总线标准,可以工作在主模式或从模式下,支持标准模式和快速模式。LM75A支持1℃的温度分辨率,并且具备可编程的温度报警功能。 在本资源中,"iic读_LM75A"指的是实现对LM75A温度传感器的IIC通信协议的读操作,这通常涉及发送启动信号、设备地址(带有读写位)、寄存器地址以及读取数据等步骤。"iic_vhdl"暗示这些操作是通过VHDL(VHSIC Hardware Description Language,一种硬件描述语言)编程实现的。VHDL广泛应用于电子系统设计中,允许设计师以文本形式描述数字电路的功能和结构,之后这些文本描述可以通过EDA工具(电子设计自动化工具)编译成可以在FPGA(现场可编程门阵列)或ASIC(专用集成电路)上实现的电路。 "lm75a_fp"可能是指FPGA项目(Field-Programmable Gate Array),在这里可能是指用VHDL实现的LM75A的IIC接口控制逻辑被应用于FPGA上进行测试和验证。 "site:***"指出了该资源的来源网站,***是一个提供各种编程相关资源下载的网站,用户可以在这里找到各种源码、文档、工具和其他相关资料。 总结起来,该资源文件包含了用VHDL语言实现的IIC协议,具体为对LM75A数字温度传感器进行数据读取的相关代码。这种实现方式适用于FPGA等可编程逻辑设备上,以实现对温度数据的实时监测。通过这种方式,工程师可以在硬件层面上直接与LM75A通信,获取温度信息,这对于需要精确温度监控的应用场景至关重要。 对于希望使用此资源的开发者来说,他们需要具备一定的硬件描述语言知识,了解IIC协议的基本操作,以及对FPGA平台有所熟悉。通过阅读和理解这份资源中的VHDL代码,开发者可以学习到如何通过IIC协议来读取外部传感器数据,并将其应用到自己的项目中去。这对于学习如何控制和集成外围设备,设计复杂的硬件系统具有实际意义。

帮我改进一这段代码import machine import time from machine import I2C from machine import Pin from machine import sleep class accel(): def __init__(self, i2c, addr=0x68): self.iic = i2c self.addr = addr self.iic.start() self.iic.writeto(self.addr, bytearray([107, 0])) self.iic.stop() def get_raw_values(self): self.iic.start() a = self.iic.readfrom_mem(self.addr, 0x3B, 14) self.iic.stop() return a def get_ints(self): b = self.get_raw_values() c = [] for i in b: c.append(i) return c def bytes_toint(self, firstbyte, secondbyte): if not firstbyte & 0x80: return firstbyte << 8 | secondbyte return - (((firstbyte ^ 255) << 8) | (secondbyte ^ 255) + 1) def get_values(self): raw_ints = self.get_raw_values() vals = {} vals["AcX"] = self.bytes_toint(raw_ints[0], raw_ints[1]) vals["AcY"] = self.bytes_toint(raw_ints[2], raw_ints[3]) vals["AcZ"] = self.bytes_toint(raw_ints[4], raw_ints[5]) vals["Tmp"] = self.bytes_toint(raw_ints[6], raw_ints[7]) / 340.00 + 36.53 vals["GyX"] = self.bytes_toint(raw_ints[8], raw_ints[9]) vals["GyY"] = self.bytes_toint(raw_ints[10], raw_ints[11]) vals["GyZ"] = self.bytes_toint(raw_ints[12], raw_ints[13]) return vals # returned in range of Int16 # -32768 to 32767 def val_test(self): # ONLY FOR TESTING! Also, fast reading sometimes crashes IIC from time import sleep while 1: print(self.get_values()) sleep(0.05) clk = Pin(("clk", 36), Pin.OUT_OD) sda = Pin(("sda", 37), Pin.OUT_OD) i2c = I2C(-1, clk, sda, freq=100000) #initializing the I2C method for ESP32 #i2c = I2C(scl=Pin(5), sda=Pin(4)) #initializing the I2C method for ESP8266 mpu= accel(i2c) while True: mpu.get_values() print(mpu.get_values()) time.sleep(2)

2023-05-30 上传
2023-05-30 上传

一句句的解释void Write_IIC_Byte(unsigned char IIC_Byte) { unsigned char i; unsigned char m,da; da=IIC_Byte; OLED_SCLK_Clr(); for(i=0;i<8;i++) { m=da; // OLED_SCLK_Clr(); m=m&0x80; if(m==0x80) {OLED_SDIN_Set();} else OLED_SDIN_Clr(); da=da<<1; OLED_SCLK_Set(); OLED_SCLK_Clr(); } } /********************************************** // IIC Write Command **********************************************/ void Write_IIC_Command(unsigned char IIC_Command) { IIC_Start(); Write_IIC_Byte(0x78); //Slave address,SA0=0 IIC_Wait_Ack(); Write_IIC_Byte(0x00); //write command IIC_Wait_Ack(); Write_IIC_Byte(IIC_Command); IIC_Wait_Ack(); IIC_Stop(); } /********************************************** // IIC Write Data **********************************************/ void Write_IIC_Data(unsigned char IIC_Data) { IIC_Start(); Write_IIC_Byte(0x78); //D/C#=0; R/W#=0 IIC_Wait_Ack(); Write_IIC_Byte(0x40); //write data IIC_Wait_Ack(); Write_IIC_Byte(IIC_Data); IIC_Wait_Ack(); IIC_Stop(); } void OLED_WR_Byte(unsigned dat,unsigned cmd) { if(cmd) { Write_IIC_Data(dat); } else { Write_IIC_Command(dat); } } /******************************************** // fill_Picture ********************************************/ void fill_picture(unsigned char fill_Data) { unsigned char m,n; for(m=0;m<8;m++) { OLED_WR_Byte(0xb0+m,0); //page0-page1 OLED_WR_Byte(0x00,0); //low column start address OLED_WR_Byte(0x10,0); //high column start address for(n=0;n<128;n++) { OLED_WR_Byte(fill_Data,1); } } } /***********************Delay****************************************/ void Delay_50ms(unsigned int Del_50ms) { unsigned int m; for(;Del_50ms>0;Del_50ms--) for(m=6245;m>0;m--); } void Delay_1ms(unsigned int Del_1ms) { unsigned char j; while(Del_1ms--) { for(j=0;j<123;j++); } }

2023-06-13 上传