⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 striplot.m

📁 文件中包含"基于计算机的信号处理实践"这本书所有的程序代码,是基于MATLAB环境下开发的,使用者可根据自已的需要,改改!
💻 M
字号:
function hp = striplot(x, fs, n, ntick, xmax)%STRIPLOT    plot long signal in horizontal strips     %-------      ( good for multi-line speech wfms )%%  Usage:  HP = striplot(X, FS, N)%%             plots waveform X with N pts/line. ALL traces %               are auto-scaled to the max signal value%%        FS :  sampling rate (Hertz); used only for labeling%        HP :  the graphics handle for the plot.%%    striplot(X, FS, N, NTICK)%                    puts markers every NTICK samples%    striplot(X, FS, N, NT, XMAX)%                  uses XMAX as the value for scaling%%   NOTE: the x-axis is always labeled with (time) indices.%         the y-axis labels are NOT AMPLITUDE, rather they%         are the INDEX OFFSET to the start of each row.%%   see also STRIPS in Sig Proc Toolbox version 3%---------------------------------------------------------------% copyright 1994, by C.S. Burrus, J.H. McClellan, A.V. Oppenheim,% T.W. Parks, R.W. Schafer, & H.W. Schussler.  For use with the book% "Computer-Based Exercises for Signal Processing Using MATLAB"% (Prentice-Hall, 1994).%---------------------------------------------------------------x = x(:);x = x/max(abs(x));	%% <-- normalize sample amplitudeif nargin < 5  xmax = max(abs(x));      %% <-- default scalingendif nargin < 4  ntick = 0;endif nargin < 3  n = 400;        %% default:  50 msec @ 8 kHzendlenx = length(x);nrows = ceil(lenx/n);if lenx < n*nrows   x(n*nrows) = 0;        %% <--- need to zero pad   lenx = n*nrows;enddel_t = 1/fs;yscale = -n*del_t;zeroy = yscale*[1;1]*[0:(nrows-1)];half = 0.50;offsets = (half*yscale)*[1;1]*ones(1,nrows);sepy = [(zeroy-offsets) (zeroy(:,nrows)+(half*yscale)*[1;1])];if ntick > 0    nnt   = [0:ntick:(lenx-1)];   xtick = del_t*[1;1]*rem(nnt,n);   ytick = yscale*( [1;1]*(fix(nnt/n)) + half*[1;-1]*ones(size(nnt)));else   xtick = 0; ytick = 0;endif xmax < 1		%% to prevent overlap of plots  xmax = 1endscale = half/xmax;x = reshape( x, n, nrows );for i = 1:nrows   x(:,i) = -yscale*scale*x(:,i) + yscale*(i-1);endends = del_t*[0;n-1];h = plot( del_t*[0:(n-1)], x, '-w',  ends, sepy, ':w',...      ends, zeroy, '--w', xtick, ytick, ':w' );axis( [ ends'  [(nrows-0.5) -0.5]*yscale ] );if( nargout>0 )  hp = h;end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -