数字电源常用传递函数

news2024/9/21 4:24:30

文章目录

            • PID控制器
            • 二阶广义积分器
            • PR谐波抑制器
            • 陷波器
            • 全通滤波器
            • 重复控制器
            • 连续域离散化的几种方法

有S域和Z域
在这里插入图片描述

PID控制器
  • 传递函数:
    在这里插入图片描述

  • bode图:
    在这里插入图片描述

  • m代码

    %% PID控制器
    % 连续域
    kp = 100;
    ki = 10;
    kd = 10;
    Ts = 1/50000;
    num = [kd kp ki];
    den = [1 0];
    Gpid = tf(num,den)
    Gzpid = c2d(Gpid,Ts,'tustin');
    p = bodeoptions;
    p.Grid = 'on';
    p.FreqUnits = 'Hz';
    bodeplot(Gpid,'g',p);
    %hold on
    %bodeplot(Gzpid,'r.',p);
    %hold off
    
  • simulink略去。。。。。。常识啦,哈哈哈

二阶广义积分器

二阶广义积分器能对特定频率交流分量进行跟踪、移相,可用于实现电压信号的正、负序分离及滤波,

  • 传递函数:
    在这里插入图片描述

  • G1 bode图
    在这里插入图片描述

  • G2 bode图
    在这里插入图片描述
    由滤波器的幅频特性与相频特性可知,
    滤波器在频率w0处的增益为1,输出信号qV与V的相位差为90°,
    表明滤波器可完成对给定频率交流信号进行无差跟踪与移相。

  • m代码

    %% 二阶广义积分器
    k = 1;
    f = 50;
    w0 = 2 * pi * f;
    Ts = 1 / 50000;
    % D(s)=v'/v
    num1 = [k*w0 0];
    den1 = [1 k*w0 w0^2];
    G2s1 = tf(num1, den1);
    G2z1 = c2d(G2s1, Ts, 'tustin');
    % Q(s)=qv'/ v 
    num2 = [k*w0^2];
    den2 = [1 k*w0 w0^2];
    G2s2 = tf(num2, den2);
    G2z2 = c2d(G2s2, Ts, 'tustin');
    % bode plot and analysis
     p = bodeoptions;
     p.Grid = 'on';
     p.FreqUnits = 'Hz';
     bodeplot(G2s1, 'b', p);
     bodeplot(G2s2, 'b', p);
    % hold on
    % bodeplot(G2z1, 'r', p);
    % hold off
    
  • simulink仿真
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

PR谐波抑制器
  • 传递函数
    在这里插入图片描述

  • bode图
    在这里插入图片描述

  • m代码

    %% PR谐振控制器
    % 连续域
    Kr = 1;
    f = 50;
    fh = 0.2;
    wc = 2 * pi * fh;
    w0 = 2 * pi * f;
    Ts = 1 / 50000;
    num1 = [Kr*2*wc 0];
    den1 = [1 2*wc w0^2];
    Gspr = tf(num1, den1)
    Gzpr = c2d(Gspr, Ts, 'tustin')
    % bode plot and analysis
    p = bodeoptions;
    p.Grid = 'on';
    p.FreqUnits = 'Hz';
    bodeplot(Gzpr, 'b', p); 
    
  • simulink仿真
    在这里插入图片描述
    在这里插入图片描述

陷波器
  • 传递函数
    在这里插入图片描述
  • Bode图
    在这里插入图片描述
  • m代码
    %% 陷波器-与PR相反
    % 连续域
    Kr = 1;
    f = 50;
    fh = 0.2;
    wc = 2 * pi * fh;
    w0 = 2 * pi * f;
    Ts = 1 / 50000;
    
    num = [1 0 w0^2];
    den = [1 2*wc w0^2];
    Gstrap = tf(num, den)
    Gztrap = c2d(Gstrap, Ts, 'tustin')
    
    % bode plot and analysis
    p = bodeoptions;
    p.Grid = 'on';
    p.FreqUnits = 'Hz';
    bodeplot(Gstrap, 'g', p); 
    % hold on
    % bodeplot(G2z1, 'r', p);
    % hold off
    
  • simulink仿真
    在这里插入图片描述
    在这里插入图片描述
全通滤波器

