exponenta event banner

getSimulationResults

Получение результатов моделирования модели и выборочных значений, используемых для расчета индексов Соболь

Описание

пример

[samplesTable,simdata,validRuns] = getSimulationResults(sobolObj,idx) возвращает результаты моделирования и выборочные значения в SimBiology.gsa.Sobol объект sobolObj для указанного индекса idx. Индекс представляет i-й столбец в sobolObj.SimulationInfo.SimData. Эта функция полезна, когда требуется устранить неполадки или выяснить, какие образцы параметров создали данные моделирования, которые привели к неудачному моделированию модели.

Примеры

свернуть все

Загрузить модель роста опухоли.

sbioloadproject tumor_growth_vpop_sa.sbproj

Получите вариант с расчетными параметрами и дозой для применения к модели.

v = getvariant(m1);
d = getdose(m1,'interval_dose');

Получить активный конфигурационный элемент и установить вес опухоли в качестве ответа.

cs = getconfigset(m1);
cs.RuntimeOptions.StatesToLog = 'tumor_weight';

Смоделировать модель и построить график профиля роста опухоли.

sbioplot(sbiosimulate(m1,cs,v,d));

Figure contains an axes. The axes with title States versus Time contains an object of type line. This object represents tumor_weight.

Выполните анализ глобальной чувствительности (GSA) на модели, чтобы найти параметры модели, к которым чувствителен рост опухоли.

Во-первых, извлеките представляющие интерес параметры модели, которые участвуют в фармакодинамике роста опухоли. Определите реакцию модели как вес опухоли.

modelParamNames = {'L0','L1','w0','k1','k2'};
outputName = 'tumor_weight';

Затем выполните GSA путем вычисления индексов Соболя первого и полного порядка с помощью sbiosobol. Набор 'ShowWaitBar' кому true для отображения хода моделирования. По умолчанию функция использует 1000 выборок параметров для вычисления индексов Соболя [1].

sobolResults = sbiosobol(m1,modelParamNames,outputName,'Variants',v,'Doses',d,'ShowWaitBar',true)
sobolResults = 
  Sobol with properties:

                Time: [444x1 double]
        SobolIndices: [5x1 struct]
            Variance: [444x1 table]
         Observables: {'[Tumor Growth Model].tumor_weight'}
    ParameterSamples: [1000x5 table]
      SimulationInfo: [1x1 struct]

Можно изменить количество проб, указав 'NumberSamples' аргумент пары имя-значение. Для функции требуется всего (number of input parameters + 2) * NumberSamples моделирование модели.

Показать средний отклик модели, результаты моделирования и закрашенную область, охватывающую 90% результатов моделирования.

plotData(sobolResults);

Figure contains an axes. The axes contains 12 objects of type line, patch. These objects represent model simulation, 90.0% region, mean value.

Можно настроить область квантиля на другой процент, указав 'Alphas' для нижнего и верхнего квантилей всех ответов модели. Например, альфа-значение 0,1 отображает затененную область между 100 * alpha и 100 * (1 - alpha) квантили всех смоделированных откликов модели.

plotData(sobolResults,'Alphas',0.1);

Figure contains an axes. The axes contains 12 objects of type line, patch. These objects represent model simulation, 80.0% region, mean value.

Постройте график временного хода индексов Соболя первого и общего порядка.

h = plot(sobolResults);
% Resize the figure.
h.Position(:) = [100 100 1280 800];

Figure contains 12 axes. Axes 1 with title [Tumor Growth Model].tumor_weight contains 3 objects of type line. Axes 2 with title [Tumor Growth Model].tumor_weight contains 3 objects of type line. Axes 3 contains 3 objects of type line. Axes 4 contains 3 objects of type line. Axes 5 contains 3 objects of type line. Axes 6 contains 3 objects of type line. Axes 7 contains 3 objects of type line. Axes 8 contains 3 objects of type line. Axes 9 contains 3 objects of type line. Axes 10 contains 3 objects of type line. Axes 11 contains 3 objects of type line. Axes 12 contains an object of type line.

