Matlab - Apostila [FEI]

Share Embed Donate


Short Description

Download Matlab - Apostila [FEI]...

Description

Faculdade de Engenharia Industrial Fundação de Ciências Aplicadas

 Matlab & Simulink São Bernardo do Campo - Dezembro de 1994 Departamento de Eletricidade

 Índice Analítico 1. Tutorial do Matlab & Simulink......... Simulink ................... .................... .................... .................... .................... .................... .............. .... 2 1.1 Matlab Básico.......................... Básico.................................... .................... ................... ................... .................... .................... ................... ......... 2 1.1.1 Introdução................... Introdução............................. .................... .................... .................... .................... .................... .................... .............. .... 3 1.1.2 Operações Matriciais........................ Matriciais................................. ................... .................... .................... .................... ............. ... 8 1.1.3 Operações em Array ................... ............................. ................... ................... .................... .................... ................. ....... 10 1.1.4 Manipulação Matricial e Vetorial Vetorial .................... .............................. .................... .................... .............. .... 13 1.1.5 Análise de Dados....................... Dados................................. .................... .................... .................... .................... ................. ....... 18 1.1.6 Funções Matriciais .................... .............................. .................... .................... .................... .................... ................. ....... 20 1.1.7 Polinômios e Processamento de Sinais Sinais .................... .............................. ..................... ................ ..... 20 1.1.8 Funções de Funções ................... ............................. .................... .................... .................... .................... ................ ...... 23 1.1.9 Gráficos .................... .............................. .................... .................... .................... .................... .................... ................... .............. ..... 27 1.1.10 Controles de Fluxo .................... .............................. .................... .................... .................... .................... ............... ..... 37 1.1.11 Arquivos M ................... ............................. .................... .................... .................... .................... .................... ................. ....... 39 1.1.12 Arquivos de Disco......... Disco ................... .................... .................... .................... .................... .................... ................. ....... 46 1.1.13 O Depurador do Matlab ................... ............................. ................... ................... .................... ................... ......... 48 1.2 Toolboxes do Matlab..................... Matlab............................... .................... .................... ................... ................... .................... ............ 49 1.2.1 Sistemas de Controle.......... Controle .................... .................... .................... .................... .................... .................... .............. .... 50 1.2.2 Outros Toolboxes .................... ............................. ................... .................... .................... .................... ................... ........... 54 1.3 Simulink Básico ................... ............................. ................... ................... .................... .................... ................... ................... ............ 55 1.3.1 Linhas Gerais................... Gerais............................ ................... .................... .................... .................... .................... .................. ........ 55 1.3.2 Construção Cons trução de Modelos............................ Modelos...................................... .................... .................... .................... .............. 56 1.3.3 Análise dos Modelos .................... ............................. ................... .................... .................... ................... ............... ...... 69 1.3.4 Como o Simulink Funciona ................... ............................. .................... ..................... ..................... ............. ... 80 1.3.5 S-Functions ................... ............................. .................... .................... .................... .................... .................... ................... ......... 80 1.3.6 Mascarando Blocos .................... .............................. .................... .................... ................... ................... ................. ....... 84 1.3.7 Adicionando um novo bloco ................... ............................. .................... .................... .................... ............. ... 87 2. Bibliografia...................... Bibliografia................................ ................... ................... .................... .................... ................... ................... .................... .............. 93

1. Tutorial do  Matlab & Simulink 1.1 Matlab Básico MATLAB é um ambiente de computação técnica de visualização e processamento numérico de alto desempenho. Ele integra análise numérica, cálculo matricial, processamento de sinais, vários aplicativos e gráficos num ambiente amigável onde problemas e soluções são expressos como eles são representados matematicamente sem a necessidade da programação tradicional. O nome MATLAB é acrônimo de laboratório de matemática. Ele foi originalmente escrito para permitir permitir um acesso fácil aos programas de cálculo matricial desenvolvidos pelos projetos LINSPACK e EISPACK, que juntos representam o estado da arte em programas de cálculo matricial. matricial. MATLAB também contempla uma família de aplicativos específicos chamados “toolboxes”. Esses aplicativos foram desenvolvidos por profissionais de expressão em cada uma das áreas e foram totalmente concebidos na forma de coleções de funções MATLAB (M-files), estendendo o ambiente MATLAB na solução de problemas particulares. Entre outros, temos os seguintes toolboxes: Processamento de Sinais; Projeto de Sistemas de Controle; Simulação de Sistemas Dinâmicos; Identificação de Sistemas; Redes Neurais; Splines; Otimização ; Análise e Síntese µ , etc. Provavelmente a característica mais importante do MATLAB é sua ampliabilidade. Isto permite que qualquer um possa ser um autor de um toolbox . Aplicativos matemáticos complexos são facilmente desenvolvidos em poucas linhas no ambiente MATLAB sem a necessidade de programação de uma única linha de código C, FORTRAM ou outro código de baixo nível.

2

Tutorial do Matlab & Simulink

3

1.1.1 Introdução O MATLAB trabalha essencialmente com um tipo de objeto: Matriz retangular numérica (real ou complexa). Em algumas situações existe significado especial agregado à matrizes de dimensão 1 (escalares) e matrizes com uma só linha ou coluna (vetores). A linguagem MATLAB não usa declaração preliminar ou dimensionamento de variáveis. Isso é feito de forma automática. Matrizes podem ser adicionadas no ambiente de várias formas, contudo a forma mais simples para matrizes pequenas é entrando com a lista dos elementos, seguindo a seguinte convenção:

• • •

Separe os elementos com espaços ou vírgulas. Delimite os elementos com colchetes []. Use ; (ponto-e-vírgula) para indicar o final da linha.

Exemplo: » A = [1 2 3; 4 5 6; 7 8 9]

Resulta: A= 1 4 7

2 5 8

3 6 9

Elementos de uma matriz podem ser quaisquer expressões MATLAB. Por exemplo: » x = [-1.3 sqrt(3) (1+2+3)*4/5]

Resulta: x= -1.3000

1.7321

4.8000

Elementos individuais podem ser referenciados pelo seu índice assim. para acrescentar elementos ao exemplo anterior

(linha,coluna):

FEI - FCA

Tutorial do Matlab & Simulink

4

» x(5) = abs(x(1))

Resulta: x= -1.3000

1.7321

4.8000

0

1.3000

Ao atribuir um valor numérico à  x(5), automaticamente x(4) é criado com valor nulo. Você pode construir matrizes maiores usando matrizes menores como seus elementos. Por exemplo, vamos adicionar uma linha a matriz  A: » r = [10 11 12]; » A = [A; r]

Isto resulta em: A= 1 4 7 10

2 5 8 11

3 6 9 12

Você pode extrair sub-matrizes de uma matriz maior usando : (dois pontos). Por exemplo: » A = A(1:3,:);

Remove as três primeiras linhas e todas as colunas da matriz atual  A e coloca o resultado em A. A= 1 4 7

2 5 8

3 6 9

Variáveis e Declarações do MATLAB

FEI - FCA

Tutorial do Matlab & Simulink

5

Declarações no MATLAB são freqüentemente feitas da seguinte forma: »

variável = expressão

ou simplesmente, »

expressão

Quando o nome da variável é omitido, o nome ans é usado como variável default . Uma definição normalmente termina com ENTER. Contudo, se o último caracter é um ponto-e-vírgula, ele suprime a apresentação no vídeo, embora faça a atribuição do mesmo jeito. Isto é especialmente importante nas situações que o resultado é muito grande, tal como uma matriz de 10 linhas e 10 colunas. Se a expressão é muito grande e não cabe em uma linha, use continuar a definição na linha seguinte. Exemplo:

(...)

para

» s = 1 - 1/2 + 1/3 - 1/4 + 1/5 -1/6 + 1/7 ... - 1/8 + 1/9 - 1/10 + 1/11 - 1/12;

Você pode formar uma variável ou nome de função com uma letra seguida de qualquer quantidade de letras (ou underscore) . MATLAB diferencia letras maiúsculas de minúsculas e usa somente os primeiros 19 caracteres do nome.

Obtendo Informação da Área de Trabalho (workspace ) Para listar as variáveis ativas use o comando who. Para obter mais informações sobre as variáveis como: nome, tamanho, número de elementos, etc., use o comando whos.

O Utilitário de HELP  

FEI - FCA

Tutorial do Matlab & Simulink

6

O comando  help produz informação on-line da maioria dos tópicos do MATLAB, mostrando uma lista dos diretórios que contém arquivos do MATLAB. Para listar as funções de um diretório particular, digite  help seguido do nome do diretório. Exemplo: » help matfun

Para obter auxílio sobre uma função específica digite  help e o nome da função. Exemplo: » help inv

Para localizar palavras-chaves em todos os arquivos do MATLAB, use o comando lookfor. Exemplo: » lookfor inverse » INVHILB ACOS ACOSH ACOT ACOTH ACSC ACSCH



Inverse Hilbert matrix Inverse cosine Inverse hyperbolic cosine Inverse cotangent Inverse hyperbolic cotangent Inverse cosecant Inverse hyperbolic cosecant



Salvando e Saindo Para sair do MATLAB digite exit. Encerrando uma seção do MATLAB, apaga-se todas as variáveis da área de trabalho (workspace). Se for necessário, salve suas variáveis digitando save. Este comando salvará todas as variáveis em um arquivo chamado matlab.mat. Para recuperar as variáveis use o comando load . Você também pode salvar somente algumas variáveis e usar o nome de um arquivo qualquer. O exemplo a seguir salva as variáveis  x,  y e  z no arquivo temp.mat. » save temp x y z

FEI - FCA

Tutorial do Matlab & Simulink

7

Números e Expressões Aritméticas O MATLAB usa notação convencional com potência de dez ou unidade complexa como sufixo: -4.534i 1.760217e-11

O MATLAB usa 16 dígitos significativos e expressões aritméticas são calculadas com a seguinte prioridade ^     * +

potenciação divisão à esquerda divisão à direita multiplicação subtração adição

\ /

Algumas funções internas retornam valores especiais. A função pi retorna o valor de π, a função inf  retorna ∞, etc. O MATLAB dispões das funções matemáticas elementares normalmente encontradas em calculadores científicas. Essas funções incluem por exemplo:  abs,  sqrt, log,  sin. Se uma operação resultar em infinito isso não implica em erro, simplesmente aquela variável terá o valor infinito. O mesmo ocorre para operações inválidas como ∞ / ∞ ou 0/0. O  Not a Number ). resultado é NaN ( Not ).

Formato de Saída Para alterar a formatação do número a ser apresentado na tela, utilize o comando format. Exemplos: » x = [4/3 1.2345e-6] » format short 1.3333

0.0000

» format short e 1.3333e+00

1.2345e-06

FEI - FCA

Tutorial do Matlab & Simulink

8

Funções Grande parte do poder do MATLAB vem do enorme conjunto de funções. Algumas das funções são internas ao processador MATLAB e outras são disponíveis como bibliotecas externas na forma de M-files. O conjunto de funções aplicadas a uma área específica são denominadas toolboxes. Cada usuário pode criar suas próprias funções que se comportam como se fossem funções internas. As seções adiante discutem cada uma das diferentes categorias de funções analíticas do MATLAB básico. É possível combinar funções de várias formas. Exemplo: » x = sqrt(log(z))

Algumas funções usam dois ou mais argumentos, e cada argumento pode ser uma expressão. Exemplo: » angulo = atan2(y,3*x)

Existem funções que retornam dois ou mais valores. Nestes casos, os valores de saída devem estar entre colchetes [] e separados por vírgula. Exemplo: » [V,D] = eig(A)

A função eig calcula os autovetores e os autovalores de  A, respectivamente. Havendo dúvida, deve-se usar help eig.

1.1.2 Operações Matriciais Transposta de uma Matriz O caracter ' (apóstrofe) denota transposta de uma matriz. Se  z for complexo, z' é o transposto conjugado complexo de z. Exemplo: » A = [1 2; 3 4]

FEI - FCA

Tutorial do Matlab & Simulink

9

A= 1 3

2 4

1 2

3 4

» B = A' B=

Adicionando e Subtraindo Matrizes Os símbolos + e - denotam adição e subtração de matrizes. A operação é definida sempre que as matrizes tenham a mesma dimensão. Exemplo: » C=A+B C= 2 5

5 8

A adição e subtração também é definida quando um dos operandos for um escalar. Exemplo: » D=C-2 D= 0 3

3 6

Multiplicação de Matrizes O símbolo * denota multiplicação de matrizes e é válida sempre que dimensões internas dos dois operandos for igual. Exemplo: » E=A*B E= 5 11

