-
Notifications
You must be signed in to change notification settings - Fork 0
/
demo_filter.html
137 lines (122 loc) · 200 KB
/
demo_filter.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge,IE=9,chrome=1"><meta name="generator" content="MATLAB R2018b"><title>Implementação de uma função para resolver uma equação de diferenças</title><style type="text/css">.rtcContent { padding: 30px; } .S0 { margin: 3px 10px 5px 4px; padding: 0px; line-height: 28.7999992370605px; min-height: 0px; white-space: pre-wrap; color: rgb(213, 80, 0); font-family: Helvetica, Arial, sans-serif; font-style: normal; font-size: 24px; font-weight: normal; text-align: left; }
.S1 { margin: 2px 10px 9px 4px; padding: 0px; line-height: 21px; min-height: 0px; white-space: pre-wrap; color: rgb(0, 0, 0); font-family: Helvetica, Arial, sans-serif; font-style: normal; font-size: 14px; font-weight: normal; text-align: left; }
.S2 { margin: 20px 10px 5px 4px; padding: 0px; line-height: 20px; min-height: 0px; white-space: pre-wrap; color: rgb(60, 60, 60); font-family: Helvetica, Arial, sans-serif; font-style: normal; font-size: 20px; font-weight: bold; text-align: left; }
.CodeBlock { background-color: #F7F7F7; margin: 10px 0 10px 0;}
.S3 { border-left: 0.833333313465118px solid rgb(233, 233, 233); border-right: 0.833333313465118px solid rgb(233, 233, 233); border-top: 0.833333313465118px solid rgb(233, 233, 233); border-bottom: 0px none rgb(0, 0, 0); border-radius: 4px 4px 0px 0px; padding: 6px 45px 0px 13px; line-height: 17.2339992523193px; min-height: 18px; white-space: nowrap; color: rgb(0, 0, 0); font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 14px; }
.S4 { border-left: 0.833333313465118px solid rgb(233, 233, 233); border-right: 0.833333313465118px solid rgb(233, 233, 233); border-top: 0px none rgb(0, 0, 0); border-bottom: 0px none rgb(0, 0, 0); border-radius: 0px; padding: 0px 45px 0px 13px; line-height: 17.2339992523193px; min-height: 18px; white-space: nowrap; color: rgb(0, 0, 0); font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 14px; }
.S5 { border-left: 0.833333313465118px solid rgb(233, 233, 233); border-right: 0.833333313465118px solid rgb(233, 233, 233); border-top: 0px none rgb(0, 0, 0); border-bottom: 0.833333313465118px solid rgb(233, 233, 233); border-radius: 0px 0px 4px 4px; padding: 0px 45px 4px 13px; line-height: 17.2339992523193px; min-height: 18px; white-space: nowrap; color: rgb(0, 0, 0); font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 14px; }
.S6 { margin: 10px 10px 9px 4px; padding: 0px; line-height: 21px; min-height: 0px; white-space: pre-wrap; color: rgb(0, 0, 0); font-family: Helvetica, Arial, sans-serif; font-style: normal; font-size: 14px; font-weight: normal; text-align: left; }
.S7 { margin: 3px 10px 5px 4px; padding: 0px; line-height: 20px; min-height: 0px; white-space: pre-wrap; color: rgb(60, 60, 60); font-family: Helvetica, Arial, sans-serif; font-style: normal; font-size: 20px; font-weight: bold; text-align: left; }
.S8 { border-left: 0.833333313465118px solid rgb(233, 233, 233); border-right: 0.833333313465118px solid rgb(233, 233, 233); border-top: 0.833333313465118px solid rgb(233, 233, 233); border-bottom: 0.833333313465118px solid rgb(233, 233, 233); border-radius: 4px 4px 0px 0px; padding: 6px 45px 4px 13px; line-height: 17.2339992523193px; min-height: 18px; white-space: nowrap; color: rgb(0, 0, 0); font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 14px; }
.S9 { color: rgb(64, 64, 64); padding: 10px 0px 6px 17px; background: rgb(255, 255, 255) none repeat scroll 0% 0% / auto padding-box border-box; font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 14px; overflow-x: hidden; line-height: 17.2339992523193px; }
.embeddedOutputsErrorElement {min-height: 18px; max-height: 250px; overflow: auto;}
.embeddedOutputsErrorElement.inlineElement {}
.embeddedOutputsErrorElement.rightPaneElement {}
.embeddedOutputsWarningElement{min-height: 18px; max-height: 250px; overflow: auto;}
.embeddedOutputsWarningElement.inlineElement {}
.embeddedOutputsWarningElement.rightPaneElement {}
.diagnosticMessage-wrapper {font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 12px;}
.diagnosticMessage-wrapper.diagnosticMessage-warningType {color: rgb(255,100,0);}
.diagnosticMessage-wrapper.diagnosticMessage-warningType a {color: rgb(255,100,0); text-decoration: underline;}
.diagnosticMessage-wrapper.diagnosticMessage-errorType {color: rgb(230,0,0);}
.diagnosticMessage-wrapper.diagnosticMessage-errorType a {color: rgb(230,0,0); text-decoration: underline;}
.diagnosticMessage-wrapper .diagnosticMessage-messagePart {white-space: pre-wrap;}
.diagnosticMessage-wrapper .diagnosticMessage-stackPart {white-space: pre;}
.embeddedOutputsTextElement,.embeddedOutputsVariableStringElement {white-space: pre; word-wrap: initial; min-height: 18px; max-height: 250px; overflow: auto;}
.textElement,.rtcDataTipElement .textElement {padding-top: 3px;}
.embeddedOutputsTextElement.inlineElement,.embeddedOutputsVariableStringElement.inlineElement {}
.inlineElement .textElement {}
.embeddedOutputsTextElement.rightPaneElement,.embeddedOutputsVariableStringElement.rightPaneElement {min-height: 16px;}
.rightPaneElement .textElement {padding-top: 2px; padding-left: 9px;}
.S10 { border-left: 0.833333313465118px solid rgb(233, 233, 233); border-right: 0.833333313465118px solid rgb(233, 233, 233); border-top: 0.833333313465118px solid rgb(233, 233, 233); border-bottom: 0.833333313465118px solid rgb(233, 233, 233); border-radius: 0px; padding: 6px 45px 4px 13px; line-height: 17.2339992523193px; min-height: 18px; white-space: nowrap; color: rgb(0, 0, 0); font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 14px; }
.S11 { border-left: 0.833333313465118px solid rgb(233, 233, 233); border-right: 0.833333313465118px solid rgb(233, 233, 233); border-top: 0px none rgb(0, 0, 0); border-bottom: 0.833333313465118px solid rgb(233, 233, 233); border-radius: 0px; padding: 0px 45px 4px 13px; line-height: 17.2339992523193px; min-height: 18px; white-space: nowrap; color: rgb(0, 0, 0); font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 14px; }
.S12 { border-left: 0.833333313465118px solid rgb(233, 233, 233); border-right: 0.833333313465118px solid rgb(233, 233, 233); border-top: 0.833333313465118px solid rgb(233, 233, 233); border-bottom: 0px none rgb(0, 0, 0); border-radius: 0px; padding: 6px 45px 0px 13px; line-height: 17.2339992523193px; min-height: 18px; white-space: nowrap; color: rgb(0, 0, 0); font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 14px; }</style></head><body><div class = rtcContent><h1 class = 'S0'><span>Implementação de uma função para resolver uma equação de diferenças</span></h1><div class = 'S1'><span>Aluno: Pedro Henrique Garcia</span></div><div class = 'S1'><span>R.A. 1829696</span></div><h2 class = 'S2'><span>Inicialização dos vetores</span></h2><div class="CodeBlock"><div class="inlineWrapper"><div class = 'S3'><span style="white-space: pre;"><span>close </span><span style="color: rgb(160, 32, 240);">all</span><span>; clear; clc; </span><span style="color: rgb(34, 139, 34);">% faça a coleta de lixo regularmente</span></span></div></div><div class="inlineWrapper"><div class = 'S4'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">%tamanho do b</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>b_size = 100;</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">%tamanho a</span></span></div></div><div class="inlineWrapper"><div class = 'S5'><span style="white-space: pre;"><span>a_size = 50;</span></span></div></div></div><div class = 'S6'><span style=' font-family: monospace;'>poly</span><span> Deveria garantir que o sistema é estável, pois todas raízes serão menores que 1, em magnitude, e portanto estão dentro do circulo unitário para números grandes de a_size, o sistema sistema continuará instável pois </span><span style=' font-family: monospace;'>max(abs(roots(a))</span><span> pode ser > 1.</span></div><div class="CodeBlock"><div class="inlineWrapper"><div class = 'S3'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>a = poly(0.01*rand(a_size,1));</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>b = randn(b_size, 1); </span><span style="color: rgb(34, 139, 34);">% declara b</span></span></div></div><div class="inlineWrapper"><div class = 'S5'><span style="white-space: pre;"><span>x = randn(100,1); </span><span style="color: rgb(34, 139, 34);">% declara o sinal</span></span></div></div></div><h2 class = 'S7'><span>Função de resolução de equações de diferenças</span></h2><div class="CodeBlock"><div class="inlineWrapper"><div class = 'S3'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% function y = phg_filter(b,a,x)</span></span></div></div><div class="inlineWrapper"><div class = 'S4'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% a função phg_filter recebe três argumentos, para resolver a equação de</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% difereças. </span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% a é um vetor dos coeficientes que acompanham y</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% b é um vetor dos coeficientes que acompanham x</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% x é um vetor do sinal</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% Uma equação de diferenças é do tipo:</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% a(n)y(n) + a(n-1)y(n-1) ... a(1)y(1) = b(n)x(n) + b(n-1)x(n-1) ... b(1)x(1)</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% podemos encontrar a saída conhecendo apenas</span></span></div></div><div class="inlineWrapper"><div class = 'S4'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% pega o maior numero </span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% pra servir de padrão pro produto escalar</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% espero que o compilador do matlab seja bom o suficiente para pular todas</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% as multiplicações por zeros desnecessárias</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>max_size = max([numel(x) numel(a) numel(b)]); </span></span></div></div><div class="inlineWrapper"><div class = 'S4'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% preenche o restante com zeros, até max_size</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>y(max_size) = 0;</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>y = transpose(y);</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>a(max_size) = 0;</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>b(max_size) = 0;</span></span></div></div><div class="inlineWrapper"><div class = 'S4'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% protege contra um vetor coluna, a e b precisam ser linhas</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(0, 0, 255);">if </span><span>(isrow(b)==0)</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span> b = transpose(b);</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(0, 0, 255);">end</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(0, 0, 255);">if </span><span>(isrow(a) == 0)</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span> a = transpose(a);</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(0, 0, 255);">end</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% assegura que x é vetor coluna</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(0, 0, 255);">if </span><span>(iscolumn(x) == 0)</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span> x = transpose(x);</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(0, 0, 255);">end</span></span></div></div><div class="inlineWrapper"><div class = 'S4'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% resolve a equação de diferenças</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(0, 0, 255);">for </span><span>n=1:numel(x)</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span> y(n) = (1/a(1))*( b(1:n)*x(n:-1:1) -a(2:n)*y(n-1:-1:1) );</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(0, 0, 255);">end</span></span></div></div><div class="inlineWrapper"><div class = 'S4'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">%trunca a saída para que a comparação com a função do matlab possa ser feita</span></span></div></div><div class="inlineWrapper"><div class = 'S5'><span style="white-space: pre;"><span>y = y( 1:numel(x) );</span></span></div></div></div><h2 class = 'S7'><span>Testes das funções</span></h2><div class = 'S1'><span>Testando o tempo de execução das duas funções.</span></div><div class="CodeBlock"><div class="inlineWrapper outputs"><div class = 'S8'><span style="white-space: pre;"><span>tic; y_matlab=filter(b,a,x); toc</span></span></div><div class = 'S9'><div class="inlineElement eoOutputWrapper embeddedOutputsTextElement" uid="2BCFD41A" data-scroll-top="null" data-scroll-left="null" data-width="983" data-height="18" data-hashorizontaloverflow="false" data-testid="output_0" style="max-height: 261px; width: 1013px;"><div class="textElement">Elapsed time is 0.017484 seconds.</div></div></div></div><div class="inlineWrapper outputs"><div class = 'S10'><span style="white-space: pre;"><span>tic; y_phg=phg_filter(b,a,x); toc</span></span></div><div class = 'S9'><div class="inlineElement eoOutputWrapper embeddedOutputsTextElement" uid="EEC71DDE" data-scroll-top="null" data-scroll-left="null" data-width="983" data-height="18" data-hashorizontaloverflow="false" data-testid="output_1" style="max-height: 261px; width: 1013px;"><div class="textElement">Elapsed time is 0.009694 seconds.</div></div></div></div></div><div class = 'S6'><span></span></div><div class = 'S1'><span>Verificando se o sistema é estável</span></div><div class="CodeBlock"><div class="inlineWrapper"><div class = 'S3'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% se max(abs(roots(a))) >1, então sistema instável. </span></span></div></div><div class="inlineWrapper outputs"><div class = 'S11'><span style="white-space: pre;"><span>max(abs(roots(a)))</span></span></div><div class = 'S9'><div class='variableElement' style='font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 12px; '>ans = 0.1391</div></div></div></div><div class = 'S6'><span>Podemos ver o maior erro entre a função escrita e o filter do matlab</span></div><div class="CodeBlock"><div class="inlineWrapper"><div class = 'S3'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% mostra o maior erro entre o phg_filter e o filter do matlab</span></span></div></div><div class="inlineWrapper outputs"><div class = 'S11'><span style="white-space: pre;"><span>maxerror = max( abs(y_matlab -y_phg) )</span></span></div><div class = 'S9'><div class='variableElement' style='font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 12px; '>maxerror = 1.7764e-14</div></div></div></div><div class = 'S6'><span></span></div><div class = 'S1'><span>Plot do erro entre as duas funções</span></div><div class="CodeBlock"><div class="inlineWrapper"><div class = 'S3'><span style="white-space: pre;"><span style="color: rgb(34, 139, 34);">% plota o erro entre o phg_filter e o filter do matlab</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>figure</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>stem( abs(y_matlab -y_phg)) </span></span></div></div><div class="inlineWrapper outputs"><div class = 'S11'><span style="white-space: pre;"><span>title(</span><span style="color: rgb(160, 32, 240);">'Erro'</span><span>)</span></span></div><div class = 'S9'><div class="inlineElement eoOutputWrapper embeddedOutputsFigure" uid="6E55BC1C" data-scroll-top="null" data-scroll-left="null" data-testid="output_4" style="width: 1013px;"><div class="figureElement" style="cursor: default;"><div class="figureContainingNode" style="width: 560px; max-width: 100%; display: inline-block;"><div class="GraphicsView" data-dojo-attach-point="graphicsViewNode,backgroundColorNode" id="uniqName_197_0" widgetid="uniqName_197_0" style="width: 100%; height: auto;"><img class="ImageView figureImage" data-dojo-attach-point="imageViewNode" draggable="false" ondragstart="return false;" id="uniqName_197_2" widgetid="uniqName_197_2" src="" style="width: 100%; height: auto;"></div></div></div></div></div></div><div class="inlineWrapper"><div class = 'S12'></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>figure</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>stem(abs(y_phg))</span></span></div></div><div class="inlineWrapper outputs"><div class = 'S11'><span style="white-space: pre;"><span>title(</span><span style="color: rgb(160, 32, 240);">'Implementação da filter'</span><span>)</span></span></div><div class = 'S9'><div class="inlineElement eoOutputWrapper embeddedOutputsFigure" uid="72DA6EC7" data-scroll-top="null" data-scroll-left="null" data-testid="output_5" style="width: 1013px;"><div class="figureElement" style="cursor: default;"><div class="figureContainingNode" style="width: 560px; max-width: 100%; display: inline-block;"><div class="GraphicsView" data-dojo-attach-point="graphicsViewNode,backgroundColorNode" id="uniqName_197_3" widgetid="uniqName_197_3" style="width: 100%; height: auto;"><img class="ImageView figureImage" data-dojo-attach-point="imageViewNode" draggable="false" ondragstart="return false;" id="uniqName_197_5" widgetid="uniqName_197_5" src="" style="width: 100%; height: auto;"></div></div></div></div></div></div><div class="inlineWrapper"><div class = 'S12'><span style="white-space: pre;"><span>figure</span></span></div></div><div class="inlineWrapper"><div class = 'S4'><span style="white-space: pre;"><span>stem(abs(y_matlab))</span></span></div></div><div class="inlineWrapper outputs"><div class = 'S11'><span style="white-space: pre;"><span>title(</span><span style="color: rgb(160, 32, 240);">'Filter nativo do matlab'</span><span>)</span></span></div><div class = 'S9'><div class="inlineElement eoOutputWrapper embeddedOutputsFigure" uid="B386824D" data-scroll-top="null" data-scroll-left="null" data-testid="output_6" style="width: 1013px;"><div class="figureElement" style="cursor: default;"><div class="figureContainingNode" style="width: 560px; max-width: 100%; display: inline-block;"><div class="GraphicsView" data-dojo-attach-point="graphicsViewNode,backgroundColorNode" id="uniqName_197_6" widgetid="uniqName_197_6" style="width: 100%; height: auto;"><img class="ImageView figureImage" data-dojo-attach-point="imageViewNode" draggable="false" ondragstart="return false;" id="uniqName_197_8" widgetid="uniqName_197_8" src="" style="width: 100%; height: auto;"></div></div></div></div></div></div></div></div><br>
<!--
##### SOURCE BEGIN #####
%% Implementação de uma função para resolver uma equação de diferenças
% Aluno: Pedro Henrique Garcia
%
% R.A. 1829696
%% Inicialização dos vetores
close all; clear; clc; % faça a coleta de lixo regularmente
%tamanho do b
b_size = 100;
%tamanho a
a_size = 50;
%%
% |poly| Deveria garantir que o sistema é estável, pois todas raízes serão
% menores que 1, em magnitude, e portanto estão dentro do circulo unitário para
% números grandes de a_size, o sistema sistema continuará instável pois |max(abs(roots(a))|
% pode ser > 1.
a = poly(0.01*rand(a_size,1));
b = randn(b_size, 1); % declara b
x = randn(100,1); % declara o sinal
%% Função de resolução de equações de diferenças
%%
% function y = phg_filter(b,a,x)
% a função phg_filter recebe três argumentos, para resolver a equação de
% difereças.
% a é um vetor dos coeficientes que acompanham y
% b é um vetor dos coeficientes que acompanham x
% x é um vetor do sinal
% Uma equação de diferenças é do tipo:
% a(n)y(n) + a(n-1)y(n-1) ... a(1)y(1) = b(n)x(n) + b(n-1)x(n-1) ... b(1)x(1)
% podemos encontrar a saída conhecendo apenas
% pega o maior numero
% pra servir de padrão pro produto escalar
% espero que o compilador do matlab seja bom o suficiente para pular todas
% as multiplicações por zeros desnecessárias
max_size = max([numel(x) numel(a) numel(b)]);
% preenche o restante com zeros, até max_size
y(max_size) = 0;
y = transpose(y);
a(max_size) = 0;
b(max_size) = 0;
% protege contra um vetor coluna, a e b precisam ser linhas
if (isrow(b)==0)
b = transpose(b);
end
if (isrow(a) == 0)
a = transpose(a);
end
% assegura que x é vetor coluna
if (iscolumn(x) == 0)
x = transpose(x);
end
% resolve a equação de diferenças
for n=1:numel(x)
y(n) = (1/a(1))*( b(1:n)*x(n:-1:1) -a(2:n)*y(n-1:-1:1) );
end
%trunca a saída para que a comparação com a função do matlab possa ser feita
y = y( 1:numel(x) );
%% Testes das funções
% Testando o tempo de execução das duas funções.
tic; y_matlab=filter(b,a,x); toc
tic; y_phg=phg_filter(b,a,x); toc
%%
%
%
% Verificando se o sistema é estável
% se max(abs(roots(a))) >1, então sistema instável.
max(abs(roots(a)))
%%
% Podemos ver o maior erro entre a função escrita e o filter do matlab
% mostra o maior erro entre o phg_filter e o filter do matlab
maxerror = max( abs(y_matlab -y_phg) )
%%
%
%
% Plot do erro entre as duas funções
% plota o erro entre o phg_filter e o filter do matlab
figure
stem( abs(y_matlab -y_phg))
title('Erro')
figure
stem(abs(y_phg))
title('Implementação da filter')
figure
stem(abs(y_matlab))
title('Filter nativo do matlab')
##### SOURCE END #####
--></body></html>