Индекс Соболя первого порядка входного параметра дает долю общей дисперсии отклика, которую можно отнести только к вариациям входного параметра. Индекс общего порядка дает долю общей дисперсии отклика, которая может быть приписана любым вариациям параметра соединения, которые включают вариации входного параметра.

Из индексов Соболь сюжеты, параметры L1 и w0 кажутся наиболее чувствительными параметрами к массе опухоли до введения дозы при t = 7. Но после применения дозы, k1 и k2 становятся более чувствительными параметрами и вносят наибольший вклад в стадию дозирования веса опухоли. График общей дисперсии также показывает большую дисперсию для стадии после дозы при t > 35, чем для стадии до дозы роста опухоли, что указывает на то, что k1 и k2 могут быть более важными параметрами для дальнейшего изучения. Доля необъяснимой дисперсии показывает некоторую дисперсию при около t = 33, но график общей дисперсии показывает небольшую дисперсию при t = 33, что означает, что необъяснимая дисперсия может быть незначительной. Доля необъяснимой дисперсии вычисляется как 1 - (сумма всех индексов Соболя первого порядка), а общая дисперсия вычисляется с помощью var(response), где response является ответом модели в каждый момент времени.

Можно также отобразить значения чувствительности на гистограмме.

bar(sobolResults)

Figure contains an axes. The axes with title [Tumor Growth Model].tumor_weight contains 22 objects of type patch, line. These objects represent first order, total order.

Можно указать больше образцов для повышения точности индексов Соболя, но для завершения моделирования может потребоваться больше времени. Использовать addsamples для добавления дополнительных образцов. Например, если указано 1500 проб, функция выполняет 1500 * (2 + number of input parameters) моделирование.

gsaMoreSamples = addsamples(gsaResults,1500)

Свойство ReservateInfo объекта результата содержит различную информацию для вычисления индексов Соболь. Например, данные моделирования модели (SimData) для каждого моделирования с использованием набора выборок параметров хранятся в SimData поле свойства. Это поле представляет собой массив SimData объекты.

sobolResults.SimulationInfo.SimData
 
   SimBiology SimData Array : 1000-by-7
 
   Index:    Name:         ModelName:         DataCount: 
   1           -           Tumor Growth Model 1          
   2           -           Tumor Growth Model 1          
   3           -           Tumor Growth Model 1          
   ...                                                   
   7000        -           Tumor Growth Model 1          
 

Можно узнать, не удалось ли выполнить моделирование модели во время вычисления, проверив ValidSample поле SimulationInfo. В этом примере поле не показывает неудачных прогонов моделирования.

all(sobolResults.SimulationInfo.ValidSample)
ans = 1x7 logical array

   1   1   1   1   1   1   1

SimulationInfo.ValidSample - таблица логических значений. Он имеет тот же размер, что и SimulationInfo.SimData. Если ValidSample указывает на то, что при любом неудачном моделировании можно получить дополнительную информацию об этих прогонах моделирования и образцах, используемых для этих прогонов, путем извлечения информации из соответствующего столбца SimulationInfo.SimDatОтвет. Предположим, что четвертый столбец содержит один или несколько неудачных прогонов моделирования. Получение данных моделирования и значений образцов, используемых для этого моделирования, с помощью getSimulationResults.

[samplesUsed,sd,validruns] = getSimulationResults(sobolResults,4);

Можно добавлять пользовательские выражения в качестве наблюдаемых и вычислять индексы Соболя для добавляемых наблюдаемых. Например, можно вычислить индексы Соболя для максимального веса опухоли, определив пользовательское выражение следующим образом.

