代码拉取完成,页面将自动刷新
%------------------------------------------------------------------------------
% Simulink scrip for rename parameters and change parameter's value.
% MATLAB : R2017a
% Author : Shibo Jiang
% Version : 0.7
% Time : 2017/12/20
% Instructions : Add change stateflow parameter function.
% Add creat new parameter function. - 0.3
% Fix bugs ,message can report clearly - 0.4
% Code refactoring - 0.5
% Add state flow parameter changed
% Add storge calss change - 0.6
% Support goto & from block - 0.7
% Support under masked block changing name - 0.8
%------------------------------------------------------------------------------
function output = change_parameter()
paraModel = bdroot;
% Original matalb version is R2017a
% 检查Matlab版本是否为R202017a
CorrectVersion_win = '9.2.0.556344 (R2017a)'; % windows
CorrectVersion_linux = '9.2.0.538062 (R2017a)'; % linux
CurrentVersion = version;
if 1 ~= bitor(strcmp(CorrectVersion_win, CurrentVersion),...
strcmp(CorrectVersion_linux, CurrentVersion))
warning(['Matlab version mismatch, this scrip should be' ...
'used for Matlab R2017a']);
end
% % Get inter parameter which defined in model workspace
% simulink_var_space = get_param(paraModel,'ModelWorkspace');
% simulink_par_inter = simulink_var_space.whos;
% Define list file's name
filename = [paraModel,'_list.xlsx'];
% Open outlink parameter which defined in data dictionary
data_dictionary = get_param(paraModel, 'DataDictionary');
current_dic = Simulink.data.dictionary.open(data_dictionary);
dic_entry = getSection(current_dic, 'Design Data');
% Find data in dictionary&model and change name
% Import excel file's data
[number_par, name_par] = xlsread(filename, 'dict');
[number_line, name_line] = xlsread(filename, 'only_line');
NAME_START_ROW = 2;
STR_COLUMN_END = 3;
% Jduge only_line & dict sheet is empty?
if isempty(number_par)
temp_judge_par = 2;
else
temp_judge_par = 0;
end
if isempty(number_line)
temp_judge_line = 1;
else
temp_judge_line = 0;
end
switch (temp_judge_line + temp_judge_par)
case 0
name_all = [name_par(NAME_START_ROW:end,1:STR_COLUMN_END);...
name_line(NAME_START_ROW:end,1:STR_COLUMN_END)];
number_all = number_par(end,1) + number_line(end,1);
case 1
name_all = name_par(NAME_START_ROW:end,1:STR_COLUMN_END);
number_all = number_par(end,1);
case 2
name_all = name_line(NAME_START_ROW:end,1:STR_COLUMN_END);
number_all = number_line(end,1);
case 3
name_all = [];
end
% Whether writing paramter's name
OLD_NAME_COL = 2;
NEW_NAME_COL = 3;
if ~isempty(name_all)
i_diff_name = 1;
for i = 1:number_all(end)
temp_old = name_all{i, OLD_NAME_COL};
temp_new = name_all{i, NEW_NAME_COL};
if ~strcmp(temp_new, temp_old)
% Find the parameter name in dict
par_dict = find(dic_entry, 'Name', temp_old);
% Find the parameter name in signal line
par_signal = find_system(paraModel,'FindAll','on',...
'LookUnderMasks','on','FollowLinks','on','type','line', 'Name',temp_old);
% % Find the parameter name in constant block
% par_const = find_system(paraModel,'FindAll','on',...
% 'LookUnderMasks','on','FollowLinks','on','BlockType', 'Constant','Value', temp_old);
% Find the paremeter name in constant which include dict constant
par_const = [];
dict_const_block = find_system(paraModel,'FindAll','on',...
'LookUnderMasks','on','FollowLinks','on','BlockType', 'Constant');
if ~isempty(dict_const_block)
par_const = zeros(1,length(dict_const_block));
for temp_index = 1:length(dict_const_block)
temp_const_name = get(dict_const_block(temp_index),'Value');
if strcmp(temp_old, temp_const_name)
par_const(temp_index) = dict_const_block(temp_index);
break;
end
end
end
% Find the parameter name in table block
par_nd_table = find_system(paraModel,'FindAll','on',...
'LookUnderMasks','on','FollowLinks','on','BlockType', 'Lookup_n-D','Table', temp_old);
par_direct_table = find_system(paraModel,'FindAll','on',...
'LookUnderMasks','on','FollowLinks','on','BlockType','LookupNDDirect',...
'Table', temp_old);
% Find the parameter name in port block
par_inport = find_system(paraModel,'FindAll','on',...
'LookUnderMasks','on','FollowLinks','on','BlockType', 'Inport','Name', temp_old);
par_outport = find_system(paraModel,'FindAll','on',...
'LookUnderMasks','on','FollowLinks','on','BlockType', 'Outport','Name', temp_old);
% Find the parameter name in stateflow
sf = sfroot;
par_sf_data = sf.find('-isa','Stateflow.Data',...
'Name', temp_old);
% Find the goto block
par_goto = find_system(paraModel,'FindAll','on',...
'LookUnderMasks','on','FollowLinks','on','BlockType', 'Goto','GotoTag', temp_old);
% Find the from block
par_from = find_system(paraModel,'FindAll','on',...
'LookUnderMasks','on','FollowLinks','on','BlockType', 'From','GotoTag', temp_old);
% Set new name
try
par_dict.Name = temp_new;
end
SetNewName(par_signal, 'Name', temp_new);
SetNewName(par_inport, 'Name', temp_new);
SetNewName(par_outport, 'Name', temp_new);
SetNewName(par_const, 'Value', temp_new);
SetNewName(par_nd_table, 'Table', temp_new);
SetNewName(par_direct_table, 'Table', temp_new);
SetNewName(par_sf_data, 'Name', temp_new);
SetNewName(par_goto, 'GotoTag', temp_new);
SetNewName(par_from, 'GotoTag', temp_new);
% Store diff name for changing value
old_name{i_diff_name} = temp_old;
new_name{i_diff_name} = temp_new;
i_diff_name = i_diff_name + 1;
else
% Do nothing
end
end
output = 'Rename parameter successful.'
else
output = 'No parameter name changed.'
end
% Find simulink parameter in list and change the datatype&value
[num_simu_par, str_simu_par] = xlsread(filename, 'simu_parameter');
SIMU_PAR_NAME_COL = 2;
SIMU_PAR_DATATYPE_COL = 4;
SIMU_PAR_STORGE = 5;
SIMU_PAR_VALUE = 6;
if ~isempty(num_simu_par)
for i = 1:num_simu_par(end,1)
temp_simu_par_name = str_simu_par(i+1, SIMU_PAR_NAME_COL);
temp_simu_par_datatype = str_simu_par(i+1, SIMU_PAR_DATATYPE_COL);
temp_simu_par_storge = str_simu_par(i+1, SIMU_PAR_STORGE);
temp_simu_par_value = num_simu_par(i, SIMU_PAR_VALUE);
% Set new property
temp_return = SetDictParameter(dic_entry,...
temp_simu_par_name{1},...
temp_simu_par_datatype{1},...
temp_simu_par_storge{1},...
temp_simu_par_value);
% Report whether set successful
if strcmp('Invalid name', temp_return)
% Use new name to try again
% Judge whether need find new name
if 1 < i_diff_name
% Find new name
for i = 1:(i_diff_name-1)
if strcmp(old_name{i}, temp_simu_par_name{1})
temp_simu_par_name{1} = new_name{i};
break;
end
end
end
% Creat new entry in dict
initial_value = Simulink.Parameter;
% Try creat new ,if parameter does not exit.
try
addEntry(dic_entry, temp_simu_par_name{1}, initial_value);
end
% Set entry's property
SetDictParameter(dic_entry,...
temp_simu_par_name{1},...
temp_simu_par_datatype{1},...
temp_simu_par_storge{1},...
temp_simu_par_value);
output = ['The parameter "' ,...
temp_simu_par_name{1},...
'" does not exit, have already created it.']
end
end
output = 'Change simulink parameter successful.'
else
output = 'No simulink parameter need changed.'
end
% Find table in list and change the datatype&value
[num_simu_table, str_simu_table] = xlsread(filename, 'simu_table');
TABLE_NAME_COL = 2;
TABLE_DATATYPE_COL = 4;
TABLE_STORGE_COL = 5;
TABLE_ROW_SPACE_COL = 6;
TABLE_COL_SPACE_COL = 7;
TABLE_VALUE_COL = 8;
% Judge whether need writing talbe data
if ~isempty(num_simu_table)
len_simu_table_temp = length(num_simu_table(:,1));
% Calculate cycle time
for i = 1: len_simu_table_temp
if ~strcmp('NaN', num2str(num_simu_table(len_simu_table_temp+1-i,1)))
cycle_time_tale = num_simu_table(len_simu_table_temp+1-i,1);
break;
end
end
% Read tabel data and write to dict
temp_row = 1;
for i = 1: cycle_time_tale
temp_table_name = str_simu_table(1+temp_row, TABLE_NAME_COL);
temp_table_datatype = str_simu_table(1+temp_row, TABLE_DATATYPE_COL);
temp_table_storge = str_simu_table(1+temp_row, TABLE_STORGE_COL);
temp_row_spacing = num_simu_table(temp_row, TABLE_ROW_SPACE_COL);
temp_column_spacing = num_simu_table(temp_row, TABLE_COL_SPACE_COL);
temp_table_data = num_simu_table(temp_row:...
(temp_row + temp_row_spacing - 1),...
TABLE_VALUE_COL:(TABLE_VALUE_COL + temp_column_spacing - 1));
% Set new property
temp_return = SetDictParameter(dic_entry,...
temp_table_name{1},...
temp_table_datatype{1},...
temp_table_storge{1},...
temp_table_data);
% Report whether creat new parameter
if strcmp('Invalid name', temp_return)
% Use new name to try again
% Judge whether need find new name
if 1 < i_diff_name
% Find new name
for i = 1:(i_diff_name-1)
if strcmp(old_name{i}, temp_table_name{1})
temp_table_name{1} = new_name{i};
break;
end
end
end
% Creat new entry in dict
initial_value = Simulink.Parameter;
% Try creat new ,if parameter does not exit.
try
addEntry(dic_entry, temp_table_name{1}, initial_value);
end
% Set entry's property
SetDictParameter(dic_entry,...
temp_table_name{1},...
temp_table_datatype{1},...
temp_table_storge{1},...
temp_table_data);
output = ['The parameter "' ,...
temp_table_name{1},...
'" does not exit, have already created it.']
end
temp_row = temp_row + temp_row_spacing;
end
output = 'Change table data successful.'
else
output = 'No table data changed.'
end
% Find stateflow in the excel,and change it.
[num_sf_par, str_sf_par] = xlsread(filename, 'sf_parameter');
SF_NAME_COL = 2;
SF_SCOPE_COL = 3;
SF_DATATYPE_COL = 4;
if isempty(num_sf_par)
output = 'No state flow parameter need changed.'
else
for i = 1:num_sf_par(end,1)
temp_sf_name = str_sf_par(i+1, SF_NAME_COL);
temp_sf_scope = str_sf_par(i+1, SF_SCOPE_COL);
temp_sf_datatype = str_sf_par(i+1, SF_DATATYPE_COL);
% Find state flow parameter in model
sf = sfroot;
temp_sf_par = sf.find('-isa','Stateflow.Data','Name',temp_sf_name{1});
if isempty(temp_sf_par)
% Report this state flow need defined in matlab
output = ['The parameter "', temp_sf_name{1},...
'" does not exit, it needs be defined in state flow']
else
% Change sf parameter
set(temp_sf_par, 'Scope', temp_sf_scope{1},...
'DataType', temp_sf_datatype{1});
end
end
output = 'Change state flow parameter successful.'
end
% Save changes to the dictionary and close it.
saveChanges(current_dic);
close(current_dic);
% Report
output = output;
end
%-----------------End of function----------------------------------------------
%-----------Start of function--------------------------------------------------
function SetNewName(input, item, new_name)
if isempty(input)
% Do Nothing
else
if 1 < length(input)
for i = 1:length(input)
try
set_param(input(i), item, new_name);
catch
try
set(input(i), item, new_name);
end
end
end
else
try
set_param(input, item, new_name);
catch
try
set(input, item, new_name);
end
end
end
end
end
%-----------------End of function----------------------------------------------
%-----------Start of function--------------------------------------------------
function output = SetDictParameter(entry, name, data_type, storge, value)
% Find the parameter name in dict
simu_par = find(entry, 'Name', name);
if isempty(simu_par)
output = 'Invalid name';
else
output = 'Valid name';
temp_change = getValue(simu_par);
temp_change.DataType = data_type;
temp_change.CoderInfo.StorageClass = storge;
temp_change.Value = value;
% Write dict
setValue(simu_par, temp_change);
end
end
%-----------------End of function----------------------------------------------
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。