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