簡體   English   中英

在Gui Matlab中繪制Bode,Nyquist和Nichols響應錯誤

[英]Error ploting bode , nyquist and nichols responses in gui matlab

我想用GUIDE Matlab創建一個圖形界面,以顯示傳遞函數的不同響應:step,impulse,bode,nyquist和nichols響應。 它對於階躍和脈沖響應工作正常,但是對於nyquist,bode和nichols卻不起作用,我應該在“ plot”功能中添加“ squeeze”,但這並不是正確的響應! 這是我僅嘗試使用圖時的錯誤:

??? 使用==>繪圖時出錯數據的尺寸不得超過2個
這是LTI .fig文件
以下代碼是.m文件的內容

function varargout = LTI(varargin)
% LTI M-file for LTI.fig
%      LTI, by itself, creates a new LTI or raises the existing
%      singleton*.
%
%      H = LTI returns the handle to a new LTI or the handle to
%      the existing singleton*.
%
%      LTI('CALLBACK',hObject,eventData,handles,...) calls the local
%      function named CALLBACK in LTI.M with the given input arguments.
%
%      LTI('Property','Value',...) creates a new LTI or raises the
%      existing singleton*.  Starting from the left, property value pairs are
%      applied to the GUI before LTI_OpeningFcn gets called.  An
%      unrecognized property name or invalid value makes property application
%      stop.  All inputs are passed to LTI_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 LTI

% Last Modified by GUIDE v2.5 24-Nov-2014 10:41:38

% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct('gui_Name',       mfilename, ...
               'gui_Singleton',  gui_Singleton, ...
               'gui_OpeningFcn', @LTI_OpeningFcn, ...
               'gui_OutputFcn',  @LTI_OutputFcn, ...
               'gui_LayoutFcn',  [] , ...
               'gui_Callback',   []);
if nargin && ischar(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 LTI is made visible.
function LTI_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 LTI (see VARARGIN)

% Choose default command line output for LTI
handles.output = hObject;

% Update handles structure
guidata(hObject, handles);

% UIWAIT makes LTI wait for user response (see UIRESUME)
% uiwait(handles.figure1);


% --- Outputs from this function are returned to the command line.
function varargout = LTI_OutputFcn(hObject, eventdata, handles) 
% varargout  cell array for returning output args (see VARARGOUT);
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)

% Get default command line output from handles structure
varargout{1} = handles.output;



function numerateur_Callback(hObject, eventdata, handles)
% hObject    handle to numerateur (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 numerateur as text
%        str2double(get(hObject,'String')) returns contents of numerateur as a double


% --- Executes during object creation, after setting all properties.
function numerateur_CreateFcn(hObject, eventdata, handles)
% hObject    handle to numerateur (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 && isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor'))
    set(hObject,'BackgroundColor','white');
end



function denumerateur_Callback(hObject, eventdata, handles)
% hObject    handle to denumerateur (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 denumerateur as text
%        str2double(get(hObject,'String')) returns contents of denumerateur as a double


% --- Executes during object creation, after setting all properties.
function denumerateur_CreateFcn(hObject, eventdata, handles)
% hObject    handle to denumerateur (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 && isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor'))
    set(hObject,'BackgroundColor','white');
end


% --- Executes on button press in rep_indic.
function rep_indic_Callback(hObject, eventdata, handles)
% hObject    handle to rep_indic (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
num= str2num(get(handles.numerateur,'String'));
denum = str2num(get(handles.denumerateur,'String'));
G=tf([num],[denum]);
axes(handles.figure)
plot(step(G))
grid on


% --- Executes on button press in lieu_bode.
function lieu_bode_Callback(hObject, eventdata, handles)
% hObject    handle to lieu_bode (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
num= str2num(get(handles.numerateur,'String'));
denum = str2num(get(handles.denumerateur,'String'));
G=tf([num],[denum]);
axes(handles.figure)
plot(squeeze(bode(G)))
grid on

% --- Executes on button press in rep_impuls.
function rep_impuls_Callback(hObject, eventdata, handles)
% hObject    handle to rep_impuls (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
num= str2num(get(handles.numerateur,'String'));
denum = str2num(get(handles.denumerateur,'String'));
G=tf([num],[denum]);
axes(handles.figure)
plot(impulse(G))
grid on

% --- Executes on button press in lieu_nyquist.
function lieu_nyquist_Callback(hObject, eventdata, handles)
% hObject    handle to lieu_nyquist (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
num= str2num(get(handles.numerateur,'String'));
denum = str2num(get(handles.denumerateur,'String'));
G=tf([num],[denum]);
axes(handles.figure)
plot(s(nyquist(G)))
grid on

% --- Executes on button press in lieu_nichols.
function lieu_nichols_Callback(hObject, eventdata, handles)
% hObject    handle to lieu_nichols (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
num= str2num(get(handles.numerateur,'String'));
denum = str2num(get(handles.denumerateur,'String'));
G=tf([num],[denum]);
axes(handles.figure)
plot(squeeze(nichols(G)))
grid on

你不提供* .FIG文件去與你的代碼,但我懷疑,我知道是什么問題: bodenyquistnichols自動生成的情節,你不需要調用plot功能。 檢查文檔以獲取調用這些函數的正確方法。 在您的GUI中,替換為:

  1. 通過bode(G) plot(squeeze(bode(G))) bode(G)
  2. plot(s(nyquist(G))) [sic]來自nyquist(G)
  3. plot(squeeze(nichols(G))) nichols(G)

根據評論進行編輯

我想你要做的就是

num= str2num(get(handles.numerateur,'String'));
denum = str2num(get(handles.denumerateur,'String'));
G=tf([num],[denum]);
axes(handles.figure)
step(G)
grid on

這同樣適用於bodenyquistnicholsimpulse ,即剛剛創建圖一組軸,和劇情將會默認顯示在這些軸。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM