setfimath

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

Синтаксис

Описание

пример

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

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

Примеры

свернуть все

Задайте fi возразите, задайте 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 возразите или целочисленный тип данных (int8int16int32int64uint8uint16uint32, или uint64). В противном случае объект fimath не применяется. Если x не fi тип данных Object или целочисленный тип данных, y = x.

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

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

свернуть все

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

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

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

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

| |

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