filtic函数 matlab_matlab filtic 函数应用 filter 解差分方程 dft 函数

matlab  filtic 函数应用 filter 解差分方程 dft 函数

一、 解差分方程

说明都在代码注释里面了

%这里要利用filtic函数 为滤波器的直接II型实现选择初始条件

%求解查分方程 y(n) - 0.4y(n-1) - 0.45y(n-2) = 0.45x(n) +0.4x(n-1) - x(n-2)

%y(-1) = 0 y(-2) = 1 x(-1) = 1 x(-2) = 2

%x(n) = 0.8 ^u(n) 状态方程H(z) = (0.45 + 0.4z^-1 - z^-2)/(1- 0.4z^-1-0.45z^-2)

% x 为滤波前序列 y 为输出 序列

% 总结一下 首先把num 和den 写出来

num = [ 0.45 0.4 -1];

den = [1 -0.4 -0.45]

% 其次把初始条件写来

x0 = [1 2] ;

y0= [0 1];

N = 50 ;

n = [1 :N-1]';

x = 0.8.^n;

%生成初始条件

Zi = filtic(num, den , y0 , x0);

[y , Zf] = filter(num , den ,x, Zi);

plot(n , x ,'R-', n, y, 'b--');

xlabel('n'); ylabel('(n)--y(n)');

legend('Input x' , 'Output y', 1);

grid;运行结果:

c3506004a94b478e0d9c9fe0c51e6aef.png

二、和上面类似简单的解差分方程

%这里要借助filter 和filtic 解差分方程

%假设输入信号为 x = 0.8.^n;

%求输出序列

%差分方程y(n) = x(n) - 5x(n-1)+ 8x(n-3)

num = [1 -5 0 8];

N = 30 ;

n =[0: N-1] ;

x = 0.8.^n;

y = filter(num , 1, x);

stem(n, y) ;

title('Response');

grid

运行结果:

90c471491f70f237c46d9804f830c832.png

三、dft 函数

%这里写出一个dft函数

% Xk = DFT[xn] = 公式

% 总结一下dft 写法首先确定xn N WN = exp(-j*2*pi/N)

%其次 确定nk = n'* k 再确定WNnk Xk = xn*WNnk

function [Xk] = dft(xn, N)

n = [0 :1 : N-1];

k = n ;

WN = exp(-j*2*pi/N);

nk = n'*k;

WNnk = WN.^nk;

Xk = xn*WNnk;

end

四、dft 应用

% x(n) = cos(0.48*pi*n) + cos(0.52*pi*n)

%绘制x(n) Xk(k) dft 变换

clf;

N = 100;

n = 0: N-1;

xn = cos(0.48*pi*n) + cos(0.52*pi*n);

Xk = dft(xn,N);

%幅度值 相位值

magXk = abs(Xk);

phaXk = angle(Xk);

% 原函数图像

subplot(221);

plot(n,xn);

xlabel('n'); ylabel('x(n)');

title('xn');

%幅度频率特性

subplot(222);

k = 0:length(magXk) - 1;

plot(k, magXk);

xlabel('k');

ylabel('abs(Xk)');

title('Xk');

运行结果:

d06187db873982b0c90aa3fa941af355.png

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

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

相关文章

rabbitmq进阶一

上一篇文章有讲到rabbitmq的安装、web管理端和springboot简单集成rabbitmq 本文重点介绍rabbitmq相关api的使用 按照官网常用的五种模式的顺序:HelloWorld、Work queues、Publish/Subscribe、Routing、Topics 模式简单介绍 HelloWorld 一个生产者,一…

mysql 相关搜索_MySQL单词搜索相关度排名

一个单词搜索的相关度排名,这个例子演示了一个单词搜索的相关度排名计算。mysql> CREATE TABLE articles (-> id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,-> title VARCHAR(200),-> body TEXT,-> FULLTEXT (title,body)-> ) ENGINEInnoDB;Query O…

IDEA使用总结

idea中使用tomcat IntelliJ IDEA配置Tomcat(完整版图文教程)_猿Bug的博客-CSDN博客_intellij tomcat配置 用上面的方式发现缺少文件,在edit configuration页面选择before lanuch前选择Run maven goal package

mysql一直copying to tmp table_mysql提示Copying to tmp table on disk

网站运行的慢了,查找原因是Copying to tmp table on disk那怎么解决这个问题呢解决一例最近常常碰到网站慢的情况,登陆到后台,查询一下 /opt/mysql/bin/mysqladmin processlist;发现一个查询状态为: Copying to tmp table 而且此查…

idea cloud bootstrap是啥_application.yml与bootstrap.yml的区别

Spring Boot 默认支持 properties(.properties) 和 YAML(.yml .yaml ) 两种格式的配置文件,yml 和 properties 文件都属于配置文件,功能一样。Spring Cloud 构建于 Spring Boot 之上,在 Spring Boot 中有两种上下文,一种是 bootst…

python读取日期_从文件中读取日期和数据(Python)

