How to plot spectrogram on Matlab App Designer with UIAxes?

58 views (last 30 days)
Hello, I'm trying to use spectrogram function to plot spectrogram with Matlab App Designer, not the old GUI. This means I got uifigures and uiaxes, not figure and axes in the old GUI system. There are some answers about using spectrogram function in the old GUI system, which are using axes() function to set current axes, unfortunately, I haven't seen something about using spectrogram function in App Designer, can anyone help, plz?
  1 Comment
a bc
a bc on 26 Nov 2017
TO make this clear, I try to use the Matlab spectrogram function in App Designer to plot spectrogram
s=spectrogram(x)
The keypoint is use this function to plot with UIFigures and UIAxes. I hope it's clear now. Any advice will be appreciated!

Sign in to comment.

Accepted Answer

Birdman
Birdman on 26 Nov 2017
Edited: Birdman on 26 Nov 2017
Imagine you have a 2D axes and you hold it in a variable:
axesSpec=app.UIAxes;
Then, I assume that you already obtain the output of spectrogram, and which actually means the psd of a signal, you need to plot it on a semilogx plot. Consider the following notation(assume that y and f are the outputs and frequency for the signal respectively):
axesSpec.XScale='log';
plot(axesSpec,f,y);
This notation should do it. Hope I am clear.
  8 Comments
Jan Kuttruff
Jan Kuttruff on 12 Apr 2018
Hello, I also try to plot my spectrogram into my App like your ideal_result.png . I have tried to understand the code lines of Birdman but I don't get it how to get it right for the result like the ideal_result. Can you show how you have done it?
a bc
a bc on 13 Apr 2018
Edited: a bc on 13 Apr 2018
Hi Jan
If you use the new MATLAB App Designer to build your App, I can't find the solution to draw spectrogram like ideal_result.png till the time I raised the question. So finally I switched to the old GUI tool to build my App and draw ideal_result.png successfully. Since the new MATLAB App Designer is far from mature, I recommend you to use the old GUI tool for full functionality for now.
If so, refer to my_github_project for the implemention detail on the old GUI tool.

Sign in to comment.

More Answers (1)

John
John on 12 May 2021
Edited: John on 12 May 2021
Please see below for an update using AppDesigner - Using 2021a
Requires signal processing toolbox - but spectrogram outputs should be similar to pspectrum outputs
% dimensions of app.dat2plot = [1 2886144]
% Sampling frequency is 4kHz
[S,F,T] = pspectrum(transpose(app.dat2plot),4000,'spectrogram', 'FrequencyLimits',[0 50],'MinThreshold',-110);
imagesc(app.UIAxes2, T, flipud(F), rot90(log(abs(S')))); %plot the log spectrum
set(app.UIAxes2,'YDir', 'normal'); % flip the Y Axis
Outputs image below in AppDesigner
  1 Comment
Andrew Cline
Andrew Cline on 1 Dec 2022
Thanks for this answer. Never would have figured this out myself.
Also, you can do this afterwards to fit it to the window
axis(app.UIAxes2,'tight')

Sign in to comment.

Products

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!