CN113206669B - 一种基于mcu的可调dac缓输出方法及系统 - Google Patents
一种基于mcu的可调dac缓输出方法及系统 Download PDFInfo
- Publication number
- CN113206669B CN113206669B CN202110547438.1A CN202110547438A CN113206669B CN 113206669 B CN113206669 B CN 113206669B CN 202110547438 A CN202110547438 A CN 202110547438A CN 113206669 B CN113206669 B CN 113206669B
- Authority
- CN
- China
- Prior art keywords
- output
- dac
- value
- dac module
- time period
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M1/00—Analogue/digital conversion; Digital/analogue conversion
- H03M1/66—Digital/analogue converters
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Analogue/Digital Conversion (AREA)
- Dc-Dc Converters (AREA)
Abstract
本发明公开了一种基于MCU的可调DAC缓输出方法及系统。该方法包括步骤:初始化DAC模块,读取DAC模块的输出高端偏移值、输出低端偏移值、DAC模块的寄存器能写入的最大值和DAC模块的输出起始值;设置DAC模块的输出目标值、DAC模块的输出时间周期、从输出起始值到输出目标值所需要的输出时间和每单位时间周期的输出电压步进值;选择输出模式为时间输出模式或步进输出模式中的一种;根据输出模式计算每个时间周期的DAC模块数字输入量,使得DAC模块的模拟量输出斜率与后级电路相匹配。本发明能够解决现有DAC模块输出与后级电路不匹配的问题,具有无需多次对设备下载程序来调试DAC输出斜率、技术方案灵活、成本低的优点。
Description
技术领域
本发明属于工业控制技术领域,更具体地,涉及一种基于MCU的可调DAC缓输出方法及系统。
背景技术
在控制系统中常见到数模转换器DAC输出在控制环路中应用时存在MCU与硬件执行电路之间的速率匹配问题。
在现有技术常用的DAC输出电路中,MCU的DAC输出变化是相当快的,一般通过放大器来放大DAC输出来为后续电路的执行,但一般的放大器有一个变化范围,当信号变化太快时,放大器会发生混乱,就需要选择更加昂贵高速的放大器,会增加成本;第二种方式是采用特定硬件方式实现的DAC芯片,这种方式需要增加元器件,会增加成本,而且随着硬件电路的增加,系统也会降低可靠性。
发明内容
针对现有技术的至少一个缺陷或改进需求,本发明提供了一种基于MCU的可调DAC缓输出方法及系统,能够连续地调整DAC信号缓输出,解决可靠性及成本高的技术问题。
为实现上述目的,按照本发明的第一方面,提供了一种基于MCU的可调DAC缓输出方法,包括步骤:
初始化DAC模块,读取DAC模块的输出高端偏移值、输出低端偏移值、DAC模块的寄存器能写入的最大值和DAC模块的输出起始值;
设置DAC模块的输出目标值、DAC模块的输出时间周期、从输出起始值到输出目标值所需要的输出时间和每单位时间周期的输出电压步进值;
选择输出模式,输出模式为时间输出模式或步进输出模式中的一种;
根据输出模式、所有读取值和设置值计算每个时间周期的DAC模块对应的输出电压变量值和DAC模块数字输入量,使得DAC模块的模拟量输出斜率与后级电路相匹配。
优选地,将DAC模块的输出高端偏移值记为DAmax、输出低端偏移值记为DAmin、DAC模块的寄存器能写入的最大值记为DACregisterMax、DAC模块的输出起始值记为Vsetmin;
将DAC模块的输出目标值记为Vsetmax、DAC模块的输出时间周期记为IntervalTime、从输出起始值Vsetmin到输出目标值Vsetmax所需要的输出时间记为t、每单位时间周期IntervalTime的输出电压步进值记为step;
若选择输出模式为时间输出模式,则DAC模块对应的输出电压变量值和DAC模块数字输入量的计算包括步骤:
根据输出起始值Vsetmin、输出最终目标值Vsetmax、输出时间t、输出时间周期IntervalTime计算每个时间周期的DAC模块对应的输出电压变量值Vout_T,根据输出电压变量值Vout_T、输出高端偏移值DAmax、输出低端偏移值DAmin、输出起始值Vsetmin、输出最终目标值Vsetmax和最大值DACregisterMax,计算时间输出模式下每个时间周期DAC模块的数字输入量DAC_Output_T。
优选地,若选择输出模式为步进输出模式,则DAC模块对应的输出电压变量值和DAC模块数字输入量的计算包括步骤:
根据输出起始值Vsetmin、输出时间周期IntervalTime、输出电压步进值step计算每个时间周期的DAC模块对应的输出电压变量值Vout_s,根据输出电压变量值Vout_s、输出高端偏移值DAmax、输出低端偏移值DAmin、输出起始值Vsetmin、输出最终目标值Vsetmax和最大值DACregisterMax,计算步进输出模式下每个时间周期DAC模块的数字输入量DAC_Output_S。
优选地,输出电压变量值Vout_T和数字输入量DAC_Output_T的计算包括步骤:
S41:计算每个时间周期DAC模块对应的输出电压变量值Vout_T,Vout_T=Vsetmin+(Vsetrange/(t/IntervalTime))*Ntimes,其中Ntimes为时间周期计数值,Ntimes周期计数值从1开始,Vsetrange=Vsetmax-Vsetmin;
S42:计算每个时间周期DAC模块的数字输入量DACoutput_T,DAC_Output_T=(DAmax-DAmin)*(Vsetmax-Vout_T)/Vsetrange+(DACregistermax-DAmax);
S43:DAC模块将数字输入量DAC_Output_T转换为模拟量并输出到后级电路;
S44:判断Ntimes周期计数值是否为t/IntervalTime,若是,保存输出时间周期IntervalTime和输出时间t,结束;若不是,Ntimes周期计数值递增1后转到S41继续执行。
优选地,输出电压变量值Vout_s和数字输入量DAC_Output_S的计算包括步骤:
S51:计算每个时间周期DAC模块对应的输出电压变量值Vout_s,Vout_s=Vout_s′+step*IntervalTime,Vout_s′为上个时间周期输出的电压变量,Vout_s′的起始值为输出起始值Vsetmin;
S52:计算每个时间周期DAC模块的数字输入量DAC_Output_S,DAC_Output_S=(DAmax-DAmin)*(Vsetmax-Vout_s)/Vsetrange+(DACRegisterMax-DAmax),
S53:DAC模块将数字输入量DAC_Output_S转换为模拟量并输出到后级电路;
S54:判断Vout_s是否等于输出最终目标电压值Vsetmax,若是,保存输出时间周期IntervalTime,输出电压步进值step,结束;若不是,则转到S51继续执行。
优选地,在选择输出模式前还包括步骤:
判断DAC缓输出是否需要调整,若需要则继续执行选择输出模式及计算DAC模块对应的输出电压变量值和DAC模块数字输入量,若不需要则结束。
优选地,判断DAC缓输出是否需要调整包括步骤:
判断此次设置的输出最终目标值Vsetmax与上一次设置的Vsetmax是否相等,若不相等则判断DAC缓输出需要调整,若相等则判断DAC缓输出不需要调整。
按照本发明的第二方面,提供了一种基于MCU的可调DAC缓输出系统,包括MCU处理器、上位机、存储器、DAC模块和通信接口:
MCU处理器,用于初始化DAC模块,读取DAC模块的输出高端偏移值、输出低端偏移值、DAC模块的寄存器能写入的最大值和DAC模块的输出起始值;
上位机,用于设置DAC模块的输出目标值、DAC模块的输出时间周期、从输出起始值到输出目标值所需要的输出时间和每单位时间周期的输出电压步进值,还用于从存储器调用输出时间、输出电压步进值、输出时间周期和输出目标值,并将MCU处理器输出的DAC的数字输入量DAC_Output通过通信接口传送给上位机;
存储器,用于存储通过上位机设置的输出目标值、DAC模块的输出时间周期、输出电压步进值;
上位机还用于选择输出模式,输出模式为时间输出模式或步进输出模式中的一种;
MCU处理器还用于根据输出模式、所有读取值和设置值计算每个时间周期的DAC模块对应的输出电压变量值和DAC模块数字输入量,使得DAC模块的模拟量输出斜率与后级电路相匹配;
通信接口,用于处理上位机和MCU处理器间的信息交互。
优选地,存储器和DAC模块集成在MCU处理器中。
总体而言,本发明与现有技术相比,具有有益效果:后台在线确定调整DAC模块输出所用参数,经计算后得到DAC输入值,实现连续地、高精度地在线调整DAC输出,匹配给后级电路。本发明方法和系统方式具有使用灵活、硬件成本低、操作方便的优点,另外在一次调整参数之后,之后上电无需调节,将直接得到期望结果。
附图说明
图1是本发明实施例的可调DAC缓输出系统的连接原理示意图;
图2是本发明实施例的可调DAC缓输出系统的操作界面示意图;
图3是本发明实施例的可调DAC缓输出方法流程图;
图4是本发明另一实施例的可调DAC缓输出方法流程图;
图5是本发明实施例的DAC缓输出在二维坐标系中对应关系改进前后示意图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅用以解释本发明,并不用于限定本发明。此外,下面所描述的本发明各个实施方式中所涉及到的技术特征只要彼此之间未构成冲突就可以相互组合。
如图1所示,本发明实施例的可调DAC缓输出系统的优选实施方式包括含有DAC模块和带电可擦写可编程只读存储器EEPROM的MCU处理器、异步收发传输器UART和上位机,MCU的DAC模块含有DAC1和DAC2两路I/O口,UART的一端连接MCU,另一端连接后台参数调整系统,MCU自带的EEPROM主要是用来存放调节过程中的调节参数,它具有掉电数据不丢失功能,能在下次上电时读取之前的保存值供计算使用。
本发明实施例的可调DAC缓输出系统及方法主要功能是调节参数使之达到期望值,当调试开始时,初始化内部的EEPROM的调整参数,经计算后得到输出值,DAC输出系统将输出值与硬件电路期望值比较,当两者相匹配时,记录此调节参数,并反馈给EEPROM模块,在下次上电时读取此参数参与计算。
在本发明实施例的可调DAC缓输出方法中,调试开始时,进行初始化,MCU处理器读取DAC模块的高端偏移值DAmax和低端偏移值DAmin,DACregisterMax为DAC模块的寄存器能写入的最大值,则MCU输出到DAC的数字输入量DAC_Output的计算公式为:
DAC_Output=(DAmax-DAmin)*(Vsetmax-Vout)/Vsetrange+(DACregistermax-DAmax) (1)
其中,DAC的高端偏移值VDAmax和低端偏移值DAmin,高端输出目标值Vsetmax(最终输出目标值Vsetmax),高端输出目标值到低端输出目标值(输出起始值Vsetmin)的范围Vsetrange,DACregistermax为DAC模块的寄存器能写入的最大值,以上5个变量值为DAC输出的校准值,在校准之后即为固定值,改变实际要输出的电压值Vout即改变DAC模块的数字输入量DAC_Output。
在本发明的缓输出方法中,通过设置DAC的输出的时间周期参数IntervalTime、DAC模块输出低端目标值到输出高端目标值的输出时间t或每个时间周期电压步进值step,计算每个时间周期输出实际目标电压值Vout,然后通过公式(1)即可实现每个时间周期有不同的DAC的输入量DAC_Output,即实现DAC缓输出。
当选择时间模式时,DAC模块的输出对应的电压变量值Vout_T,按公式(2)计算,
Vout_T=Vsetmin+(Vsetrange/(t/IntervalTime))*Ntimes (2)
其中,Vsetmax为输出电压的目标值,Ntimes为时间周期计数值,Ntimes周期计数值从1开始,每个时间周期,将Vout_T值代入公式(1)计算MCU输出的DAC数字输入量为:
DAC_Output_T=(DAmax-DAmin)*(Vsetmax-Vout_T)/Vsetrange+(DACregistermax-DAmax),
每经过一个时间周期IntervalTime,Ntimes递增1,Vout_T值改变,DAC数字入量DAC_Output_T相应改变,Ntimes最大值为t/IntervalTime,当Ntimes等于最大值t/IntervalTime时,Vout_T输出达到目标值即等于Vsetmax,该次DAC缓输出退出,进入常规的DAC输出。那么在IntervalTime值不变的条件下,只要改变时间参数t,就可以改变DAC每个时间周期输出量,并使之逐渐达到目标输出值。
当选择步进模式时,由公式(1)DAC模块的输出对应的电压变量值为Vout_s,其计算按公式(3),
Vout_s=Vout_s′+step*IntervalTime (3)
其中,Vout_s′为上个步进的DAC输出电压值,将Vout_S值代入公式(1)计算每个时间周期DAC数字输入量为DAC_Output_S=(DAmax-DAmin)*(Vsetmax-Vout_S)/Vsetrange+(DACRegisterMax-DAmax);
每经过一个时间周期IntervalTime,DAC输出的步进值值增加step*IntervalTime,Vout_s值改变,DAC数字输入量DAC_Output_S相应改变,当Vout_s等于达到目标值即等于Vsetmax时,该DAC缓输出退出,进入常规的DAC输出。
DAC缓输出退出时,将时间参数t值和步进step及DAC输出间隔时间IntervalTime值保存在EEPROM中。
在每次上电时系统,初始化DAC,读取DAC模块输出的高端偏移值DAmax和低端偏移值DAmin,DAC模块的寄存器写入的最大值DACregisterMax;判断DAC缓输出是否需要调整;若不需要,则自动读取时间参数t值和步进step及DAC输出间隔时间IntervalTime值并参与计算,即可得到一个DAC输出与硬件相匹配的缓输出斜率,每一次对目标电压的调整执行一次。
如某使用场景中,某DAC模块最大输出参考电压为2.5V,最大12位精度,则此DAC模块最大输出参考电压为2.5V,寄存器写入最大值DACregisterMax为4095,设备要求直流开关电源输出从50.0V到250.0V可调整,MCU的内部DAC输出口经过LM258AD放大器放大之后接入移相谐振控制器UC2875DWP来达到调整输出电压的功能;当设定输出为50.0V时对应DAC输出的DAC模块最小输出参考电压接近2.5V,当设定输出电压为250.0V时对应DAC模块最大输出参考电压0V,当MCU接受指令将DAC输出从0V到2.5V时转换速率为1.2us变化2.5V即接近2.1V/us,而后面的硬件电路中的放大器LM258AD依数据手册可知转换速率SR最大为0.6V/us,导致放大器出错。但按本发明的方法,调整t值或step值,DAC输出有一个斜率输出,各变量在二维坐标系中的对应DAC缓输出关系如下图5所示。调整时间参数t或步进参数step,使DAC输出的速率为小于0.6V/us,以达到与放大器相匹配的结果。
在这一实施例中,如图2所示,DAC缓输出系统的上位机上的操作界面中,④处IntervalTime值保持10ms不变的条件下,选定③处中的时间模式,调整图2中的①处的上下按钮,使DAC缓输出从输出低端目标值Vsetmin(输出起始值Vsetmin)到输出高端目标值Vsetmax输出时间为100ms,即DAC从0V输出到2.5V输出的上升时间为100ms,即相当于输出速率为0.25V/us,即小于放大器LM258AD的最大转换速率0.6V/us,满足放大器LM258AD的要求。当在图2的③处选择步进模式时,调整图2中的②处的上下按钮,使DAC缓输出步进为50mV/ms,那DAC输出达到2.5V时,每个时间周期10ms输出500mV,需要50ms,即相当于输出速率为0.05V/ms,即小于放大器LM258AD的最大转换速率0.6V/us,也满足放大器LM258AD的要求。
当DAC输出的①、②、③、④通道停止调整时,模块UART串口在200ms内没接收到调整指令时,MCU将自动保存调整结果t、step、IntervalTime和模式选择到EEPROM中,完成DAC通道的缓输出调整。调整结束重新上电初始化时,系统将自动读取EEPROM中调整后的t、step、IntervalTime和模式选择的值按图3所示所示处理流程进行输出。
如图3所示,本发明实施例的一种基于MCU的可调DAC缓输出方法,包括步骤:
S1:DAC初始化,读取DAC模块的高端偏移值DAmax和低端偏移值DAmin,输出起始值Vsetmin,DACregisterMax为DAC模块的寄存器能写入的最大值:
S2:设置DAC输出的时间周期参数IntervalTime为10ms、DAC模块从输出低端目标值Vsetmin(输出起始值Vsetmin)到输出高端目标值Vsetmax输出时间为100ms、每单位时间周期IntervalTime输出电压步进值50mV/ms以及DAC输出电压最大值;
S3:选择按缓输出模式,若选择按时间输出模式,执行步骤S41;若选择步进模式输出模式,执行步骤S51;
S41:依据输出实际1电压值250V,计算每时间周期IntervalTime的DAC输出电压值:第一个时间周期,Vout_T=50V+(200V/(100ms/10ms))*1=70V,其中Ntimes为时间周期计数值(最大值为100ms/10ms=10),Ntimes周期计数值从1开始;
S42:计算第一个时间周期MCU输出的DAC数字输入量DAC_Output_T1,DAC_Output_T1=(DAmax-DAmin)*(250-70)/200+(4095-DAmax);
S43:DAC模块将数字输入量DAC_Output_T转换为模拟量并输出到后续LM258AD电路,LM258AD电路转化为实际的电压值70V。
S44:判断Ntimes周期计数值是否为10(t/IntervalTime),若是,上位机通知MCU保存保存周期参数10ms,DAC的输出时间100ms,退出DAC缓输出;若不是,Ntimes周期计数值递增1后转到S41;
S51:为步进模式时,根据公式Vout_s=Vout_s′+step*IntervalTime计算第一个步进的DAC输出电压值Vout_s=50V+50mV/ms*10ms=50.5V;
S52:计算每个步进MCU的DAC数字输入量DAC_Output_S,
DAC_Output_S=(DAmax-DAmin)*(250-50.5)/200+(4095-DAmax),
其中,DACregistermax为DAC模块的寄存器能写入的最大值,DAC的高端偏移值DAmax和低端偏移值DAmin,高端输出标称目标值250V,低端输出标称目标值到高端输出标称目标值的范围200V;
S53:DAC模块将数字输入量DAC_Output_S转换为模拟量并输出到后续LM258AD电路,LM258AD电路转化为实际的电压值50.5V。
S54:判断Vout_s是否等于输出目标电压值250V,若是,上位机通知MCU保存周期参数10ms,DAC的输出的步进值50mV/ms到EEPROM,退出DAC缓输出,若不是,则转到S51。
至此,DAC缓输出即可完成,系统再上电时初始化时程序将自动加载之前保存在EEPROM中的参数值,并代入计算,以获得与硬件放大器相匹配的执行速率。整个调参过程中无需对产品进行开箱操作,只需将通信工装夹具按要求连接好,打开上位机并运行用于调参的后台程序即可对待调模块进行调参,这将大大缩短DAC缓输出调参时间。
依此类推,如有DAC第二通道或更多DAC通道,按如上步骤操作使DAC输出进行缓输出处理。至此,DAC缓输出的过程即可完成,当程序下次上电初始化时程序将自动加载之前保存在EEPROM中的参数值,并代入计算,以获得与硬件电路相匹配的DAC缓输出斜率。
如图4所示,本发明实施例的一种基于MCU的可调DAC缓输出方法,在选择输出模式前还包括步骤:判断DAC缓输出是否需要调整(图中步骤S21),若需要则继续执行选择输出模式及计算DAC模块对应的输出电压变量值和DAC模块数字输入量,若不需要则结束。其他步骤和图3实施例类似,此处不再赘述。
进一步地,判断DAC缓输出是否需要调整的具体方法是:判断此次设置的输出最终目标值Vsetmax与上一次设置的Vsetmax是否相等,若不相等则判断DAC缓输出需要调整,若相等则判断DAC缓输出不需要调整。
本发明提供的DAC缓输出系统的优选实施方式包括DAC模块、MCU、EEPROM存储器、UART和上位机,EEPROM用来存放调节过程中的调节参数t、step、IntervalTime值,DAC模块和EEPROM可集成于MCU中。
需要说明的是,存储器除采用EEPROM外,还可采用其它非易失性存储器,如FLASH存储器;通信接口除采用UART串口外,还可采用如以太网口、CAN接口、USB接口等可用于数据通信的接口。
必须说明的是,上述任一实施例中,方法并不必然按照序号顺序依次执行,只要从执行逻辑中不能推定必然按某一顺序执行,则意味着可以以其他任何可能的顺序执行。
本领域的技术人员容易理解,以上所述仅为本发明的较佳实施例而已,并不用以限制本发明,凡在本发明的精神和原则之内所作的任何修改、等同替换和改进等,均应包含在本发明的保护范围之内。
Claims (7)
1.一种基于MCU的可调DAC缓输出方法,其特征在于,包括步骤:
初始化DAC模块,读取DAC模块的输出高端偏移值、输出低端偏移值、DAC模块的寄存器能写入的最大值和DAC模块的输出起始值,将DAC模块的输出高端偏移值记为DAmax、输出低端偏移值记为DAmin、DAC模块的寄存器能写入的最大值记为DACregisterMax、DAC模块的输出起始值记为Vsetmin;
设置DAC模块的输出目标值、DAC模块的输出时间周期、从输出起始值到输出目标值所需要的输出时间和每单位时间周期的输出电压步进值,将DAC模块的输出目标值记为Vsetmax、DAC模块的输出单位时间周期记为IntervalTime、从输出起始值Vsetmin到输出目标值Vsetmax所需要的输出时间记为t、每单位时间周期IntervalTime的输出电压步进值记为step;
选择输出模式,输出模式为时间输出模式或步进输出模式中的一种;
根据输出模式、所有读取值和设置值计算每个时间周期的DAC模块对应的输出电压变量值和DAC模块数字输入量,使得DAC模块的模拟量输出斜率与后级电路相匹配;
若选择输出模式为时间输出模式,则DAC模块对应的输出电压变量值和DAC模块数字输入量的计算包括步骤:
根据输出起始值Vsetmin、输出最终目标值Vsetmax、输出时间t、输出单位时间周期IntervalTime计算每个时间周期的DAC模块对应的输出电压变量值Vout_T,根据输出电压变量值Vout_T、输出高端偏移值DAmax、输出低端偏移值DAmin、输出起始值Vsetmin、输出最终目标值Vsetmax和最大值DACregisterMax,计算时间输出模式下每个时间周期DAC模块的数字输入量DAC_Output_T;
Vout_T和DAC_Output_T的计算公式为:
Vout_T=Vsetmin+(Vsetrange/(t/IntervalTime))*Ntimes,其中Ntimes为时间周期计数值,Ntimes周期计数值从1开始,Vsetrange=Vsetmax-Vsetmin,
DAC_Output_T=(DAmax-DAmin)*(Vsetmax-Vout_T)/Vsetrange+(DACregistermax-DAmax);
若选择输出模式为步进输出模式,则DAC模块对应的输出电压变量值和DAC模块数字输入量的计算包括步骤:
根据设置的输出起始值Vsetmin、输出单位时间周期IntervalTime、输出电压步进值step计算每个时间周期的DAC模块对应的输出电压变量值Vout_s,再根据所述的输出电压变量值Vout_s、输出高端偏移值DAmax、输出低端偏移值DAmin、输出起始值Vsetmin、输出最终目标值Vsetmax和最大值DACregisterMax,计算步进输出模式下每个时间周期DAC模块的数字输入量DAC_Output_S;
Vout_s和DAC_Output_S的计算公式为:
Vout_s=Vout_s′+step*IntervalTime,Vout_s′为上个时间周期输出的电压变量,Vout_s′的起始值为输出起始值Vsetmin;
DAC_Output_S=(DAmax-DAmin)*(Vsetmax-Vout_S)/Vsetrange+(DACRegisterMax-DAmax)。
2.如权利要求1所述的一种基于MCU的可调DAC缓输出方法,其特征在于,输出电压变量值Vout_T和数字输入量DAC_Output_T的计算包括步骤:
S41:计算每个时间周期DAC模块对应的输出电压变量值Vout_T;
S42:计算每个时间周期DAC模块的数字输入量DAC_Output_T;
S43:DAC模块将数字输入量DAC_Output_T转换为模拟量并输出到后级电路;
S44:判断Ntimes周期计数值是否为t/IntervalTime,若是,保存输出单位时间周期IntervalTime和输出时间t,结束;若不是,Ntimes周期计数值递增1后转到S41继续执行。
3.如权利要求1所述的一种基于MCU的可调DAC缓输出方法,其特征在于,输出电压变量值Vout_s和数字输入量DAC_Output_S的计算包括步骤:
S51:计算每个时间周期DAC模块对应的输出电压变量值Vout_s;
S52:计算每个时间周期DAC模块的数字输入量DAC_Output_S;
S53:DAC模块将数字输入量DAC_Output_S转换为模拟量并输出到后级电路;
S54:判断Vout_s是否等于输出最终目标电压值Vsetmax,若是,保存输出单位时间周期IntervalTime,输出电压步进值step,结束;若不是,则转到S51继续执行。
4.如权利要求1所述的一种基于MCU的可调DAC缓输出方法,其特征在于,在选择输出模式前还包括步骤:
判断DAC缓输出是否需要调整,若需要则继续执行选择输出模式及计算DAC模块对应的输出电压变量值和DAC模块数字输入量,若不需要则结束。
5.如权利要求4所述的一种基于MCU的可调DAC缓输出方法,其特征在于,判断DAC缓输出是否需要调整包括步骤:
判断此次设置的输出最终目标值Vsetmax与上一次设置的Vsetmax是否相等,若不相等则判断DAC缓输出需要调整,若相等则判断DAC缓输出不需要调整。
6.一种基于MCU的可调DAC缓输出系统,其特征在于,包括MCU处理器、上位机、存储器、DAC模块和通信接口:
MCU处理器,用于初始化DAC模块,读取DAC模块的输出高端偏移值、输出低端偏移值、DAC模块的寄存器能写入的最大值和DAC模块的输出起始值,将DAC模块的输出高端偏移值记为DAmax、输出低端偏移值记为DAmin、DAC模块的寄存器能写入的最大值记为DACregisterMax、DAC模块的输出起始值记为Vsetmin;
上位机,用于设置DAC模块的输出目标值、DAC模块的输出时间周期、从输出起始值到输出目标值所需要的输出时间和每单位时间周期的输出电压步进值,还用于从存储器调用输出时间、输出电压步进值、输出时间周期和输出目标值,并将MCU处理器输出的DAC的数字输入量DAC_Output通过通信接口传送给上位机,将DAC模块的输出目标值记为Vsetmax、DAC模块的输出单位时间周期记为IntervalTime、从输出起始值Vsetmin到输出目标值Vsetmax所需要的输出时间记为t、每单位时间周期IntervalTime的输出电压步进值记为step;
存储器,用于存储通过上位机设置的输出目标值、DAC模块的输出时间周期、输出电压步进值;
上位机还用于选择输出模式,输出模式为时间输出模式或步进输出模式中的一种;
MCU处理器还用于根据输出模式、所有读取值和设置值计算每个时间周期的DAC模块对应的输出电压变量值和DAC模块数字输入量,使得DAC模块的模拟量输出斜率与后级电路相匹配,
若选择输出模式为时间输出模式,则DAC模块对应的输出电压变量值和DAC模块数字输入量的计算包括步骤:
根据输出起始值Vsetmin、输出最终目标值Vsetmax、输出时间t、输出单位时间周期IntervalTime计算每个时间周期的DAC模块对应的输出电压变量值Vout_T,根据输出电压变量值Vout_T、输出高端偏移值DAmax、输出低端偏移值DAmin、输出起始值Vsetmin、输出最终目标值Vsetmax和最大值DACregisterMax,计算时间输出模式下每个时间周期DAC模块的数字输入量DAC_Output_T;
Vout_T和DAC_Output_T的计算公式为:
Vout_T=Vsetmin+(Vsetrange/(t/IntervalTime))*Ntimes,其中Ntimes为时间周期计数值,Ntimes周期计数值从1开始,Vsetrange=Vsetmax-Vsetmin,
DAC_Output_T=(DAmax-DAmin)*(Vsetmax-Vout_T)/Vsetrange+(DACregistermax-DAmax);
若选择输出模式为步进输出模式,则DAC模块对应的输出电压变量值和DAC模块数字输入量的计算包括步骤:
根据设置的输出起始值Vsetmin、输出单位时间周期IntervalTime、输出电压步进值step计算每个时间周期的DAC模块对应的输出电压变量值Vout_s,再根据所述的输出电压变量值Vout_s、输出高端偏移值DAmax、输出低端偏移值DAmin、输出起始值Vsetmin、输出最终目标值Vsetmax和最大值DACregisterMax,计算步进输出模式下每个时间周期DAC模块的数字输入量DAC_Output_S;
Vout_s和DAC_Output_S的计算公式为:
Vout_s=Vout_s′+step*IntervalTime,Vout_s′为上个时间周期输出的电压变量,Vout_s′的起始值为输出起始值Vsetmin;
DAC_Output_S=(DAmax-DAmin)*(Vsetmax-Vout_S)/Vsetrange+(DACRegisterMax-DAmax);
通信接口,用于处理上位机和MCU处理器间的信息交互。
7.如权利要求6所述的一种基于MCU的可调DAC缓输出系统,其特征在于,存储器和DAC模块集成在MCU处理器中。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110547438.1A CN113206669B (zh) | 2021-05-19 | 2021-05-19 | 一种基于mcu的可调dac缓输出方法及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110547438.1A CN113206669B (zh) | 2021-05-19 | 2021-05-19 | 一种基于mcu的可调dac缓输出方法及系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113206669A CN113206669A (zh) | 2021-08-03 |
CN113206669B true CN113206669B (zh) | 2022-10-18 |
Family
ID=77031798
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110547438.1A Active CN113206669B (zh) | 2021-05-19 | 2021-05-19 | 一种基于mcu的可调dac缓输出方法及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113206669B (zh) |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5319370A (en) * | 1992-08-31 | 1994-06-07 | Crystal Semiconductor, Inc. | Analog-to-digital converter with a continuously calibrated voltage reference |
US5440305A (en) * | 1992-08-31 | 1995-08-08 | Crystal Semiconductor Corporation | Method and apparatus for calibration of a monolithic voltage reference |
TW201243358A (en) * | 2011-04-29 | 2012-11-01 | Novatek Microelectronics Corp | Digital-to-analog converter circuit with rapid built-in self-test and test method |
CN105227184A (zh) * | 2015-10-09 | 2016-01-06 | 武汉永力科技股份有限公司 | 一种adc/dac信号数字校正方法及系统 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6917316B2 (en) * | 2003-05-19 | 2005-07-12 | Semtech Corporation | Digital adjustment of gain and offset for digital to analog converters |
-
2021
- 2021-05-19 CN CN202110547438.1A patent/CN113206669B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5319370A (en) * | 1992-08-31 | 1994-06-07 | Crystal Semiconductor, Inc. | Analog-to-digital converter with a continuously calibrated voltage reference |
US5440305A (en) * | 1992-08-31 | 1995-08-08 | Crystal Semiconductor Corporation | Method and apparatus for calibration of a monolithic voltage reference |
TW201243358A (en) * | 2011-04-29 | 2012-11-01 | Novatek Microelectronics Corp | Digital-to-analog converter circuit with rapid built-in self-test and test method |
CN105227184A (zh) * | 2015-10-09 | 2016-01-06 | 武汉永力科技股份有限公司 | 一种adc/dac信号数字校正方法及系统 |
Non-Patent Citations (2)
Title |
---|
An 8-bit 400-MS/s Asynchronous SAR ADC with Single-ended/Differential Configurable Input Mode;Liang Zhang;《2018 IEEE 3rd International Conference on Integrated Circuits and Microsystems (ICICM)》;20181231;387-390 * |
基于DAC5687的高速多通道信号模拟器设计;李一飞;《微处理机》;20101231;124-127 * |
Also Published As
Publication number | Publication date |
---|---|
CN113206669A (zh) | 2021-08-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6936999B2 (en) | System and method for controlling output-timing parameters of power converters | |
CN202025338U (zh) | 数据采集卡校准装置 | |
US6886120B2 (en) | Memory control circuit | |
US20120072650A1 (en) | Memory system and dram controller | |
CN113206669B (zh) | 一种基于mcu的可调dac缓输出方法及系统 | |
WO2023116366A1 (zh) | 一种闪存控制器、延迟调整方法及存储设备 | |
JP2007249738A (ja) | メモリアクセス制御装置 | |
CN112799457B (zh) | 电压校准电路和方法 | |
US7715268B2 (en) | Non-volatile storage apparatus and a control method thereof | |
US20090058516A1 (en) | Sensor apparatus having sensor element | |
CN103943146A (zh) | 一种快速设定目标电压的装置和方法 | |
CN116340008A (zh) | Ssd功耗控制参数的定标方法、装置、存储介质及系统 | |
US20240097570A1 (en) | Memory system and power control circuit | |
US9940274B2 (en) | Memory system and control method of memory system | |
US7565476B2 (en) | Memory device | |
US11194741B2 (en) | Control device and adjustment method | |
CN114020343B (zh) | 一种驱动能力调节方法、装置、设备及可读存储介质 | |
US7710793B2 (en) | Write voltage generating circuit and method | |
CN116610512B (zh) | 一种存储测试设备及其测试方法 | |
CN221352070U (zh) | 一种芯片烧录电路 | |
CN114371772B (zh) | 一种高低温自适应上电时序的方法,装置、设备 | |
ASIC | User's Guide | |
CN108337054A (zh) | 功率校准方法、系统、计算机设备及存储介质 | |
JP2011158976A (ja) | メモリ制御装置 | |
US8032665B2 (en) | Controller, program and methods for communicating with devices coupled to the controller |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |