В этом примере показано, как использовать metric API модели для программного сбора подсистемы и счетчиков блоков для модели. После сбора метрик для модели можно получить доступ к результатам и экспортировать их в файл.
Open model vdp.
model = 'vdp';
open_system(model);
Чтобы собрать метрические данные о модели, создайте объект metric engine и вызовите execute
.
metric_engine = slmetric.Engine(); setAnalysisRoot(metric_engine,'Root','vdp','RootType','Model'); execute(metric_engine);
Updating Model Advisor cache... Model Advisor cache updated. For new customizations, to update the cache, use the Advisor.Manager.refresh_customizations method.
Использование getMetrics
метод, укажите метрики, которые вы хотите собрать. В данном примере укажите количество блоков и метрики подсистемы для vdp
модель. getMetrics
возвращает массив slmetric.metric.ResultCollection
объекты.
res_col = getMetrics(metric_engine,{'mathworks.metrics.SimulinkBlockCount',... 'mathworks.metrics.SubSystemCount'});
Создайте metricData
массива ячеек для хранения
MetricID
, ComponentPath
, и Value
для результатов метрики. The MetricID
- идентификатор метрики, ComponentPath
- путь к компоненту, для которого вычисляется метрика, и Value
- значение метрики. Напишите цикл, чтобы отобразить результаты.
metricData ={'MetricID','ComponentPath','Value'}; cnt = 1; for n=1:length(res_col) if res_col(n).Status == 0 results = res_col(n).Results; for m=1:length(results) disp(['MetricID: ',results(m).MetricID]); disp([' ComponentPath: ',results(m).ComponentPath]); disp([' Value: ',num2str(results(m).Value)]); metricData{cnt+1,1} = results(m).MetricID; metricData{cnt+1,2} = results(m).ComponentPath; metricData{cnt+1,3} = results(m).Value; cnt = cnt + 1; end else disp(['No results for:',res_col(n).MetricID]); end disp(' '); end
MetricID: mathworks.metrics.SimulinkBlockCount
ComponentPath: vdp
Value: 13
MetricID: mathworks.metrics.SimulinkBlockCount
ComponentPath: vdp/More Info
Value: 1
MetricID: mathworks.metrics.SimulinkBlockCount
ComponentPath: vdp/More Info/Model Info
Value: 1
MetricID: mathworks.metrics.SimulinkBlockCount
ComponentPath: vdp/More Info/Model Info/EmptySubsystem
Value: 0
MetricID: mathworks.metrics.SubSystemCount
ComponentPath: vdp
Value: 1
MetricID: mathworks.metrics.SubSystemCount
ComponentPath: vdp/More Info
Value: 0
MetricID: mathworks.metrics.SubSystemCount
ComponentPath: vdp/More Info/Model Info
Value: 1
MetricID: mathworks.metrics.SubSystemCount
ComponentPath: vdp/More Info/Model Info/EmptySubsystem
Value: 0
Как экспортировать metricData
результаты MetricID
, ComponentPath
, и Value
в электронную таблицу используйте writetable
чтобы записать содержимое metricData
на MySpreadsheet.xlsx
.
filename = 'MySpreadsheet.xlsx';
T=table(metricData);
writetable(T,filename);
Чтобы экспортировать результаты метрики в XML- файл, используйте exportMetrics
способ. Для каждого метрического результата XML- файл включает в себя ComponentID
, ComponentPath
, MetricID
, Value
, AggregatedValue
, и Measure
.
filename='MyMetricResults.xml';
exportMetrics(metric_engine,filename)
Закройте модель vdp
.
bdclose(model);
Для одной модели вы не можете собрать метрические данные в тот же файл базы данных (то есть Metrics.db
файл) на нескольких платформах.
slmetric.Engine
| slmetric.metric.Result
| slmetric.metric.ResultCollection