setfimath

Присоедините объект fimath к fi объект

Синтаксис

Описание

пример

y = setfimath(x,f) возвращает fi объект, y, с xnumerictype и значение, и присоединенный объект fimath, f. Эта функция и связанные removefimath функция используется для предотвращения ошибок в embedded.fimath обоих операндов, которые должны быть равными.

The y = setfimath (x, f) синтаксис не изменяет вход, x. Изменение x, использовать x = setfimath(x,f). Если вы используете setfimath в выражении, таком как a*setfimath(b,f)объект fimath используется во временной переменной, но b не изменяется.

Примеры

свернуть все

Задайте fi object, задайте fimath объект и использование setfimath для присоединения fimath объект для fi объект.

Создайте fi объект без fimath объект.

a = fi(pi)
a = 
    3.1416

          DataTypeMode: Fixed-point: binary point scaling
            Signedness: Signed
            WordLength: 16
        FractionLength: 13

Создайте fimath объект и прикрепить его к fi объект.

f = fimath('OverflowAction','Wrap','RoundingMethod','Floor');
b = setfimath(a,f)
b = 
    3.1416

          DataTypeMode: Fixed-point: binary point scaling
            Signedness: Signed
            WordLength: 16
        FractionLength: 13

        RoundingMethod: Floor
        OverflowAction: Wrap
           ProductMode: FullPrecision
               SumMode: FullPrecision

Используйте шаблон x = setfimath(x,f) и y = removefimath(y) для изоляции переменных от fimath настройки вне функции. Этот шаблон не создает копии данных в сгенерированном коде.

function y = fixed_point_32bit_KeepLSB_plus_example(a,b)
   f = fimath('OverflowAction','Wrap',...
      'RoundingMethod','Floor',...
      'SumMode','KeepLSB',...
      'SumWordLength',32);
   a = setfimath(a,f);
   b = setfimath(b,f);
   y = a + b;
   y = removefimath(y);
end
 

Если у вас есть MATLAB® Coder™ продукта вы можете сгенерировать код С Этот пример генерирует код С на компьютере с 32-битным собственным целым типом.

a = fi(0,1,16,15);
b = fi(0,1,16,15);
codegen -config:lib  fixed_point_32bit_KeepLSB_plus_example...
       -args {a,b} -launchreport
     
int fixed_point_32bit_KeepLSB_plus_example(short a, short b)
{
  return a + b;
}

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

свернуть все

Входные данные, заданные как fi объект или встроенное целочисленное значение, из которого можно скопировать тип данных и значение в выход. x должен быть fi объект или целочисленный тип данных (int8, int16, int32, int64, uint8, uint16, uint32, или uint64). В противном случае объект fimath не применяется. Если x не является fi объект или целочисленный тип данных, y = x.

Входные fimath объект, заданный как существующий объект fimath для присоединения к выходу. Ошибка возникает, если f не является fimath объект.

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

свернуть все

Выходные fi объект, возвращенный как fi объект с совпадающим типом данных и значением, что и x вход. y также имеет прикрепленный fimath объект, f. Если вход, x, не является fi объект или целочисленный тип данных, затем y = x.

Расширенные возможности

Генерация кода C/C + +
Сгенерируйте код C и C++ с помощью Coder™ MATLAB ®

.

См. также

| |

Введенный в R2012b