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

相关文章

linux批量替换文件内容的实现方式

《linux批量替换文件内容的实现方式》本文总结了Linux中批量替换文件内容的几种方法,包括使用sed替换文件夹内所有文件、单个文件内容及逐行字符串,强调使用反引号和绝对路径,并分享个人经验供参考... 目录一、linux批量替换文件内容 二、替换文件内所有匹配的字符串 三、替换每一行中全部str1为st

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

SpringBoot集成EasyPoi实现Excel模板导出成PDF文件

《SpringBoot集成EasyPoi实现Excel模板导出成PDF文件》在日常工作中,我们经常需要将数据导出成Excel表格或PDF文件,本文将介绍如何在SpringBoot项目中集成EasyPo... 目录前言摘要简介源代码解析应用场景案例优缺点分析类代码方法介绍测试用例小结前言在日常工作中,我们经

基于Python实现简易视频剪辑工具

《基于Python实现简易视频剪辑工具》这篇文章主要为大家详细介绍了如何用Python打造一个功能完备的简易视频剪辑工具,包括视频文件导入与格式转换,基础剪辑操作,音频处理等功能,感兴趣的小伙伴可以了... 目录一、技术选型与环境搭建二、核心功能模块实现1. 视频基础操作2. 音频处理3. 特效与转场三、高

Python实现中文文本处理与分析程序的示例详解

《Python实现中文文本处理与分析程序的示例详解》在当今信息爆炸的时代,文本数据的处理与分析成为了数据科学领域的重要课题,本文将使用Python开发一款基于Python的中文文本处理与分析程序,希望... 目录一、程序概述二、主要功能解析2.1 文件操作2.2 基础分析2.3 高级分析2.4 可视化2.5

Java实现预览与打印功能详解

《Java实现预览与打印功能详解》在Java中,打印功能主要依赖java.awt.print包,该包提供了与打印相关的一些关键类,比如PrinterJob和PageFormat,它们构成... 目录Java 打印系统概述打印预览与设置使用 PageFormat 和 PrinterJob 类设置页面格式与纸张

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

Python实现终端清屏的几种方式详解

《Python实现终端清屏的几种方式详解》在使用Python进行终端交互式编程时,我们经常需要清空当前终端屏幕的内容,本文为大家整理了几种常见的实现方法,有需要的小伙伴可以参考下... 目录方法一:使用 `os` 模块调用系统命令方法二:使用 `subprocess` 模块执行命令方法三:打印多个换行符模拟

SpringBoot+EasyPOI轻松实现Excel和Word导出PDF

《SpringBoot+EasyPOI轻松实现Excel和Word导出PDF》在企业级开发中,将Excel和Word文档导出为PDF是常见需求,本文将结合​​EasyPOI和​​Aspose系列工具实... 目录一、环境准备与依赖配置1.1 方案选型1.2 依赖配置(商业库方案)二、Excel 导出 PDF

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho