movmad

Скользящее медианное абсолютное отклонение

Описание

пример

M = movmad(A,k) возвращает массив локального k- укажите средние абсолютные отклонения (MADs), где каждый MAD вычисляется по раздвижному окну длины k через соседние элементы AM одного размера с A.

Когда k является нечетным, окно сосредоточено об элементе в текущем положении. Когда k является четным, окно сосредоточено о текущих и предыдущих элементах. Размер окна является автоматически усеченным в конечных точках, когда существует недостаточно элементов, чтобы заполнить окно. Когда окно является усеченным, MAD взят только по элементам, которые заполняют окно.

  • Если A вектор, затем movmad действует вдоль вектора.

  • Если A многомерный массив, затем movmad действует вдоль первого измерения массива, размер которого не равняется 1.

пример

M = movmad(A,[kb kf]) вычисляет Обезумевшее от окна длины kb+kf+1 это включает элемент в текущее положение, kb элементы назад и kf элементы вперед.

пример

M = movmad(___,dim) вычисляет MAD по измерению dim для любого из предыдущих синтаксисов. Например, movmad(A,k,2) для матричного A действует через столбцы A, вычисление k- скользящий MAD элемента для каждой строки.

пример

M = movmad(___,nanflag) задает, включать ли или не использовать NaN значения от вычисления для любого из предыдущих синтаксисов. movmad(A,k,'includenan') включает весь NaN значения в вычислении, которое является значением по умолчанию. movmad(A,k,'omitnan') игнорирует их и вычисляет MAD по меньшему количеству точек.

пример

M = movmad(___,Name,Value) задает дополнительные параметры для движущегося MAD с помощью одного или нескольких аргументов пары "имя-значение". Например, если x вектор из временных стоимостей, затем movmad(A,k,'SamplePoints',x) вычисляет движущийся MAD A относительно времен в x.

Примеры

свернуть все

Вычислите движущийся MAD в центре с тремя точками вектора-строки. Когда существует меньше чем три элемента в окне в конечных точках, вычисляют по элементам, которые доступны.

A = [1 2 4 -1 -2 -3 -1 3 2 1];
M = movmad(A,3)
M = 1×10

    0.5000    1.0000    2.0000    1.0000    1.0000    1.0000    2.0000    1.0000    1.0000    0.5000

Вычислите запаздывание с тремя точками движущийся MAD вектора-строки. Когда существует меньше чем три элемента в окне в конечных точках, вычисляют по элементам, которые доступны.

A = [1 2 1 -1 -2 -3 -1 3 4 1];
M = movmad(A,[2 0])
M = 1×10

         0    0.5000         0    1.0000    1.0000    1.0000    1.0000    2.0000    1.0000    1.0000

Вычислите движущийся MAD в центре с 3 точками для каждой строки матрицы. Аргумент размерности равняется 2, который двигает окно через столбцы A. Окно запускается на первой строке, скользит горизонтально в конец строки, затем перемещается во вторую строку и так далее.

A = [1 2 1; -1 -2 -3; -1 3 4]
A = 3×3

     1     2     1
    -1    -2    -3
    -1     3     4

M = movmad(A,3,2)
M = 3×3

    0.5000         0    0.5000
    0.5000    1.0000    0.5000
    2.0000    1.0000    0.5000

Вычислите движущийся MAD в центре с тремя точками вектора-строки, содержащего два NaN элементы.

A = [2 1 NaN -1 -2 -3 NaN 3 4 1];
M = movmad(A,3)
M = 1×10

    0.5000       NaN       NaN       NaN    1.0000       NaN       NaN       NaN    1.0000    1.5000

Повторно вычислите движущийся MAD, не использующий NaN значения. Когда movmad отбрасывания NaN элементы, это вычисляет по остающимся элементам в окне.

M = movmad(A,3,'omitnan')
M = 1×10

    0.5000    0.5000    1.0000    0.5000    1.0000    0.5000    3.0000    0.5000    1.0000    1.5000

Вычислите 3-часовой движущийся MAD в центре данных в A согласно временному вектору t.

A = [4 8 6 -1 -2 -3];
k = hours(3);
t = datetime(2016,1,1,0,0,0) + hours(0:5)
t = 1x6 datetime
Columns 1 through 3

   01-Jan-2016 00:00:00   01-Jan-2016 01:00:00   01-Jan-2016 02:00:00

Columns 4 through 6

   01-Jan-2016 03:00:00   01-Jan-2016 04:00:00   01-Jan-2016 05:00:00

M = movmad(A,k,'SamplePoints',t)
M = 1×6

    2.0000    2.0000    2.0000    1.0000    1.0000    0.5000