11 25

Naturalmente, um escalar (matriz de dimensão 1) pode multiplicar ou ser multiplicado por qualquer matriz. Exemplo: » F = 2*E

FEI - FCA

Tutorial do Matlab & Simulink

10

F= 10 22

22 50

Divisão de Matrizes Existe dois símbolos de divisão de matrizes: / e \ . Os significados são: X = A\B é solução do sistema A*X = B X = B/A é solução do sistema X*A = B

Funções Elementares e Transcendentais O MATLAB enxerga expressões como exp(A) e sqrt(A) como operação sobre cada um dos elementos de um vetor (linha ou coluna). Existem funções para calculo de funções transcendentais de matrizes, quando essas são quadradas. Exemplos:

• • •

expm logm sqrtm

exponencial de uma matriz logaritmo de uma matriz raiz quadrada de uma matriz

Outras funções elementares sobre matrizes incluem:

• • •

poly det trace

polinômio caraterístico determinante traço

1.1.3 Operações em Array Refere-se a operações em array as operações aritméticas realizadas elemento a elemento ao invés da operação matricial algébrica usual definida pelos símbolos * \ / ^ e '. Para indicar que a operação é elemento-a-elemento usase um ponto (.) antes do símbolo da operação.

FEI - FCA

Tutorial do Matlab & Simulink

11

Somando e Subtraindo Arrays  Para a adição e subtração, as operações de arrays e as de matrizes são as mesmas. Neste caso + e - podem ser usados sem o ponto.

Multiplicando e Dividindo Arrays  O símbolo .* denota multiplicação elemento-a-elemento. Se  A e  B têm mesma dimensão, então A.*B resulta num array cujos elementos são o produto dos elementos individuais de A e de B. Exemplo: » x = [1 2 3]; y = [4 5 6]; » z = x.*y z= 4

10

18

A expressão A./B e A.\B resulta no quociente de cada elemento. Exemplo: » z = x.\y z= 4.0000

2.5000

2.000

Usando Potenciação com Arrays O símbolo .^ denota potenciação elemento-a-elemento. Exemplo: » z = x.^y z= 1

32

729

Operadores Relacionais Para comparar-se matrizes de dimensões idênticas existem seis (6) operadores relacionais. < >= == ~=

12

maior maior ou igual igual diferente

O MATLAB compara os pares de elementos correspondentes. O resultado é uma matriz de "uns" e "zeros", onde "um" representa "verdadeiro" e "zero" representa "falso". Exemplo: » 2 + 2 ~= 4 ans = 0

O exemplo abaixo, ilustra como encontrar os elementos das matriz  A que são divisíveis por 3: » A = [8 1 6; 3 5 7; 4 9 2]; » G = rem(A,3); » P = (G == 0) P= 0 1 0

0 0 1

1 0 0

A função rem(A,3) retorna a matriz dos restos da divisão por 3. Cada um dos elementos de G informa se a operação relacional é falsa (0) ou verdadeira (1). A função find é muito usada em conjunto com operadores relacionais. O exemplo abaixo ilustra como localizar todos os elementos de Y  que são maiores que 3 e substituí-los por 10. » Y = [1 2 3 4 5 6 7 8 9]; » i = find(Y > 3.0); » Y(i) = 10*ones(size(i));

Operadores Lógicos

FEI - FCA

Tutorial do Matlab & Simulink

13

Os operadores &, |, e ~ são os operadores lógicos "e", "ou" e "não" respectivamente. As funções  any e  all  são muito utilizadas em conjunto com operadores lógicos. A função any(x) retorna "1" se qualquer elemento de  x for não nulo e retorna "0" caso contrário. A função all(x) retorna "1" somente se todos os elementos de  x são não nulos. Essas funções são particularmente úteis na declaração de um if . if all(A < 0.5) faça alguma coisa  end

Funções Matemáticas Um conjunto de funções matemáticas elementares são aplicáveis elemento-a-elemento num array. » A = [ -1 2 -3; 4 -5 6]; » B = abs(A) B= 1 4

2 5

3 6

1.1.4 Manipulação Matricial e Vetorial A capacidade de indexação do MATLAB permite manipulação de linhas e colunas, elementos individuais e submatrizes de matrizes. Os vetores são o ponto central da indexação e eles são gerados com o uso de : (dois pontos).

Gerando Vetores A declaração abaixo ilustra a criação de um vetor usando (:) dois pontos: » x = 1:5 x= 1

2

3

4

5

FEI - FCA

Tutorial do Matlab & Simulink

14

Você pode também criar o vetor com incrementos diferentes da unidade. No exemplo a seguir o passo é de π /4. » y = 0 : pi/4 : pi y= 0.0000 0.7854 1.5708 2.3562 3.1416

» z = 6: -1 : 1 z= 6 5 4 3 2 1

A uso de (:) permite a criação rápida de tabelas como ilustrado a seguir: » x = (0 : 0.2 : 3)'; » y = exp(-x).*sin(x); » [x y] ans = 0 0.2000 0.4000 0.6000 0.8000 1.0000 1.2000 1.4000 1.6000 1.8000 2.0000 2.2000 2.4000 2.6000 2.8000 3.0000

0 0.1627 0.2610 0.3099 0.3223 0.3096 0.2807 0.2430 0.2018 0.1610 0.1231 0.0896 0.0613 0.0383 0.0204 0.0070

Existem outras funções para a geração de vetores tal como logspace que gera um vetor espaçado logaritmicamente: » w = logspace(-1,1,5) w= 0.1000

0.3162

1.0000

3.1623 10.0000

Indexando

FEI - FCA

Tutorial do Matlab & Simulink

15

Elementos individuais de matrizes podem ser referenciados inserindo seus índices de linha e coluna entre parênteses. Se uma expressão for usada como índice, o resultado é aproximado aproximado paro o inteiro mais próximo. » A = [1 2 3; 4 5 6; 7 8 9]; » A(3,3) = A(1,3) + A(3,1) A= 1 4 7

2 5 8

3 6 10

Usando (:) dois pontos, podemos indexar todas as linhas ou colunas ou uma parte: » A(:,1) A= 1 4 7

» A(2:3,1:2) A= 4 7

5 8

O exemplo a seguir mostra como fazer referência explícita a algumas linhas ou colunas. Coloca-se os números das linhas e colunas dentro de colchetes: » A([1 3],[1 3]) A= 1 3 7 10

Um outro uso para os dois pontos (:) é no empilhamento das colunas de uma matriz qualquer. No caso de vetores, obteremos sempre o vetor coluna: » A = [1 2; 3 4; 5 6]; » B = A(:) B= 1

FEI - FCA

Tutorial do Matlab & Simulink

16

2 3 4 5 6

Usando Vetores de 0s-1s na Indexação Você pode usar vetores de "uns", usualmente criados a partir de operadores relacionais no referenciamento de submatrizes. Suponha que A é uma matriz de dimensão m-por-n e  L um vetor linha de "zeros" e "uns" de dimensão m. Então, » A(L,:)

especifica as linhas de  A cujos elementos de L são não nulos. Ou seja, os uns de  L apontam para as linhas de  A. O exemplo a seguir mostra como extrair de  X  as linhas cuja terceira coluna é maior ou igual a 100. » L = X(:,3) > 100; » Y = X(L,:);

Matrizes vazias A declaração, » X = []

atribui a matriz de dimensão zero-por-zero à  X , sendo possível usar a variável  X  em cálculos. Criar a matriz  X vazia é diferente do que apagar a variável  X com o comando  clear  X . Com o uso de matrizes vazias é possível remover linhas e colunas de uma matriz, como mostra o exemplo a seguir que apaga as colunas 2 e 4 da matriz A: » A(:,[2 4]) = []

Matrizes Especiais

FEI - FCA

Tutorial do Matlab & Simulink

17

Existe uma coleção de funções que geram matrizes que são encontradas nos problemas de álgebra linear e processamento de sinais. Exemplos:

• • • • • • • • • • •

compan - gera a matriz a partir do polinômio caraterístico diag - matriz diagonal pascal - constrói o triângulo de Pascal zeros - matriz de "zeros" ones - matriz de "uns" eye - matriz identidade logspace - vetores espaçados logaritmicamente linspace - vetores espaçados linearmente rand - elementos randômicos uniformemente distribuídos randn - elementos randômicos normalmente distribuídos etc ...

