Сворачивание выражения оптимизирует код, чтобы минимизировать вычисление промежуточных результатов в блоке выходные параметры и устройство хранения данных таких результатов во временных буферах или переменных. Когда сворачивание выражения включено, коллапсы генератора кода (сгибы) блокируют вычисления в отдельное выражение, вместо того, чтобы генерировать отдельные операторы кода и объявления устройства хранения данных для каждого блока в модели. Большинство блоков Simulink поддерживает сворачивание выражения.
Сворачивание выражения повышает эффективность сгенерированного кода, часто достигая результатов, которые выдерживают сравнение с ручным оптимизированным кодом. Во многих случаях целые группы образцовых вычислений сворачиваются в одну, высоко оптимизированную строку кода.
model = 'rtwdemo_slexprfold';
open_system(model);
Сворачивание выражения доступно только, когда параметр Повторного использования памяти устанавливается на на том, потому что сворачивание выражения работает только с выражениями, включающими локальные переменные. Повторное использование памяти и Устраняет лишние локальные переменные (сворачивание выражения), параметры включены по умолчанию. Очистите Устранение лишних локальных переменных (сворачивание выражения) параметр или введите следующую команду в Окно Команды MATLAB, чтобы выключить параметр:
set_param(model, 'ExpressionFolding','off');
Создайте временную папку для сборки и инспекционного процесса.
currentDir = pwd; [~,cgDir] = rtwdemodir();
Создайте модель.
rtwbuild(model)
### Starting build procedure for model: rtwdemo_slexprfold ### Successful completion of build procedure for model: rtwdemo_slexprfold
С выражением, сворачивающимся прочь, в файле rtwdemo_slexprfold.c
, существуют отдельные операторы кода прежде и в операции блока switch.
cfile = fullfile(cgDir,'rtwdemo_slexprfold_grt_rtw','rtwdemo_slexprfold.c'); rtwdemodbtype(cfile,'/* Model step', '/* Model initialize', 1, 0);
/* Model step function */ void rtwdemo_slexprfold_step(void) { boolean_T rtb_LogicalOperator; boolean_T rtb_RelationalOperator; real_T rtb_Gain; /* RelationalOperator: '<Root>/Relational Operator1' incorporates: * Constant: '<Root>/Constant' * Inport: '<Root>/In2' */ rtb_LogicalOperator = (rtwdemo_slexprfold_P.UPPER >= rtwdemo_slexprfold_U.In2); /* RelationalOperator: '<Root>/Relational Operator' incorporates: * Constant: '<Root>/Constant1' * Inport: '<Root>/In2' */ rtb_RelationalOperator = (rtwdemo_slexprfold_U.In2 <= rtwdemo_slexprfold_P.LOWER); /* Logic: '<Root>/Logical Operator' */ rtb_LogicalOperator = (rtb_LogicalOperator || rtb_RelationalOperator); /* Switch: '<Root>/Switch' */ if (rtb_LogicalOperator) { /* Gain: '<Root>/Gain' incorporates: * Inport: '<Root>/In1' */ rtb_Gain = 2.0 * rtwdemo_slexprfold_U.In1; /* Lookup_n-D: '<Root>/Look-Up Table' */ rtwdemo_slexprfold_Y.Out1 = look1_binlx(rtb_Gain, rtwdemo_slexprfold_P.T1Break, rtwdemo_slexprfold_P.T1Data, 10U); } else { /* Lookup_n-D: '<Root>/Look-Up Table (2-D)' incorporates: * Inport: '<Root>/In3' * Inport: '<Root>/In4' */ rtwdemo_slexprfold_Y.Out1 = look2_binlx(rtwdemo_slexprfold_U.In3, rtwdemo_slexprfold_U.In4, rtwdemo_slexprfold_P.T2Break, rtwdemo_slexprfold_P.T2Break, rtwdemo_slexprfold_P.T2Data, rtCP_LookUpTable2D_maxIndex, 3U); } /* End of Switch: '<Root>/Switch' */ }
Введите следующую команду, чтобы включить сворачивание выражения:
set_param(model, 'ExpressionFolding','on');
Создайте модель.
rtwbuild(model);
### Starting build procedure for model: rtwdemo_slexprfold ### Successful completion of build procedure for model: rtwdemo_slexprfold
Следующее является фрагментом rtwdemo_slexprfold.c. В оптимизированном коде генератор кода сворачивает все вычисления в операцию блока switch.
rtwdemodbtype(cfile,'/* Model step', '/* Model initialize', 1, 0);
/* Model step function */ void rtwdemo_slexprfold_step(void) { /* Switch: '<Root>/Switch' incorporates: * Constant: '<Root>/Constant' * Constant: '<Root>/Constant1' * Inport: '<Root>/In2' * Logic: '<Root>/Logical Operator' * RelationalOperator: '<Root>/Relational Operator' * RelationalOperator: '<Root>/Relational Operator1' */ if ((rtwdemo_slexprfold_P.UPPER >= rtwdemo_slexprfold_U.In2) || (rtwdemo_slexprfold_U.In2 <= rtwdemo_slexprfold_P.LOWER)) { /* Outport: '<Root>/Out1' incorporates: * Gain: '<Root>/Gain' * Inport: '<Root>/In1' * Lookup_n-D: '<Root>/Look-Up Table' */ rtwdemo_slexprfold_Y.Out1 = look1_binlx(2.0 * rtwdemo_slexprfold_U.In1, rtwdemo_slexprfold_P.T1Break, rtwdemo_slexprfold_P.T1Data, 10U); } else { /* Outport: '<Root>/Out1' incorporates: * Inport: '<Root>/In3' * Inport: '<Root>/In4' * Lookup_n-D: '<Root>/Look-Up Table (2-D)' */ rtwdemo_slexprfold_Y.Out1 = look2_binlx(rtwdemo_slexprfold_U.In3, rtwdemo_slexprfold_U.In4, rtwdemo_slexprfold_P.T2Break, rtwdemo_slexprfold_P.T2Break, rtwdemo_slexprfold_P.T2Data, rtCP_LookUpTable2D_maxIndex, 3U); } /* End of Switch: '<Root>/Switch' */ }
Закройте отчет генерации кода и модель.
bdclose(model) rtwdemoclean; cd(currentDir)
Для примера, в котором выражения кода являются выражением, свернутым между Simulink и Stateflow, откройте эту модель rtwdemo_sfexprfold
.