www.gusucode.com > 声音的处理有:LPC,FFT,共振峰,频谱源码程序 > siganlandsystemusingMatlab/SSUM/filters/pzfilter/pzfilterexpogui.m

    function varargout = pzfilterexpogui(varargin)
% PZFILTEREXPOGUI M-file for pzfilterexpogui.fig
%      PZFILTEREXPOGUI, by itself, creates a new PZFILTEREXPOGUI or raises the existing
%      singleton*.
%
%      H = PZFILTEREXPOGUI returns the handle to a new PZFILTEREXPOGUI or the handle to
%      the existing singleton*.
%
%      PZFILTEREXPOGUI('CALLBACK',hObject,eventData,handles,...) calls the local
%      function named CALLBACK in PZFILTEREXPOGUI.M with the given input arguments.
%
%      PZFILTEREXPOGUI('Property','Value',...) creates a new PZFILTEREXPOGUI or raises the
%      existing singleton*.  Starting from the left, property value pairs are
%      applied to the GUI before pzfilterexpogui_OpeningFunction gets called.  An
%      unrecognized property name or invalid value makes property application
%      stop.  All inputs are passed to pzfilterexpogui_OpeningFcn via varargin.
%
%      *See GUI Options on GUIDE's Tools menu.  Choose "GUI allows only one
%      instance to run (singleton)".
%
% See also: GUIDE, GUIDATA, GUIHANDLES

% Edit the above text to modify the response to help pzfilterexpogui

% Last Modified by GUIDE v2.5 04-Aug-2004 22:05:11

% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct('gui_Name',       mfilename, ...
                   'gui_Singleton',  gui_Singleton, ...
                   'gui_OpeningFcn', @pzfilterexpogui_OpeningFcn, ...
                   'gui_OutputFcn',  @pzfilterexpogui_OutputFcn, ...
                   'gui_LayoutFcn',  @pzfilterexpogui_LayoutFcn, ...
                   'gui_Callback',   []);
if nargin & isstr(varargin{1})
    gui_State.gui_Callback = str2func(varargin{1});
end

if nargout
    [varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});
else
    gui_mainfcn(gui_State, varargin{:});
end

% End initialization code - DO NOT EDIT

% --- Executes just before pzfilterexpogui is made visible.
function pzfilterexpogui_OpeningFcn(hObject, eventdata, handles, varargin)
% This function has no output args, see OutputFcn.
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
% varargin   command line arguments to pzfilterexpogui (see VARARGIN)

% Choose default command line output for pzfilterexpogui
	handles.output = hObject;
	guidata(hObject, handles);
	set(gcf,'UserData',handles);
	pzfilterexpofn;

if (nargin > 3)
    datastruct = varargin{1};
    pzfilterexpofn('readinput',datastruct);
end

% --- Outputs from this function are returned to the command line.
function varargout = pzfilterexpogui_OutputFcn(hObject, eventdata, handles)
	varargout{1} = handles.output;


% --------------------------------------------------------------------
function FileMenu_Callback(hObject, eventdata, handles)


% --------------------------------------------------------------------
function OpenMenuItem_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'loadsound';

% --------------------------------------------------------------------
function PrintMenuItem_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'print';

% --------------------------------------------------------------------
function CloseMenuItem_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'close';

% --- Executes on button press in zoomin.
function zoomin_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'zoomin';

% --- Executes on button press in zoomout.
function zoomout_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'zoomout';

% --- Executes on button press in play.
function play_Callback(hObject, eventdata, handles)
    pzfilterexpofn 'playsound';

% --- Executes on button press in dBcheckbox.
function dBcheckbox_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'db';

% --- Executes during object creation, after setting all properties.
function fftsize_CreateFcn(hObject, eventdata, handles)
if ispc
    set(hObject,'BackgroundColor','white');
else
    set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor'));
end

% --- Executes on selection change in fftsize.
function fftsize_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'fftsize';

% --- Executes during object creation, after setting all properties.
function Window_CreateFcn(hObject, eventdata, handles)
if ispc
    set(hObject,'BackgroundColor','white');
else
    set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor'));
end


% --- Executes on selection change in Window.
function Window_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'window';

% --- Executes during object creation, after setting all properties.
function colormap_CreateFcn(hObject, eventdata, handles)
if ispc
    set(hObject,'BackgroundColor','white');
else
    set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor'));
end


% --- Executes on selection change in colormap.
function colormap_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'colormap';

% --- Executes on button press in inverse.
function inverse_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'inverse';

% --- Executes on button press in interpolate.
function interpolate_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'interpolate';

% --- Executes on button press in playoriginal.
function playoriginal_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'playoriginal';

% --- Executes on button press in print.
function print_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'print';


% --- Executes on button press in plotfreqz.
function plotfreqz_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'plotfreqz';


% --- Executes during object creation, after setting all properties.
function fftdisplay_CreateFcn(hObject, eventdata, handles)
if ispc
    set(hObject,'BackgroundColor','white');
else
    set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor'));
end


% --- Executes on selection change in fftdisplay.
function fftdisplay_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'fftdisplay';

% --- Executes on button press in doFilter.
function doFilter_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'apply_filter';

% --- Executes on button press in undo.
function undo_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'undo';

% --- Executes on button press in addzero.
function addzero_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'addzero';

