exponenta event banner

removefimath

Удалить объект fimath из fi объект

Синтаксис

Описание

пример

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

Примеры

свернуть все

В этом примере показано, как определить fi объект, определите объект fimath, присоедините fimath объект для fi объект, а затем удалите прикрепленный fimath объект.

a = fi(pi)
a = 
    3.1416

          DataTypeMode: Fixed-point: binary point scaling
            Signedness: Signed
            WordLength: 16
        FractionLength: 13
f = fimath('RoundingMethod','Floor','OverflowAction','Wrap');
a = setfimath(a,f)
a = 
    3.1416

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

        RoundingMethod: Floor
        OverflowAction: Wrap
           ProductMode: FullPrecision
               SumMode: FullPrecision
b = removefimath(a)
b = 
    3.1416

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

Использовать шаблон 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™ можно создать код C. В этом примере код C генерируется на компьютере с 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). Если x не является объектом fi или целым типом данных, то y = x.

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

свернуть все

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

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

Создание кода C/C + +
Создайте код C и C++ с помощью MATLAB ® Coder™

.

См. также

| |

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