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一直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…

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

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

navicat for mysql 13_Navicat for MySQL下载

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

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虚拟机内存监控_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免检异常_java-异常

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

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

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

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

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

java const关键字_const关键字:终于拥有真正的常量声明语句

你好,今天大叔想和你唠扯唠扯 ES6 新增的关键字 —— const。在说 const 关键字之前,大叔先和你唠唠大叔自己对 const 的感受 —— JavaScript 尼玛终于可以声明真正的常量啦!大叔为啥会发出这样滴感叹?实在是“天下苦秦久矣”呀~…

workerman高并发异步mysql_workerman怎么实现高并发

并发概念太模糊,这里以两种可以量化的指标并发连接数和并发请求数来说明。并发连接数是指服务器当前时刻一共维持了多少TCP连接,而这些连接上是否有数据通讯并不关注。 (推荐学习: workerman教程)例如一台消息推送服务器上可能维持了百万的设…

checkout 撤销修改_Git的4个阶段的撤销更改

虽然git诞生距今已有12年之久,网上各种关于git的介绍文章数不胜数,但是依然有很多人(包括我自己在内)对于它的功能不能完全掌握。以下的介绍只是基于我个人对于git的理解,并且可能生编硬造了一些不完全符合git说法的词语。目的只是为了让git通…

java访问权限最高_java 访问权限

Java语言中的访问权限修饰符有4种,但是仅有3个关键字,因为不写访问权限,在Java中被称为默认权限,或同包权限,本文中以(default)代替。下面按照权限从小到大的顺序对4中访问权限分别介绍。class我个人,我有很…

java中fork函数_java中的forkjoin框架的使用

fork join框架是java 7中引入框架,这个框架的引入主要是为了提升并行计算的能力。fork join主要有两个步骤,第一就是fork,将一个大任务分成很多个小任务,第二就是join,将第一个任务的结果join起来,生成最后…

java中已定义类型car_Java 8 习惯用语(8):Java 知道您的类型

Java™8是第一个支持类型推断的 Java 版本,而且它仅对 lambda 表达式支持此功能。在 lambda表达式中使用类型推断具有强大的作用,它将帮助您做好准备以应对未来的 Java版本,在今后的版本中还会将类型推断用于变量等更多可能。这里的诀窍在于恰…

java web 来源页_Java:Java Web--分页效果

先来看一看分页的实现原理万能公式.jpg项目目录.PNG首先,新建Java Web项目一. 梳理业务逻辑重定向到URL(跳转到StudentViewAction页面)//index.jsp页面1.从页面接收可变的值2.接收值有问题时,初始化为13.如果没有问题,把String类型接收值强转成Integer4.实例DAO方法,调用findSt…

java 浏览器 安全_安全策略-IE浏览器防黑十大秘籍

1.管理好Cookie在IE6.0中,打开“工具”→“Internet选项”→“隐私”对话框,这里设定了“阻止所有Cookie”、“高”、“中高”、“中”、“低”、“接受所有Cookie”六个级别,你只要拖动滑块就可以方便地进行设定,而点击下方的“编…

php截取指定字符串之后,php截取字符串(截取指定字符串之间的字符串)

一、PHP截取两个指定字符后边的字符$a "123abc#456";$b (strpos($a,""));$c (strpos($a,"#"));echo substr($a,$b1,$c-1);二、常用截取字符串技巧。//构造字符串$str "ABCDEFGHIJKLMNOPQRSTUVWXYZ";echo "原字符串:…