% Suppress an information warning that is issued during simulation.
warnSettings = warning('off', 'SimBiology:sbservices:SB_DIMANALYSISNOTDONE_MATLABFCN_UCON');
% Add the observable expression.
sobolObs = addobservable(sobolResults,'Maximum tumor_weight','max(tumor_weight)','Units','gram');

Постройте график вычисленных результатов моделирования, показывающих область квантиля 90%.

h2 = plotData(sobolObs);
h2.Position(:) = [100 100 1280 800];

Figure contains 2 axes. Axes 1 contains 12 objects of type line, patch. These objects represent model simulation, 90.0% region, mean value. Axes 2 contains 12 objects of type line, patch. These objects represent model simulation, 90.0% region, mean value.

Можно также удалить наблюдаемый объект, указав его имя.

gsaNoObs = removeobservable(sobolObs,'Maximum tumor_weight');

Восстановите параметры предупреждения.

warning(warnSettings);

Входные аргументы

свернуть все

Результаты, содержащие индексы Соболя первого и общего порядка, указанные как SimBiology.gsa.Sobol объект.

Индекс для извлечения результатов моделирования в sobolObj.SimulationInfo.SimData, указано как положительное целое число. Индекс должен быть меньше params + 2, где params - количество входных параметров. Дополнительные сведения см. в разделе Получение результатов моделирования и образцов значений с помощью метода getResults.

Типы данных: double

Выходные аргументы

свернуть все

Таблица, содержащая значения выборки параметров, возвращенная в виде таблицы.

Результаты моделирования, полученные с использованием образцов в samplesTable, возвращенный как вектор SimData объекты.

Индикаторы успешного или неуспешного выполнения, возвращенные как логический вектор. Каждый элемент указывает на успешность или неудачу соответствующего прогона моделирования в simdata.

Подробнее

свернуть все

Извлечение результатов моделирования и образцов значений с помощью getSimulationResults

getSimulationResults возвращает i-й столбец из массива SimData sobolObj.SimulationInfo.SimData, которое является одним из свойств объекта.

Как объясняется в Saltelli Method to Compute Sobol Indices, A и B являются матрицами выборки. ABi является матрицей, где все столбцы являются A, за исключением i-го столбца, который является B для i = 1, 2,..., парамов. params - количество входных параметров.

Данные моделирования, используемые для вычисления индексов Соболь, хранятся в sobolObj.SimulationInfo.SimData. Размер массива: NumberSamples-by-params + 2, где NumberSamples - количество выборок. Количество столбцов: 2 + params поскольку первые два столбца соответствуют результатам моделирования из A и B. Остальные столбцы соответствуют AB1, AB2,..., ABparams. Другими словами, можно рассмотреть следующее:

sobolObj. SimulationInfo. SimData = [SimData (A), SimData (B), SimData (AB1), SimData (AB2)..., SimData (ABparams)]

Здесь первый столбец соответствует данным моделирования с использованием матрицы А выборки, второй столбец соответствует данным моделирования с использованием матрицы В выборки, третий столбец соответствует данным моделирования с использованием матрицы AB1 и так далее.

Например, getSimulationResults(sobolObj,3) возвращает:

  • samplesTable (первый выход), который является AB1.

  • simdata (второй вывод), который содержит результаты моделирования с использованием выборок из AB1. Это третий столбец sobolObj.SimulationInfo.SimData.

  • validRuns (третий вывод), который содержит логические значения, указывающие на успех или неудачу каждого прогона моделирования в simdata (второй выход). validRuns соответствует i-му столбцу sobolObj.SimulationInfo.ValidSample.

Ссылки

[1] Сальтелли, Андреа, Паола Аннони, Ивано Адзини, Франческа Камполонго, Марко Ратто и Стефано Тарантола. "Анализ чувствительности выходных данных модели на основе дисперсии. Конструктор и оценщик для общего индекса чувствительности ". Компьютерная физика связи 181, № 2 (февраль 2010): 259-70. https://doi.org/10.1016/j.cpc.2009.09.018.

Представлен в R2020a