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

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import