% --- Executes on button press in addpole.
function addpole_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'addpole';


% --- Executes on button press in Hz_logf.
function Hz_logf_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'Hz_logf';


% --------------------------------------------------------------------
function help_Callback(hObject, eventdata, handles)
	pzfilterexpofn 'help';


% --------------------------------------------------------------------
function Untitled_1_Callback(hObject, eventdata, handles)
% hObject    handle to Untitled_1 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)


% --------------------------------------------------------------------
function Untitled_2_Callback(hObject, eventdata, handles)
% hObject    handle to Untitled_2 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)


% --------------------------------------------------------------------
function beet_Callback(hObject, eventdata, handles)
% hObject    handle to beet (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel','beet');


% --------------------------------------------------------------------
function bit_Callback(hObject, eventdata, handles)
% hObject    handle to bit (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel', 'bit');


% --------------------------------------------------------------------
function bet_Callback(hObject, eventdata, handles)
% hObject    handle to bet (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel', 'bet');


% --------------------------------------------------------------------
function bat_Callback(hObject, eventdata, handles)
% hObject    handle to bat (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel', 'bat');


% --------------------------------------------------------------------
function bart_Callback(hObject, eventdata, handles)
% hObject    handle to bart (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel', 'bart');


% --------------------------------------------------------------------
function bort_Callback(hObject, eventdata, handles)
% hObject    handle to bort (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel', 'bort');


% --------------------------------------------------------------------
function but_Callback(hObject, eventdata, handles)
% hObject    handle to but (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel', 'but');


% --------------------------------------------------------------------
function boot_Callback(hObject, eventdata, handles)
% hObject    handle to boot (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel', 'boot');


% --------------------------------------------------------------------
function bert_Callback(hObject, eventdata, handles)
% hObject    handle to bert (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn('loadvowel', 'bert');


% --- Executes during object creation, after setting all properties.
function freqzoom_CreateFcn(hObject, eventdata, handles)
% hObject    handle to freqzoom (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    empty - handles not created until after all CreateFcns called

% Hint: slider controls usually have a light gray background, change
%       'usewhitebg' to 0 to use default.  See ISPC and COMPUTER.
usewhitebg = 1;
if usewhitebg
    set(hObject,'BackgroundColor',[.9 .9 .9]);
else
    set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor'));
end


% --- Executes on slider movement.
function freqzoom_Callback(hObject, eventdata, handles)
% hObject    handle to freqzoom (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)

% Hints: get(hObject,'Value') returns position of slider
%        get(hObject,'Min') and get(hObject,'Max') to determine range of slider
	pzfilterexpofn 'freqzoom';


% --- Executes on button press in zoomreset.
function zoomreset_Callback(hObject, eventdata, handles)
% hObject    handle to zoomreset (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
    pzfilterexpofn 'zoomreset';


% --------------------------------------------------------------------
function save_Callback(hObject, eventdata, handles)
% hObject    handle to save (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
    pzfilterexpofn 'save';


% --------------------------------------------------------------------
function Untitled_3_Callback(hObject, eventdata, handles)
% hObject    handle to Untitled_3 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)


% --------------------------------------------------------------------
function pzexpo_Callback(hObject, eventdata, handles)
% hObject    handle to pzexpo (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn 'pzexpo';


% --- Executes on button press in normalize.
function normalize_Callback(hObject, eventdata, handles)
% hObject    handle to normalize (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn 'normalize';


% --------------------------------------------------------------------
function Untitled_4_Callback(hObject, eventdata, handles)
% hObject    handle to Untitled_4 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)


% --------------------------------------------------------------------
function fourier_Callback(hObject, eventdata, handles)
% hObject    handle to fourier (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn 'fourier';


% --------------------------------------------------------------------
function convexpo_Callback(hObject, eventdata, handles)
% hObject    handle to convexpo (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
	pzfilterexpofn 'convexpo';


% --- Executes on button press in dB.
function dB_Callback(hObject, eventdata, handles)
% hObject    handle to dB (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)

% Hint: get(hObject,'Value') returns toggle state of dB
    pzfilterexpofn 'Hz_dB';

% --- Executes during object creation, after setting all properties.
function gain_CreateFcn(hObject, eventdata, handles)
% hObject    handle to gain (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    empty - handles not created until after all CreateFcns called

% Hint: edit controls usually have a white background on Windows.
%       See ISPC and COMPUTER.
if ispc
    set(hObject,'BackgroundColor','white');
else
    set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor'));
end



function gain_Callback(hObject, eventdata, handles)
% hObject    handle to gain (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)

% Hints: get(hObject,'String') returns contents of gain as text
%        str2double(get(hObject,'String')) returns contents of gain as a double
    val = str2num(get(hObject,'String'));
    val = abs(val);
    set(hObject,'String',num2str(val));
    pzfilterexpofn 'plotfreqz';



% --- Creates and returns a handle to the GUI figure. 
function h1 = pzfilterexpogui_LayoutFcn(policy)
% policy - create a new figure or use a singleton. 'new' or 'reuse'.

persistent hsingleton;
if strcmpi(policy, 'reuse') & ishandle(hsingleton)
    h1 = hsingleton;
    return;
end

h1 = figure(...
'Units','characters',...
'Color',[0.925490196078431 0.913725490196078 0.847058823529412],...
'Colormap',[0 0 0.5625;0 0 0.625;0 0 0.6875;0 0 0.75;0 0 0.8125;0 0 0.875;0 0 0.9375;0 0 1;0 0.0625 1;0 0.125 1;0 0.1875 1;0 0.25 1;0 0.3125 1;0 0.375 1;0 0.4375 1;0 0.5 1;0 0.5625 1;0 0.625 1;0 0.6875 1;0 0.75 1;0 0.8125 1;0 0.875 1;0 0.9375 1;0 1 1;0.0625 1 1;0.125 1 0.9375;0.1875 1 0.875;0.25 1 0.8125;0.3125 1 0.75;0.375 1 0.6875;0.4375 1 0.625;0.5 1 0.5625;0.5625 1 0.5;0.625 1 0.4375;0.6875 1 0.375;0.75 1 0.3125;0.8125 1 0.25;0.875 1 0.1875;0.9375 1 0.125;1 1 0.0625;1 1 0;1 0.9375 0;1 0.875 0;1 0.8125 0;1 0.75 0;1 0.6875 0;1 0.625 0;1 0.5625 0;1 0.5 0;1 0.4375 0;1 0.375 0;1 0.3125 0;1 0.25 0;1 0.1875 0;1 0.125 0;1 0.0625 0;1 0 0;0.9375 0 0;0.875 0 0;0.8125 0 0;0.75 0 0;0.6875 0 0;0.625 0 0;0.5625 0 0],...
'IntegerHandle','off',...
'InvertHardcopy',get(0,'defaultfigureInvertHardcopy'),...
'MenuBar','none',...
'Name','pzfilterexpo',...
'NumberTitle','off',...
'PaperOrientation','landscape',...
'PaperPosition',get(0,'defaultfigurePaperPosition'),...
'PaperSize',[11 8.5],...
'Pointer','crosshair',...
'Position',[61 3 200 51.8461538461538],...
'Renderer',get(0,'defaultfigureRenderer'),...
'RendererMode','manual',...
'HandleVisibility','callback',...
'Tag','pzfilterexpo_fig',...
'UserData',zeros(1,0));

setappdata(h1, 'GUIDEOptions', struct(...
'active_h', [], ...
'taginfo', struct(...
'figure', 2, ...
'axes', 8, ...
'pushbutton', 15, ...
'popupmenu', 8, ...
'listbox', 2, ...
'text', 16, ...
'slider', 3, ...
'checkbox', 6, ...
'radiobutton', 5, ...
'frame', 2, ...
'edit', 5), ...
'override', 1, ...
'release', 13, ...
'resize', 'simple', ...
'accessibility', 'callback', ...
'mfile', 1, ...
'callbacks', 1, ...
'singleton', 1, ...
'syscolorfig', 1, ...
'lastSavedFile', 'C:\Documents and Settings\Bob\Desktop\SSUM_WIN\filters\pzfilter\pzfilterexpo.m', ...
'blocking', 0));


h2 = uimenu(...
'Parent',h1,...
'Callback','pzfilterexpogui(''FileMenu_Callback'',gcbo,[],guidata(gcbo))',...
'Label','File',...
'Tag','FileMenu');

h3 = uimenu(...
'Parent',h2,...
'Callback','pzfilterexpogui(''OpenMenuItem_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Open ...',...
'Tag','OpenMenuItem');

h4 = uimenu(...
'Parent',h2,...
'Callback','pzfilterexpogui(''save_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Save',...
'Tag','save');

h5 = uimenu(...
'Parent',h2,...
'Callback','pzfilterexpogui(''PrintMenuItem_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Print ...',...
'Tag','PrintMenuItem');

h6 = uimenu(...
'Parent',h2,...
'Callback','pzfilterexpogui(''CloseMenuItem_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Close',...
'Separator','on',...
'Tag','CloseMenuItem');

h7 = axes(...
'Parent',h1,...
'Units','characters',...
'ALim',get(0,'defaultaxesALim'),...
'ALimMode','manual',...
'CameraPosition',[0.5 0.5 9.16025403784439],...
'CameraPositionMode','manual',...
'CameraTarget',[0.5 0.5 0.5],...
'CameraTargetMode','manual',...
'CameraUpVector',[0 1 0],...
'CameraUpVectorMode','manual',...
'CameraViewAngle',6.60861036031192,...
'CameraViewAngleMode','manual',...
'CLim',get(0,'defaultaxesCLim'),...
'CLimMode','manual',...
'Color',get(0,'defaultaxesColor'),...
'ColorOrder',get(0,'defaultaxesColorOrder'),...
'DataAspectRatio',get(0,'defaultaxesDataAspectRatio'),...
'DataAspectRatioMode','manual',...
'DrawMode','fast',...
'PlotBoxAspectRatio',get(0,'defaultaxesPlotBoxAspectRatio'),...
'PlotBoxAspectRatioMode','manual',...
'Position',[6.6485084306096 3.31369661266568 108.793774319066 14.7459499263623],...
'TickDir',get(0,'defaultaxesTickDir'),...
'TickDirMode','manual',...
'XColor',get(0,'defaultaxesXColor'),...
'XLim',get(0,'defaultaxesXLim'),...
'XLimMode','manual',...
'XTick',[0 0.2 0.4 0.6 0.8 1],...
'XTickLabel',{ '0  ' '0.2' '0.4' '0.6' '0.8' '1  ' },...
'XTickLabelMode','manual',...
'XTickMode','manual',...
'YColor',get(0,'defaultaxesYColor'),...
'YLim',get(0,'defaultaxesYLim'),...
'YLimMode','manual',...
'YTick',[0 0.2 0.4 0.6 0.8 1],...
'YTickLabel',{ '0  ' '0.2' '0.4' '0.6' '0.8' '1  ' },...
'YTickLabelMode','manual',...
'YTickMode','manual',...
'ZColor',get(0,'defaultaxesZColor'),...
'ZLim',get(0,'defaultaxesZLim'),...
'ZLimMode','manual',...
'ZTick',[0 0.5 1],...
'ZTickLabel','',...
'ZTickLabelMode','manual',...
'ZTickMode','manual',...
'Tag','timeplot',...
'UserData',zeros(1,0));


h8 = get(h7,'title');

set(h8,...
'Parent',h7,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[0.496575342465753 1.04452054794521 1.00005459937205],...
'VerticalAlignment','bottom',...
'HandleVisibility','off');

h9 = get(h7,'xlabel');

set(h9,...
'Parent',h7,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[0.496575342465753 -0.160958904109589 1.00005459937205],...
'VerticalAlignment','cap',...
'HandleVisibility','off');

h10 = get(h7,'ylabel');

set(h10,...
'Parent',h7,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[-0.195205479452055 0.48972602739726 1.00005459937205],...
'Rotation',90,...
'VerticalAlignment','bottom',...
'HandleVisibility','off');

h11 = get(h7,'zlabel');

set(h11,...
'Parent',h7,...
'Color',[0 0 0],...
'HorizontalAlignment','right',...
'Position',[-0.565068493150685 1.45547945205479 1.00005459937205],...
'HandleVisibility','off',...
'Visible','off');

h12 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'Callback','pzfilterexpogui(''dBcheckbox_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.694552529182879 0.19440353460972 0.0340466926070039 0.0279823269513991],...
'String','dB',...
'Style','checkbox',...
'Value',1,...
'Tag','dBcheckbox');


h13 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','pzfilterexpogui(''play_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[117.315953307393 4.51172538801405 10 1.5],...
'String','Play',...
'Tag','play');


h14 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'BackgroundColor',[1 1 1],...
'Callback','pzfilterexpogui(''fftsize_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.818093385214008 0.248895434462445 0.0846303501945525 0.0279823269513991],...
'String',{ '64' '128' '256' '512' '1024' '2048' '4096' '8192' '16384' '32768' },...
'Style','popupmenu',...
'Value',4,...
'CreateFcn','pzfilterexpogui(''fftsize_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','fftsize');


h15 = axes(...
'Parent',h1,...
'Units','characters',...
'ALim',get(0,'defaultaxesALim'),...
'ALimMode','manual',...
'CameraPosition',[0.5 0.5 9.16025403784439],...
'CameraPositionMode','manual',...
'CameraTarget',[0.5 0.5 0.5],...
'CameraTargetMode','manual',...
'CameraUpVector',[0 1 0],...
'CameraUpVectorMode','manual',...
'CameraViewAngle',6.60861036031192,...
'CameraViewAngleMode','manual',...
'CLim',get(0,'defaultaxesCLim'),...
'CLimMode','manual',...
'Color',get(0,'defaultaxesColor'),...
'ColorOrder',get(0,'defaultaxesColorOrder'),...
'DataAspectRatio',get(0,'defaultaxesDataAspectRatio'),...
'DataAspectRatioMode','manual',...
'PlotBoxAspectRatio',get(0,'defaultaxesPlotBoxAspectRatio'),...
'PlotBoxAspectRatioMode','manual',...
'Position',[6.6485084306096 18.970913107511 108.793774319066 30.8173784977909],...
'TickDir',get(0,'defaultaxesTickDir'),...
'TickDirMode','manual',...
'XColor',get(0,'defaultaxesXColor'),...
'XLim',get(0,'defaultaxesXLim'),...
'XLimMode','manual',...
'XTick',[0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1],...
'XTickLabel',{ '0  ' '0.1' '0.2' '0.3' '0.4' '0.5' '0.6' '0.7' '0.8' '0.9' '1  ' },...
'XTickLabelMode','manual',...
'XTickMode','manual',...
'YColor',get(0,'defaultaxesYColor'),...
'YLim',get(0,'defaultaxesYLim'),...
'YLimMode','manual',...
'YTick',[0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1],...
'YTickLabel',{ '0  ' '0.1' '0.2' '0.3' '0.4' '0.5' '0.6' '0.7' '0.8' '0.9' '1  ' },...
'YTickLabelMode','manual',...
'YTickMode','manual',...
'ZColor',get(0,'defaultaxesZColor'),...
'ZLim',get(0,'defaultaxesZLim'),...
'ZLimMode','manual',...
'ZTick',[0 0.5 1],...
'ZTickLabel','',...
'ZTickLabelMode','manual',...
'ZTickMode','manual',...
'Tag','specplot',...
'UserData',zeros(1,0));


h16 = get(h15,'title');

set(h16,...
'Parent',h15,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[0.497237569060773 1.0207182320442 1.00005459937205],...
'VerticalAlignment','bottom',...
'HandleVisibility','off');

h17 = get(h15,'xlabel');

set(h17,...
'Parent',h15,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[0.497237569060773 -0.0621546961325967 1.00005459937205],...
'VerticalAlignment','cap',...
'HandleVisibility','off');

h18 = get(h15,'ylabel');

set(h18,...
'Parent',h15,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[-0.0662983425414364 0.498618784530387 1.00005459937205],...
'Rotation',90,...
'VerticalAlignment','bottom',...
'HandleVisibility','off');

h19 = get(h15,'zlabel');

set(h19,...
'Parent',h15,...
'Color',[0 0 0],...
'HorizontalAlignment','right',...
'Position',[-0.397790055248619 1.03729281767956 1.00005459937205],...
'HandleVisibility','off',...
'Visible','off');

h20 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'BackgroundColor',[1 1 1],...
'Callback','pzfilterexpogui(''Window_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.724708171206226 0.248895434462445 0.0846303501945525 0.0279823269513991],...
'String',{ 'Hann' 'Rectangle' 'Triangle' 'Hamming' 'Kaiser' 'Bartlett' 'Blackman-Harris' 'Gaussian' },...
'Style','popupmenu',...
'Value',1,...
'CreateFcn','pzfilterexpogui(''Window_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','Window');


h21 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'BackgroundColor',[1 1 1],...
'Callback','pzfilterexpogui(''colormap_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.630350194552529 0.248895434462445 0.0846303501945525 0.0279823269513991],...
'String',{ 'Jet' 'Bone' 'HSV' 'Gray' 'Hot' 'Cool' },...
'Style','popupmenu',...
'Value',1,...
'CreateFcn','pzfilterexpogui(''colormap_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','colormap');


h22 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'Callback','pzfilterexpogui(''inverse_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.631322957198444 0.19440353460972 0.0583657587548638 0.0279823269513991],...
'String','Inverse',...
'Style','checkbox',...
'Tag','inverse');


h23 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'FontSize',12,...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[0.724708171206226 0.276877761413844 0.0700389105058366 0.03240058910162],...
'String','Window',...
'Style','text',...
'Tag','text4');


h24 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'FontSize',12,...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[0.821011673151751 0.276877761413844 0.0807392996108949 0.03240058910162],...
'String','FFT Size',...
'Style','text',...
'Tag','text5');


h25 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'FontSize',12,...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[0.631322957198444 0.276877761413844 0.0865758754863813 0.03240058910162],...
'String','Colormap',...
'Style','text',...
'Tag','text6');


h26 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'Callback','pzfilterexpogui(''interpolate_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.631322957198444 0.148748159057437 0.0700389105058366 0.0279823269513991],...
'String','Interpolate',...
'Style','checkbox',...
'Tag','interpolate');


h27 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','pzfilterexpogui(''playoriginal_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[128.014007782101 4.58819530984479 10 1.5],...
'String','Play',...
'Tag','playoriginal');


h28 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'FontAngle','italic',...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[0.718871595330739 0.150220913107511 0.190661478599222 0.0206185567010309],...
'String','WARNING: This could take a while.',...
'Style','text',...
'Tag','text9');


h29 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','pzfilterexpogui(''doFilter_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[127.8 17.0769230769231 10 1.46153846153846],...
'String','Apply',...
'Tag','doFilter');


h30 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','pzfilterexpogui(''undo_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[139.6 17.0769230769231 10 1.46153846153846],...
'String','Undo',...
'Tag','undo');


h31 = axes(...
'Parent',h1,...
'Units','characters',...
'ALim',get(0,'defaultaxesALim'),...
'ALimMode','manual',...
'CameraPosition',[0.5 0.5 9.16025403784439],...
'CameraPositionMode','manual',...
'CameraTarget',[0.5 0.5 0.5],...
'CameraTargetMode','manual',...
'CameraUpVector',[0 1 0],...
'CameraUpVectorMode','manual',...
'CameraViewAngle',6.60861036031192,...
'CameraViewAngleMode','manual',...
'CLim',get(0,'defaultaxesCLim'),...
'CLimMode','manual',...
'Color',get(0,'defaultaxesColor'),...
'ColorOrder',get(0,'defaultaxesColorOrder'),...
'DrawMode','fast',...
'Position',[145 33.6923076923077 52.8 18.0769230769231],...
'TickDir',get(0,'defaultaxesTickDir'),...
'TickDirMode','manual',...
'XColor',get(0,'defaultaxesXColor'),...
'XLim',get(0,'defaultaxesXLim'),...
'XLimMode','manual',...
'XTick',[0 0.2 0.4 0.6 0.8 1],...
'XTickLabel',{ '0  ' '0.2' '0.4' '0.6' '0.8' '1  ' },...
'XTickLabelMode','manual',...
'XTickMode','manual',...
'YColor',get(0,'defaultaxesYColor'),...
'YLim',get(0,'defaultaxesYLim'),...
'YLimMode','manual',...
'YTick',[0 0.2 0.4 0.6 0.8 1],...
'YTickLabel',{ '0  ' '0.2' '0.4' '0.6' '0.8' '1  ' },...
'YTickLabelMode','manual',...
'YTickMode','manual',...
'ZColor',get(0,'defaultaxesZColor'),...
'ZLim',get(0,'defaultaxesZLim'),...
'ZLimMode','manual',...
'ZTick',[0 0.5 1],...
'ZTickLabel','',...
'ZTickLabelMode','manual',...
'ZTickMode','manual',...
'Tag','pz_plot',...
'UserData',zeros(1,0));


h32 = get(h31,'title');

set(h32,...
'Parent',h31,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[0.495454545454545 1.025 1.00005459937205],...
'VerticalAlignment','bottom',...
'HandleVisibility','off');

h33 = get(h31,'xlabel');

set(h33,...
'Parent',h31,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[0.495454545454545 -0.0886363636363634 1.00005459937205],...
'VerticalAlignment','cap',...
'HandleVisibility','off');

h34 = get(h31,'ylabel');

set(h34,...
'Parent',h31,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[-0.109090909090909 0.493181818181818 1.00005459937205],...
'Rotation',90,...
'VerticalAlignment','bottom',...
'HandleVisibility','off');

h35 = get(h31,'zlabel');

set(h35,...
'Parent',h31,...
'Color',[0 0 0],...
'HorizontalAlignment','right',...
'Position',[-3.58636363636364 1.00227272727273 1.00005459937205],...
'HandleVisibility','off',...
'Visible','off');

h36 = axes(...
'Parent',h1,...
'Units','characters',...
'ALim',get(0,'defaultaxesALim'),...
'ALimMode','manual',...
'CameraPosition',[0.5 0.5 9.16025403784439],...
'CameraPositionMode','manual',...
'CameraTarget',[0.5 0.5 0.5],...
'CameraTargetMode','manual',...
'CameraUpVector',[0 1 0],...
'CameraUpVectorMode','manual',...
'CameraViewAngle',6.60861036031192,...
'CameraViewAngleMode','manual',...
'CLim',get(0,'defaultaxesCLim'),...
'CLimMode','manual',...
'Color',get(0,'defaultaxesColor'),...
'ColorOrder',get(0,'defaultaxesColorOrder'),...
'DrawMode','fast',...
'Position',[139.8 21.7692307692308 58.2 12.0769230769231],...
'TickDir',get(0,'defaultaxesTickDir'),...
'TickDirMode','manual',...
'XColor',get(0,'defaultaxesXColor'),...
'XLim',get(0,'defaultaxesXLim'),...
'XLimMode','manual',...
'XTick',[0 0.2 0.4 0.6 0.8 1],...
'XTickLabel',{ '0  ' '0.2' '0.4' '0.6' '0.8' '1  ' },...
'XTickLabelMode','manual',...
'XTickMode','manual',...
'YColor',get(0,'defaultaxesYColor'),...
'YLim',[-80 0],...
'YLimMode','manual',...
'YTick',[0 0.2 0.4 0.6 0.8 1],...
'YTickLabel',{ '0  ' '0.2' '0.4' '0.6' '0.8' '1  ' },...
'YTickLabelMode','manual',...
'YTickMode','manual',...
'ZColor',get(0,'defaultaxesZColor'),...
'ZLim',get(0,'defaultaxesZLim'),...
'ZLimMode','manual',...
'ZTick',[0 0.5 1],...
'ZTickLabel','',...
'ZTickLabelMode','manual',...
'ZTickMode','manual',...
'Tag','Hz_plot',...
'UserData',zeros(1,0));


h37 = get(h36,'title');

set(h37,...
'Parent',h36,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[0.49645390070922 2.76950354609929 1.00005459937205],...
'VerticalAlignment','bottom',...
'HandleVisibility','off');

h38 = get(h36,'xlabel');

set(h38,...
'Parent',h36,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[0.49645390070922 -91.4148936170212 1.00005459937205],...
'VerticalAlignment','cap',...
'HandleVisibility','off');

h39 = get(h36,'ylabel');

set(h39,...
'Parent',h36,...
'Color',[0 0 0],...
'HorizontalAlignment','center',...
'Position',[-0.148936170212766 -40.3510638297872 1.00005459937205],...
'Rotation',90,...
'VerticalAlignment','bottom',...
'HandleVisibility','off');

h40 = get(h36,'zlabel');

set(h40,...
'Parent',h36,...
'Color',[0 0 0],...
'HorizontalAlignment','right',...
'Position',[-5.80851063829787 161.63475177305 1.00005459937205],...
'HandleVisibility','off',...
'Visible','off');

h41 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','pzfilterexpogui(''addzero_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[137.080155642023 47.1054718477399 10 1.5],...
'String','Add Zero',...
'Tag','addzero');


h42 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','pzfilterexpogui(''addpole_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[137.080155642023 44.5819644273252 10 1.5],...
'String','Add Pole',...
'Tag','addpole');


h43 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'Callback','pzfilterexpogui(''Hz_logf_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.9 0.329376854599407 0.058 0.0267062314540059],...
'String','Log(f)',...
'Style','checkbox',...
'Tag','Hz_logf');


h44 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[0.629377431906615 0.114874815905744 0.0486381322957199 0.0279823269513991],...
'String','Filtered',...
'Style','text',...
'Tag','text13');


h45 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[0.687418936446174 0.114874815905744 0.0486381322957199 0.0271232204221895],...
'String','Original',...
'Style','text',...
'Tag','text14');


h46 = uimenu(...
'Parent',h1,...
'Callback','pzfilterexpogui(''Untitled_1_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Load',...
'Tag','Untitled_1');

h47 = uimenu(...
'Parent',h46,...
'Callback','pzfilterexpogui(''Untitled_2_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Vowels',...
'Tag','Untitled_2');

h48 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''beet_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bEEt',...
'Tag','beet');

h49 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''bit_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bIt',...
'Tag','bit');