Construindo Matrizes Grandes É possível formar matrizes maiores a partir de matrizes menores, envolvendo as matrizes menores entre colchetes . Por exemplo, se  A é uma matriz quadrada, » C = [A A'; ones(size(A)) A.^2]

cria a matriz C  com o dobro do tamanho de  A. Note que na construção de matrizes usando matrizes, as dimensões das matrizes menores devem ser compatíveis ou então aparecerá uma mensagem de erro.

Manipulando Matrizes Várias funções estão disponíveis para a manipulação matricial como:  rot90 (rotação),  tril (parte triangular superior),  triu (parte triangular inferior),  reshape (alteração da dimensão) etc.

FEI - FCA

Tutorial do Matlab & Simulink

18

1.1.5 Análise de Dados Esta seção apresenta uma introdução à análise de dados usando o MATLAB. Técnicas mais poderosas estão disponíveis usando funções de álgebra linear e funções de processamento de sinais na seção 1.1.7 (polinômios e processamento de sinais).

Convenção Por convenção, as diferentes variáveis em um conjunto de dados são colocadas em colunas, permitindo observação vertical dos dados através das linhas. Portanto, um conjunto de dados de 50 amostras de 13 variáveis é armazenado numa matriz de dimensão 50-por-13. O conjunto de dados armazenados na matriz count será usado para ilustrar o uso de algumas funções count = 11 43 38 61 12

57 178 163 420 59

291 1011 1095 2407 287

Para esse exemplo temos 5 observações para 3 variáveis. Isso pode ser obtido como segue: » [n,p] = size(count) n= 5 p= 3

Um grupo de funções (abaixo) confere a capacidade de análise de dados básica: • max - máximo valor • min - mínimo valor • mean - valor médio • median - mediana • std - desvio padrão

FEI - FCA

Tutorial do Matlab & Simulink

• • • • • • • •

sort sum prod cumsum cumprod diff  corrcoef  cov

19

- ordenação - soma dos elementos - produto dos elementos - soma cumulativa dos elementos - Produto cumulativos dos elementos - Aproximação da derivada - Coeficientes de correlação - Matriz de covariância

Para argumentos vetoriais não faz diferença se o vetor é linha ou coluna. Para arrays as funções são orientadas por colunas. Continuando com o exemplo anterior, as declarações abaixo » mx = max(count); » mu = mean(count); » sigma = std(count);

resultam em: mx = 61

420

2407

mu = 1.0e+003 * 0.0330

0.1754

1.0182

sigma = 21.4126 147.9503 865.7639

Ajuste de Curvas Uma das alternativas possíveis no MATLAB para encontrarmos os coeficientes de p(x) a partir de dados tabelados é através da função polyfit, onde n é o grau do polinômio. p( x)

=

d

c1 x

+ c2 xd −1 +  + cn

A sintaxe de chamada é a seguinte, onde  x é a abcissa, p o valor da função para cada x(i) e n o grau do polinômio.

FEI - FCA

Tutorial do Matlab & Simulink

20

» c = polifit(x,p,n)

1.1.6 Funções Matriciais Autovalores e Autovetores Se  A é uma matriz n-por-n, os n números λ  que satisfazem a equação  Ax = λ  x, são os autovalores de A. Eles são encontrados usando » eig(A)

Se o comando for usado com dois parâmetros de saída, obteremos os autovalores em D e os autovetores em X : » [X,D] = eig(A)

Norma, Posto e Condicionamento As funções MATLAB que calculam a norma, posto e número de condicionamento de uma matriz são:

• • • •

cond norm rank rcond

- número de condicionamento usando norma 2 - norma 1, norma 2, norma F e norma ∞ - posto da matriz - estimativa do condicionamento

1.1.7 Polinômios e Processamento de Sinais O MATLAB possui funções para manipulação polinomial e para o processamento digital de sinais. Essas funções operam primordialmente com vetores.

Representação de Polinômios O MATLAB representa polinômios como vetores linha contendo os coeficientes ordenados em ordem decrescente dos expoentes. Por exemplo, o polinômio característico de

FEI - FCA

Tutorial do Matlab & Simulink

21

A= 1 4 7

2 5 8

3 6 0

é calculado com » p = poly(A) p= 1 -6 -72 -27

Esta é a representação MATLAB do polinômio equação são

s

3

− 6s2 − 72s − 27. As raízes dessa

» r = roots(p) r= 12.1229 -5.7345 -0.3884

Essas raízes são os mesmos que os autovalores da matriz  A. Você pode remontar o polinômio original com a função poly » p2 = poly(r) p2 = 1 -6 -72 -27

Considere os polinômios a(s) = s2 + 2s + 3 e b(s) = 4s2 + 5s + 6 . O produto dos polinômios é a convolução dos seus coeficientes » a = [1 2 3]; b = [4 5 6]; » c = conv(a,b) c= 4 13 28 27 18

Você pode utilizar a convolução inversa para dividir dois polinômios, e no caso do exemplo, obter b novamente.

FEI - FCA

Tutorial do Matlab & Simulink

22

» [q,r] = deconv(c,a) q= 4 5 6 r= 0 0 0 0 0

A lista de funções de polinômios inclui:

• • • • • • • • •

poly roots polyval polyvalm conv deconv residue polyder polyfit

- polinômio característico - raízes de um polinômio - cálculo do valor numérico do polinômio - cálculo do polinômio de matrizes - multiplicação (convolução) - divisão (deconvolução) - expansão em frações parciais - derivada do polinômio - ajuste polinomial de curva

Processamento de Sinais Vetores são usados para armazenar sinais de dados amostrados, ou seqüências, para o processamento dos sinais. Para sistemas com múltiplas entradas, cada linha da matriz corresponde a uma amostra. O MATLAB básico contém as funções a seguir, enquanto que o Signal Processing Toolbox contém muitas funções adicionais.

• • • • • • • • • • •

abs angle conv deconv fft ifft fftshift fft2 ifft2 fftshift conv2

- magnitude complexa - ângulo de fase - convolução - deconvolução - transformada rápida de Fourier - transformada rápida inversa de Fourier - alterna quadrantes de matrizes - FFT de duas dimensões - FFT inversa de duas dimensões - rearranja os resultados da FFT - convolução de duas dimensões

Filtragem de Dados

FEI - FCA

Tutorial do Matlab & Simulink

23

A função, » y = filter(b,a,x)

filtra os dados do vetor  x com o filtro descrito pelos vetores a e b, criando o dado y filtrado. x

y

H(z)

A estrutura do filtro é dada a seguir pela sua função de transferência de tempo discreta  H (z) =

Y (z )  X (z)

b(1) + b( 2)z − ++ b(nb)z − nb − 1

=

(

1)

1 + a(2)z−1 ++ a(na)z − ( na −1)

A função  freqz do Signal Processing Toolbox, calcula a resposta em freqüência de filtros digitais. Além dessa, exemplificada abaixo, esse Toolbox contém inúmeras funções para o projeto de filtros digitais. » » » » »

[h,w] = freqz(b,a,n); mag = abs(h); fase = angle(h); semilogy(w,mag) plot(w,fase)

1.1.8 Funções de Funções A classe de funções MATLAB para cálculo que não é sobre matrizes numéricas, mais sim com funções matemáticas é aqui designada por funções de funções e incluem:

• • •

Integração Numérica Equações não lineares e Otimização Solução de Equações Diferenciais

FEI - FCA

Tutorial do Matlab & Simulink

24

O MATLAB representa funções matemáticas através de arquivos-M (Mfiles). Por exemplo, a função  f (x ) =

1 1 + −6 ( x − 0,3)2 + 0,01 (x − 0,9)2 + 0,04

torna-se disponível no MATLAB se criarmos um arquivo com extensão exemplo chamado humps.m, cuja listagem é mostrada a seguir:

.m,

por

% listagem do arquivo humps.m function y = humps(x) y = 1./((x-.3).^2 + .01) + 1./((x-.9).^2 + .04) - 6;

O gráfico dessa função é obtido como segue » x = -1:.01:2; » plot(x,humps(x)) 100

80

60

40

20

0

-20 -1

-0.5

0

0 .5

1

1 .5

2

Integração Numérica Uma função, tal como  humps, pode ser integrada numericamente pelo processo chamado de quadratura. Exemplo:

FEI - FCA

Tutorial do Matlab & Simulink

25

» q = quad('humps',0,1) q= 29.8583

O MATLAB oferece duas funções para o processo de quadratura:

• •

quad - regra de Simpson adaptativa quad8 - regra de Newton adaptativa

Note que o primeiro argumento da função quad  é uma string que contém o nome de uma função. Isso mostra porque essa função é chamada função de função (é uma função que opera com outras funções). Os outros dois argumentos são os limites de integração.

Equações Não Lineares e Funções de Otimização No MATLAB básico encontramos algumas funções para a manipulação de equações não lineares e para otimizações.

• • •

fmin - mínimo de uma função de uma variável var iável fmins - mínimo de uma função multivariável fzero - zero de uma função de uma variável

Continuando com o exemplo definido pela função humps.m, a localização do mínimo da função na região de 0.5 a 1 é calculada com fmin: » xm = fmin('humps',0.5, 1) xm = 0.6370

e o seu valor no mínimo é » y = humps(xm) y= 11.2528

A localização do zero da função que está próximo de x = 0 e de x = 1 é,

FEI - FCA

Tutorial do Matlab & Simulink

26

» xz1 = fzero('humps',0) xz1 = -0.1316 » xz2 = fzero('humps',1) xz2 = 1.2995

No Optimization Toolbox temos inúmeras outras funções como por exemplo,

• • • • • • •

attgoal constr fminu fsolve leastsq minimax seminf 

- goal attainment multi-objetivo - minimização com restrições - minimização sem restrições - solução de equações não lineares - mínimos quadrados não linear - solução do problema pr oblema minimax - minimização semi-infinita

Equações Diferenciais As funções disponíveis para a solução de equações diferenciais ordinárias são:

• •

ode23 ode45

- método Runge-Kutta de 2ª/3ª ordem - método Runge-Kutta-Fehlberg de 4ª/5ª ordem

Considere a equação diferencial de segunda ordem conhecida como equação de Van der Pol. x  + ( x2

− 1) x + x = 0

Esta equação pode ser escrita como um sistema de equações diferenciais de primeira ordem

= x1 (1 −  x 2 = x1 x1

x22 ) − x2

FEI - FCA

Tutorial do Matlab & Simulink

27

O primeiro passo para simular este sistema é criar um arquivo que contem este sistema de equações diferenciais. Chamaremos este arquivo ar quivo de vdpol.m function xponto = vdpol(t,x) xponto(1) = x(1).*(1-x(2).^2)-x(2); x(1).*(1-x(2).^2)-x(2); xponto(2) = x(1);

Para simular a equação diferencial no intervalo 0 ≤ t  ≤ 20 , use a função  ode23. » » » »

t0 = 0; tf = 20; x0 = [0 0.25]'; % condicoes iniciais [t,x] = ode23('vdpol',t0,tf,x0); plot(t,x) 3

2

1

0

-1

-2

-3

0

5

10

15

20

Para aqueles que trabalham com equações diferenciais recomenda-se o SIMULINK que é uma extensão gráfica do MATLAB para a simulação de equações diferenciais.

1.1.9 Gráficos O sistema gráfico do MATLAB oferece uma variedade de técnicas sofisticadas para representar e visualizar dados. São funções gráficas em 2-D e 3-D.

Gráficos 2-D

FEI - FCA

Tutorial do Matlab & Simulink

28

O MATLAB fornece uma variedade de funções para a visualização de dados em duas dimensões (2-D).

Funções Gráficas Elementares A lista abaixo sumariza as funções gráficas básicas. Elas diferem apenas na escala dos eixos. Cada entrada pode ser um vetor ou uma matriz e as escalas são ajustadas automaticamente para acomodar os dados de entrada.

• • • • • • • • • •

plot loglog semilogx semilogy title xlabel ylabel text gtext grid

- cria um plot de vetores ou colunas de matrizes - escala logarítmica nos dois eixos - escala logarítmica no eixo x e linear em y - escala logarítmica no eixo y e linear em x - adiciona um título ao gráfico - adiciona um nome ao eixo x - adiciona um nome ao eixo y - mostra um texto na posição especificada - coloca o texto no gráfico usando o mouse - coloca linhas de grid 

Criando um Plot  Se  y é um vetor, plot(y) produz um gráfico linear dos elementos de  y em função do indexador de  y. Se você especificar dois vetores como argumentos, plot(x,y) produz um gráfico de  y versus  x. Você pode também especificar vários conjuntos de dados e definir o estilo da linha e sua cor para cada conjunto de dados, tudo isso num mesmo comando: » » » » » » » »

t = 0:pi/100:2*pi; x = sin(t); y1 = sin(t + 0.25); y2 = sin(t + 0.5); plot(x,y1,'r-',x,y2,'g--') title('Defasagem') xlabel('x=sin(t)') ylabel('y=sin(t+)')

FEI - FCA

Tutorial do Matlab & Simulink

29

Defasagem 1 0.8 0.6 0.4 0.2 y=sin(t+)

0 -0.2 -0.4 -0.6 -0.8 -1 -1

-0.5

0

0.5

1

x=sin(t)

Estilos de Linhas, Marcadores e Cores Tal como mostrou-se no exemplo anterior, você pode passar um caractere como um argumento à função  plot para especificar um dos vários estilos de linha, símbolos e cores. Na declaração plot(X,Y,S), S é uma string de 1, 2 ou 3 caracteres (delimitados por apóstrofes) com as funções definidas pela tabela a seguir. Se você não especificar uma cor, ele usa as cores da tabela automaticamente.

FEI - FCA

Tutorial do Matlab & Simulink

Símbolo y m c r g b w k

Cor yellow magenta cyan red green blue white black

30

Símbolo . o x + * : -. --

Linha ponto círculo marca x marca + marca * sólida pontilhada traço-ponto tracejada

Adicionando Linhas num Gráfico Existente Você pode adicionar outras curvas em um gráfico que já foi construído usando o comando  hold . Quando você seleciona  hold on, o MATLAB não remove as linhas atuais, ao invés disso ele adiciona as linhas atuais ao gráfico atual. O que ele pode fazer é mudar a escala dos eixos automaticamente se os novos dados não se acomodarem dentro da escala anterior. Exemplo: » » » » »

plot(x) hold on plot(y1,'--') plot(y2,'-.') hold off

Resulta,

FEI - FCA

Tutorial do Matlab & Simulink

31

1 0.8 0.6 0.4 0.2 0 -0.2 -0.4 -0.6 -0.8 -1

0

50

100

150

20 0

25 0

Dados Imaginários e Complexos Quando os argumentos da função  plot são complexos, isto é, eles têm parte imaginária diferente de zero, a parte imaginária é ignorada exceto quando  plot é usado com um único argumento. Nesta situação, o comando é um comando gráfico resumido da parte real versus a parte imaginária. Portanto, plot(z) ,  , quando  z é um vetor ou matriz complexa, é equivalente à, plot(real(z),imag(z)). Para ilustrar isso, o exemplo a seguir usa a distribuição dos autovalores de uma matriz 20-por-20 randômica: » plot(eig(randn(20,20)),’x’) Distribuição de Autovalores 4

3

2

1

0

-1

-2

-3

-4 -4

-2

0

2

4

6

FEI - FCA

Tutorial do Matlab & Simulink

32

Plotando Matrizes A função  plot pode ter um único argumento, como plot(Y). Ela desenha uma curva para cada coluna de Y . O eixo  x é formado pelo índice de cada linha. Se X e Y são matrizes, plot(X,Y) plota as coluna de X versus cada as colunas de Y . » » » »

X = 0:pi/50:2*pi; Y = sin(X); Z = cos(X); W = log(X); A = [Y' Z' W']; plot(A)

Resulta, 2 1.5 1 0.5 0 -0.5 -1 -1.5 -2 -2.5 -3

0

20

40

60

80

10 0

12 0

Importando Dados Você pode importar e plotar dados gerados fora do MATLAB. Suponha você tenha um arquivo chamado dados.dat contento valores de duas funções e da variável independente.

FEI - FCA

Tutorial do Matlab & Simulink

33

dados.dat 2.3 3.1 4.5 5.6 4.8 4.7 4.4 4.0 4.2

1.0 1.9 2.2 2.6 3.5 4.7 5.3 6.0 7.1

1.0 2.0 3.0 4.0 5.0 6.0 7.0 8.0 9.0

O comando load dados.dat produz uma matriz chamada dados, 9-por-3. A seguir, mostra-se como renomear cada uma das variáveis e como plotar cada função separadamente. » » » » » »

load dados.dat F1 = dados(:,1); F2 = dados(:,2); X = dados(:,3); subplot(211), plot(X,F1) subplot(212), plot(X,F2)

Resulta, 6 5 4 3 2 0

2

4

6

8

10

0

2

4

6

8

10

8 6 4 2 0

Funções Gráficas Especializadas em 2-D

FEI - FCA

Tutorial do Matlab & Simulink

34

O MATLAB inclui uma variedade de funções especializadas, conforme descrito resumidamente a seguir.

• • • • • • • • • • •

bar compass errorbar feather fplot hist polar quiver rose stairs fill

- gráfico de barras - gráfico de ângulos com setas - gráfico de barras de erros - gráfico de ângulos - calcula e plota uma função - cria um histograma - gráfico em coordenadas polares - cria um gráfico de um gradiente - histograma em ângulo - gráfico similar ao de barras sem linhas internas - desenha um polígono e preenche o interior

Plotando Funções Matemáticas Você pode plotar o gráfico de uma função, y = f ( x) . A solução pela força bruta é calcular a função para algumas centenas de pontos no intervalo de interesse. Por exemplo, a função a seguir oscila com freqüência tendendo para infinito quando  x = 0,5. » x = (0:1/2000:1)'; » plot(x,cos(tan(pi*x)))

Resulta,

FEI - FCA

Tutorial do Matlab & Simulink

35

y = cos(tan(pi*x))

1 0.8 0.6 0.4 0.2 0 -0.2 -0.4 -0.6 -0.8 -1 0

0.2

0. 4

0.6

0. 8

1

No exemplo, a função é plotada no intervalo [0,1]. Neste caso, a função  fplot é mais efetiva para obtermos a representação gráfica da função pois ela escolhe automaticamente uma quantidade maior de pontos na faixa que é necessário maior resolução gráfica. Para usar a função  fplot, primeiro crie um arquivo que conterá a função a ser plotada, por exemplo com o nome fofx.m function y = fofx(x) y = cos(tan(pi*x)); cos(tan(pi*x));

Agora basta passar o nome da função como argumento de fplot. » fplot('fofx',[0 1], 25,20,10)

Resulta,

FEI - FCA

Tutorial do Matlab & Simulink

36

y = cos(tan(pi*x))

1 0.8 0.6 0.4 0.2 0 -0.2 -0.4 -0.6 -0.8 -1 0

0. 2

0.4

0 .6

0 .8

1

Gráficos 3-D O MATLAB oferece uma variedade de funções para a visualização de dados em 3-D, conforme sumarizado pelas funções a seguir. Contudo, não faremos um detalhamento, visto que o assunto é muito longo e pouco interessante para os objetivos iniciais deste trabalho.

• • • • • • • • • •

plot3 - plota linhas e pontos em 3-D. contour, contour3 - plotagem de contornos pcolor - desenha uma matriz retangular de células cujas cores são determinadas pelos elementos da matriz. image - mostra uma matriz como uma imagem mapeando os elementos da matriz para o mapa de cores cor es atuais. mesh, meshc, meshz - cria uma perspectiva em 3-D dos elementos da matriz. fill3 - cria um polígono 3-D e preenche com uma cor sólida ou interpola cores. zlabel - cria um label para o eixo z. clabel - adiciona um label à plotagem de contorno. view - determina o ponto de visualização atual. viewmtx - calcula uma transformação 4x4.

FEI - FCA

Tutorial do Matlab & Simulink

37

1.1.10 Controles de Fluxo O MATLAB possui declarações para controle de fluxo tal como aqueles encontrados na maioria das linguagem de computador. O controle de fluxo torna o MATLAB mais do que uma calculadora científica, permitindo que seja usado como uma linguagem de programação de alto nível completa.

FOR O MATLAB possui a sua versão própria dos loops DO ou FOR. Com isso é possível repetir um grupo de declarações por um número predeterminado de vezes. Por exemplo, » for i = 1:n, x(i) = 0, end

impõe o valor "0" para todos os primeiros n elementos de  x. Se n é menor que "1", a construção ainda é permitida, mas as declarações internas ao loop não são executadas. Se  x não existe ou tem menos elementos que  x, então espaços adicionais são alocados automaticamente. Você pode criar loops dentro de loops e pode fazer as declarações diretamente no  prompt  do MATLAB, embora o uso de um  M-file seja recomendado nestes casos. » for i = 1:1:m for j = 1:1:n » » A(i,j) = 1/(i+j-1); » end » end » A

A expressão do for é usualmente do tipo m:i:n, onde m é o valor inicial, n o final e i o incremento, sendo que esse pode ser negativo.

WHILE

FEI - FCA

Tutorial do Matlab & Simulink

38

Tal como o for, a declaração while, também é para realizar um grupo de declarações um certo número de vezes. A diferença básica é que no while, o controle do loop é feito por uma condição lógica. Para ilustrar, vamos resolver um problema: Qual é o primeiro inteiro n para o qual n! (fatorial de n) é um número de 100 dígitos ? » n = 1; » while prod(1:n) < 1.e100, n = n+1; end » n

A função prod realiza o produtos dos elementos do argumento. Logo, é o fatorial de n.

prod(1:n)

Declarações IF e BREAK Os exemplos a seguir ilustram a utilização da declaração if . O primeiro exemplo mostra como um cálculo pode ser dividido em três casos dependendo do sinal e da paridade de n. if n < 0 A = negative(n) elseif rem(n,2) == 0 A = even(n) else A = odd(n) end

O segundo exemplo envolve um problema não resolvido da teoria dos números: "Pegue um número inteiro. Se ele for par, divida por dois; se for impar, multiplique ele por 3 e some 1. Repita esse processo até que o inteiro seja igual a um. O problema é saber se existe algum inteiro para o qual o processo nunca termina".

Este programa MATLAB ilustra as declarações while e if . Também é mostrado o uso da função input que interrompe a execução para a entrada de dados e da declaração break que permite interromper um loop.

FEI - FCA

Tutorial do Matlab & Simulink

39

% Problema classico "3n+1" da teoria dos números while 1 n = input('Entre com n [negativo aborta]. '); if n 1 if rem(n,2) == 0 n = n/2 else n = 3*n+1 end end end

1.1.11 Arquivos M O MATLAB normalmente é usado no modo de comando. Quando você entra com uma linha de comando, ele processa e imediatamente mostra o resultado. O MATLAB também pode executar uma seqüência de comandos que está armazenada num arquivo. Estes dois modos formam um ambiente interpretativo. Os arquivos que contém declarações MATLAB são chamados Mfiles porque usam a extensão .m. Por exemplo, o arquivo bessel.m contém declarações MATLAB para o cálculo de funções Bessel. Um M-file consiste de uma seqüência de declarações MATLAB normais, podendo incluir referencias à outros M-files. Um M-file pode chamar ele próprio de forma recursiva. Você pode criar um M-file usando um editor de texto tal como o  Notepad  do Windows™,  Edit  do DOS ou outro qualquer. Dois tipos de M-files podem ser usadas: manuscritas ( scripts) e funções. Arquivos scripts automatizam uma seqüência longa de comandos. Arquivos de função permite criar novas funções às existentes. Ambos, scripts e funções são arquivos texto tipo ASCII.

Arquivos Scripts  O exemplo a seguir ilustra como calcular os primeiros 16 números de Fibonacci usando um arquivo script . Suponha que o nome do arquivo seja fibno.m. Digitando fibno no prompt do MATLAB, faz com os comandos contidos no arquivo sejam executados. Note que depois da execução do programa as variáveis  f  e i permanecem na área de trabalho (workspace) do MATLAB. Verifique isso com who. Isso acontece porque os scripts operam globalmente

FEI - FCA

Tutorial do Matlab & Simulink

40

com dados no workspace. Os demos fornecidos junto como MATLAB são bons exemplos de como usar scripts para realizar tarefas mais complexas. Para chamar os demos digite demo no prompt do MATLAB. % M-file (script) para calcular números de Fibonacci f = [ 1 1]; i = 1; while f(i) + f(i+1) < 1000 f(i+2) = f(i) + f(i+1); i = i + 1; end plot(f)

Quando você chama o MATLAB, ele automaticamente executa um script  chamado startup.m (se voce o criou). Nesse arquivo você pode colocar as definições iniciais do workspace tal como constantes, fatores de conversão, etc.

Arquivos de Funções Um M-file que contém a palavra function no início da primeira linha é um arquivo de função. Uma função difere de um script  no fato de que argumentos podem ser passados; variáveis definidas e manipuladas no arquivo são locais à função e não operam globalmente no workspace. A função listada à seguir é do seu disco e tem o nome mean.m.

FEI - FCA

Tutorial do Matlab & Simulink

41

function y = mean(x) % MEAN Average or mean value. % For vectors, MEAN(X) is the mean value value of of the % elements in X. % For matrices, MEAN(X) is a row vector containing containing % the mean value of each column.

[m,n] = size(x); if m == 1 m = n; end y = sum(x) / m;

Por exemplo, se z é um vetor de inteiros de 1 à 99, sua média pode ser calculada como segue: » z = 1:99; » mean(z) ans = 50

A seguir, descreve-se alguns detalhes de mean.m:

• • • • •



A primeira linha declara o nome da função, os argumentos de entrada e os de saída. Sem esta linha, o arquivo é um script  ao invés de função; O símbolo % indica que o resto da linha é um comentário e deve ser ignorado; As primeiras linhas documentam um M-file e são mostradas quando pedimos help mean; A primeira linha de help, conhecida como linha "H1", é incluída no arquivo contents.m e é usada pelo comando lookfor; As variáveis m, n e  y são locais à função e não existem no workspace depois que do término da função. (Caso a variável já existisse antes da chamada de mean, ela continuaria existindo depois e inalterada); Não foi necessário colocar os inteiros inteiros de 1 a 99 numa variável chamada  x. De fato, nós usamos mean com um variável chamada  z. O vetor  z foi passado ou copiado dentro da função onde ela tornou-se uma variável local chamada x.

FEI - FCA

Tutorial do Matlab & Simulink

42

Você pode criar uma função um pouco mais mais complexa que mean, chamada stat, que também calcula o desvio padrão. Neste exemplos ilustramos o uso de múltiplos argumentos de saída. function [mean,stdev] = stat(x) [m,n] = size(x); if m == 1 m = n; end mean = sum(x) / m; stdev = sqrt(sum(x.^2)/m - mean.^2);

Uma função que calcula o posto de uma matriz usa múltiplos argumentos de entrada: No caso geral teríamos múltiplos argumentos de entrada e de saída. function r = rank(x,tol) % rank (posto em Portugues) da matrix s = svd(x); if (nargin == 1) tol = max(size(x)) * s(1) * eps; end r = sum(s > tol);

Este exemplo também mostra o uso da variável permanente nargin para encontrar o número de argumentos de entrada. A variável nargout, embora não usada neste exemplo, contém o número de argumentos de saída.

Criando um Help  para Seus Arquivos Pessoais você pode criar um help online para os seus M-files pessoais entrando o texto em uma ou mais linhas de comentário, começando sempre pela segunda linha do arquivo. Por exemplo, o arquivo da função angle,

FEI - FCA

Tutorial do Matlab & Simulink

43

function p = angle(h) % ANGLE Phase angle. % ANGLE(H) returns the phase angles, in radians, of a % matrix with complex elements. % % See also ABS, UNWRAP. p = atan2(imag(h), atan2(imag(h), real(h));

têm 5 linhas contíguas de comentário a partir da segunda linha. Quando digitamos help angle, todo esse bloco é mostrado. O mecanismo de help ignora linhas de comentário que aparecem mais a frente, depois de uma declaração ou mesmo uma linha em branco.

Informações Úteis Quando você chama uma função pela primeira vez, o MATLAB compila a função e a coloca na memória. Ela estará então disponível para os usos subseqüentes sem a necessidade de ser compilada. Permanecerá na memória até o final da seção ou até que você fique com pouca memória, acarretando na sua eliminação automática. O comando what mostra uma listagem dos M-files no diretório atual do disco. O comando type lista os M-files e ! é usado para comandos do DOS. De uma maneira geral, quando você digita um nome de algo no MATLAB, por exemplo whoopie, o interpretador do MATLAB executa os seguintes passos: 1. 2. 3. 4.

Procura por whoopie como variável; Verifica se whoopie é uma função interna; Procura um o arquivo whoopie.m no diretório atual; Procura um o arquivo whoopie.m nos diretórios especificados pelo path do MATLAB.

ECHO, INPUT, KEYBOARD, PAUSE

FEI - FCA

Tutorial do Matlab & Simulink

44

Normalmente, enquanto um M-file está sendo executado, os comandos contidos no arquivo não são mostrados na tela. O comando echo permite visualizar o comando a medida que ele vai sendo executado. Isso é especialmente útil na depuração de uma programa ou para a confecção de um programa demonstrativo. A função input permite obter dados do usuário. por exemplo, n = input('Entre com o valor de n = ')

interrompe a execução, mostra a frase na tela, espera, e então atribui o valor ou expressão digitada para a variável n. Similar à input, mas muito mais poderosa, é a função  keyboard . Esta função torna o teclado do computador um script . Quando colocada dentro de Mfiles, torna ágil a depuração e permite a modificação de variáveis durante a execução. O comando  pause interrompe a execução até que o usuário pressiona uma tecla qualquer. pause(n) interrompe por n segundos antes de continuar.

Variáveis Globais Cada função MATLAB possui suas próprias variáveis locais que são separadas daquelas de outras funções e daquelas que estão no workspace. Contudo, se você declarar uma variável como global, todas as funções e o workspace vão enxergar a mesma variável. Para diferenciar das demais variáveis, costuma-se identificar uma variável global declarando-a com um nome longo e em letras maiúsculas, embora isso não seja uma imposição. Suponha que você queira estudar o comportamento dos coeficientes α  e  β  no problema do modelo predador-vítima de Latka-Volterra. y1 y2

y1

α y2 y1 y2 β y2 y1

Crie o arquivo lotka.m:

FEI - FCA

Tutorial do Matlab & Simulink

45

function yp = lotka(t,y) % modelo Votka-Voltera global ALFA BETA yp = [y(1) - ALFA*y(1)*y(2); -y(2) + BETA*y(1)*y(2)];

Interativamente, entre como as seguintes declarações: » » » » »

global ALFA BETA ALFA = 0.01; BETA = 0.02; [t,y] = ode23('lotka',0,10,[1; 1]); plot(t,y)

Uma vez que ALFA e BETA são globais você pode altera-las interativamente e novas soluções podem ser obtidas sem ter que editar nenhum arquivo e sem passar os valores como argumentos.

Variáveis Alfanuméricas Variáveis tipo texto são introduzidas no MATLAB envolvendo o texto com quotas simples (apóstrofos). Por exemplo, » s = 'Ola' s= Ola

O texto é armazenado num vetor, um caracter por elemento. Desejando concatenar textos, use colchetes: » s = [s, ' Pessoal'] s= Ola Pessoal

Valores numéricos são convertidos em variáveis tipo texto via  sprintf ,  num2str e int2str. Exemplo, » c = 23; » title(['A temperatura é',num2str(c),' graus C'])

A Função EVAL

FEI - FCA

Tutorial do Matlab & Simulink

46

A função eval lida com variáveis tipo texto para implementar recursos de macros de texto. eval(t) força que o texto contido na variável t  seja "resolvido". O exemplo a seguir mostra como usar o comando load  para carregar 10 arquivos seqüencialmente numerados: dados1.mat, dados2.mat, ... » fname = "dados"; » for i = 1:10 » eval(['load ',fname,int2str(i)]) » end

A função eval  é especialmente útil na passagem de argumentos de funções cujo parâmetro é um nome de outra função. Um exemplo típico é o função  fplot que passa como argumento o nome da função a ser plotada, exemplo: » fplot('sin',[0 10])

1.1.12 Arquivos de Disco Os comandos load  e  save recuperam e armazenam dados do workspace no disco.

Manipulação de Arquivos de Disco Os comandos dir,  type,  delete e  cd  servem à manipulação de arquivos. Para a maioria desses comandos devemos especificar o path, wildcards e o drive de destino como normalmente se faz no DOS. O comando type difere do comando type usual de uma forma importante. Se nenhuma extensão é especificada, o MATLAB assume .m como default . Portanto, esse comando é bastante usado para obtermos a listagem de um M-file na teta do computador. O comando  diary cria um diário (log) da sua seção MATLAB na forma de um arquivo ASCII. Todos os comandos e resultados, exceto gráficos, são automaticamente acrescentados ao arquivo de diário.

Rodando Programas Externos

FEI - FCA

Tutorial do Matlab & Simulink

47

O ponto de exclamação ! é a forma de acessar o DOS de dentro do MATLAB. Você pode executar qualquer programa externo tal como o editor EDIT do DOS. » ! edit c:\usuario\teste.doc

Transferência de Dados Você pode introduzir dados de outros programas dentro do MATLAB. Similarmente, você pode exportar dados do MATLAB para outros programas. Também é possível usar o formato que o MATLAB usa para armazenar dados: MAT-files.

Importando Dados O melhor método de importar dados depende de quantos dados existem, qual o seu formato, etc. A seguir, listamos algumas opções:



Entre com os dados como uma lista explícita dos elementos. Se o número de elementos for pequeno (10-15 elementos) é mais simples digitar os dados explicitamente usando colchetes.



Crie um M-file e escreva os dados de forma explícita usando um editor de texto.



Carregue do dados de um arquivo ASCII.



Escreva um programa em C ou FORTRAN para converter seus dados no formato dos MAT-files e então use o comando load .

Exportando dados do MATLAB Para exportar dados também existem várias opções, das quais algumas são listadas a seguir:

FEI - FCA

Tutorial do Matlab & Simulink

48



Para matrizes pequenas use o comando  diary para criar uma arquivo de diário e então liste as variáveis neste arquivo. Você pode, mais tarde, usar um editor de texto para manipular os dados.



Salve os dados num formato ASCII usando o comando  save com a opção -ascii. Por exemplo, » A = rand(4,3); » save temp.dat A -ascii

cria um arquivo ASCII chamado temp.dat



Salve os dados como MAT-files usando o comando  save e então escreva um programa em C ou FORTRAN para reformatar os dados conforme necessário para a aplicação.

1.1.13 O Depurador do Matlab Embora o MATLAB seja uma linguagem menos complexa que outras linguagens de programação, ele tem sua sintaxe própria e você pode precisar corrigir alguns erros. O MATLAB encontra erros de sintaxe durante a fase de compilação e esses erros, em geral, são simples de corrigir. O MATLAB também encontra erros na fase de execução do programa; esses erros tendem a ser mais mais difíceis de solucionar por causa do workspace local às funções ser perdido quando um erro interrompe a execução. Quando isto ocorre, retornamos ao workspace base do MATLAB. Se você usou ponto-e-vírgula para suprimir os resultados intermediários da tela, não terá como saber onde o erro ocorreu. Para mostrar os resultados intermediários, você pode usar um dos métodos a seguir:

• • •

Remova os ponto-e-vírgula de interesse; Use a declaração keyboard para permitir que o workspace seja examinado no ponto da declaração; Torne a primeira linha da função uma linha de comentário, de tal forma que a função possa ser executada como um script ,

FEI - FCA

Tutorial do Matlab & Simulink



49

fazendo com que os resultados intermediários sejam acessíveis no workspace base do MATLAB; Use o depurador do MATLAB.

Comandos de Depuração • • • • • • • • • •

dbstop - coloca um brekpoint  - remove um brekpoint  dbclear dbcont - continua a execução dbdown- troca o contexto do workspace dbstack - lista quem chamou quem - lista todos os brekpoint  dbstatus - executa uma ou mais linhas dbstep dbtype - lista um M-file com número de linhas - troca o contexto do workspace dbup dbquit - sai do modo de depuração

Usando o Depurador Quando você encontra um erro num M-file, use os comandos de depuração para inserir breakpoints para ajuda-lo da depuração do erro. Quando a execução pára num breakpoint  você pode introduzir qualquer comando válido do MATLAB. Lembre-se que os comandos de depuração funcionam com arquivos de funções, não com scripts.

1.2 Toolboxes do Matlab O MATLAB possui um rica coleção de funções imediatamente úteis. Os toolboxes estendem essa capacidade com funções especializadas. A seguir, resume-se as funções disponíveis no toolbox de sistema de controle e enumerase outros toolboxes. É importante perceber que as ferramentas que não são encontradas nos toolboxes podem ser criadas escrevendo-se novos M-files.

FEI - FCA

Tutorial do Matlab & Simulink

50

1.2.1 Sistemas de Controle O toolbox de sistema de controle usa ffunções unções de matrizes do MATLAB na construção de funções especializadas para o engenheiro de controle. Esse toolbox é uma coleção de algoritmos expresso, na sua maior parte, por M-files, que implementam projetos comuns de sistemas de controle, análises e técnicas de modelamento. Aqui, sistemas de controle podem ser representados por funções de transferências ou na forma de espaço de estado, permitindo que você use técnicas clássicas e modernas. Trata-se tanto dos sistemas de tempo contínuo como os de tempo discreto. Estão disponíveis funções de conversão entre as várias formas de representação de um modelo. Respostas temporais, respostas em freqüência, lugar das raízes, etc, podem ser calculados e plotados. Outras funções fornecem recurso para a alocação de pólos, controle ótimo e estimação/filtragem.

Construção de Modelos • • • • • • • • • • • • • • • • • • •

append - concatena sistemas dinâmicos augstate - aumenta estados às saídas blkbuild - obtém equação de estado a partir do diag. em blocos cloop - fecha a malha connect - modelagem via diagrama em blocos conv - convolução de dois polinômios destim - estimar de tempo discreto dreg - estimador/controlador discreto drmodel - cria um modelo discreto randômico estim - estimador de tempo contínuo d ois sistemas numa realimentação feedback - conexão de dois ord2 - cria A, B, C, D de um sistema de segunda ordem pade - aproximação Padé de um atraso parallel - conexão de sistemas em paralelo reg - controlador/estimador contínuo rmodel - cria um modelo contínuo randômico ra ndômico series - conexão série de sistemas ssdelete - apaga, entradas, saídas ou estados de um sistema ssselect - seleciona um subsistema de um sistema maior

FEI - FCA

Tutorial do Matlab & Simulink

51

Conversão de Modelos • • • • • • • • • • • • •

c2d - conversão de tempo contínuo para tempo discreto c2dm - conversão de contínuo para discreto com método c2dt - conversão de tempo contínuo para discreto com atraso d2c - conversão de tempo discreto para contínuo co ntínuo com método d2cm - tempo discreto para contínuo poly - conversão de raízes para polinômio residue - expansão em frações parciais ss2tf - espaço de estado para função de transferência ss2zp - espaço de estado para zero-pólo tf2ss - função de transferência para espaço de estado tf2zp - função de transferência para zero-pólo zp2tf - zero-pólo para função de transferência zp2ss - zero-pólo para espaço de estado

Redução de Modelos • • • • •

balreal - realização balanceada dbalreal - realização balanceada discreta dmodred - redução da ordem de modelos discretos minreal - realização mínima e cancelamento de pólos e zeros modred - redução da ordem do modelo

Realização de Modelos • • • •

canon - forma canônica ctrbf - forma controlável obsvf - forma observável ss2ss - aplica transformação de similaridade

FEI - FCA

Tutorial do Matlab & Simulink

52

Propriedade de Modelos • • • • • • • • • • • • • • • • •

covar - resposta contínua ao ruído branco ctrb - matriz de controlabilidade damp - fator de amortecimento e freqüência natural dcgain - ganho DC de regime permanente contínuo dcovar - resposta discreta ruído branco ddamp - fator de amortecimento e freqüência natural discreta ddcgain - ganho DC de regime permanente discreto dgram - gramianos discretos controlabilidade/observabilidade dsort - ordena autovalores discretos pela tamanho eig - autovalores e autovetores esort - ordena autovalores contínuos pela parte real gram - gramianos de controlabilidade/observabilidade obsv - matriz de observabilidade printsys - mostra o sistema formatadamente roots - raízes de polinômio tzero - zeros de transmissão tzero2 - zeros trans. usando método randômico de perturbação

Resposta Temporal • • • • • • • • • • •

dimpulse - resposta discreta ao impulso dinitial - resposta discreta às condições iniciais dlsim - simulação discreta a entradas arbitrárias dstep - resposta discreta ao degrau filter - simulação SISO da transformada Z impulse - resposta impulsiva initial - resposta contínua às condições iniciais lsim - simulação contínua a entradas arbitrárias ltitr - função de baixo nível para cálculo de resposta temporal step - resposta ao degrau stepfun - função degrau

FEI - FCA

Tutorial do Matlab & Simulink

53

Resposta em Freqüência • • • • • • • • • • • • • •

bode - diagrama de Bode (resposta em freqüência) dbode - diagrama de Bode discreto (resposta em freqüência) dnichols - diagrama de Nichols discreto dnyquist - diagrama de Nyquist discreto dsigma - diagrama em freqüência de valores singulares discretos fbode - diagrama rápido de Bode para sistemas contínuos freqs - resposta em freqüência da transformada de Laplace freqz - resposta em freqüência da transformada Z ltifr - função de baixo nível para resposta em freqüência margin - margem de ganho e fase nichols - diagrama de Nichols ngrid - desenha um grid de linhas no diagrama de Nichols nyquist - diagrama de Nyquist sigma - diagrama em freqüência de valores singulares contínuos

Lugar das Raízes • • • • •

pzmap - mapeamento de pólos e zeros rlocfind - determinação interativa do ganho no lugar das raízes rlocus - lugar das raízes de Evans sgrid - grid para o lugar das raízes contínuo zgrid - grid para o lugar das raízes discreto

Seleção de Ganhos • •

acker - alocação SISO de pólos dlqe - projeto do estimador linear quadrático discreto

FEI - FCA

Tutorial do Matlab & Simulink

• • • • • • • • • • • •

54

dlqew - estimador linear quadrático discreto generalizado dlqr - projeto do regulador linear quadrático discreto dlqry - regulador discreto com penalização nas saídas lqe - projeto do estimador linear quadrático lqed - estimador discreto a partir do funcional contínuo lqe2 - estimador linear quadrático usando método Schur lqew - estimador linear quadrático contínuo generalizado. lqr - projeto do regulador linear quadrático lqrd - regulador discreto a partir do funcional contínuo lqry - regulador contínuo com penalização nas saídas lqr2 - regulador linear quadrático usando método Schur place - alocação multivariável de pólos

Solução de Equações • • • •

are - solução da equação algébrica de Riccati dlyap - solução da equação discreta de Lyapunov lyap - solução da equação contínua de Lyapunov lyap2 - solução da equação de Lyapunov usando diagonalização

Demonstrativos • ctrldemo - Introdução ao toolbox de sistemas de controle • boildemo - projeto LQG para uma caldeira •  jetdemo - o clássico projeto do jet transport yaw damper . • diskdemo - projeto do controlador digital de um winchester  • kalmdemo - projeto e simulação de um filtro de Kalman

1.2.2 Outros Toolboxes Processamento de Sinais, Otimização, Identificação de Sistemas, Controle Robusto, Análise e Síntese µ , Splines, Redes Neurais, Estatística, Projeto de Controle Não Linear, etc.

FEI - FCA

Tutorial do Matlab & Simulink

55

1.3 Simulink Básico O SIMULINK é uma extensão gráfica do MATLAB para a simulação dinâmica de sistemas. Existem duas fases distintas de uso: a definição do modelo e análise do modelo. Para facilitar a definição do modelo, o SIMULINK fornece uma ferramenta gráfica de edição em blocos, onde o modelo é criado e editado tipicamente via mouse. Depois de definir o modelo, você pode analisá-lo diretamente do menu na   janela atual do SIMULINK ou entrando os comandos devidos pela janela de comando do MATLAB. Dentre as ferramentas de análise de modelos temos a simulação propriamente dita, linearização de modelos, etc.

1.3.1 Linhas Gerais Descreve-se brevemente a seguir as ações que são necessárias para iniciar o uso do SIMULINK: 1. Entre com o comando simulink no  prompt  do MATLAB para abrir a biblioteca principal de blocos. 2. Clique no menu File e selecione New. O SIMULINK abre uma  janela em branco como o nome "Untitled". Esse nome pode ser alterado na hora de salvar o arquivo. 3. Abra uma ou mais bibliotecas e arraste os blocos para a janela ativa. 4. Depois de alocar os blocos, desenhe linhas para ligar os blocos, movendo a ponta do seta do mouse enquanto segura o botão esquerdo do mouse apertado. 5. Abra os blocos (dois cliques) e altere seus parâmetros. Os parâmetros podem ser qualquer expressão válida do MATLAB. 6. Salve o arquivo com o Save do menu File.

FEI - FCA

Tutorial do Matlab & Simulink

56

7. Execute a simulação selecionando Start no menu Simulation. Durante a simulação o menu Start é alterado para Stop. Se você seleciona-lo, voltará a aparecer Start. 8. Você pode alterar os parâmetros de simulação selecionando  Parameters no menu Simulation. 9. Você pode monitorar o comportamento do seu sistema com um osciloscópio (bloco Scope), ou você pode usar o bloco To Worksspace para enviar os dados para a área de trabalho do MATLAB e manipular os resultados com funções do MATLAB.

1.3.2 Construção de Modelos O SIMULINK permite que você represente um sistema dinâmico por meio de diagramas em bloco.

Construção de um Modelo Elementar Para definir um sistema, os blocos são copiados das bibliotecas de blocos padrões do SIMULINK ou daquelas criadas por você mesmo. A biblioteca padrão é organizada em vários subsistemas que agrupam blocos de acordo com sua função. Para rodar o SIMULINK, primeiro inicialize o MATLAB clicando duas vezes sobre o ícone do Windows e então entre o comando simulink. » simulink

Este comando mostra uma nova janela contendo ícones dos blocos de subsistemas que constituem a biblioteca padrão.

FEI - FCA

Tutorial do Matlab & Simulink

57

Estes blocos podem ser abertos (clicando duas vezes), abrindo janelas de onde os blocos serão copiados para a sua janela de trabalho. Abra uma nova   janela vazia selecionando New no menu  File. Para copiar os blocos, clique sobre o bloco desejado e arraste-o para a sua janela enquanto mantém o botão esquerdo do mouse apertado. Inicialmente clique sobre a biblioteca Sources e arraste um gerador de funções para a nova janela (untitled).

FEI - FCA

Tutorial do Matlab & Simulink

58

Os blocos arrastados são copiados com os seus parâmetros originais. A maioria dos blocos pode ser aberta mostrando seus parâmetros numa janela independente. Modificando os parâmetros você personaliza o bloco.

Clicando 2 vezes sobre o bloco gerador de sinais abre-se a janela de parâmetros. Selecione a forma de onda da saída como senoidal, sua freqüência e amplitude iguais a 1, arrastando o cursor ou introduzindo o novo valor diretamente no campo numérico. Quando terminar clique sobre o OK. Abra agora a biblioteca Sinks e arraste um bloco de osciloscópio (scope) para dentro da nova janela de sistema.

FEI - FCA

Tutorial do Matlab & Simulink

59

Para abrir a janela do osciloscópio, clique duas vezes sobre ele. Posicione a janela num lugar conveniente com o mouse e escolha a faixa horizontal e vertical igual a 10 e 3 respectivamente. Não clique sobre OK , pois fecharia a  janela de observação do osciloscópio.

FEI - FCA

Tutorial do Matlab & Simulink

60

Usando mouse conecte a saída do gerador de sinais com a entrada do osciloscópio. Aperte e mantenha o botão esquerdo do mouse arrastando a linha da entrada para a saída ou vice-versa.

Enquanto puxa a linha, você poderá apertar também o botão central do mouse para obter qualquer angulação da reta. Quando você solta o botão esquerdo muito próximo do ponto a ser conectado, ele indica a conexão preenchendo a seta de preto. Caso você solte o botão muito longe do ponto, ele interrompe a linha com uma seta não preenchida e desconectada. A partir daí  você pode ligar esse pedaço de linha ao destino com uma outra linha, não precisando desenhar tudo novamente. Desta forma é possível traçar uma ligação

FEI - FCA

Tutorial do Matlab & Simulink

61

com qualquer formato. A cada vez que você solta o botão esquerdo e aperta novamente inicia-se uma nova linha ligada a anterior a partir desse ponto. Se você não gostou do resultado apague a linha selecionando-a com um clique em qualquer ponto da linha e então pressione a tecla DELETE ou use Cut ou Clear no menu Edit. Depois de terminado o modelo você pode disparar a simulação. Para selecionar o método de integração e demais parâmetros clique no menu Simulation e escolha Parameteres.

Selecione o quadrado do parâmetro de máximo passo de integraçao e altere o valor default  para 0.01. Ao final clique sobre OK . Inicie a simulação escolhendo Start no menu Simulation. Os controle do osciloscópio e do gerador de sinais permanecem ativos durante a simulação. Você pode selecionar uma forma de onda diferente e verificar o resultado imediatamente no osciloscópio. Mova os cursores dos osciloscópio para ver o efeito. A simulação termina quando o tempo máximo de simulação é atingido ou quando selecionamos s elecionamos Stop no menu Simulation.

FEI - FCA

Tutorial do Matlab & Simulink

62

Você possui agora um modelo que pode ser salvo em disco como um arquivo do MATLAB do tipo M-file. Selecione Save no menu  File e selecione um diretório, um nome para seu modelo e depois clique sobre o OK .

Para encerrar a edição do seu modelo selecione Close no menu File.

Construção de outro Modelo Simples

FEI - FCA

Tutorial do Matlab & Simulink

63

Se você salvou o modelo anterior com o nome novo.m, você pode abrir a  janela com o diagrama simplesmente, digitando "novo" na linha de comando do MATLAB. » novo

Os blocos dentro de uma janela do SIMULINk podem ser movidos livremente. Se mais de um bloco de movido simultaneamente, eles mantém sua posição relativa e as linhas de conexão também são movidas. Selecione o gerador de sinais, osciloscópio e a linha de conexão envolvendo-os com o mouse. Para tanto, aperte o botão esquerdo do mouse estando acima e a esquerda ou abaixo e a direita dos objetos, e ai arrastando o mouse até envolver todos os objetos. Os objetos objetos serão então marcados com pequenos quadrados nos vértices dos blocos e na linha de conexão. Arraste os blocos selecionados para o topo da   janela e solte o botão do mouse. Agora copie um bloco Gain do subsistema  Linear .

FEI - FCA

Tutorial do Matlab & Simulink

64

Scope Scope

Signal Signal Gen. 1 Gain

Clique duas vezes sobre o bloco Gain para abrir a janela de configuração do bloco e altere o valor do ganho para 2. Para ligar a entrada do bloco Gain à linha de conexão entre o gerador e o osciloscópio, você pode começar o traçado da entrada do bloco de ganho ou por exemplo, da saída do gerador

Signal Signal Gen.

Scope Scope 2 Gain

Scope

Signal Signal Gen. 2 Gain

Signa Signall Gen.

Scope 2 Gain

Para mover o ponto onde dois segmentos de reta se encontram, clique no vértice e arraste o círculo

FEI - FCA

Tutorial do Matlab & Simulink

65

Signal Gen.

S co p e 2 Gain

Você também pode mover o segmento de linha, clicando no meio do segmento e arrastando-a enquanto mantém o botão esquerdo do mouse apertado. Adicione agora um osciloscópio na saída do ganho, sendo que para isso não é necessário copia-lo da biblioteca. Copie daquela que já existe no diagrama, segurando o botão direito do mouse enquanto arrasta o bloco para a posição desejada. O bloco copiado tem os mesmos parâmetros do bloco original.

Scope

Signal ignal Gen en.. 2 Gain

Scope1

A seguir, conecte o ganho do segundo osciloscópio, abra os dois e inicie a simulação. Para parar a simulação clique sobre Stop no menu Simulation. Para remover blocos ou linhas, selecione os objetos que deseja remover e aperte a tecla DEL ou escolha Cut ou Clear no menu  Edit. Para selecionar mais de um objeto, mantenha apertada a tecla SHIFT enquanto aperta o botão esquerdo do mouse. No exemplo anterior, selecione o segundo osciloscópio e a linha que liga este bloco ao bloco de ganho e então remova estes objetos. Insira um bloco Mux da biblioteca Connections. Mux Signal Signal Gen.

Mux

Scope

2 Gain

FEI - FCA

Tutorial do Matlab & Simulink

66

Abra o bloco Mux e altere o número de entradas para 2 e então feche a caixa de diálogo.

O  Mux tem agora 2 entradas. Conecte o gerador de sinais e o bloco de ganho nas entradas do  Mux e ligue a saída deste ao osciloscópio. Os dois sinais comporão um vetor de dimensão 2 que será visualizado simultaneamente no osciloscópio.

Mux Signal Signal Gen.

Mux

Scope

2 Gain

Agora, copie um bloco To Workspace da biblioteca Sinks e então abra a caixa de diálogo.

Mux Signa Signall Gen. Mux

2 Gain

Scope

yout To Workspace

O bloco To Workspace envia um vetor de qualquer tamanho para o workspace do MATLAB como uma matriz. Essa matriz tem uma linha para cada

FEI - FCA

Tutorial do Matlab & Simulink

67

instante de tempo até o limite especificado na caixa de diálogo. Na caixa de diálogo também podemos mudar o nome da variável que conterá o vetor.

Altere o nome da variável para matriz1 e conecte o bloco To Workspace na saída do Mux.

Mux Signal Signal Gen.

Mux

Scope

2

matriz1

Gain

To Workspace Workspace

Inicie a simulação desse modelo e obtenha a figura a seguir. Pare a simulação e salve o modelo. Para verificar se a variável matriz1 foi criada no workspace do MATLAB, use o comando whos na janela de comando do MATLAB: Name Size Elements matriz1 1000 by 2 2000

Bytes Density Complex 16000 Full No

Grand total is 2000 elements using 16000 bytes

FEI - FCA

Tutorial do Matlab & Simulink

68

Como a variável matriz1 está disponível, qualquer manipulação poderá ser realizada. A coisa mais simples que podemos fazer é plotar o gráfico da matriz matriz1 usando comando plot(matriz1). Cada uma das linhas contém 1000 pontos que foram capturados durante a simulação. 2

1.5

1

0.5

0

-0.5

-1

-1.5

-2 0

20 0

4 00

60 0

80 0

1000

FEI - FCA

Tutorial do Matlab & Simulink

69

1.3.3 Análise dos Modelos Nesta seção discutiremos como usar o SIMULINK numa simulação e num processo de linearização.

Níveis de Uso Existem três formas distintas de usar o SIMULINK. A forma mais interativa, e também a mais fácil, é controlar a simulação de dentro da janela do diagrama em blocos e observar os resultados com osciloscópios. Esta é a forma recomendada quando você simular um novo sistema pela primeira vez, pois será mais fácil para depura-lo. O segunda forma é simulando o sistema através da linha de comando do MATLAB. Esse método não é tão interativo como o primeiro mas proporciona maior flexibilidade. Obtendo os resultados da simulação no workspace do MATLAB, você poderá fazer outras análises e também plotar os resultados usando todos os recursos do MATLAB. A forma mais complexa e flexível de usar o SIMULINK é acessando diretamente a S-function do modelo. Todo modelo SIMULINK é disponível no MATLAB como uma S-function de mesmo nome que o diagrama. O próprio simulador usa essas funções para realizar suas tarefas. Nessas S-functions estão presentes informações como o número de entradas e saídas, a equação de estado que descreve o diagrama, etc.

Simulação Simular um modelo do SIMULINK significa resolver numericamente um conjunto de equações diferenciais ordinárias. Estão disponíveis para isso um conjunto de métodos de integração. Infelizmente, devido à diversidade de comportamentos dinâmicos que os sistemas podem apresentar, não existe um método único capaz de garantir sempre a melhor exatidão e eficiência de simulação. Logo, a escolha do método e dos parâmetros de simulação são cruciais para uma simulação apurada.

Simulação via Menu

FEI - FCA

Tutorial do Matlab & Simulink

70

A simulação pode ser iniciada tanto pela linha de comando como pelo menu Simulation. Selecione Start nesse menu depois de colocar o valor de cada parâmetro ou o nome da variável MATLAB correspondente.

A linha Return Variables pode ser usada para colocar o tempo, vetor de estado e vetor de saída no workspace do MATLAB. Se este campo for deixado em branco nenhuma variável será enviada ao workspace.

Simulação a partir da Linha de Comando O exemplo a seguir realiza a mesma simulação anterior. » [t,x,y] = euler('novo',[T_inicial, T_final],... » x0, [Tolerancia, Passo_Minimo_Integracao,... » Passo_Maximo_Integracao]);

As condições iniciais, as quais não podem ser definidas no menu de simulação, são definidas no vetor  x0. O valor numérico de  x0 sobrepõe as condições iniciais impostas aos blocos, a menos que  x0 seja uma matriz vazia "[]".

FEI - FCA

Tutorial do Matlab & Simulink

71

A simulação a partir da linha de comando tem as seguintes vantagens quando comparada com a simulação via menu:

• • • • •

Condições iniciais dos blocos podem ser sobrepostas; Não especificando argumentos de saída na linha de comando, o gráfico das saídas as trajetórias de estado (quando não houver saídas), é automaticamente plotado; Entradas externas podem ser especificadas usando variáveis extras na linha de comando; A simulação pode ser incorporada a um M-file maior como uma linha do programa, permitindo por exemplo a alteração de parâmetros dos blocos; Para modelos pequenos, a simulação é um pouco mais rápida;

Todos os algoritmos de integração têm a mesma sintaxe de chamada, de tal forma que métodos diferentes podem ser selecionados simplesmente trocando o nome da função: [t,x,y] = euler('nome_modelo', tfinal); [t,x,y] = rk23('nome_modelo', tfinal); [t,x,y] = rk45('nome_modelo', tfinal); [t,x,y] = linsim('nome_modelo', tfinal); [t,x,y] = adams('nome_modelo', tfinal); [t,x,y] = gear('nome_modelo', tfinal);

Para obter informações detalhadas sobre os argumentos de entrada digite, por exemplo: type rk45.m

Plotando as Variáveis de Saída Os gráficos das variáveis de saída do SIMULINK podem ser obtidos de uma das três formas:

• • •

Blocos Scope (osciloscópio) Variáveis de retorno e comandos gráficos do MATLAB Blocos To Workspace e comando gráficos do MATLAB

Usando o bloco Scope:

FEI - FCA

Tutorial do Matlab & Simulink

72

1 s +1

Step Fcn

Transfer ransfer Fcn

Scope

Usando variáveis de retorno, você pode usar os comandos gráficos do MATLAB. A saída, neste exemplo, é obtida por um bloco do tipo output  aqui denominado saida. A integração pode ser iniciada pela linha de comando do MATLAB como segue: 1 s +1

Step St ep Fcn

Transfer ransfer Fcn

1 Saida

» [t,x,y] = linsim('novo1', 2); » plot(t,y)

Usando o bloco To Workspace: Como o passo de integração durante a simulação pode ser variável, é necessário enviarmos também a base temporal para o workspace quando usamos o bloco To Workspace.

Step St ep Fcn

1 s +1 Transfer ransfer Fcn

saida To Workspace orkspace

tempo Clock

To Workspace1 orkspace1

» plot(tempo,saida)

Condições Iniciais As condições iniciais, as quais são impostas no instante inicial de simulação, são geralmente colocadas dentro dos blocos. Essas condições iniciais

FEI - FCA

Tutorial do Matlab & Simulink

73

que colocamos como parâmetros de um dado bloco pode ser sobreposta usando um argumento extra na chamada da simulação: » [t,x,y] = linsim('modelo',tfinal,x0);

Quando o vetor  x0 é uma matriz vazia " []" ou não é especificada, a condição definida no bloco é usada. Caso contrário, os valores definidos em  x0 serão os usados. Para determinar quais condições iniciais foram definidas nos blocos do modelo digite, » [sizes,x0] = modelo

onde "modelo" é o nome do modelo. O nome do bloco associado a cada uma das variáveis de estado é obtido com um terceiro argumento de saída: » [sizes,x0,nome_bloco] [sizes,x0,nome_bloco] = modelo

Loops Algébricos algébricos, ou implícitos, ocorrem quando blocos que possuem ligação direta (ganho) da entrada para a saída, formam uma malha fechada. Quando isso ocorre, o SIMULINK precisa fazer iterações à cada passo da simulação para determinar se existe uma solução para o problema.  Loops algébricos reduzem consideravelmente a velocidade de simulação e podem ser insolúveis. Portanto, evite-os sempre que possível. Alguns blocos com ligação direta da entrada para saída são:  Loops

• • • • •

Blocos de ganho; A maioria dos blocos não lineares; Função-de-transferência quando numerador e denominador são da mesma ordem; Blocos Zero-Pólo-Ganho quando existem tantos zeros quanto pólos; Blocos Espaço-de-Estado quando a matriz D é não nula;

O sistema abaixo é um exemplo de loop algébrico:

FEI - FCA

Tutorial do Matlab & Simulink

1 Inport

+ + Sum

74

s +2 s +1 Transfer Transfer Fcn Fcn

1 Outport

1 Gain

Interpolação de Dados As funções de integração do SIMULINK são de passo variável. Isso significa que a integração pode resultar em intervalos não igualmente espaçados no tempo, tornando difícil a comparação de diferentes simulações. Nestas situações recomenda-se o uso de funções de interpolação. O exemplo a seguir mostra como gerar um gráfico com uma resolução temporal maior. » » » »

[t,x,y] = rk45('modelo',10,[],[tol mstep Mstep]); tfino = 0:mstep/100:10; yfino = spline(t,y,tfino); plot(tfino,yfino,t,y)

Escolha do Algoritmo de Simulação O desempenho da simulação em termos de velocidade e exatidão, é função do modelo e das condições. A seguir dá-se algumas sugestões para a seleção do método.

linsim É usado para modelos lineares. Modelos lineares são aqueles compostos por blocos lineares tais como: funções de transferência, ganhos, somadores, espaço de estado, etc. Se o sistema é quase que totalmente composto por blocos lineares e poucos blocos não lineares, então linsim ainda funciona bem. Esse algoritmo é particularmente recomendado quando os blocos lineares têm dinâmicas muito distintas (problemas mal condicionados " stiff "). ").

rk45, rk23

FEI - FCA

Tutorial do Matlab & Simulink

75

Os métodos de Runge-Kutta de terceira e quinta ordem, em geral, têm desempenho superior aos outros métodos quando o sistema é altamente não linear e/ou possui descontinuidades. Este método não funciona bem para problemas stiffs, sendo que nestes casos recomenda-se o linsim e gear.

gear Use este método quando o sistema não apresentar descontinuidades e for não linear. Ele funciona comparativamente muito bem para problemas stiff  e é menos eficiente que os demais quando o problema não é stiff .

adams Use este método quando o sistema não apresentar descontinuidades e for não linear e não for stiff .

euler Use este método apenas para fins didáticos.

Controle do Passo de Integração O parâmetro tol, usado na integração, especifica o valor aceitável do erro relativo em cada passo da simulação. [t,x,y] = linsim('modelo',tf,x0,[tol,mpasso,Mpasso]);

Como regra geral, este parâmetros está entre 0.1 e 1e-6. Quanto menor o valor de tol, mais passos serão necessários na simulação.

Sistemas de Tempo Discreto O SIMULINK possui a habilidade de simular sistemas discretos (dados amostrados). Os modelos podem ter múltiplas taxas de amostragem e conter tanto blocos discretos como contínuos. Todos os blocos discretos encontrados nas bibliotecas possuem embutido um amostrador nas entradas e seguradores de ordem zero nas saídas. O período de amostragem é introduzido na caixa de diálogo dos blocos. Normalmente o período de amostragem é definido por um escalar; contudo, é

FEI - FCA

Tutorial do Matlab & Simulink

76

possível definir um offset  ao período, usando um vetor de 2 elementos no mesmo campo.

O vetor [Ts, offset] define o período de amostragem Ts e o valor do offset , significando que o bloco só é atualizado nos instantes múltiplos inteiros do período de amostragem mais o offset : t = n*Ts + offset

onde n é um inteiro e o offset  pode ser tanto positivo como negativo. O offset  é especialmente útil quando desejamos que certos blocos sejam atualizados antes ou depois que outros. Nos Sistemas puramente discretos, para obtermos a informação somente nos períodos de amostragem, basta selecionar o passo de integração mínimo maior que o passo de integração máximo.

Linearização O SIMULINK oferece as funções linmod  e  dlinmod  para extrair modelos lineares do diagrama, na forma de espaço de estado, x= Ax+ Bu

y= Cx+ Du

FEI - FCA

Tutorial do Matlab & Simulink

77

onde  x, u e  y são vetor de estado, vetor de entrada e vetor de saída, respectivamente. Crie o modelo a seguir e chame-o de modelo. 2 y(2) 1

1

+ -

Inport

2

s +2s+ 2s+1

1 y(1)

Planta 1 s +1 Realimentacao

Para extrair o modelo linear associado a esse diagrama entre com o comando: » [A,B,C,D] = linmod('modelo') A= -1 -1 0

0 -2 1

1 -1 0

0 0

1 0

B= 0 1 0 C= 0 -1 D= 0 1

As entradas e saídas do modelo devem ser definidas usando blocos Input e Output  da biblioteca Connections. Note que geradores de sinais e osciloscópios não funcionam como blocos desse tipo. Blocos  Input  podem ser usados junto com geradores de sinais usando blocos somadores. Uma vez que o dado está na forma de espaço de estado, as funções do Control System Toolbox podem ser utilizadas para outras análises, tais como:

FEI - FCA

Tutorial do Matlab & Simulink



78

conversão para a forma de função de transferência [num,den] = ss2tf(A,B,C,D)



diagramas de Bode bode(A,B,C,D)



resposta temporal linearizada step(A,B,C,D) impulse(A,B,C,D) lsim(A,B,C,D,u,t)

Quando o modelo é não linear, um ponto de operação deve ser escolhido para o qual o modelo linearizado será obtido. O modelo não linear também é sensível ao tamanho da perturbação utilizada para extrair o modelo. Argumentos extras permitem escolher o ponto de operação e as perturbações: [A,B,C,D] = linmod('modelo',x,u,xpert,upert)

Para sistemas de tempo discreto ou sistemas mistos, use a função  dlinmod para a linearização. Utilize o help para saber mais sobre essa função.

Determinação do Estado Estacionário A função trim do SIMULINK permite determinar os pontos de equilíbrio do estado estacionário. Considere, por exemplo, o modelo chamado modelo:

FEI - FCA

Tutorial do Matlab & Simulink

79

2 y(2) 1

+ -

Inport

1 2

s +2s+ 2s+1

1 y(1)

Planta 1 s +1 Realimentacao

Determine os valores da entrada e dos estados que fazem as duas saídas serem iguais à 1. Primeiro, forneça uma estimativa inicial para as variáveis e para a entrada: » x = [0; 0; 0]; » u = 0;

Em seguida, imponha os valores desejados para as saídas: » y = [1; 1];

Use os índices das variáveis para indicar quais delas podem variar livremente e quais devem ficar inalteradas: % permita a variacao dos estados » ix = []; » iu = []; % permita a variacao da entrada » iy = [1;2]; % fixe tanto a saida 1 como a 2

Chame a função trim: » [x,u,y,dx] = trim('modelo',x,u,y,ix,iu,iy) x= 1.0000 0.0000 1.0000 u= 2

FEI - FCA

Tutorial do Matlab & Simulink

80

y= 1.0000 1.0000 dx = 1.0e-015 * -0.3331 -0.2244 0.0567

1.3.4 Como o Simulink Funciona No SIMULINK. o diagrama em blocos é convertido numa estrutura mais apropriada à simulação. Primeiro, cada um dos parâmetros dos blocos é calculado pelo MATLAB, trocando variáveis pelo valor numérico. Em seguida, os blocos são ordenados, desfeitos os agrupamentos de blocos e os loops algébricos são detectados. Finalmente, ele confere as ligações entre os blocos. Terminada a conversão de estrutura, a simulação está pronta para ser iniciada. O sistema é então simulado via integração numérica e o modelo é tratado como uma função do tipo S-function que fornece as derivadas de todos os estados a cada passo. Sabendo o valor das derivadas num instante, a integração determina qual o novo vetor de estado e assim por diante.

1.3.5 S-Functions Quando você cria um modelo no SIMULINK, uma nova função do tipo S-function, com o mesmo nome do diagrama, fica disponível no MATLAB. Essa função define as dinâmicas do modelo e se comporta operacionalmente como qualquer outra função MATLAB. É essa função que será usada pelo método de integração para simular o modelo. Sua sintaxe de chamada é, » sys = modelo(t,x,u,flag)

onde modelo é o nome do modelo e flag é quem define qual informação vai ser colocada de volta em sys. Por exemplo, se flag é colocado em 1, o conteúdo de sys após a chamada da função será o vetor de estado no instante t. Note portanto que você pode criar seu modelo diretamente escrevendo uma S-function sem ter que desenhar o diagrama em blocos. Essa forma é aconselhada nos casos que seu modelo pode ser escrito de forma concisa como um conjunto de equações diferenciais.

FEI - FCA

Tutorial do Matlab & Simulink

81

Tal como qualquer outra função, as S-function podem ser encadeadas, fazendo com que uma S-function chame outras. Um outro mecanismo interessante é o mascaramento de blocos que permite que você defina uma janela particular de diálogo com o usuário, seu ícone, e os comandos de inicialização. Você pode então mascarar uma S function e tornar um modelo inteiro, disponível como um bloco.

Argumentos das S-function As possíveis opções numéricas da variável flag e o conteúdo retornado no argumento de saída são:

• • • • •

flag = 0 flag = 1 flag = 2 flag = 3 flag = 4

- tamanho dos parâmetros e condições iniciais - derivadas dos estados de tempo contínuo - estados de tempo discreto - vetor de saída - próximo t para atualização de tempo discreto

Para entender melhor as S-functions, coloque-se na posição do SIMULINK. Cada um dos valores possíveis do flag corresponde a algo que você vai precisar em instantes distintos da simulação. Por exemplo, no início da simulação você precisa saber quantas variáveis serão simuladas, quantas delas são de tempo contínuo, quantas são discretas e as condições iniciais associadas com essas variáveis. Para ter a resposta a essas perguntas, chame a S-function com flag = 0: » [sizes,x0] = modelo([],[],[],0);

onde x0 contém as condições iniciais de cada estado e informações:

• • • • • •

sizes(1) sizes(2) sizes(3) sizes(4) sizes(5) sizes(6)

sizes

as seguintes

- número de estados contínuos - número de estados discretos - número de saídas - número de entradas - número de raízes descontínuas - usado para encontrar loops algébricos

FEI - FCA

Tutorial do Matlab & Simulink

82

Nas outras etapas da simulação você chamará novamente a S-function com outros valores em flag para obter outras informações.

Exemplo de uma S-function Considere a equação diferencial de segunda ordem conhecida como equação de Van der Pol. x  + ( x2

− 1) x + x = 0

Esta equação pode ser escrita como um sistema de equações diferenciais de primeira ordem.

= x1 (1 −  x 2 = x1 x1

2

x2 ) − x2

Como neste caso, muitas vezes é mais interessante transcrever o sistema de equações como uma S-function ao invés de criar o diagrama de blocos associado. X2 1 f(u)

*

+

X1' 1/s

1/s Scope

(1-x2*x2) X1

A  M-file que realiza a S-function com as equações de Van der Pol resulta:

FEI - FCA

Tutorial do Matlab & Simulink

83

function [sys, x0] = vdpm(t,x,u,flag) % equacao de Vanderpol como uma M-file. if abs(flag) == 1, % Retorna as derivadas sys(1) = x(1) .* (1 - x(2).^2) - x(2); sys(2) = x(1); elseif flag == 0, % Retorna as condicoes iniciais sys = [2;0;0;0;0;0]; x0 = [0.25; 0.25]; else sys = []; end

Esta função pode ser chamada com diversos valores de flag para retornar a informação necessária. Os algoritmos de integração tal como o  rk45, lidam convenientemente com o  flag durante a simulação. Note portanto, que seria muito fácil você desenvolver seu próprio algoritmo de integração. » [t,x] = rk45('vdpm',10); » plot(t,x) Van der Pol 3

2

1

0

-1

-2

-3

0

2

4

6

8

10

Tempo (seg) (seg)

Você pode preferir construir o diagrama em blocos que realiza as equações. Contudo, quando você salvar o diagrama um arquivo será criado com o mesmo nome da diagrama e com um conteúdo muito parecido com o do vdpm. A grande diferença é que o SIMULINK também salva todos os desenhos para reconstruir o diagrama.

Convertendo uma S-function em Bloco

FEI - FCA

Tutorial do Matlab & Simulink

84

Um recurso bastante poderoso é converter a S-function criada num bloco. Ou seja, você optou por escrever diretamente a S-function que realiza as equações, mas está interessado que sejam usadas dentro do ambiente do SIMULINK. Para converter a S-function vdpm.m num bloco, simplesmente coloque seu nome dentro de um bloco do tipo S-function, que é encontrado na biblioteca  Nonlinear .

Os campo Function parameters, permite que parâmetros adicionais sejam passados a cada iteração.

1.3.6 Mascarando Blocos A função Masking permite que você altere a característica de um bloco. É possível marcar qualquer bloco, incluindo subsistemas e blocos S-function. O exemplo a seguir mostra como converter um bloco  Zero-Pole em um bloco de filtro  Butterworth que mostra sua resposta impulsiva no próprio ícone. Inicie com um bloco Zero-Pole:

FEI - FCA

Tutorial do Matlab & Simulink

85

(s-1) s(s+1) Zero-Pole

As variáveis z, p e k são respectivamente os zeros, pólos e o ganho. Selecione o bloco com um clique único do mouse e altere o nome o bloco marcando o nome dele e digitando filtro PB. Selecione então  Mask  no menu Options. O caixa de diálogo a seguir é então mostrada:

Os campos da caixa de diálogo são descritos a seguir:

Block Type filtro LP

Este nome define o tipo do bloco mascarado.

Dialog Strings

FEI - FCA

Tutorial do Matlab & Simulink

86

Butterworth passa baixas | Freqüência de corte (rad/s) | Ordem Esta string define a nova caixa de diálogo que aparecerá quando o bloco for clicado duas vezes. Separe os dados com o símbolo "|". O primeiro dos dados é o título da caixa de diálogo. Os demais são os nomes dos campos que apareceram na nova caixa de diálogo. O número máximo de campos é seis. Ao invés de abrir a caixa de diálogo quando você clica sobre o novo bloco, você pode fazer com que um comando do MATLAB seja executado. Isso é possível usando a função eval . Por exemplo, entrando com eval('plot(1:10')

no campo  Dialog Strings , uma linha é plotada na janela gráfica do MATLAB toda vez que o bloco é clicado duas vezes.

Initialization Commands [z,p,k] = buttap(@2); z = @1*z; p = @1*p; [a,b,c,d] = zp2ss(z,p,k); t = [0:0.2:3*@2]/@1; [y,x] = impulse(a,b,c,d,1,t);

Os comandos de inicialização definem as funções que serão executadas pelo bloco durante a simulação. Os valores das expressões MATLAB colocadas como parâmetros na caixa de diálogo do novo bloco, podem ser acessados com @1, @2, etc. Neste exemplo, o valor da freqüência de corte é obtida com @1 e o parâmetro associado à ordem do filtro é obtido com @2. Qualquer expressão MATLAB pode ser usada. As variáveis são locais e elas não se sobrepõem às do workspace do MATLAB.

Drawing Commands plot(t,y,[0;max(t),[0;0])

Os três comandos a seguir são reconhecidos no processo de mascaramento:



desenha o numerador e denominador da função de transferência. dpoly(num,den)

FEI - FCA

Tutorial do Matlab & Simulink

• •

87

desenha a função de transferência no formato ZeroPólo-Ganho. plot(x,y,x1,y1) plota o gráfico no bloco. droots(z,p,k)

O comando  plot  é similar ao  plot do MATLAB, exceto que a opção tipo de linhas não é disponível. Qualquer outra informação colocada neste campo aparece desenhada no interior do bloco.

Help String Este bloco realiza um filtro Butterworth passa baixas

Esta mensagem é mostrada quando você clica no botão  Help na caixa de diálogo criada.

1.3.7 Adicionando um novo bloco Nesta seção mostra um exemplo completo da criação de um novo bloco usando uma S-function e mascarando-a. Imagine que você deseja criar um integrador com limite superior e inferior. Este modelo pode ser descrito facilmente por uma equação diferencial lb e u < 0) ou ( x  x ≥  ub e u > 0), então de primeira ordem. Por exemplo, se ( x ≤  lb

dx = 0 dt  Caso contrário,

dx u = dt 



∫ 

x = u dt  

onde  x é o estado, u é a entrada do integrador e lb e ub são respectivamente o limite inferior e superior. Existem três etapas na definição de um novo bloco do tipo S-function: 1. Crie uma S-function através de um diagrama no SIMULINK ou escrevendo diretamente o arquivo da função.

FEI - FCA

Tutorial do Matlab & Simulink

88

2. Converta a S-function num bloco S-function. 3. Mascare o bloco S-function criando seu ícone personalizado, sua caixa de diálogo e os comandos de inicialização.

Passo 1: Crie a S-function Uma das várias formas de entrar com a equação diferencial e as condições que descrevem o integrador com limitação é usando o bloco de propósito geral chamado Fcn:

1 Inport

Mux

f(u)

1 s

Mux

Fcn

Integrador

1 Outport

O bloco Fcn contem a expressão relacional a seguir: u[2]*((((u[1]>lb)+(u[2]>=0))>0)*(((u[1], >=,
View more...

Comments

Copyright ©2017 KUPDF Inc.
SUPPORT KUPDF