Остаток после деления
r = rem(a,b)
возвращает остаток после деления от r = rem(a,b)
a
b
, где a
является дивидендом, и b
является делителем. Эта функция часто вызывается операция остатка, которая может быть выражена как r = a - b.*fix(a./b)
B. Функция rem
следует соглашению, что rem(a,0)
является NaN
.
Найдите остаток после деления для вектора целых чисел и делителя 3
.
a = 1:5; b = 3; r = rem(a,b)
r = 1×5
1 2 0 1 2
Найдите остаток после деления для набора целых чисел и включая положительные и включая отрицательные величины. Обратите внимание на то, что ненулевые результаты имеют тот же знак как дивиденд.
a = [-4 -1 7 9]; b = 3; r = rem(a,b)
r = 1×4
-1 -1 1 0
Найдите остаток после деления для нескольких углов с помощью делителя 2*pi
. Когда возможно, rem
пытается привести к точным целочисленным результатам путем компенсации эффектов округления с плавающей точкой.
theta = [0.0 3.5 5.9 6.2 9.0 4*pi]; b = 2*pi; r = rem(theta,b)
r = 1×6
0 3.5000 5.9000 6.2000 2.7168 0
a
ДивидендДивиденд, заданный как скаляр, вектор, матрица или многомерный массив. a
должен быть массивом с действительным знаком любого числового типа. Числовые входные параметры a
и b
должны или быть одного размера или иметь размеры, которые совместимы (например, a
является M
-by-N
матрица, и b
является скаляром или 1
-by-N
вектор - строка). Для получения дополнительной информации см. "Совместимые размеры массивов для основных операций".
Если a
и b
являются массивами длительности, то они должны быть одного размера, если каждый не скаляр. Если один входной параметр является массивом длительности, другой входной параметр может быть массивом длительности или числовым массивом. В этом контексте rem
обрабатывает числовые значения как многие стандартные 24-часовые дни.
Если один входной параметр имеет целочисленный тип данных, то другой входной параметр должен иметь тот же целочисленный тип данных или является скалярным double
.
Типы данных: единственный
| удваиваются
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
| длительность
| char
b
ДелительДелитель, заданный как скаляр, вектор, матрица или многомерный массив. b
должен быть массивом с действительным знаком любого числового типа. Числовые входные параметры a
и b
должны или быть одного размера или иметь размеры, которые совместимы (например, a
является M
-by-N
матрица, и b
является скаляром или 1
-by-N
вектор - строка). Для получения дополнительной информации см. "Совместимые размеры массивов для основных операций".
Если a
и b
являются массивами длительности, то они должны быть одного размера, если каждый не скаляр. Если один входной параметр является массивом длительности, другой входной параметр может быть массивом длительности или числовым массивом. В этом контексте rem
обрабатывает числовые значения как многие стандартные 24-часовые дни.
Если один входной параметр имеет целочисленный тип данных, то другой входной параметр должен иметь тот же целочисленный тип данных или является скалярным double
.
Типы данных: единственный
| удваиваются
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
| длительность
| char
Концепция остатка после деления исключительно не задана, и две функции mod
и rem
, каждый вычисляет различное изменение. Функция mod
приводит к результату, который является или нулем или имеет тот же знак как делитель. Функция rem
приводит к результату, который является или нулем или имеет тот же знак как дивиденд.
Другим различием является соглашение, когда делитель является нулем. Функция mod
следует соглашению, что mod(a,0)
возвращает a
, тогда как функция rem
следует соглашению, что rem(a,0)
возвращает NaN
.
Оба варианта имеют свое использование. Например, в обработке сигналов, функция mod
полезна в контексте периодических сигналов, потому что его вывод является периодическим (с периодом, равным делителю).
Эта функция полностью поддерживает "высокие" массивы. Для получения дополнительной информации см. Раздел "Высокие массивы".
Указания и ограничения по применению:
Сгенерированный код выполняет арифметику с помощью выходного класса. Результаты не могут совпадать с MATLAB® из-за различий в погрешностях округления.
Если один из входных параметров имеет, вводят int64
или uint64
, то оба входных параметра должны иметь тот же тип.
Указания и ограничения по применению:
64-битные целые числа не поддержаны.
Для получения дополнительной информации смотрите функции MATLAB Выполнения на GPU (Parallel Computing Toolbox).
Эта функция полностью поддерживает распределенные массивы. Для получения дополнительной информации смотрите функции MATLAB Выполнения с Распределенными Массивами (Parallel Computing Toolbox).
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.