h50 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''bet_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bEt',...
'Tag','bet');

h51 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''bat_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bAt',...
'Tag','bat');

h52 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''bart_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bARt',...
'Tag','bart');

h53 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''bort_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bORt',...
'Tag','bort');

h54 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''but_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bUt',...
'Tag','but');

h55 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''boot_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bOOt',...
'Tag','boot');

h56 = uimenu(...
'Parent',h47,...
'Callback','pzfilterexpogui(''bert_Callback'',gcbo,[],guidata(gcbo))',...
'Label','bERt',...
'Tag','bert');

h57 = uimenu(...
'Parent',h1,...
'Callback','pzfilterexpogui(''Untitled_3_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Send Filter to...',...
'Tag','Untitled_3');

h58 = uimenu(...
'Parent',h57,...
'Callback','pzfilterexpogui(''pzexpo_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Pole-Zero Explorer',...
'Tag','pzexpo');

h59 = uimenu(...
'Parent',h57,...
'Callback','pzfilterexpogui(''convexpo_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Convolution Explorer',...
'Tag','convexpo');

h60 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'BackgroundColor',[0.9 0.9 0.9],...
'Callback','pzfilterexpogui(''freqzoom_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.00162127107652399 0.366961217476681 0.010538261997406 0.593519882179676],...
'String',{ '' },...
'Style','slider',...
'Value',1,...
'CreateFcn','pzfilterexpogui(''freqzoom_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','freqzoom');


