代码拉取完成,页面将自动刷新
%------------------------------------------------------------------------------
% Simulink scrip for patameters adding as defined.
% MATLAB version: R2017a
% Author : Shibo Jiang
% Version : 0.2
% Instructions :
%------------------------------------------------------------------------------
function add_parameter_result = add_sig_parameter()
paraModel = bdroot;
% Original matalb version is R2017a
% 检查Matlab版本是否为R2017a
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
% Original environment character encoding: GBK
% 脚本编码环境是否为GBK
% if ~strcmpi(get_param(0, 'CharacterEncoding'), 'GBK')
% warning('Simulink:EncodingUnMatched', 'The target character encoding...
% (%s) is different from the original (%s).',...
% get_param(0, 'CharacterEncoding'), 'GBK');
% end
all_line = find_system(paraModel,'FindAll','on','type','line');
% Parameters define
k = 1;
named_flag = 0;
length_line = length(all_line);
% Find the line which have name
for i = 1:length_line
% Detect 'Signal name'
current_line_name = get(all_line(i),'Name');
% judge whether signal has name
if 1 == isempty(current_line_name)
% no name
ne_flag = 1;
else
% have name
ne_flag = 0;
end
% collect signals name
if 0 == ne_flag
named_signals_line(k) = all_line(i);
k = k + 1;
named_flag = 1;
else
% Do nothing,keep named_flag = 0;
end
end
% find simulink's variables
simulink_var_space = get_param(paraModel,'ModelWorkspace');
simulink_var = simulink_var_space.whos;
if 1 == isempty(simulink_var)
% no variable defined
simulink_var_flag = 0;
else
% have some variables defined
simulink_var_flag = 1;
end
% judge whether signal's name have been defined to variables
var_define_enable = 0;
% have signal names and have some variables defined
if (1 == named_flag)&&(1 == simulink_var_flag)
length_named_line = length(named_signals_line);
length_var = length(simulink_var);
k = 1;
for i = 1:length_named_line
signal_name = get(named_signals_line(i),'Name');
for j = 1:length_var
var_name = simulink_var(j).name;
if 1 == strcmp(signal_name,var_name)
break;
else
% collect name which need be defined
if length_var == j
var_need_defined{k} = signal_name;
k = k + 1;
var_define_enable = 1;
else
% Do nothing ,wrong state
end
end
end
end
% have signal names and have no variables defined
elseif (1 == named_flag)&&(0 == simulink_var_flag)
length_named_line = length(named_signals_line);
k = 1;
for i = 1:length_named_line
var_need_defined{k} = get(named_signals_line(i),'Name');
k = k + 1;
end
var_define_enable = 1;
% have no signal names, do not auto define variables
else
% Do nothing
end
% auto add variables in simulink workspace
if 1 == var_define_enable
length_add_var = length(var_need_defined);
for i = 1:length_add_var
name_defined = var_need_defined{i};
% get the parameter datatpye
data_type = name_defined(end-2:end);
% translate the upper to lower
data_type = lower(data_type);
% calculate the data type config
switch data_type
case '_u8'
data_type_cfg = 'uint8';
case 'u16'
data_type_cfg = 'uint16';
case 'u32'
data_type_cfg = 'uint32';
case 'f32'
data_type_cfg = 'single';
case 'f64'
data_type_cfg = 'double';
case '_s8'
data_type_cfg = 'int8';
case 's16'
data_type_cfg = 'int16';
case 's32'
data_type_cfg = 'int32';
case '_bl'
data_type_cfg = 'boolean';
otherwise
data_type_cfg = 'uint8';
end
% add the parameter
try
temp_defined = Simulink.Signal;
temp_defined.DataType = data_type_cfg;
assignin('base',name_defined,temp_defined);
catch
% do nothing
end
end
% report configurate results
add_parameter_result = 'Add signal parameters successful';
else
% report configurate results
add_parameter_result = 'No signal line have names';
end
end
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。