需要得到一个与原信号有相位差的信号,可以看作是一个信号发生器

  • 传递函数
    在这里插入图片描述
  • bode图
    在这里插入图片描述
  • m代码
    %% 全通滤波器
    % 连续域
    k = 1;
    f = 50;
    w0 = 2 * pi * f;
    Ts = 1 / 50000;
    
    num = [1 -k*w0 w0^2];
    den = [1 w0 w0^2];
    Gsf = tf(num, den)
    Gzf = c2d(Gsf, Ts, 'tustin');
    % bode plot and analysis
    p = bodeoptions;
    p.Grid = 'on';
    p.FreqUnits = 'Hz';
    bodeplot(Gsf, 'y', p); 
    % hold on
    % bodeplot(Gzf, 'r', p);
    % hold off
    
  • simulink仿真
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

在这里插入图片描述

重复控制器

依据内模原理
在这里插入图片描述

  • simulink仿真
    在这里插入图片描述

在这里插入图片描述
继续放大!!!
在这里插入图片描述
制造一个输入信号的传递函数模型,去抑制干扰带来的周期性的变化!!!

连续域离散化的几种方法

在这里插入图片描述

视频链接:https://www.bilibili.com/video/BV1zC4y1t7Cs/?spm_id_from=333.337.search-card.all.click&vd_source=000517e2f52ac26c3dd3a8f0f47a1852
资料链接:
链接:https://pan.baidu.com/s/1L2cj8_NhlF0QLnGUdtut-Q
提取码:nN8q

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1005639.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在使用 gson 时,数字被自动转为 double 类型

背景 在将一个 JsonObject 转成 Map<String, Object> 的时候&#xff0c;数字全部被转成了 double 类型&#xff0c; 如下所示&#xff0c;年龄从 2 变成了 2.0&#xff0c;身高正常显示 98.2&#xff0c;登记时间成了 1.694533284627E12 /*** name小红* record_time1.6…

UG\NX二次开发 复制3元素的double数组到另一个数组 UF_VEC3_copy

文章作者:里海 来源网站:王牌飞行员_里海_里海NX二次开发3000例,里海BlockUI专栏,C\C++-CSDN博客 简介: UG\NX二次开发 复制3元素的double数组到另一个数组 UF_VEC3_copy。仔细看第二段代码 。 效果: 代码: #include "me.hpp"void ufusr(char* param, …

pandas 筛选数据的 8 个骚操作

日常用Python做数据分析最常用到的就是查询筛选了&#xff0c;按各种条件、各种维度以及组合挑出我们想要的数据&#xff0c;以方便我们分析挖掘。 东哥总结了日常查询和筛选常用的种骚操作&#xff0c;供各位学习参考。本文采用sklearn的boston数据举例介绍。 from sklearn …

3基于MATLAB的齿轮啮合仿真,可根据需要调节齿轮参数,实现齿轮啮合转动动态过程。程序已调通,可直接运行。

基于MATLAB的齿轮啮合仿真&#xff0c;可根据需要调节齿轮参数&#xff0c;实现齿轮啮合转动动态过程。程序已调通&#xff0c;可直接运行。 3matlab齿轮啮合仿真动态啮合 (xiaohongshu.com)

动态负荷对电力系统摆幅曲线的影响研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

springboot使用freemarker导出word

springboot使用freemarker导出word 一、需求说明二、制作模板文件1.修改word留下占位符并另存为.xml文件2.将xml文件后缀名改为.ftl3.打开ftl文件格式化内容4.将占位符替换成变量 三、代码实现1.引入依赖2.将模板引入resource下3.编写word导出工具包4.创建接口调用 一、需求说明…

eslint写jsx报错

eslint写jsx报错 ChatGPT提示 在写JSX时&#xff0c;ESLint可能会报出一些语法错误&#xff0c;这些错误通常是由于ESLint默认配置中不支持JSX语法导致的。为了解决这些错误&#xff0c;我们需要在ESLint配置文件中启用对JSX语法的支持。 首先&#xff0c;需要安装eslint-pl…

100道基于Android毕业设计的选题题目,持续更新

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝30W,Csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 大家好&#xff0c;我是程序员徐师兄、今天给大家谈谈基于android的app开发毕设题目&#xff0c;以及基于an…

苹果数据恢复软件:Omni Recover Mac

Omni Recover是一款十分实用的Mac数据恢复软件&#xff0c;为用户提供了简单、安全、快速和高效的数据恢复服务。如果您遇到了Mac或iOS设备中的数据丢失和误删情况&#xff0c;不要着急&#xff0c;不妨尝试一下Omni Recover&#xff0c;相信它一定会给您带来惊喜。 首先&…

