function[x,n]=delta(n0,n1,n2) n=[n1:n2]; x=[(n-n0)==0]; %定义函数1 function[x,n]=step(n0,n1,n2) n=[n1:n2]; x=[(n-n0)>=0]; %定义函数2 [x1,n]=delta(3,1,10); [x2,n]=step(-2,1,10); [x3,n]=delta(-3,1,10); [x4,n]=step(2,1,10); subplot(2,3,1);stem(n,(x1+x2));title('f1(t)');grid on subplot(2,3,2);stem(n,(x3+x4));title('f2(t)');grid on; subplot(2,3,3);stem(n,(x1+x2)+(x3+x4));title('f1+f2');grid on; subplot(2,3,4);stem(n,(x1+x2)-(x3+x4));title('f1-f2');grid on; subplot(2,3,5);stem(n,(x1+x2).*(x3+x4));title('f1*f2');grid on;
时间: 2024-04-04 19:30:27 浏览: 78
编制具有如下原型的函数prime,用来判断整数n是否为素数:bool prime(int n); 而后编制主函数,任意输入一个大于4的偶数d,找出满足d=d1+d2的所有数对,其中要求d1与d2均为素数(通过调用prime来判断素数)。如偶数18可以分解为11+7以及13+5;而偶数80可以分解为:43+37、61+19、67+13、73+7。
4星 · 用户满意度95%
这段代码定义了两个函数delta和step,并利用这两个函数绘制了5个离散时间信号的图像。其中,delta函数表示一个以n0为中心的单位脉冲信号,step函数表示一个从n0开始的单位阶跃信号。代码中的5个信号分别为:
1. f1(t) = delta[n-3] + u[n+2],其中u[n]表示从n=0开始的单位阶跃信号。
2. f2(t) = delta[n+3] - u[n-2]。
3. f1(t) + f2(t)
4. f1(t) - f2(t)
5. f1(t) * f2(t)
subplot函数用于将这5个信号的图像绘制在同一张图中,方便对比和分析。每个图像的标题表示对应的信号名称,grid on命令用于显示图像的网格线。注意,这段代码中的变量名和函数名不能与MATLAB的内置函数重名,否则会出现错误。
阅读全文