一、获取代码方式

获取代码方式1:

完整代码已上传我的资源:【光学】基于matlab GUI带切趾的光线布拉格光栅滤波特性仿真【含Matlab源码 1505期】

获取代码方式2:

通过订阅紫极神光博客​付费专栏​,凭支付凭证,​私信博主​,可获得此代码。

备注:

订阅紫极神光博客​付费专栏​,可免费获得​1​份代码(​有效期​为订阅日起,三天内有效);

二、部分源代码

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

% Last Modified by GUIDE v2.5 06-Sep-2021 14:39:09

% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct('gui_Name', mfilename, ...
'gui_Singleton', gui_Singleton, ...
'gui_OpeningFcn', @MaskGUI_OpeningFcn, ...
'gui_OutputFcn', @MaskGUI_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 MaskGUI is made visible.
function MaskGUI_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 MaskGUI (see VARARGIN)

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

% Update handles structure
guidata(hObject, handles);

% UIWAIT makes MaskGUI wait for user response (see UIRESUME)
% uiwait(handles.figure1);
% neff_h = findobj('Tag','axes14')
clc;
neff_h = findobj('tag','neff_axis');
axes(neff_h);
set(neff_h,'visible','off');
text(0,0.5,'n_{neff}','fontsize',18);

delta_n_h = findobj('tag','delta_n_axis');
axes(delta_n_h);
set(delta_n_h,'visible','off');
text(0,0.5,'\Deltan','fontsize',18);

delta_n_unit_h = findobj('tag','delta_n_unit_axis');
axes(delta_n_unit_h);
set(delta_n_unit_h,'visible','off');
text(0,0.5,'×10^{-4}','fontsize',10)

dlambda_b_h = findobj('tag','lambda_b_axis');
axes(dlambda_b_h);
set(dlambda_b_h,'visible','off');
text(0,0.5,'\lambda_B','fontsize',18)


[x y] = GetMaskFunction(handles);
Mask_h = handles.Mask_axis;
axes(Mask_h);
plot(x,y,'linewidth',2);
grid on;
title('切趾形状','fontsize',24);

global annota;
annota = [];

% --- Outputs from this function are returned to the command line.
function varargout = MaskGUI_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 neff_Callback(hObject, eventdata, handles)
% hObject handle to neff (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 neff as text
% str2double(get(hObject,'String')) returns contents of neff as a double


% --- Executes during object creation, after setting all properties.
function neff_CreateFcn(hObject, eventdata, handles)
% hObject handle to neff (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 delta_n_Callback(hObject, eventdata, handles)
% hObject handle to delta_n (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 delta_n as text
% str2double(get(hObject,'String')) returns contents of delta_n as a double


% --- Executes during object creation, after setting all properties.
function delta_n_CreateFcn(hObject, eventdata, handles)
% hObject handle to delta_n (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 Grate_Length_Callback(hObject, eventdata, handles)
% hObject handle to Grate_Length (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 Grate_Length as text
% str2double(get(hObject,'String')) returns contents of Grate_Length as a double


% --- Executes during object creation, after setting all properties.
function Grate_Length_CreateFcn(hObject, eventdata, handles)
% hObject handle to Grate_Length (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 chirp_Callback(hObject, eventdata, handles)
% hObject handle to chirp (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 chirp as text
% str2double(get(hObject,'String')) returns contents of chirp as a double


% --- Executes during object creation, after setting all properties.
function chirp_CreateFcn(hObject, eventdata, handles)
% hObject handle to chirp (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 begin_lamuda_Callback(hObject, eventdata, handles)
% hObject handle to begin_lamuda (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 begin_lamuda as text
% str2double(get(hObject,'String')) returns contents of begin_lamuda as a double


% --- Executes during object creation, after setting all properties.
function begin_lamuda_CreateFcn(hObject, eventdata, handles)
% hObject handle to begin_lamuda (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

三、运行结果

【光学】基于matlab GUI带切趾的光线布拉格光栅滤波特性仿真【含Matlab源码 1505期】_matlab

四、matlab版本及参考文献

1 matlab版本

2014a

2 参考文献

[1] 门云阁.MATLAB物理计算与可视化[M].清华大学出版社,2013.