h61 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','pzfilterexpogui(''zoomreset_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[139.437354085603 4.51172538801405 13 1.5],...
'String','Zoom Reset',...
'Tag','zoomreset');


h62 = uimenu(...
'Parent',h1,...
'Callback','pzfilterexpogui(''Untitled_4_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Send Data to...',...
'Tag','Untitled_4');

h63 = uimenu(...
'Parent',h62,...
'Callback','pzfilterexpogui(''fourier_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Fourier Explorer',...
'Tag','fourier');

h64 = uimenu(...
'Parent',h1,...
'Callback','pzfilterexpogui(''help_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Help',...
'Tag','help');

h65 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','pzfilterexpogui(''normalize_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[117.406614785992 2.5681148748159 13 1.5],...
'String','Normalize',...
'Tag','normalize');


h66 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'Callback','pzfilterexpogui(''dB_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.962 0.329376854599407 0.038 0.0267062314540059],...
'String','dB',...
'Style','checkbox',...
'Tag','dB');


h67 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'FontSize',10,...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[0.815 0.333827893175074 0.029 0.0207715133531157],...
'String','Gain',...
'Style','text',...
'Tag','text15');


h68 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'BackgroundColor',[1 1 1],...
'Callback','pzfilterexpogui(''gain_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.848 0.329376854599407 0.038 0.0267062314540059],...
'String','1',...
'Style','edit',...
'CreateFcn','pzfilterexpogui(''gain_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','gain');



hsingleton = h1;


% --- Handles default GUIDE GUI creation and callback dispatch
function varargout = gui_mainfcn(gui_State, varargin)


%   GUI_MAINFCN provides these command line APIs for dealing with GUIs
%
%      PZFILTEREXPOGUI, by itself, creates a new PZFILTEREXPOGUI or raises the existing
%      singleton*.
%
%      H = PZFILTEREXPOGUI returns the handle to a new PZFILTEREXPOGUI or the handle to
%      the existing singleton*.
%
%      PZFILTEREXPOGUI('CALLBACK',hObject,eventData,handles,...) calls the local
%      function named CALLBACK in PZFILTEREXPOGUI.M with the given input arguments.
%
%      PZFILTEREXPOGUI('Property','Value',...) creates a new PZFILTEREXPOGUI or raises the
%      existing singleton*.  Starting from the left, property value pairs are
%      applied to the GUI before untitled_OpeningFunction gets called.  An
%      unrecognized property name or invalid value makes property application
%      stop.  All inputs are passed to untitled_OpeningFcn via varargin.
%
%      *See GUI Options on GUIDE's Tools menu.  Choose "GUI allows only one
%      instance to run (singleton)".

%   Copyright 1984-2002 The MathWorks, Inc.
%   $Revision: 1.4 $ $Date: 2002/05/31 21:44:31 $

