Сохраните переменные рабочей области и их значения в формате кода MATLAB
Simulink.saveVars(
filename
)
Simulink.saveVars(filename
, VarNames
)
Simulink.saveVars(filename
,
'-regexp', RegExps
)
Simulink.saveVars(filename
, Specifications,
UpdateOption
)
Simulink.saveVars(filename
, Specifications,
Configuration
)
Simulink.saveVars(filename
, Specifications
, MatlabVer
)
[r1
, r2
]
= Simulink.saveVars(filename
, Specifications
)
Примечание
Simulink.saveVars
не рекомендуется. Использование matlab.io.saveVariablesToScript
вместо этого.
Simulink.saveVars(
сохраняет все переменные в текущей рабочей области, для которой код MATLAB® может быть сгенерирован к файлу MATLAB под названием filename
)
. Если код MATLAB не может быть сгенерирован для переменной, переменная сохранена в сопутствующий MAT-файл под названием filename
M
, и предупреждение сгенерировано. Если любой файл уже существует, он перезаписывается. filename
.matfilename
не может совпадать с именем никакой переменной в текущей рабочей области и может опционально включать суффиксный .m
. Используя Simulink.saveVars
не оказывает влияния на содержимое никакой рабочей области.
Выполнение файла MATLAB восстанавливает переменные, сохраненные в файле к текущей рабочей области. Если сопутствующий MAT-файл существует, код в файле MATLAB загружает MAT-файл, восстанавливая его переменные также. Когда и файл MATLAB и MAT-файл существуют, не загружайте файл MATLAB, если файл MAT не будет доступен, или ошибка произойдет. Не загружайте MAT-файл непосредственно, или восстановление неполных данных закончится. Никакое предупреждение не происходит, если загрузка файла перезаписывает любые существующие переменные.
Можно отредактировать файл MATLAB что Simulink.saveVars
создает. Можно вставить комментарии между или в разделах кода MATLAB для сохраненных переменных. Однако, если вы дальнейшее использование Simulink.saveVars
чтобы обновиться или добавить к файлу, только комментирует между разделами кода MATLAB, будет сохранен. Внутренние комментарии должны поэтому использоваться только в файлах, которые вы не ожидаете изменять дальше.
Вы не должны редактировать раздел заголовка в файле MATLAB, который включает первые пять строк с комментариями. Simulink® не проверяет, что вручную отредактированный файл MATLAB синтаксически правилен. MathWorks рекомендует не редактировать код MATLAB в файле. Вы не можете отредактировать MAT-файл и никогда не должны пытаться сделать так.
Simulink.saveVars(
сохраняет только переменные, заданные в filename
, VarNames
)VarNames
, который является списком, разделенным запятыми имен переменных. Можно использовать подстановочный символ *
сохранить все переменные, которые совпадают с шаблоном. *
соответствия один или несколько символов, включая неалфавитно-цифровые символы.
Simulink.saveVars(
сохраняет только переменные, имена которых совпадают с одним из регулярных выражений в filename
,
'-regexp', RegExps
)RegExps
, который является списком, разделенным запятыми выражений. Смотрите Регулярные выражения для получения дополнительной информации. Вызов функции может задать оба VarNames
и-regexps
, в том порядке и разделенный от запятой.RegExps
Simulink.saveVars(
сохраняет переменные, описанные filename
, Specifications,
UpdateOption
)Specifications
(который представляет переменные технические требования в любом из вышеупомянутых синтаксисов), как направлено UpdateOption
, который может быть любым из следующего:
'-create'
— Создайте новый файл MATLAB (и MAT-файл в случае необходимости), как направлено Specifications
. Если любой файл уже существует, он перезаписывается. Это поведение по умолчанию.
'-update'
— Обновите существующий файл MATLAB (и MAT-файл в случае необходимости) заданный filename
путем заменения только переменных, которые совпадают с Specifications
и уже существуйте в любых файлах. Порядок переменных в файлах сохраняется. Комментарии в разделах кода MATLAB не сохраняются.
'-append'
— Обновите существующий файл MATLAB (и MAT-файл в случае необходимости) заданный filename
:
Обновление переменных, которые совпадают с Specifications
и уже существуйте в файле или файлах, сохраняя существующий порядок в файле или файлах. Комментарии в разделах кода MATLAB не сохраняются.
Добавление переменных, которые совпадают с Specifications
и не существуйте в файле или файлах путем добавления переменных к файлу или файлам. Эти новые разделы первоначально не имеют никаких комментариев.
Simulink.saveVars(
сохраняет переменные, описанные filename
, Specifications,
Configuration
)Specifications
(который представляет переменные технические требования в любом из вышеупомянутых синтаксисов) согласно заданному Configuration
. Configuration
может содержать любые из следующих опций, в любом порядке, разделенном запятыми, если больше чем один появляется:
'-maxnumel'
— Ограничивает число элементов, сохраненное для массива к MaxNum
MaxNum
, который должен быть целым числом между 1 и 10000. Для символьного массива верхний предел устанавливается к дважды значению, которое вы задаете с MaxNum
. Если массив больше, чем MaxNum
, целый массив появляется в MAT-файле, а не файле MATLAB, генерируя предупреждение. Значение по умолчанию: 1000
'-maxlevels'
MaxLevels
ограничивает количество уровней иерархии, сохраненной для массива структур или массива ячеек к MaxLevels
, который должен быть целым числом между 1 и 200. Если массив структур или массив ячеек более глубоки, чем MaxLevels
, целая сущность появляется в MAT-файле, а не файле MATLAB, генерируя предупреждение. Значение по умолчанию: 20
'-textwidth'
TextWidth
наборы текст переносят ширину в файл MATLAB к TextWidth
, который должен быть целым числом между 32 и 256. Значение по умолчанию: 76
'-2dslice'
— Наборы две размерности для 2D срезов, которые представляют n-D (где n
больше 2) char, логики или данных о числовом массиве. Simulink.saveVars
использует первые две размерности n-D массива, чтобы задать размер 2D среза, если вы не предоставляете два положительных целочисленных аргумента после -2dslice
опция. Если вы задаете два целочисленных аргумента:
Эти два целых числа должны быть положительными.
Эти два целых числа должны быть меньше чем или равны количеству размерностей n-D массива.
Второе целое число должно быть больше первого.
Simulink.saveVars(
действия, аналогичные описанному filename
, Specifications
, MatlabVer
)Specifications
(который представляет технические требования после filename
в любом из вышеупомянутых синтаксисов) сохраняющий любой MAT-файл, который это создает в формате, требуемом версией MATLAB, заданной MatlabVer
. Возможные значения:
'-v7.3'
— 7.3 или позже
'-v7.0'
— 7.0 или позже
'-v6'
— Версия 6 или позже
'-v4'
— Любая версия MATLAB
[
действия, аналогичные описанному r1
, r2
]
= Simulink.saveVars(filename
, Specifications
)Specifications
(который представляет технические требования после filename
в любом из вышеупомянутых синтаксисов) и отчеты, какие переменные это имеет сохраненный:
r1
— Массив ячеек из символьных векторов. Векторы символов называют все переменные (если таковые имеются), которые были сохранены в файл MATLAB.
r2
— Массив ячеек из символьных векторов. Векторы символов называют все переменные (если таковые имеются), которые были сохранены в MAT-файл.
|
Имя файла или имена файлов, которые функция создает или обновляет. |
|
Переменная или последовательность разделенных от запятой переменных. Функция сохраняет только заданные переменные в выходной файл. Можно использовать подстановочный символ |
|
После ключевого слова, регулярного выражения или последовательности разделенных от запятой регулярных выражений. Функция сохраняет в выходной файл только те переменные, имена которых совпадают с одним из выражений. Смотрите Регулярные выражения для получения дополнительной информации, вызов функции может задать оба |
|
Любое из трех ключевых слов, которые управляют действием функции. Возможные значения:
Значение по умолчанию: |
|
Любые из следующих опций, в любом порядке, разделенном запятыми, если больше чем один появляется:
Примечание Можно использовать Настройки MATLAB, чтобы изменить значения по умолчанию для |
|
Задает версию MATLAB, синтаксис которой будет использоваться любым MAT-файлом, сохраненным функцией.
Значение по умолчанию: |
|
Список имен всех переменных (если таковые имеются), которые были сохранены в файл MATLAB. |
|
Список имен всех переменных (если таковые имеются), которые были сохранены в MAT-файл. |
Задайте некоторые переменные базового рабочего пространства, затем сохраните их всех в новый файл MATLAB под названием MyVars.m
использование значений по умолчанию для всех входных параметров кроме filename
.
a = 1; b = 2.5; c = 'A string'; d = {a, b, c}; Simulink.saveVars('MyVars');
Задайте дополнительные переменные базового рабочего пространства, затем добавьте их к существующему файлу MyVars.m
не изменяя значения, ранее сохраненные в файле:
K = Simulink.Parameter; MyType = fixdt (1,16,3); Simulink.saveVars('MyVars', '-append', 'K', 'MyType');
Обновите переменные V1
и V2
с их значениями в файле MATLAB, или для любого, значение которого не может быть преобразовано в код MATLAB в MAT-файле. Файл должен уже существовать. Любой массив больше чем с 10 элементами будет сохранен в MAT-файл, который может загрузиться на любой версии MATLAB. Возвращаемый аргумент r1
перечисляет имена любых переменных, сохраненных в файл MATLAB; r2
списки любой сохраненный в MAT-файл.
[r1, r2] = Simulink.saveVars('MyFile', 'V1', 'V2', '-update', '-maxnumel', 10, '-v4');
Задайте 2D срез для выхода my3Dtable
Трехмерный массив. Укажите, что 2D срез расширяется по первым и третьим измерениям:
my3DTable = zeros(3, 4, 2, 'single'); Simulink.saveVars('mfile.m', 'my3DTable', '-2dslice', 1, 3);
Сгенерированный код MATLAB:
my3DTable = zeros(3, 4, 2, 'single'); my3DTable (:,1,:) = single ( ... [1 13; 5 17; 9 21]); my3DTable (:,2,:) = single( ... [2 14; 6 18; 10 22]); my3DTable (:,3,:) = single( ... [3 15; 7 19; 11 23]); my3DTable (:,4,:) = single( ... [4 16; 8 20; 12 24]);
Simulink.saveVars
функция:
Не сохраняет совместно использованные ссылки.
Игнорирует динамические свойства объектов.
Сохраняет следующее в MAT-файл несмотря на то, что они могли появиться в файле MATLAB:
Simulink.ConfigSet
объекты с пользовательскими целевыми компонентами.
(Используйте Simulink.ConfigSet
метод saveAs
вместо этого.)
и Simulink.Timeseries
объекты.Simulink.ModelDataLogs
Если вы сохраняете много переменных, сгенерированный файл MATLAB может содержать много строк кода и занять много времени, чтобы выполниться. Чтобы избежать долгого времени выполнения, рассмотрите эти альтернативы:
Постоянно сохраните переменные в словаре данных вместо использования Simulink.saveVars
. Словарь данных также обеспечивает больше инструментов для переменных управления. Смотрите Определяют, Где Сохранить Переменные и Объекты для Моделей Simulink.
Сохраните переменные в MAT-файле при помощи save
функция.
Если вы не должны сохранять переменные в понятной форме, смотрите save
функция.
Если необходимо сохранить только объекты шины, используйте Simulink.Bus.save
функция.
Если необходимо сохранить только конфигурацию модели, используйте Simulink.ConfigSet
.saveAs
метод.
matlab.io.saveVariablesToScript
| save
| Simulink.Bus.save
| Simulink.Bus.save
| Simulink.ConfigSet