view m-toolbox/m/gui/specwin_viewer/ltpda_specwin_viewer_build_window.m @ 42:f90d4f666cc7 database-connection-manager

Cleanup
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Mon, 05 Dec 2011 18:04:34 +0100
parents f0afece42f48
children
line wrap: on
line source

function ltpda_specwin_viewer_build_window(varargin)
% Function to build the window and display it.

plotType = varargin{end};

mainfig = findobj('Tag', 'LTPDAspecwin_viewer');
ax      = getappdata(mainfig, 'axes');
info    = findobj('Tag', 'LTPDA_specwin_viewer_wininfo');

% get window type
winTxt = findobj('Tag', 'LTPDA_specwin_viewer_WinType');
wins   = get(winTxt, 'String');
win    = wins{get(winTxt, 'Value')};

% Get window size
sizeTxt = findobj('Tag', 'LTPDA_specwin_viewer_WinSize');
winlen  = str2num(get(sizeTxt, 'String'));

if strcmpi(win, 'Kaiser')
  % get psll
  psllTxt = findobj('Tag', 'LTPDA_specwin_viewer_PSLL');
  psll    = str2num(get(psllTxt, 'String'));  
  w = specwin(win, winlen, psll);  
  cstr = sprintf('specwin(''%s'', %d, %f)', win, winlen, psll);
else  
  w = specwin(win, winlen);
  cstr = sprintf('specwin(''%s'', %d)', win, winlen);
end

consTxt = findobj(mainfig, 'Tag', 'LTPDA_specwin_viewer_cstr');
set(consTxt, 'String', cstr);


titleStr  = '';
legendStr = '';

switch plotType
  case 'Time-domain'
    hl = plot(ax, 1:length(w.win), w.win);
    xlabel('sample');
    ylabel('amplitude');
  case 'Freq-domain'
    % Freq response
    f = linspace(-30,30,1000);
    r = zeros(size(f));
    N = length(w.win);

    % do dft
    for j=1:length(f)
      k = [0:N-1].';
      r(j) = (w.win * exp(-2*pi*1i*f(j)*k/N) )./w.ws;
    end

    % convert to dB
    dbr = 20*log10(abs(r));    hl = plot(ax, f, dbr);
    xlabel('bin');
    ylabel('amplitude [dB]');
end

col = [0.8 0.1 0.1];
set(hl, 'Color', col);
titleStr = [titleStr, utils.plottools.label(w.type), ', '];
titleStr = titleStr(1:end-2);
title(sprintf('Window: %s', titleStr));
axis tight
grid on


% Info string
lstr = [sprintf('alpha = %g\n', w.alpha)...
  sprintf('psll = %g\n', w.psll)...
  sprintf('rov = %g\n', w.rov)...
  sprintf('nenbw = %g\n', w.nenbw)...
  sprintf('w3db = %g\n', w.w3db)...
  sprintf('flatness = %g\n', w.flatness)];
legendStr = [legendStr cellstr(lstr)];
set(info, 'String', legendStr);

% Constructor