Вычислите движущийся MAD в центре с тремя точками вектора-строки, но отбросьте любое вычисление, которое использует меньше чем три точки от выхода. Другими словами, возвратите только MADs, вычисленный из полного трехэлементного окна, отбросив вычисления конечной точки.

A = [1 2 1 -1 -2 -3 -1 3 4 1];
M = movmad(A,3,'Endpoints','discard')
M = 1×8

     0     1     1     1     1     2     1     1

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

свернуть все

Входной массив, заданный как векторный, матричный или многомерный массив.

Типы данных: double | single | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical

Длина окна в виде числового скаляра или скаляра длительности. Когда k положительный целочисленный скаляр, MAD в центре включает элемент в текущее положение плюс окружение соседей. Например, MAD с тремя точками, заданный окном длины три результата в следующем вычислении для векторного A:

Типы данных: double | single | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | duration

Направленная длина окна в виде числового вектора-строки или вектора-строки длительности, содержащего два элемента. Когда kb и kf положительные целочисленные скаляры, вычисление по kb+kf+1 элементы. Вычисление включает элемент в текущее положение, kb элементы перед текущим положением и kf элементы после текущего положения. Например, MAD с четырьмя точками задан направленным окном [2 1] результаты в следующем вычислении для векторного A:

Типы данных: double | single | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | duration

Величина для работы, заданная как положительный целый скаляр. Если значение не задано, то по умолчанию это первый размер массива, не равный 1.

Рассмотрите матричный A.

  • Если dim = 1, затем movmad(A,k,1) запускается с первого столбца и скользит вертикально по каждой строке. MAD вычисляется по k элементы за один раз. Затем это перемещается во второй столбец и повторяет расчет. Этот процесс продолжается, пока все столбцы не исчерпываются.

  • Если dim = 2, затем movmad(A,k,2) запускается с первой строки и скользит горизонтально по каждому столбцу, вычисляющему по k элементы за один раз. Затем это перемещается во вторую строку и повторяет расчет. Этот процесс продолжается, пока все строки не исчерпываются.

Типы данных: double | single | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

NaN условие в виде одного из этих значений:

  • 'includenan' — Включайте NaN значения от входа при вычислении MAD, приведении к NaN вывод .

  • 'omitnan' — Проигнорируйте весь NaN значения во входе. Если окно содержит только NaN значения, затем movmad возвращает NaN.

Аргументы в виде пар имя-значение

Задайте дополнительные разделенные запятой пары Name,Value аргументы. Name имя аргумента и Value соответствующее значение. Name должен появиться в кавычках. Вы можете задать несколько аргументов в виде пар имен и значений в любом порядке, например: Name1, Value1, ..., NameN, ValueN.

Пример: M = movmad(A,k,'Endpoints','fill')

Метод, чтобы обработать окна около конечных точек в виде разделенной запятой пары, состоящей из 'Endpoints' и одно из следующего:

'Endpoints' ЗначениеОписание
'shrink'Уменьшите размер окна около конечных точек входа, чтобы включать только существующие элементы.
'discard'Не выводите значения MAD, когда окно не полностью перекроется с существующими элементами.
'fill'Замените несуществующие элементы на NaN.
числовой или логический скалярЗамените несуществующие элементы на заданное числовое или логическое значение.

Типы данных: double | single | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical | char | string

Точки выборки для вычисления MADs в виде разделенной запятой пары, состоящей из 'SamplePoints' и вектор. Точки выборки представляют местоположения данных в A. Точки выборки не должны быть однородно произведены. По умолчанию вектором точек выборки является [1 2 3 ... ].

Движущиеся окна заданы относительно точек выборки, которые должны быть отсортированы и содержать уникальные элементы. Например, если t вектор времен, соответствуя входным данным, затем movmad(rand(1,10),3,'SamplePoints',t) имеет окно, которое представляет временной интервал между t(i)-1.5 и t(i)+1.5.

Когда вектор точек выборки имеет тип данных datetime или duration, затем движущаяся длина окна должна иметь, вводят duration.

Если точки выборки расположены с неоднородными интервалами и 'Endpoints' пара "имя-значение" задана, затем ее значением должен быть 'shrink'.

Типы данных: double | single | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | datetime | duration

Больше о

свернуть все

Среднее абсолютное отклонение

Для вектора случайной переменной A составил из скалярных наблюдений N, среднее абсолютное отклонение (MAD) задано как

MAD = median(|Aimedian(A)|)

для i = 1,2,...,N.

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

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

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

| | | |

Введенный в R2017a