ismaxphase

Определите, является ли фильтр максимально-фазовым

Синтаксис

flag = ismaxphase(b,a)
flag = ismaxphase(sos)
flag = ismaxphase(d)
flag = ismaxphase(...,tol)
flag = ismaxphase(h)

Описание

flag = ismaxphase(b,a) возвращает логический выходной параметр, flag, равняйтесь true если фильтр, заданный коэффициентами числителя, b, и коэффициенты знаменателя, a, максимальный фильтр фазы.

flag = ismaxphase(sos) возвращает true если фильтр, заданный вторым порядком, разделяет матрицу, sos, максимальный фильтр фазы. sos K-by-6 матрица, где количество разделов, K, должно быть больше или быть равно 2. Каждая строка sos соответствует коэффициентам второго порядка (biquad) фильтр. i th строка sos матрица соответствует [bi(1) bi(2) bi(3) ai(1) ai(2) ai(3)].

flag = ismaxphase(d) возвращает true если цифровой фильтр, d, имеет максимальную фазу. Используйте designfilt сгенерировать d на основе технических требований частотной характеристики.

flag = ismaxphase(...,tol) использует допуск, tol, определить, когда два числа достаточно близки, чтобы быть рассмотренными равными. Если не заданный, tol, значения по умолчанию к eps^(2/3).

 Детали для вычислений с фиксированной точкой

flag = ismaxphase(h) возвращает true если dfilt объект фильтра h максимальный фильтр фазы.

Примеры

свернуть все

Спроектируйте максимальную фазу и фильтры решетки минимальной фазы и проверьте их тип фазы.

k = [1/6 1/1.4];
bmax = latc2tf(k,'max');
bmin = latc2tf(k,'min');
max_flag = ismaxphase(bmax)
max_flag = logical
   1

min_flag = isminphase(bmin)
min_flag = logical
   1

Учитывая фильтр, заданный с набором числителя одинарной точности и коэффициентов знаменателя, проверяйте, является ли это максимальная фаза для различных значений допуска.

b = single([1 -0.9999]);
a = single([1 0.45]);
max_flag1 = ismaxphase(b,a)
max_flag1 = logical
   0

max_flag2 = ismaxphase(b,a,1e-3)
max_flag2 = logical
   1

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

| | | | |

Введенный в R2013a