早教吧作业答案频道 -->其他-->
simulink中的s函数我用simulink搭建了一个模块,用到了s函数,用来实现以下功能:对于一个给定的连续信号u,输出y(t)=(u(t)+u(t+T)+u(t+2*T)+u(t+3*T)+u(t+4*T)+u(t+5*T)+u(t+6*T)+u(t+7*T)+u(t+8*T)+u(t+9*T))/10,其中T是采
题目详情
simulink中的s函数
我用simulink搭建了一个模块,用到了s函数,用来实现以下功能:对于一个给定的连续信号u,输出y(t)=(u(t)+u(t+T)+u(t+2*T)+u(t+3*T)+u(t+4*T)+u(t+5*T)+u(t+6*T)+u(t+7*T)+u(t+8*T)+u(t+9*T))/10,其中T是采样时间(T=0.1s),其主要目的是使有噪声的信号u变的平滑,请问实现这一功能如何用s函数实现,并希望能附带必要的解释,
我用simulink搭建了一个模块,用到了s函数,用来实现以下功能:对于一个给定的连续信号u,输出y(t)=(u(t)+u(t+T)+u(t+2*T)+u(t+3*T)+u(t+4*T)+u(t+5*T)+u(t+6*T)+u(t+7*T)+u(t+8*T)+u(t+9*T))/10,其中T是采样时间(T=0.1s),请问实现这一功能如何用s函数实现,并希望能附带必要的解释,
我用simulink搭建了一个模块,用到了s函数,用来实现以下功能:对于一个给定的连续信号u,输出y(t)=(u(t)+u(t+T)+u(t+2*T)+u(t+3*T)+u(t+4*T)+u(t+5*T)+u(t+6*T)+u(t+7*T)+u(t+8*T)+u(t+9*T))/10,其中T是采样时间(T=0.1s),其主要目的是使有噪声的信号u变的平滑,请问实现这一功能如何用s函数实现,并希望能附带必要的解释,
我用simulink搭建了一个模块,用到了s函数,用来实现以下功能:对于一个给定的连续信号u,输出y(t)=(u(t)+u(t+T)+u(t+2*T)+u(t+3*T)+u(t+4*T)+u(t+5*T)+u(t+6*T)+u(t+7*T)+u(t+8*T)+u(t+9*T))/10,其中T是采样时间(T=0.1s),请问实现这一功能如何用s函数实现,并希望能附带必要的解释,
▼优质解答
答案和解析
function [sys,x0,str,ts] = filter(t,x,u,flag)
switch flag,
case 0,
[sys,x0,str,ts]=mdlInitializeSizes; %调用初始化函数
case 2,
sys=mdlUpdate(t,x,u); %调用离散函数
case 3,
sys=mdlOutputs(t,x,u); %调用输出函数
case {1,4,9},
sys=[];
otherwise
error(['Unhandled flag = ',num2str(flag)]);
end
function [sys,x0,str,ts]=mdlInitializeSizes %定义10个离散变量及初值,1个输入,1个输出
sizes = simsizes;
sizes.NumContStates = 0;
sizes.NumDiscStates = 10;
sizes.NumOutputs = 1;
sizes.NumInputs = 1;
sizes.DirFeedthrough = 1;
sizes.NumSampleTimes = 1;
sys = simsizes(sizes);
x0=[0 0 0 0 0 0 0 0 0 0];%依次用来保存u(t)到u(t-9T)
str = [];
ts = [1e-4];
function sys=mdlUpdate(t,x,u)
for i=9:-1:1
x(i+1)=x(i);%每调用依次s-function,则将x中的数值向右移动,为计算做准备
end
x(1)=u(1);
sys=x;
function sys=mdlOutputs(t,x,u)
sys=sum(x)/10;%计算平均值
switch flag,
case 0,
[sys,x0,str,ts]=mdlInitializeSizes; %调用初始化函数
case 2,
sys=mdlUpdate(t,x,u); %调用离散函数
case 3,
sys=mdlOutputs(t,x,u); %调用输出函数
case {1,4,9},
sys=[];
otherwise
error(['Unhandled flag = ',num2str(flag)]);
end
function [sys,x0,str,ts]=mdlInitializeSizes %定义10个离散变量及初值,1个输入,1个输出
sizes = simsizes;
sizes.NumContStates = 0;
sizes.NumDiscStates = 10;
sizes.NumOutputs = 1;
sizes.NumInputs = 1;
sizes.DirFeedthrough = 1;
sizes.NumSampleTimes = 1;
sys = simsizes(sizes);
x0=[0 0 0 0 0 0 0 0 0 0];%依次用来保存u(t)到u(t-9T)
str = [];
ts = [1e-4];
function sys=mdlUpdate(t,x,u)
for i=9:-1:1
x(i+1)=x(i);%每调用依次s-function,则将x中的数值向右移动,为计算做准备
end
x(1)=u(1);
sys=x;
function sys=mdlOutputs(t,x,u)
sys=sum(x)/10;%计算平均值
看了 simulink中的s函数我...的网友还看了以下:
用平移三角尺的方法可以检验图中共有平行线()A.3对B.4对C.5对D.6对 2020-04-13 …
如图,AC是矩形ABCD的对角线,E是边BC延长线上一点,AE与CD相交于F,则图中的相似三角形共 2020-04-27 …
如图,∠ACB=90°,CD⊥AB,则图中互余的角有()A.2对B.3对C.4对D.5对 2020-05-14 …
如图5.1-45,图中同位角的对数有( )A.2对 B.3对 C.4对 D.5对 2020-05-16 …
下列各数对数中,互为相反数的有().+(-3)与-3+(+3)与-3-(-3)与+(-3)-(-3 2020-07-17 …
三条直线相交于一点,对顶角最多有()A.4对B.5对C.6对D.7对 2020-07-21 …
平面上3条互不重合的直线交于一点,其中对顶角有()A.4对B.5对C.6对D.7对 2020-08-01 …
如图,圆内接四边形ABCD的对角线相交于E,AB、DC的延长线相交于P,则图中一定相似的三角形有A 2020-08-01 …
如图所示,AD平分∠BAC,AB=AC,连结BD、CD并延长分别交AC、AB于F、E点,则此图中全等 2020-11-03 …
在△ABC中,已知AB=AC,中线BE与中线CF相交于点O,则其中全等三角形共有几对?A.3对B.4 2021-01-12 …