matlab与数字信号处理的不定期更新

Matlab 复制代码
function [y,n] = sigshift(x,nx,m)
% 实现 y(n) = x(n-m)   m>0右移,m<0左移
n = nx + m;    % 1. 新的时间轴(n) = 旧时间轴(nx) + 平移量(m)
y = x;         % 2. 样本值本身不变,只是"搬家"
end

//
sigshift:函数名

x,nx,m:输入的形参

y,n:return
Matlab 复制代码
function [y,n] = sigadd(x1,n1,x2,n2)
% 功能:把两条任意长度、任意起点/终点的序列相加
% 调用:[y,n] = sigadd(x1,n1,x2,n2)
% 输入:x1,n1 ------ 第一条序列的"值"和"时间轴"
%       x2,n2 ------ 第二条序列的"值"和"时间轴"
% 输出:y,n   ------ 相加后的序列和对应的时间轴

% 1. 找出公共时间范围:从最早点开始到最晚点结束
n = min(min(n1),min(n2)):max(max(n1),max(n2));

% 2. 先按公共长度填两条全零序列,准备"插值"
y1 = zeros(1,length(n));   % 第一条序列的"插值板"
y2 = y1;                   % 第二条序列的"插值板"

% 3. 把 x1 的原始值塞进公共轴上它本该在的位置,其余保持 0(补零)
y1(find((n>=min(n1))&(n<=max(n1))==1)) = x1;

% 4. 同理,把 x2 也塞进公共轴
y2(find((n>=min(n2))&(n<=max(n2))==1)) = x2;

% 5. 现在两条序列长度一致、时间轴一致,逐点相加即可
y = y1 + y2;
end
Matlab 复制代码
x = [1 2 3 4 5 6 7 6 5 4 3 2 1];
nx = 0:length(x)-1;

% (a) x1(n)=2x(n-5)-3x(n+4)
[x5,n5] = sigshift(x,nx, 5);     % x(n-5)
[x4,n4] = sigshift(x,nx,-4);     % x(n+4)

[x1,n1] = sigadd(2*x5,n5, -3*x4,n4);

figure(1);
stem(n1,x1,'filled'); grid on;
xlabel('n'); title('x_1(n) = 2x(n-5) - 3x(n+4)');

在 MATLAB 里,符号 ":" 只有两种最常见、最核心的含义:

  1. 生成等间隔向量 ("冒号表达式"):起点 : 步长 : 终点
Matlab 复制代码
0:5          % → [0 1 2 3 4 5]
1:2:9        % → [1 3 5 7 9]
10:-1:6      % → [10 9 8 7 6]
  1. 用来索引、截取数组("冒号索引"):数组(起始下标 : 步长 : 结束下标)
Matlab 复制代码
A = [10 20 30 40 50];
A(2:4)       % → [20 30 40]
A(1:2:end)   % → [10 30 50]   隔一个取一个

冒号 ":" 在 MATLAB 里要么是

"生成一串数 ",要么是

"取一串元素"------其余花哨用法都是这两件事的变形。


相关推荐
卡卡酷卡BUG4 小时前
Java 后端面试干货:四大核心模块高频考点深度解析
java·开发语言·面试
Yolo566Q4 小时前
OpenLCA生命周期评估模型构建与分析
java·开发语言·人工智能
安娜的信息安全说4 小时前
深入浅出 MQTT:轻量级消息协议在物联网中的应用与实践
开发语言·物联网·mqtt
在坚持一下我可没意见5 小时前
HTTP 协议基本格式与 Fiddler 抓包工具实战指南
java·开发语言·网络协议·tcp/ip·http·java-ee·fiddler
樱花开了几轉5 小时前
element ui下拉框踩坑
开发语言·javascript·ui
报错小能手5 小时前
C++笔记(面向对象)RTTI操作符
开发语言·c++·笔记
草明5 小时前
Go 的 IO 多路复用
开发语言·后端·golang
晟盾科技5 小时前
报表类系统后端API设计思路
开发语言·windows·php
AI纪元故事会5 小时前
冰泪与雨丝:一个AI的Python挽歌
开发语言·人工智能·python