DSP实现逐波限流或限压,保护电路器件

2024-01-25 07:30

本文主要是介绍DSP实现逐波限流或限压,保护电路器件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 一、背景介绍

        在做相关数字电源控制时,电路中有某些器件耐压过流限制的,我们控制时要确保不会因为过流或过压导致器件的损坏,使用软件保护存在响应较慢,来不及实施保护措施等问题;使用硬件保护,需要搭建外围电路,提高了成本。那么,接下来介绍一种基于TI的TMS320F28377芯片内部模块的逐波限流或限压保护措施。

二、模拟比较器(CMPSS)

        模拟比较器存在两个输入端:

①正输入端:CMPINxP引脚同时也是ADC采样引脚,也就是需要限流或限压的采样信号

②负输入端:可选内部DAC输出或CMPINxN引脚;选择CMPINxN引脚则是两个采样信号的比较,选择内部DAC输出则是限流或限压的采样信号与设置的限流/限压值进行比较

        当正输入端 > 负输入端时,比较器输出1,否则输出0。输出信号 --> 极性翻转 --> 滤波器 --> 最终输出信号。

三、信号链接器(X-BAR)

         信号链接器可将一个外设模块的输出信号与另一个外设的输入信号进行链接,实现多个模块之前的联合运转,互相配合。如上图,可将模拟比较器输出的比较信号链接到EPWM模块的TRIPx信号。

        每个TRIPx信号存在32个MUX,每个MUX的取值为0~3,可通过查表得到某个信号对应的MUX以及该MUX的取值。

四、发波模块(EPWM)

        EPWM主要用来发波,控制开关器件达到控制电流、电压。除了发波任务,EPWM还有两个子模块用来实现检测限压/限流信号,停止发波的功能,分别是DC子模块、TZ子模块。

1、DC子模块

        DC模块有两个事件发生器:Event A Qual、Event B Qual。每个发生器有两个输入DCxH/DCxL,每个输入可以是TRIPIN1~12/14的单个信号,或是由TRIPIN1~12/14经过或门组合的TRIPIN15。可通过配置DCxH/DCxL信号为高低电平的不同组合输出不同事件,每个发生器可产生两个事件DCxEVT1/2,可选择经过滤波器产生DCEVTFILT事件信号,然后经过事件触发器输出不同触发信号给到其他外设或者模块;或者不经过滤波器直接经过事件触发器输出不同触发信号给到其他外设或者模块。

        事件触发器可输出以下几种触发信号:

①DCxEVT1/2.force:该信号送往TZ子模块,进行封波处理,实现限流/限压,保护电路器件。

②DCAEVT1/2.inter:该信号产生故障中断到PIE。

③DCAEVT1.soc:该信号可产生ADC启动转换信号。

④DCAEVT1.sync:该信号可生成时基计数器的同步脉冲。

2、TZ子模块

        上图为TZ模块框图,如图中①所示,TZ模块封波存在三种模式:

(1)直接以DCxEVT1/2.force信号触发封波,这一种模式,只要有DCxEVT1/2.force信号就会进行封波,没有则会释放,所以存在一个PWM周期内进行多次封波释放操作

(2)如②所示,通过TZ1~TZ6、DCAEVT2.force、DCBEVT2.force组合信号设置CBC触发器,间接触发封波,CBC触发器会将触发信号锁存,直到收到清零信号,清零信号可由如图中③所示的CTR = 0 或 PRD触发。所以,CBC触发器模式可以实现每个PWM周期都清除触发信号,重新检测,这就是逐波限流或限压

(3)如②所示,通过TZ1~TZ6、DCAEVT2.force、DCBEVT2.force组合信号设置OSHT触发器,间接触发封波,CBC触发器会将触发信号锁存,直到收到清零信号,清零信号可由如图中④所示的软件清零位置位来清除。所以,OSHT触发器不会自动清除触发信号,直到在程序中手动置清零标志位来清除

这篇关于DSP实现逐波限流或限压,保护电路器件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/642522

相关文章

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

SpringBoot利用@Validated注解优雅实现参数校验

《SpringBoot利用@Validated注解优雅实现参数校验》在开发Web应用时,用户输入的合法性校验是保障系统稳定性的基础,​SpringBoot的@Validated注解提供了一种更优雅的解... 目录​一、为什么需要参数校验二、Validated 的核心用法​1. 基础校验2. php分组校验3

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Pydantic中model_validator的实现

《Pydantic中model_validator的实现》本文主要介绍了Pydantic中model_validator的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录引言基础知识创建 Pydantic 模型使用 model_validator 装饰器高级用法mo

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文