【Bun1.0】使用 Bun.js 构建快速、可靠和安全的 JavaScript 应用程序

bun.js Bun 是一个现代的JavaScript运行环境&#xff0c;如Node, Deno。主要特性如下: 启动速度快。更高的性能。完整的工具&#xff08;打包器、转码器、包管理&#xff09;。 官网 https://bun.sh 优点 与传统的 Node.js 不同&#xff0c;Bun.js 提供了一些新的特性和功…

第8章_freeRTOS入门与工程实践之内存管理

本教程基于韦东山百问网出的 DShanMCU-F103开发板 进行编写&#xff0c;需要的同学可以在这里获取&#xff1a; https://item.taobao.com/item.htm?id724601559592 配套资料获取&#xff1a;https://rtos.100ask.net/zh/freeRTOS/DShanMCU-F103 freeRTOS系列教程之freeRTOS入…

《Linkerd 2.0:下一代服务网格的探索》

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f405;&#x1f43e;猫头虎建议程序员必备技术栈一览表&#x1f4d6;&#xff1a; &#x1f6e0;️ 全栈技术 Full Stack: &#x1f4da…

C++下基于模拟退火算法解决TSP问题

一、原理 首先明确TSP问题的目标是什么&#xff0c;假设当前有3个城市&#xff0c;需要你从第一个城市开始&#xff0c;遍历所有城市&#xff0c;然后回到初始位置&#xff0c;要求总路径最短。这个时候就需要计算每个城市之间的两两距离&#xff0c;然后按顺序确定一条最短路…

【Unity】2D 对话模块的实现

对话模块主要参考 【Unity教程】剧情对话系统 实现。 在这次模块的构建将基于 unity ui 组件 和 C#代码实现一个从excel 文件中按照相应规则读取数据并展示的逻辑。这套代码不仅能实现正常的对话&#xff0c;也实现了对话中可以通过选择不同选项达到不同效果的分支对话功能。 …

机器视觉康耐视visionpro-CogFitLineTool拟合直线错误上的理解

视频详细解答&#xff1a;康耐视VisionPro高级脚本系列教程-2.拟合指教脚本遍历编写 什么是直线&#xff1f; 直线&#xff1a;那么直线是由无线的点组成的。特点是无端点&#xff1b;不能度量&#xff0c;两边无限延长。错误示例子如下&#xff1a; 首先上面是错误的理解&…

UG\NX CAM二次开发 设置工序切削区域 UF_CAMGEOM_append_items

文章作者:代工 来源网站:NX CAM二次开发专栏 简介: UG\NX CAM二次开发 设置工序切削区域 UF_CAMGEOM_append_items 效果: 代码: static int init_proc(UF_UI_selection_p_t select, void* user_data) { int errorCode = 0; int num_triples = 1;//UF_UI_mas…

来可LCWLAN-600P产品使用和常见问题说明

01LCWLAN-600P简介 LCWLAN-600P是来可电子最新生产的一款CAN转WiFi设备&#xff0c;该设备的主要功能是将CAN数据转换成网络数据并通过无线网络转发出去。设备支持8~30V宽压供电&#xff0c;出厂默认配置为AP模式&#xff0c;设备供电后可在电脑的WiFi搜索栏搜索到名称为LCWLA…

2023年意大利富时MIB指数研究报告

第一章 指数概况 1.1 指数基本情况 富时MIB指数&#xff08;意大利语&#xff1a;Financial Times Stock Exchange Milano Indice di Borsa, FTSE MIB&#xff09;&#xff0c;2009年6月之前称为S&P/MIB&#xff0c;是意大利证券交易所的基准股票市场指数。该指数于2004年…

[其他]IDEA中Maven项目配置国内源

配置国内源主要解决了,在maven项目中pom.xml下载jar包失败或过慢的问题. 在IDEA中的设置分成两种,设置当前项目与新创项目. 我们就需要两种都进行设置,不然只有在当前项目配置了国内源,新创项目的时候还是默认的状态. 由于下面两种设置的界面与方法是一致的,下面以当前项目设…

jmeter采集ELK平台海量业务日志( 采用Scroll)

由于性能测试需要&#xff0c;需采集某业务系统海量日志&#xff08;百万以上&#xff09;来使用&#xff0c;做稳定性压测使用。但Elasticsearch的结果分页size单次最大为10000&#xff08;运维同事为保证ES安全&#xff09;。为了能够快速采集ELK平台业务日志&#xff0c;可以…