我想从文件中读取时间字符串和数据,但是当我使用loadtxt时,我不能同时读取字符串和数字,因为字符串不是浮点型的。所以我尝试使用genfromtxt并使用delimiter[][][]作为我所拥有的列,但是字符串的读起来像nan。我希望像时间数组(da…

一个小白如何创建MYSQL数据表_MySQL小白扫盲(二)--建表、添加、查询

1.SELECT子句字句名称          使用目的select           确定结果集中应该包含哪些列from           指明所要提取数据的表,以及这些表示如何连接的where           过滤掉不需要的数据group by         用于…

元数据解决分表不可 mysql_MySQL InnoDB技术内幕:内存管理、事务和锁

前面有多篇文章介绍过MySQL InnoDB的相关知识,今天我们要更深入一些,看看它们的内部原理和机制是如何实现的。一、内存管理我们知道,MySQl是一个存储系统,数据最后都写在磁盘上。我们以前也提到过,磁盘的速度特别是大容…

navicat for mysql 13_Navicat for MySQL下载

Navicat for MySQL 是一套管理和开发 MySQL 或 MariaDB 的理想解决方案。它使你以单一程序同时连接到 MySQL 和 MariaDB。这个功能齐备的前端软件为数据库管理、开发和维护提供了直观而强大的图形界面。它提供了一组全面的工具给 MySQL 或MariaDB 新手,同时给专业人…

mysql 日期型中文报错_mysql日期类型默认值'0000-00-00' 报错,是什么问题?

如题,本来是 从另一个数据库中导出的sql文件,在我电脑上导入报这个错误,不知道是不是mysql 版本问题。多方搜索无果,所以上来求助。DROP TABLE IF EXISTS workreport_member;CREATE TABLE workreport_member (uid int(10) unsigne…

python在线作业_南开大学20春学期《Python编程基础》在线作业参考答案

南开大学20春学期(1709、1803、1809、1903、1909、2003)《Python编程基础》在线作业试卷总分:100 得分:98一、单选题(共20 道试题,共40 分)1.已知“stra\rb\r\nc\n”,则“str.splitlines()”的返回结果是( )。A.[a,b,c]B.[a\r,b\r\n,c\n]C.[a\r,b\r,c]D.[a\r,b,c]答案:A2.已知“…

spring兼容mysql_springboot 最新版本支持 mysql6.0.6吗

缥缈止盈1.首先在pom文件中加入下列依赖,一个使用jpa所需依赖,一个连接MySQL使用的依赖:mysqlmysql-connector-javaorg.springframework.bootspring-boot-starter-data-jpa 123456789102.在配置文件中添加datasource配置和jpa配置,在mysql中已经提前创建了一个名为db_test的数据…

java集合map_JAVA中的集合类Map、Set、List

*精炼的总结:Collection 是对象集合, Collection 有两个子接口 List 和 SetList 可以通过下标 (1,2..) 来取得值,值可以重复而 Set 只能通过游标来取值,并且值是不能重复的ArrayList , Vector , LinkedList…

java虚拟机内存监控_java虚拟机内存监控工具jps,jinfo,Jstack,jstat,jmap,jhat使用...

将会打印出很多jvm运行时参数信息,由于比较长这里不再打印出来,可以自己试试,内容一目了然Jstack(Stack Trace for Java):JVM堆栈跟踪工具jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如…

idea 调试java技巧_IDEA 调试Java代码的两个技巧

本文介绍两个使用IDEA 调试Java代码的两个技巧:修改变量值使用RuntimeException终止代码执行修改变量值在Java代码调试过程中,我们可以修改变量值,使其达到走指定分支的目的,或者使其满足某个条件。我们以给变量beanName赋值为例&…

java 10进制转 000x_java 如何把 00 转换成 0x00 或者 10 转换成 0x10

public static void main(String[] args) {String s "00000018A0010098C68E00989A690000000000BC614E000055AA55AA";System.out.println(s);byte[] b HexString2Bytes(s);System.out.println(Bytes2HexString(b));}/*** 将指定byte数组以16进制的形式打印到控制台*…

java免检异常_java-异常

java提供了异常处理机制:程序运行受阻时候的处理方式。1、异常分类Error:系统错误,由java虚拟机抛出,很少发生;免检异常RuntimeException:程序设计错误,通常由java虚拟机抛出;免检异…

java编程需要数学知识吗_初学Java编程,需要英语和数学基础吗?

原标题:初学Java编程,需要英语和数学基础吗?“学习Java编程英语和数学是必备条件吗?”很多Java零基础学习或者转型IT行业的都会有这样的疑问,其实刚开始学习Java编程是不需要太高深的数学和英语基础的。刚开始学习Java…

java map put报错_java 集合(Map)

-------------------|Map 储存的数据都是以键值对的形式,键不可重复,值可重复。----------------------------| HashMap----------------------------| TreeMap----------------------------| HashTableMap接口的方法:添加:put(K…

java简单数据结构_图解Java常用数据结构

最近在整理数据结构方面的知识, 系统化看了下 Java 中常用数据结构, 突发奇想用动画来绘制数据流转过程.主要基于 jdk8, 可能会有些特性与 jdk7 之前不相同, 例如 LinkedList LinkedHashMap 中的双向列表不再是回环的.HashMap 中的单链表是尾插, 而不是头插入等等, 后文不再赘叙…