gui_StateFields =  {'gui_Name'
                    'gui_Singleton'
                    'gui_OpeningFcn'
                    'gui_OutputFcn'
                    'gui_LayoutFcn'
                    'gui_Callback'};
gui_Mfile = '';
for i=1:length(gui_StateFields)
    if ~isfield(gui_State, gui_StateFields{i})
        error('Could not find field %s in the gui_State struct in GUI M-file %s', gui_StateFields{i}, gui_Mfile);        
    elseif isequal(gui_StateFields{i}, 'gui_Name')
        gui_Mfile = [getfield(gui_State, gui_StateFields{i}), '.m'];
    end
end

numargin = length(varargin);

if numargin == 0
    % PZFILTEREXPOGUI
    % create the GUI
    gui_Create = 1;
elseif numargin > 3 & ischar(varargin{1}) & ishandle(varargin{2})
    % PZFILTEREXPOGUI('CALLBACK',hObject,eventData,handles,...)
    gui_Create = 0;
else
    % PZFILTEREXPOGUI(...)
    % create the GUI and hand varargin to the openingfcn
    gui_Create = 1;
end

if gui_Create == 0
    varargin{1} = gui_State.gui_Callback;
    if nargout
        [varargout{1:nargout}] = feval(varargin{:});
    else
        feval(varargin{:});
    end
