Como os pólos e zeros afetam a magnitude da resposta em frequência de um sistema?
Anteriormente (no tópico: [Funções Trasferência]) foi mostrado como a localização dos pólos e zeros afeta os contornos da superfície de um sistema:
Neste documento, será mostrado como os pólos e zeros afetam a resposta de frequência de um sistema usando vários exemplos. Você pode achar que o primeiro exemplo não é muito claro, mas se você relacionar cada um dos exemplos entre si, isso pode ajudar na sua compreensão.
Para o primeiro exemplo, será usado o sistema fornecido pelo diagrama de fluxo de sinal mostrado abaixo. Também são fornecidas a equação de diferenças de sistemas e a função de transferência.
A eq. de diferenças do sistema ilustrado acima fica:
Trabalhando esta expressão algebricamente:
Que rende a seguinte função transferência:
eue rende a seguinte função transferência
Neste função percebemos 2 zeros (raízes do numerador), localizados em .
Adicionalmente temos pólos em .
Os pólos correspondem às raízes do denominador de .
Um diagrama pólo-zero deste sistema rende:
Usando a função bode()
do Matlab para sistemas discretos (no plano-z), rende algo como:
Note que o próprio Matlab alerta para a forma como calcula este diagrama:
Para modelos de tempo discreto com tempo de amostragem ,
bode()
usa a transformação para mapear o círculo unitário para o eixo real de frequência. A resposta de frequência é plotada apenas para frequências menores que a frequência de Nyquist (rad) ou (graus), e o valor padrão 1, para unidade de tempo (= 1 segundo), é assumido quando não é especificado.
O gráfico anterior foi feito usando os comandos:
x>> H=tf([1 0 0.64],[1 1.1314 0.64],1)
H =
z^2 + 0.64
--------------------
z^2 + 1.131 z + 0.64
Sample time: 1 seconds
Discrete-time transfer function.
>> bode(H)
Podemos usar a função bodeplot()
que agrega mais opções para melhorar o gráfico anterior:
xxxxxxxxxx
>> handler=bodeplot(H);
>> setoptions(handler,'FreqUnits','Hz','PhaseVisible','off');
>> xlim([1/(2*10) 1/2])
E então temos o gráfico:
Note que o "eixo " (das frequências), ainda está na escala logarítmica ().
Modificando para variação linear do eixo (frequências) obtemos um gráfico mais útil:
xxxxxxxxxx
>> setoptions(handler,'FreqScale','linear');
Note que o Matlab vai variar a frequência deste "Diagrama de Bode" até a metade da frequência de Nyquist. Neste caso: Hz, então, o diagrama só avança até 0,5 Hz.
Este gráfico indica um pico de atenuação do sinal de entrada na frequência aproximada de 0,243 Hz ou, se considerarmos um gráfico genérico, temos que considerar que corresponde à .
No caso anterrior, quando ingressamos a transfer function no Matlab, somos "obrigados" à especificar um período de amostragem, e neste caso foi adotado segundo, o que corresponde à Hz. Mas o sistema será implementado usando segundos !?
Se este sistema for amostrado à Hz, o pico de atenuação de sinal ( dB) terá ocorrido em Hz. Ou:
xxxxxxxxxx
>> H=tf([1 0 0.64],[1 1.1314 0.64], 1/100)
H =
z^2 + 0.64
--------------------
z^2 + 1.131 z + 0.64
Sample time: 0.01 seconds
Discrete-time transfer function.
>> % Note que H(z) não mudou (em relação à fs = 1 Hz)
>> % Mas o "diagrama de Bode" vai mudar
>> handler=bodeplot(H);
>> setoptions(handler,'FreqUnits','Hz','FreqScale','linear','PhaseVisible','off');
>> xlim([100/(2*10) 100/2]) % iniciando uma década abaixo de fs/2 até fs/2
>> grid
Voltando ao primeiro gráfico usando Hz, seu diagrama completo (amplitudes e fase frequência) rende:
Note que o gráfico anterior corresponde à vista superior de um gráfico de superfície da função :
Pode-se perceber os picos positivos associados com os zeros de e os picos negativos associados com os pólos de . Uma "vista superior" rende:
Gráficos gerados usando script:
xxxxxxxxxx
z_real_vals = [-1.2:0.125:1.2]; % z_real_vals = [-1.2:0.02:1.2];
z_imag_vals = [-1.2:0.125:1.2];
for m = 1: length(z_real_vals)
for n = 1: length(z_imag_vals)
z = z_real_vals(m)+z_imag_vals(n)*j;
H_z(n,m) = (z*z+0.64)/(z*z+1.1314*z+0.64);
end
end
figure
[X,Y,Z]=cylinder(1); % cria cilindro "3D", raio=1
Z1=Z*20; % alturas -20 e +20 para anéis circulares cilindro
Z2=Z*(-20);
u=length(Z);
h1=surf (X, Y, Z1);
h1.FaceAlpha = 0.5;
hold on
h2=surf (X, Y, Z2);
h2.FaceAlpha = 0.5;
% gráfico de superfície de H(z)
h3=surf(z_real_vals, z_imag_vals, 20*log10(abs(H_z)));
h3.FaceAlpha = 0.8;
xlabel('Re\{z\}')
ylabel('Im\{z\}')
zlabel('Magnitude (dB)')
title('H(z)')
Perceba mais alguns detalhes comparando o gráfico anterior com o diagrama de pólos e zeros:
Gráfico de superfície de | Diagrama pólo-zero |
---|---|
Perceba a intersecção entre o círculo unitário e a superfície formada por . A figura abaixo mostra os pontos de intersecção que o cilindro faria com o superfície de , mostrada como linhas de cores diferentes (azul, verde, vermelho e amarelo):
Uma vista superior plana (com um diagrama de pólo zero sobreposto) mostra que a linha azul está associada ao intervalo de ângulos de a (rad) (0 à ) e a linha verde está associada aos ângulos de à radianos ( à ). Você também deve observar que os contornos das linhas azuis e amarelas serão “espelhados” no eixo real. Da mesma forma, as linhas de contorno verdes e vermelhas serão “espelhadas” ao longo do eixo real:
Se você traçasse a magnitude dos pontos de intersecção em relação ao ângulo feito com o eixo real, na faixa de ângulos de a radianos ( à ), (ou seja, plotasse a amplitude das linhas coloridas de interseção em relação ao ângulo), você obteria o gráfico mostrado abaixo:
Você notará que o lado esquerdo do gráfico acima "espelha” o lado direito. Traçar o lado direito, de 0 a radianos (ou de 0 até ), por si só resulta no gráfico a seguir:
Note que o aumento da magnitude no ângulo de é causado pelo "contorno do cone" associado ao pólo localizado em . Observe também que a redução na magnitude em um ângulo de é causada pelo "contorno do cone invertido" associado ao zero localizado em .
Acontece que se o eixo do ângulo horizontal for interpretado como frequência com unidades de radianos por amostra, então o gráfico acima é a magnitude da resposta em frequência do sistema, conforme mostrado na figura abaixo:
Observe que se você quisesse interpretar a resposta de frequência em Hertz (em vez de radianos por amostra), então você precisaria saber a taxa de amostragem associada ao sinal que estava passando pelo sistema. Para converter o eixo horizontal para Hertz, substitua por "metade da taxa de amostragem". Por exemplo, se a taxa de amostragem fosse de 100 Hz, então o ponto médio de radianos por amostra no gráfico acima equivaleria a 25 Hz ():
Note que o gráfico só avança até a frequência de Nyquist ().
O Matlab pode facilitar as coisas ao disponibilizar a função:
Esta função retorna o diagrama de resposta frequêncial (magnitude e fase) e o vetor que corresponderá a frequência física real (em Hz), de pontos da função transferência do filtro fornecida com base nos seus coeficientes e . se o usuário não quiser especificar o número desejado de pontos.
Note:
Onde: grau do numerador, (ou número de zeros de ); grau do denominador, (ou número de pólos de ).
Lembre-se eventualmente da função filter().
A função freqz() aplicada no caso anterior, resultaria em:
xxxxxxxxxx
>> figure;
>> zpk(H)
ans =
(z^2 + 0.64)
---------------------
(z^2 + 1.131z + 0.64)
Sample time: 0.01 seconds
Discrete-time zero/pole/gain model.
>> [numd, dend]=tfdata(H,'v')
numd =
1 0 0.64
dend =
1 1.1314 0.64
>> freqz(numd, dend, [], 100)
⚠️ Detalhes: você verá que um pólo ou zero localizado na origem () não afeta a resposta em frequência de um sistema.
Considere a função transferência abaixo:
Este sistema possui um pólo localizado em , isto é, na origem do plano-z.
Num sistema com um único pólo na origem, a intersecção da superfície com o cilindro unitário seria tal que a amplitude dos pontos de interseção seria igual, conforme mostrado nas ilustrações abaixo. Na verdade, você descobrirá que a amplitude dos pontos de interseção seria de 0 dB.
Outra interpretação pode ser feita de um ponto de vista matemático. Recorde que a superfície de mostra a magnitude de na escala de decibéis (ou seja, ) para um intervalo de valores de e é um número complexo. Na imagem anterior, para gerar a superfície , foram calculados pontos para vários valores de , com a parte real variando no intervalo: e a parte imaginária variando no intervalo: .
As interseções ocorrem quando a magnitude de é igual à 1, ou . Alguns pontos de interseção são fáceis de serem identificados, por exemplo quando é igual à: , , e , os quais possuem magnitude de 1.
Para encontrar todos os pontos de intersecção será necessário avaliar a expressão para todos os casos de magnitude de igual à 1. Uma vez que , então , assim, a magnitude de será igual à 1 quando :
Ou do ponto de vista "superior":
Uma situação muito semelhante surgiria se existisse um único zero na superfície . Desta vez você descobriria que a interseção da superfície com o cilindro unitário seria tal que a amplitude dos pontos de interseção seria igual a 0 dB ().
Atenção:
👋 O que isso mostra é que: pólos ou zeros colocados na origem não afetarão a magnitude da resposta em frequência de um sistema.
Isto levanta a questão:
− Por que então é que existem pólos e zeros na origem se eles não afectam o comportamento de “magnitude” do sistema?
A resposta é que, embora não afetem a resposta de magnitude, afetam os atrasos no sistema (que está associado ao diagrama de fase (ou defasagens) na resposta frequêncial de um sistema).
Em geral, você descobrirá que um sistema normalmente possui um número igual de pólos e zeros. Sistemas que não possuem um número igual de pólos e zeros terão atrasos “desnecessários” introduzidos no sistema.
Voltando ao sistema anterior (com pólo na origem do plano-z):
Se multiplicarmos o numerador e denominador por , a função transferência fica:
Adaptando esta expressão para o formato usualmente adotado para filtros, podemos determinar os componentes a . Neste caso, , e . A equação de diferenças fica:
Na forma de um diagrama de fluxo de sinais teríamos algo como:
Que rende uma estrutura simplificada como:
O que você deve perceber é que este sistema simplesmente atrasa a entrada em uma amostra e nada mais. Embora possa haver razões práticas para querer atrasar um sinal por uma amostra, em muitos casos, como na filtragem de sinais, o atraso pode não ser desejável e serve simplesmente para desacelerar um processo em uma amostra.
Na maioria dos casos, você descobrirá que os sistemas terão o mesmo número de pólos e zeros; caso contrário, atrasos desnecessários poderão ser introduzidos no sistema, como demonstrado no exemplo anterior.
Neste segundo exemplo, como no primeiro exemplo, há também um par de pólos e um par de zeros. No entanto, os pólos e zeros estão em locais diferentes. Observe que os pólos estão mais próximos do círculo unitário e em um ângulo diferente, quando comparados ao primeiro exemplo. Os zeros estão à mesma distância do círculo unitário, mas estão localizados em um ângulo de 45 graus ( radianos). Esta mudança na localização dos pólos e zeros resulta em contornos diferentes na superfície H(z) e, portanto, as interseções do ‘cilindro unitário’ com a superfície H(z) também serão diferentes.
A expressão para neste caso é:
Trabalhando esta expressão no Matlab/Ocatve, descobrimos que:
xxxxxxxxxx
>> T=1; % definindo uma taxa de amostragam arbitrária de 1 Hz
>> H=tf([1 -1.1314 0.64], [1 0.95 0.9025], T)
H =
z^2 - 1.131 z + 0.64
---------------------
z^2 + 0.95 z + 0.9025
Sample time: 1 seconds
Discrete-time transfer function.
>> pole(H)
ans =
-0.475 + 0.82272i
-0.475 - 0.82272i
>> zero(H)
ans =
0.5657 + 0.56567i
0.5657 - 0.56567i
>> pzmap(H)
>> axis equal
>> % isolando magnitude e fase de um dos zeros:
>> angle([0.5657 + 0.56567i])
ans =
0.78537
>> ans*180/pi % resposta em graus
ans =
44.998
>> abs(0.5657 + 0.56567i)
ans =
0.8
>> % calculando magnitude e fase de um dos pólos:
>> angle([-0.475 + 0.82272i])
ans =
2.0944
>> ans*180/pi
ans =
120
>> abs([-0.475 + 0.82272i])
ans =
0.95
>> % observando os resultados no gráfico do plano-z...
Percebemos a seguinte disposição no plano-z:
Um gráfico de superfície de gera:
Destacando a intersecção com o círculo unitário temos:
O gráfico à seguir mostra a amplitude dos pontos de intersecção em relação ao ângulo feito com o eixo real, na faixa de ângulos de a para este segundo exemplo.
Você deve comparar isso com o primeiro exemplo e notar a amplificação significativa em e radianos (), causada pelos pólos estarem mais próximos do círculo unitário e posicionados na linha de ângulo radial 0,66π radianos e -0,66π radianos. Note, que a antenução (cones negativos) está concentrada próxima dos (onde estão localizados os zeros de ).
Mais uma vez, os lados esquerdo e direito são versões espelhadas um do outro e vamos nos concentrar no lado direito de 0 a radianos (ou de 0 à ) (que corresponde à freq. de Nyquist, ou ):
Gráfico similar pode ser obtido no Matlab fazendo-se:
xxxxxxxxxx
>> figure; handler=bodeplot(H);
>> setoptions(handler,'FreqUnits','Hz','PhaseVisible','off');
>> xlim([1/(2*10) 1/2])
>> setoptions(handler,'FreqScale','linear');
>> grid
Opcional:
O site do Matemática/Wolfrang traz um aplicativo Java capaz de gerar os gráficos acima para filtros de 1a-ordem:
First-Order Digital Filter Design (acessado em 13/05/2024);
⏩ Próximo tópico sugerido: projeto de sistema usando alocação pólo-zero.
Theme: Fluent.