Error "It must be of type 'Type::MATLABOutput"
6 views (last 30 days)
Show older comments
James Manns
on 1 Feb 2024
Answered: Walter Roberson
on 1 Feb 2024
I have a signal x(t)=exp(-100t), t>0. I'm trying to plot the ESD against frequency and then find and plot the 3dB bandwidth. The EDS plots fine but I get the following error for the 3dB plot:
"Error using / Invalid return value '[1/(2*abs(100 + w*1i)^2)]'. It must be of type'Type::MATLABOutput'.
Error in untitled3 (line 22) f_3dB = solve(ESD == max(ESD)/2, f);"
The code is below:
clc
clear all
syms t w;
x_t = exp(-100*t)*(heaviside(t));
X_w = fourier(x_t, w);
ESD = abs(X_w)^2;
% Plot ESD against linear frequency
f = linspace(-10, 10, 1000); % frequency range for plotting
ESD_plot = subs(ESD, w, 2*pi*f);
figure;
plot(f, ESD_plot);
title('Energy Spectral Density (ESD)');
xlabel('Frequency (Hz)');
ylabel('ESD');
grid on;
f_3dB = solve(ESD == max(ESD)/2, f);
disp(['3 dB Bandwidth: ', num2str(2*f_3dB)]);
0 Comments
Accepted Answer
Walter Roberson
on 1 Feb 2024
syms t w;
x_t = exp(-100*t)*(heaviside(t));
X_w = fourier(x_t, w);
ESD = abs(X_w)^2;
% Plot ESD against linear frequency
f = linspace(-10, 10, 1000); % frequency range for plotting
ESD_plot = subs(ESD, w, 2*pi*f);
figure;
plot(f, ESD_plot);
title('Energy Spectral Density (ESD)');
xlabel('Frequency (Hz)');
ylabel('ESD');
grid on;
[maxESD, maxESDidx] = max(ESD_plot);
[~, halfidx] = min( abs(ESD_plot(1:maxESDidx) - maxESD/2) );
f_3dB = double(ESD_plot(halfidx));
disp(['3 dB Bandwidth: ', num2str(2*f_3dB)]);
0 Comments
More Answers (0)
See Also
Categories
Find more on Calculus in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!