else
    if gui_State.gui_Singleton
        gui_SingletonOpt = 'reuse';
    else
        gui_SingletonOpt = 'new';
    end
    
    % Open fig file with stored settings.  Note: This executes all component
    % specific CreateFunctions with an empty HANDLES structure.
    
    % Do feval on layout code in m-file if it exists
    if ~isempty(gui_State.gui_LayoutFcn)
        gui_hFigure = feval(gui_State.gui_LayoutFcn, gui_SingletonOpt);
    else
        gui_hFigure = local_openfig(gui_State.gui_Name, gui_SingletonOpt);            
        % If the figure has InGUIInitialization it was not completely created
        % on the last pass.  Delete this handle and try again.
        if isappdata(gui_hFigure, 'InGUIInitialization')
            delete(gui_hFigure);
            gui_hFigure = local_openfig(gui_State.gui_Name, gui_SingletonOpt);            
        end
    end
    
    % Set flag to indicate starting GUI initialization
    setappdata(gui_hFigure,'InGUIInitialization',1);

    % Fetch GUIDE Application options
    gui_Options = getappdata(gui_hFigure,'GUIDEOptions');
    
    if ~isappdata(gui_hFigure,'GUIOnScreen')
        % Adjust background color
        if gui_Options.syscolorfig 
            set(gui_hFigure,'Color', get(0,'DefaultUicontrolBackgroundColor'));
        end

        % Generate HANDLES structure and store with GUIDATA
        guidata(gui_hFigure, guihandles(gui_hFigure));
    end
    
    % If user specified 'Visible','off' in p/v pairs, don't make the figure
    % visible.
    gui_MakeVisible = 1;
    for ind=1:2:length(varargin)
        if length(varargin) == ind
            break;
        end
        len1 = min(length('visible'),length(varargin{ind}));
        len2 = min(length('off'),length(varargin{ind+1}));
        if ischar(varargin{ind}) & ischar(varargin{ind+1}) & ...
                strncmpi(varargin{ind},'visible',len1) & len2 > 1
            if strncmpi(varargin{ind+1},'off',len2)
                gui_MakeVisible = 0;
            elseif strncmpi(varargin{ind+1},'on',len2)
                gui_MakeVisible = 1;
            end
        end
    end
    
    % Check for figure param value pairs
    for index=1:2:length(varargin)
        if length(varargin) == index
            break;
        end
        try, set(gui_hFigure, varargin{index}, varargin{index+1}), catch, break, end
    end

    % If handle visibility is set to 'callback', turn it on until finished
    % with OpeningFcn
    gui_HandleVisibility = get(gui_hFigure,'HandleVisibility');
    if strcmp(gui_HandleVisibility, 'callback')
        set(gui_hFigure,'HandleVisibility', 'on');
    end
    
    feval(gui_State.gui_OpeningFcn, gui_hFigure, [], guidata(gui_hFigure), varargin{:});
    
    if ishandle(gui_hFigure)
        % Update handle visibility
        set(gui_hFigure,'HandleVisibility', gui_HandleVisibility);
        
        % Make figure visible
        if gui_MakeVisible
            set(gui_hFigure, 'Visible', 'on')
            if gui_Options.singleton 
                setappdata(gui_hFigure,'GUIOnScreen', 1);
            end
        end

        % Done with GUI initialization
        rmappdata(gui_hFigure,'InGUIInitialization');
    end
    
    % If handle visibility is set to 'callback', turn it on until finished with
    % OutputFcn
    if ishandle(gui_hFigure)
        gui_HandleVisibility = get(gui_hFigure,'HandleVisibility');
        if strcmp(gui_HandleVisibility, 'callback')
            set(gui_hFigure,'HandleVisibility', 'on');
        end
        gui_Handles = guidata(gui_hFigure);
    else
        gui_Handles = [];
    end
    
    if nargout
        [varargout{1:nargout}] = feval(gui_State.gui_OutputFcn, gui_hFigure, [], gui_Handles);
    else
        feval(gui_State.gui_OutputFcn, gui_hFigure, [], gui_Handles);
    end
    
    if ishandle(gui_hFigure)
        set(gui_hFigure,'HandleVisibility', gui_HandleVisibility);
    end
end    

function gui_hFigure = local_openfig(name, singleton)
if nargin('openfig') == 3 
    gui_hFigure = openfig(name, singleton, 'auto');
else
    % OPENFIG did not accept 3rd input argument until R13,
    % toggle default figure visible to prevent the figure
    % from showing up too soon.
    gui_OldDefaultVisible = get(0,'defaultFigureVisible');
    set(0,'defaultFigureVisible','off');
    gui_hFigure = openfig(name, singleton);
    set(0,'defaultFigureVisible',gui_OldDefaultVisible);
end