1

所以我创建了一个 .m 文件,其中包含我正在尝试调制的锯齿信号波。我生成波形没有问题,但是当我尝试获取 .m 文件并将其乘以“c”时,MATLAB 返回原始波形。这个特定的程序使用双边带调制技术。第一部分是我的波形。

function y = Signal
% Signal Summary of this function goes here
n = 23; % Number of Harmonics
t = 0:.0002:n; % incremental value
y = sawtooth(t,.2); % Wave creation
plot(t,y);
ylabel ('Amplitude');
xlabel ('Time');
title('Sawtooth Wave');

end

下一部分是我试图调用 .m 文件的地方,将其乘以“c”并绘制结果函数。

function [ DSBModulation ] = DSB( DSBModulation )
% Program for DSB-AM

n = 23; 
fc = 100;
t = 0:.0002:n;
sig = Signal; % this is how im trying to call the .m file so i can manipulate it

c = cos((2*pi*fc*t)); % using this as the modulating function
u(sig) = (sawtooth(t,.2)).*c; % Multiplying the signal
plot(t,u(sig)); %Displaying the Signal

end 
4

1 回答 1

0

信号生成的结果存储在函数sig以下行的变量中DSB

sig = Signal;

因此,调制生成信号的进一步操作应使用该sig变量,而不是尝试使用sawtooth定义在 范围内的局部变量Signal。然后您还应该注意,u(sig)Matlab 中的符号表示u由 中的值索引的向量sig,而不是u变量函数的数学概念sig

因此,要计算调制信号矢量,您将使用:

u = sig.*c; % Multiplying the signal 

最后,要在同一个图形上绘制结果,您可以使用hold命令,或者使用单独figure的(否则您的第二个plot命令将擦除第一个的图形plot):

close all;
plot(t,u); %Displaying the Signal
hold on; plot(t,sig,'r','LineWidth',3); % Overlay the unmodulated signal for reference

ylabel ('Amplitude');
xlabel ('Time');

这应该会给你以下结果:

在此处输入图像描述

于 2016-05-11T21:50:57.107 回答