symReadSSCVariables

Загрузите переменные из компонента Simscape

Синтаксис

[names,values,units] = symReadSSCVariables(componentName)
[names,values,units] = symReadSSCVariables(componentName,'ReturnFunctions',true)

Описание

пример

[names,values,units] = symReadSSCVariables(componentName) возвращает массивы ячеек, содержащие имена, значения и модули всех переменных из компонента Simscape™ под названием componentName.

пример

[names,values,units] = symReadSSCVariables(componentName,'ReturnFunctions',true) возвращает имена как символьные функции переменной t.

Примеры

свернуть все

Загрузите имена, значения и модули переменных компонента Simscape.

Предположим, что у вас есть компонент Simscape friction.ssc в вашей текущей папке.

type('friction.ssc');
component friction < foundation.mechanical.rotational.branch

parameters
    brkwy_trq = { 25, 'N*m' };          % Breakaway friction torque
    Col_trq = { 20, 'N*m' };            % Coulomb friction torque
    visc_coef = { 0.001, 'N*m*s/rad' }; % Viscous friction coefficient
    trans_coef = { 10, 's/rad' };       % Transition approximation coefficient
    vel_thr = { 1e-4, 'rad/s' };        % Linear region velocity threshold
end

parameters (Access=private)
    brkwy_trq_th = { 24.995, 'N*m' };   % Breakaway torque at threshold velocity
end

function setup
    % Parameter range checking
    if brkwy_trq <= 0
        pm_error('simscape:GreaterThanZero','Breakaway friction torque' )
    end
    if Col_trq <= 0
        pm_error('simscape:GreaterThanZero','Coulomb friction torque' )
    end
    if Col_trq > brkwy_trq
        pm_error('simscape:LessThanOrEqual','Coulomb friction torque',...
                 'Breakaway friction torque')
    end
    if visc_coef < 0
        pm_error('simscape:GreaterThanOrEqualToZero','Viscous friction coefficient')
    end
    if trans_coef <= 0
        pm_error('simscape:GreaterThanZero','Transition approximation coefficient')
    end
    if vel_thr <= 0
        pm_error('simscape:GreaterThanZero','Linear region velocity threshold')
    end

    % Computing breakaway torque at threshold velocity
    brkwy_trq_th = visc_coef * vel_thr + Col_trq + (brkwy_trq - Col_trq) * ...
        exp(-trans_coef * vel_thr);
end

equations
    if (abs(w) <= vel_thr)
        % Linear region
        t == brkwy_trq_th * w / vel_thr;
    elseif w > 0
        t == visc_coef * w + Col_trq + ...
            (brkwy_trq - Col_trq) * exp(-trans_coef * w);
    else
        t == visc_coef * w - Col_trq - ...
            (brkwy_trq - Col_trq) * exp(-trans_coef * abs(w));
    end
end

end

Загрузите имена, значения и модули переменных friction.ssc компонента.

[names,values,units] = symReadSSCVariables('friction.ssc');

В этом примере все элементы получившихся массивов ячеек являются скалярами. Можно преобразовать массивы ячеек в символьные векторы.

names_sym = cell2sym(names)
names_sym =
[ t, w]
values_sym = cell2sym(values)
values_sym =
[ 0, 0]

Создайте отдельные символьные переменные из элементов массива ячеек names в рабочей области MATLAB®. Эта команда создает символьные переменные t и w, когда sym возражает в рабочей области.

syms(names)

Загрузите имена переменных компонента Simscape при преобразовании их в символьные функции переменной t.

Предположим, что у вас есть компонент Simscape source.ssc в вашей текущей папке.

type('source.ssc');
component source
% Electrical Source
% Defines an electrical source with positive and negative external nodes.
% Also defines associated through and across variables.

nodes
    p = foundation.electrical.electrical; % :top
    n = foundation.electrical.electrical; % :bottom
end

variables(Access=protected)
    i = { 0, 'A' }; % Current
    v = { 0, 'V' }; % Voltage
end

branches
    i : p.i -> n.i;
end

equations
     v == p.v - n.v;
end

end

Загрузите имена переменных source.ssc компонента установкой 'ReturnFunctions' к true.

[names,~,~] = symReadSSCVariables('source.ssc','ReturnFunctions',true);

В этом примере все элементы получившихся массивов ячеек являются скалярами. Можно преобразовать массивы ячеек в символьные векторы.

names_symfun = cell2sym(names)
names_symfun =
[ i(t), v(t)]

Создайте отдельные символьные функции из элементов массива ячеек names в рабочем пространстве MATLAB. Эта команда создает символьные функции i и v, когда symfun возражает, и их переменная t как объект sym в рабочей области.

syms(names)

Входные параметры

свернуть все

Имя компонента Simscape, заданное как имя файла, заключено в одинарные кавычки. Файл должен иметь дополнительный .ssc. Если вы не обеспечиваете расширение файла, symReadSSCVariables принимает его, чтобы быть .ssc. Компонент должен быть на пути MATLAB или в текущей папке.

Пример: 'MyComponent.ssc'

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

свернуть все

Имена всех переменных компонента Simscape, возвращенного как массив ячеек.

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

Значения всех переменных компонента Simscape, возвращенного как массив ячеек.

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

Модули всех переменных компонента Simscape, возвращенного как массив ячеек.

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

Смотрите также

|

Введенный в R2016a

Для просмотра документации необходимо авторизоваться на сайте