Если Simulink® Coverage™ установлен, можно собрать метрики покрытия кода во время программного обеспечения в цикле (SIL) или процессор в цикле (PIL), симуляция - видит, Собирают Покрытие для Кода (Simulink Coverage). В этом примере можно собрать метрики покрытия кода со сторонней программой, i.e., BullseyeCoverage или Инструмент ldra. Необходимо установить стороннюю программу - смотрите Поддержку Инструмента Покрытия кода.
Этот снимок экрана показывает отчет покрытия кода, полученный путем выполнения SIL симуляции с включенным инструментом покрытия кода. Аннотации зависят от инструмента покрытия кода, который вы задаете.
В этом примере вы измеряете покрытие модели во время симуляции режима normal mode и повторяете ту же симуляцию в режиме SIL, чтобы измерить покрытие кода. При помощи гиперссылок в покрытии модели и отчетах покрытия кода, можно сравнить результаты покрытия кода и покрытие модели.
Для SIL симуляции и примеров PIL симуляции, смотрите Тестовый Сгенерированный код с SIL симуляциями и PIL симуляциями.
Убедитесь, что модель недавно открыта.
model='rtwdemo_sil_topmodel';
close_system(model,0)
open_system(model)
Удалите существующие папки сборки.
buildFolder=RTW.getBuildDir(model); if exist(buildFolder.BuildDirectory,'dir') rmdir(buildFolder.BuildDirectory,'s'); end
Сконфигурируйте генерацию отчета покрытия модели.
set_param(model, 'RecordCoverage','on') clear covCumulativeData
Настройте данные о стимуле.
T=0.1; % sample time [ticks_to_count, reset, counter_mode, count_enable, ... counter_mode_values_run1, counter_mode_values_run2, ... count_enable_values_run1, count_enable_values_run2] = ... rtwdemo_sil_topmodel_data(T);
Модель сконфигурирована, чтобы собрать метрики покрытия модели. Когда симуляция завершена, отчет покрытия модели открывается. Используйте окно экрана покрытия, чтобы перейти от блоков в модели к соответствующим разделам отчета покрытия.
counter_mode.signals.values = counter_mode_values_run1; count_enable.signals.values = count_enable_values_run1; set_param(model,'SimulationMode','normal');
Настройте Инспектора Данных моделирования для интерактивного просмотра и сравнения результатов симуляции.
Simulink.sdi.view; Simulink.sdi.clear;
Запустите симуляцию.
simout_normal_run1 = sim(model, 'ReturnWorkspaceOutputs', 'on');
Получите результаты.
Simulink.sdi.createRun('Run 1 (normal mode)', 'namevalue',... {'simout_normal_run1'}, {simout_normal_run1});
Для первой симуляции отчет показывает, что достигнутое покрытие меньше 100%. Запустите вторую симуляцию с различными входными сигналами, которые увеличивают уровень покрытия MC/DC к 100%. Обратите внимание на то, что отчет покрытия модели сконфигурирован, чтобы показать совокупное покрытие через оба запуска симуляции.
counter_mode.signals.values = counter_mode_values_run2; count_enable.signals.values = count_enable_values_run2; set_param(model,'SimulationMode','normal'); simout_normal_run2 = sim(model, 'ReturnWorkspaceOutputs', 'on'); Simulink.sdi.createRun('Run 2 (normal mode)', 'namevalue',... {'simout_normal_run2'}, {simout_normal_run2});
Прежде, чем запустить SIL симуляцию, проверьте наличие сторонних программ и сконфигурируйте модель, чтобы собрать метрики покрытия кода. Если сторонняя программа не доступна, модель использует Simulink® Verification и Validation™.
covToolPath = ''; ldraPath = coder.coverage.LDRA.getPath; bullseyePath = coder.coverage.BullseyeCoverage.getPath; coverageSettings = get_param(model,'CodeCoverageSettings'); coverageSettings.TopModelCoverage='on'; if ~isempty(ldraPath) coverageSettings.CoverageTool='LDRAcover or LDRA tool suite'; elseif ~isempty(bullseyePath) coverageSettings.CoverageTool='BullseyeCoverage'; else coverageSettings.CoverageTool='None'; end set_param(model,'CodeCoverageSettings',coverageSettings);
Симуляции режима normal mode производят метрики покрытия для модели. С SIL симуляцией можно применить те же входные сигналы стимула к сгенерированному коду и измерить покрытие кода.
Запустите первую симуляцию в режиме SIL.
counter_mode.signals.values = counter_mode_values_run1; count_enable.signals.values = count_enable_values_run1; set_param(model,'SimulationMode','software-in-the-loop'); set_param(model,'CodeExecutionProfiling','off'); set_param(model,'CodeProfilingInstrumentation','off'); simout_sil_run1 = sim(model, 'ReturnWorkspaceOutputs', 'on'); Simulink.sdi.createRun('Run 1 (SIL mode)', 'namevalue',... {'simout_sil_run1'}, {simout_sil_run1});
### Starting build procedure for: rtwdemo_sil_topmodel ### Successful completion of build procedure for: rtwdemo_sil_topmodel Build Summary Top model targets built: Model Action Rebuild Reason ===================================================================================================== rtwdemo_sil_topmodel Code generated and compiled Code generation information file does not exist. 1 of 1 models built (0 models already up to date) Build duration: 0h 0m 44.156s ### Preparing to start SIL simulation ... Building with 'MinGW64 Compiler (C)'. MEX completed successfully. ### Updating code generation report with SIL files ... ### Starting SIL simulation for component: rtwdemo_sil_topmodel ### Stopping SIL simulation for component: rtwdemo_sil_topmodel ### Completed code coverage analysis
Запустите вторую симуляцию в режиме SIL.
counter_mode.signals.values = counter_mode_values_run2; count_enable.signals.values = count_enable_values_run2; set_param(model,'SimulationMode','software-in-the-loop'); set_param(model,'CodeExecutionProfiling','off'); set_param(model,'CodeProfilingInstrumentation','off'); simout_sil_run2 = sim(model, 'ReturnWorkspaceOutputs', 'on'); Simulink.sdi.createRun('Run 2 (SIL mode)', 'namevalue',... {'simout_sil_run2'}, {simout_sil_run2});
### Starting build procedure for: rtwdemo_sil_topmodel ### Generated code for 'rtwdemo_sil_topmodel' is up to date because no structural, parameter or code replacement library changes were found. ### Successful completion of build procedure for: rtwdemo_sil_topmodel Build Summary Top model targets built: Model Action Rebuild Reason ============================================================================== rtwdemo_sil_topmodel Code compiled Compilation artifacts were out of date. 1 of 1 models built (0 models already up to date) Build duration: 0h 0m 3.656s ### Preparing to start SIL simulation ... ### Starting SIL simulation for component: rtwdemo_sil_topmodel ### Stopping SIL simulation for component: rtwdemo_sil_topmodel ### Completed code coverage analysis
Когда симуляция будет завершена, щелкните по ссылке в Командном окне, чтобы открыть отчет покрытия кода и просмотреть совокупные результаты покрытия кода. Ссылка доступна, только если вам установили стороннюю программу.
Используйте гиперссылки в покрытии кода, сообщают, чтобы перейти к соответствующим местоположениям в блок-схеме. Затем при помощи окна экрана покрытия можно открыть соответствующие разделы отчета покрытия модели. Сравните результаты покрытия кода и покрытие модели.
Инспектор Данных моделирования открывается автоматически, позволяя интерактивный просмотр и анализ результатов. Используйте Сравнивание и панели Inspect, чтобы подтвердить, что SIL и регистрируемые сигналы режима normal mode идентичны для обоих запусков.
В этом примере, вас:
Собранные метрики покрытия модели во время симуляции режима normal mode.
Собранные метрики покрытия кода во время SIL симуляции.
Перемещенный между покрытием кода и отчетами покрытия модели.
Перепроверенные метрики из обоих отчетов.