Você está na página 1de 75

Matlab

Índice

1.1 Introdução ............................................................................................. 2

1.2 Operações Matriciais ............................................................................ 8

1.3 Operações de Vetores ou Array .......................................................... 10

1.4 Manipulação Matricial e Vetorial ....................................................... 13

1.5 Funções Matriciais .............................................................................. 20

1.6 Polinômios e Processamento de Sinais ............................................... 21

1.7 Funções de Funções ............................................................................ 23

1.8 Gráficos ............................................................................................... 28

1.9 Controles de Fluxo .............................................................................. 36

1.10 Arquivos M ......................................................................................... 39

1.11 Manipulação de Arquivos ................................................................... 46

1.12 Depuração ........................................................................................... 48

1.13 Toolbox de Matemática Simbólica ..................................................... 48

1.14 Toolbox de Sistema de Controle ......................................................... 59


1.1 Introdução

Parte do material deste texto é uma adaptação livre dos próprios manuais
disponíveis do MATLAB.

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.

O nome MATLAB é acrônimo de laboratório de matrizes. Ele foi


originalmente escrito para permitir um acesso fácil aos programas de cálculo
matriciais desenvolvidos pelos projetos LINSPACK e EISPACK, que juntos
representavam o estado da arte em programas de cálculo matricial.

MATLAB também contempla uma família de aplicativos específicos


chamados “toolboxes” na forma de coleções de funções MATLAB, estendendo
o ambiente MATLAB na solução de problemas particulares. Entre outros, temos
os seguintes toolboxes: Processamento de Sinais; Identificação de Sistemas;
Redes Neurais; Otimização etc.

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.

2
Introdução ao MATLAB 3

Exemplo:

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

Resulta:
A=
1 2 3
4 5 6
7 8 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 (linha,coluna).


Veja o exemplo a seguir:

» 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 à matriz A:

» r = [ 10 11 12 ];
» A = [ A; r ]

Isto resulta em:


Introdução ao MATLAB 4

A=
1 2 3
4 5 6
7 8 9
10 11 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 2 3
4 5 6
7 8 9

Variáveis e Declarações do MATLAB

Declarações no MATLAB são frequentemente 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. Se o último caracter é


um ponto-e-vírgula, ele suprime a apresentação no vídeo, embora faça a
Introdução ao MATLAB 5

atribuição da mesma forma. 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 (...) para
continuar a definição na linha seguinte. Exemplo:

» 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 traço-baixo (underscore). O
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

O comando help produz informações resumidas sobre funções


específicas ou sobre tópicos do MATLAB. Para listar um grupo de funções,
digite help seguido do nome do grupo de funções. Exemplo:

» help matfun

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

» help inv
Introdução ao MATLAB 6

Para localizar palavras-chaves em todos os arquivos do MATLAB, use o


comando lookfor. Exemplo:

» lookfor inverse

ifft - Inverse discrete Fourier transform.


ifft2 - Two-dimensional inverse discrete Fourier transform.
ifftn - N-dimensional inverse discrete Fourier transform.
ifftshift - Inverse FFT shift.
acos - Inverse cosine, result in radians.

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

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, de cima para baixo

^ potenciação
\ divisão à esquerda
/ divisão à direita
* multiplicação
- subtração
+ adição
Introdução ao MATLAB 7

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
resultado é NaN (Not a Number).

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

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 é denominado toolbox. 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) )
Introdução ao MATLAB 8

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.

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 ]
A=
1 2
3 4

» B = A'
B=
1 3
2 4
Introdução ao MATLAB 9

Adicionando e Subtraindo Matrizes

Os símbolos + e - denotam adição e subtração de matrizes. Portanto, a


operação é definida se as matrizes têm a mesma dimensão. Exemplo:

» C=A+B
C=
2 5
5 8

A adição e subtração são definidas também para o caso que um dos


operandos é 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 forem iguais. 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
F=
10 22
22 50
Introdução ao MATLAB 10

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 considera 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 exponencial de uma matriz


 logm logaritmo de uma matriz
 sqrtm raiz quadrada de uma matriz

Outras funções elementares sobre matrizes incluem:

 poly polinômio caraterístico


 det determinante
 trace traço

1.3 Operações de Vetores ou Array

Refere-se às operações com vetores ou 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 usa-se um ponto (.) antes do símbolo da operação.
Introdução ao MATLAB 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 se comparar matrizes de dimensões idênticas, existem operadores


relacionais:
Introdução ao MATLAB 12

< menor
<= menor ou igual
> 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 da 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 0 1
1 0 0
0 1 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));
Introdução ao MATLAB 13

Operadores Lógicos

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 comando 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. Exemplo:

» A = [ -1 2 -3; 4 -5 6];
» B = abs(A)
B=
1 2 3
4 5 6

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:


Introdução ao MATLAB 14

» x = 1:5
x=
1 2 3 4 5

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
0.2000 0.1627
0.4000 0.2610
0.6000 0.3099
0.8000 0.3223
1.0000 0.3096
1.2000 0.2807
1.4000 0.2430
1.6000 0.2018
1.8000 0.1610
2.0000 0.1231
2.2000 0.0896
2.4000 0.0613
2.6000 0.0383
2.8000 0.0204
3.0000 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
Introdução ao MATLAB 15

Indexando

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 índice é 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 2 3
4 5 6
7 8 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 5
7 8

O exemplo a seguir mostra como fazer referência explícita a algumas


linhas ou colunas. Colocam-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:
Introdução ao MATLAB 16

» A = [1 2; 3 4; 5 6];
» B = A(:)
B=
1
2
3
4
5
6

Usando Vetores de 0 e 1 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
Introdução ao MATLAB 17

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

Existe uma coleção de funções que geram matrizes que são normalmente
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 a partir de Matrizes

É 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.
Introdução ao MATLAB 18

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.6 (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 57 291
43 178 1011
38 163 1095
61 420 2407
12 59 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
Introdução ao MATLAB 19

 std - desvio padrão


 sort - ordenação
 sum - soma dos elementos
 prod - produto dos elementos
 cumsum - soma cumulativa dos elementos
 cumprod - Produto cumulativos dos elementos
 diff - Aproximação numérica da derivada
 corrcoef - Coeficientes de correlação
 cov - Matriz de covariância
 var - Variâ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.
Introdução ao MATLAB 20

px  c1x d  c2x d 1    cn

A sintaxe usada é a seguinte, onde x é a abscissa, p o valor da função para


cada x(i) e n o grau do polinômio.

» c = polifit(x,p,n)

1.5 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 - número de condicionamento usando norma-2


 norm - norma-1, norma-2, norma-F e norma-
 rank - posto da matriz
 rcond - estimativa do condicionamento
Introdução ao MATLAB 21

1.6 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

A=
1 2 3
4 5 6
7 8 0

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

Esta é a representação MATLAB do polinômio s3  6s2  72s  27. As raízes dessa


equação são

» 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


reconstruir o polinômio original com a função poly

» p2 = poly(r)
p2 =
1 -6 -72 -27
Introdução ao MATLAB 22

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.

» [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 - polinômio característico


 roots - raízes de um polinômio
 polyval - cálculo do valor numérico do polinômio
 polyvalm - cálculo do polinômio de matrizes
 conv - multiplicação (convolução)
 deconv - divisão (deconvolução)
 residue - expansão em frações parciais
 polyder - derivada do polinômio
 polyfit - ajuste polinomial de curva

Processamento de Sinais

Vetores são usados, por exemplo, 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.
Introdução ao MATLAB 23

 abs - magnitude complexa


 angle - ângulo de fase
 conv - convolução
 deconv - deconvolução
 fft - transformada rápida de Fourier
 ifft - transformada rápida inversa de Fourier
 fftshift - alterna quadrantes de matrizes
 fft2 - FFT de duas dimensões
 ifft2 - FFT inversa de duas dimensões
 fftshift - rearranja os resultados da FFT
 conv2 - convolução de duas dimensões

Filtragem de Dados

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

Y ( z ) b(1)  b(2) z 1    b(nb) z  ( nb1)


H ( z)  
X ( z) 1  a(2) z 1    a(na) z  ( na1)

1.7 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 (funfun) e incluem:
Introdução ao MATLAB 24

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

Para o uso das funções de funções, é usual representar as funfun através


de arquivos-M (M-files). Por exemplo, a função

1 1
f (x )   6
(x  0,3)  0,01 (x  0,9)2  0,04
2

foi codificada num arquivo com extensão .m, por exemplo chamado humps.m,
cuja listagem é mostrada a seguir:

% listagem do arquivo humps.m


function y = humps(x)
y = 1./((x-.3).^2 + .01) + 1./((x-.9).^2 + .04) - 6;
end

O gráfico dessa função é obtido como segue

» x = -1:.01:2;
» plot(x,humps(x))

100

80

60

40

20

-20
-1 -0.5 0 0.5 1 1.5 2
Introdução ao MATLAB 25

Integração Numérica

Uma função, tal como humps, pode ser integrada numericamente pelo
processo chamado de quadratura que é uma funfun denomindada quad.
Exemplo:

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

A maioria das funções de funções permite que se use o @ em vez de


colocar o nome da função entre aspas simples.

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

Note que o primeiro argumento da função quad é 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. Exemplos:

 fminsearch - 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 fminsearch:
Introdução ao MATLAB 26

» xm = fminsearch('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 é,

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

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

 fgoalattain - otimização de metas


 fmincon - minimização com restrições
 fminsearch - minimização sem restrições
 fsolve - solução de equações algébricas não lineares
 fzero - busca de zeros
 fminimax - solução do problema minimax
 linprog - programação linear
 quadprog - programação quadrática

Equações Diferenciais

Duas das funções disponíveis para a solução de equações diferenciais


ordinárias são:

 ode23 - método Runge-Kutta de ordem baixa


 ode45 - método Runge-Kutta de ordem média
Introdução ao MATLAB 27

Considere a equação diferencial de segunda ordem conhecida como


equação de Van der Pol.

x  (x 2  1)x  x  0

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


primeira ordem

x1  x1 (1  x22 )  x2
x 2  x1

O primeiro passo para simular este sistema é criar um arquivo que contem este
sistema de equações diferenciais. Chamaremos este arquivo de vdpol.m

function xponto = vdpol(t,x)


xponto(1,1) = x(1).*(1-(x(2).^2))-x(2);
xponto(2,1) = x(1);
end

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

» t0 = 0; tf = 20;
» x0 = [0 0.25]'; % condições iniciais
» [t,x] = ode23( 'vdpol', [t0 tf], x0 );
» plot(t,x)

-1

-2

-3
0 5 10 15 20
Introdução ao MATLAB 28

Para a solução numérica de equações diferenciais recomenda-se também o


SIMULINK que é uma extensão gráfica do MATLAB para a simulação de
equações diferenciais.

1.8 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

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 - gráfico de vetores ou de colunas de matrizes


 loglog - escala logarítmica nos dois eixos
 semilogx - escala logarítmica no eixo x e linear em y
 semilogy - escala logarítmica no eixo y e linear em x
 title - adiciona um título ao gráfico
 xlabel - adiciona um nome ao eixo x
 ylabel - adiciona um nome ao eixo y
 text - mostra um texto na posição especificada
 gtext - coloca o texto no gráfico usando o mouse
 grid - coloca linhas de grid

Criando um Gráfico
Introdução ao MATLAB 29

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+)')

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 se mostrou no exemplo anterior, você pode passar um caractere


como um argumento à função plot para especificar um dos vários estilos de
Introdução ao MATLAB 30

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.

Símbolo Cor Símbolo Linha


y amarela . ponto
m magenta o círculo
c ciano x marca x
r vermelha + marca +
g verde * marca *
b azul - sólida
w branca : pontilhada
k preta -. traço-ponto
-- tracejada
s quadrado
d diamante
v triângulo (p/ baixo)
^ triângulo (p/ cima)
< triângulo (p/esquerda)
> triângulo (p/diereita)
P pentragrama
h hexagrama

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:
Introdução ao MATLAB 31

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

Resulta,
1

0.8

0.6

0.4

0.2

-0.2

-0.4

-0.6

-0.8

-1
0 50 100 150 200 250

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’)
Introdução ao MATLAB 32

Distribuição de Autovalores
4

-1

-2

-3

-4
-4 -2 0 2 4 6

Exibindo Gráficos de 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) exibe o gráfico das colunas de X versus 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

0.5

-0.5

-1

-1.5

-2

-2.5

-3
0 20 40 60 80 100 120
Introdução ao MATLAB 33

Importando Dados

Você pode importar e exibir o gráfico de dados gerados fora do


MATLAB. Suponha você tenha um arquivo chamado dados.dat contento
valores de duas funções e da variável independente:

2.3 1.0 1.0


3.1 1.9 2.0
4.5 2.2 3.0
5.6 2.6 4.0
4.8 3.5 5.0
4.7 4.7 6.0
4.4 5.3 7.0
4.0 6.0 8.0
4.2 7.1 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 exibir o
gráfico de 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

2
0 2 4 6 8 10

0
0 2 4 6 8 10
Introdução ao MATLAB 34

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

O MATLAB inclui uma variedade de funções especializadas, conforme


descrito resumidamente a seguir.

 bar - gráfico de barras


 compass - gráfico de ângulos com setas
 errorbar - gráfico de barras de erros
 feather - gráfico de ângulos
 fplot - calcula e exibe o gráfico de uma função
 hist - cria um histograma
 polar - gráfico em coordenadas polares
 quiver - cria um gráfico de um gradiente
 rose - histograma em ângulo
 stairs - gráfico similar ao de barras sem linhas internas
 fill - desenha um polígono e preenche o interior

Gráfico de Funções Matemáticas

Você pode exibir 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,
Introdução ao MATLAB 35

1 y = c o s ( t a n ( p i* x ) )

0 .8

0 .6

0 .4

0 .2

-0 .2

-0 .4

-0 .6

-0 .8

-1
0 0 .2 0 .4 0 .6 0 .8 1

No exemplo, a função é exibida 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 exibida por meio de um gráfico, por exemplo
com o nome fofx.m

function y = fofx(x)
y = cos(tan(pi*x));
end

Agora basta passar o nome da função como argumento de fplot.

» fplot('fofx',[0 1], 25,20,10)

Resulta,
Introdução ao MATLAB 36

y = cos(tan(pi*x))
1

0.8

0.6

0.4

0.2

-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. Contudo, não faremos um detalhamento, visto que o assunto é
longo e pouco interessante para os nossos objetivos.

1.9 Controles de Fluxo

O MATLAB possui declarações para controle de fluxo tal como aqueles


encontrados na maioria das linguagens 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


Introdução ao MATLAB 37

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

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 os produtos dos elementos do argumento. Logo, prod(1:n)


é o fatorial de n.
Introdução ao MATLAB 38

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 = -1;
elseif rem(n,2) == 0
A=0
else
A=1
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.

% Problema clássico "3n+1" da teoria dos números

while 1
n = input('Entre com n [negativo aborta] = ');
if n <= 0, break, end

while n > 1
if rem(n,2) == 0
n = n/2
else
n = 3*n+1
end
end
end
Introdução ao MATLAB 39

1.10 Arquivos M

A maneira mais simples de se usar o MATLAB é 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 sequência de
comandos que está armazenada num arquivo. Os arquivos que contém
declarações MATLAB são chamados M-files 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 sequência de declarações MATLAB normais,


podendo incluir referencias a 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 Bloco de Notas do Windows, ou outro qualquer. Dois tipos
usuais de M-files são: lotes (scripts) e funções (functions). Arquivos scripts
automatizam uma sequência de comandos. Arquivos de função permitem 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 (sem a extensão) 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 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.
Introdução ao MATLAB 40

% M-file (script) para calcular números de Fibonacci menores de 1000

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)

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 a seguir tem
o nome media1.m.

function y = media1(x)
% calculo da média
% soma / m

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

end

Por exemplo, se z é um vetor de inteiros de 1 a 99, sua média pode ser calculada
como segue:

» z = 1:99;
» media1(z)
ans =
50
Introdução ao MATLAB 41

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 media1;
 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 media1, ela continuaria
existindo depois e inalterada);
 Não foi necessário colocar os inteiros de 1 a 99 numa variável
chamada x. De fato, nós usamos media1 com uma 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.

Você pode criar uma função um pouco mais complexa que media1,
chamada stat, que também calcula o desvio padrão. Neste exemplo 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);

end

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.
Introdução ao MATLAB 42

function r = rank(x,tol)
% rank (posto em Português) da matriz

s = svd(x);
if (nargin == 1)
tol = max(size(x)) * s(1) * eps;
end
r = sum(s > tol);

end

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,

function p = angle(h)

% ANGLE Phase angle.


% ANGLE(H) returns the phase angles, in radians, of a matrix with
% complex elements.
%
% Class support for input X:
% float: double, single
%
% See also ABS, UNWRAP.

% Copyright 1984-2010 The MathWorks, Inc.


% $Revision: 5.7.4.2 $ $Date: 2010/04/21 21:31:19 $

p = atan2(imag(h), real(h));

têm 8 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.
Introdução ao MATLAB 43

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
subsequentes 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.

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. Procura por whoopie como variável;


2. Verifica se whoopie é uma função interna;
3. Procura um o arquivo whoopie.m no diretório atual;
4. Procura um o arquivo whoopie.m nos diretórios especificados
pelo path do MATLAB.

INPUT e PAUSE

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.

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.
Introdução ao MATLAB 44

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.

d
 y1   y1   y2 y1
dt
d
 y2    y2   y2 y1
dt

Crie o arquivo lotka.m:

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)];

end

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 alterá-las interativamente e
novas soluções podem ser obtidas sem ter que editar nenhum arquivo e sem
passar os valores como argumentos.
Introdução ao MATLAB 45

Variáveis Alfanuméricas

Variáveis do 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 do tipo texto via


sprintf, num2str e int2str. Exemplo,

» c = 23;
» title(['A temperatura é ',num2str(c),' graus C'])

A Função EVAL

A função eval é usada com variáveis do tipo texto para implementar


recursos de macros de texto. A função 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 sequencialmente 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
Introdução ao MATLAB 46

função fplot que passa como argumento o nome da função a ser exibida,
exemplo:

» fplot( 'sin', [0 10] )

1.11 Manipulação de Arquivos

Os comandos load e save recuperam e armazenam dados do workspace


em 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 considera a extensão “.m”
como default. Portanto, esse comando é normalmente usado para obtermos uma
rápida 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.

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:
Introdução ao MATLAB 47

 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 os dados de um arquivo ASCII.

 Escreva um programa em C para converter seus dados no


formato dos MAT-files e então use o comando load.

 Importe os dados do Excel.

Exportando dados do MATLAB

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

 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.

 Exporte os dados para o Excel.


Introdução ao MATLAB 48

1.12 Depuração

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 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,
fazendo com que os resultados intermediários sejam acessíveis
no workspace base do MATLAB;
 Use o depurador do MATLAB.

1.13 Toolbox de Matemática Simbólica

Com o Toolbox de processamento simbólico é possível resolver e


manipular expressões matemáticas simbólicas resolvendo analiticamente, por
exemplo, diferenciações, integrações, simplificações, transformadas, solução de
equações etc.

Variáveis Simbólicas

Para declarar, por exemplo, as variáveis x e y como objetos simbólicos


use o comando syms:
Introdução ao MATLAB 49

» syms x y

Depois de criados os objetos simbólicos, se podem realizar cálculos


matemáticos tais como:

» z=x+x+y
z=

2*x + y

Matriz de variáveis simbólicas

Depois de declarar as variáveis simbólicas elas podem fazer parte da


definição de uma matriz. Exemplo:

» syms a b c d e f g h i
» A = [ a b c ;d e f; g h i ]
A=

[ a, b, c ]
[ d, e, f ]
[ g, h, i ]

Note que não é necessário declarar explicitamente a matriz A como um


objeto simbólico. Agora podemos operar simbolicamente com a matriz A. Veja
alguns exemplos:

» determinante = det(A)
determinante =

a*e*i - a*f*h - b*d*i + b*f*g + c*d*h - c*e*g

» B=A+A
B=

[ 2*a, 2*b, 2*c ]


[ 2*d, 2*e, 2*f ]
[ 2*g, 2*h, 2*i ]
Introdução ao MATLAB 50

Simplificações

Existem algumas funções que alteram a forma de uma função simbólica.


Os exemplos a seguir ilustram alguns desses comandos: pretty, collect,
expand, horner, factor, simplify.

» syms x
» f = x^3 - 6*x^2 + 11*x - 6;
» pretty (f) % visualização elegante

3 2
x - 6 x + 11 x – 6

» syms x
» f = (x-1)*(x-2)*(x-3);
» collect (f) % agrega potências iguais

x^3 - 6*x^2 + 11*x – 6

» syms a x y
» f = a*(x + y);
» expand (f) % distributiva

a*x + a*y

» syms x
» f = x^3 - 6*x^2 + 11*x - 6;
» horner (f) % forma aninhada

x*(x*(x - 6) + 11) - 6

» syms x
» f = x^3 - 6*x^2 + 11*x - 6;
» factor (f) % fator de menor ordem

(x - 3)*(x - 1)*(x - 2)

* syms x y
* f = exp(x) * exp(y);
* simplify (f) % simplificação

exp(x + y)
Introdução ao MATLAB 51

Substituições

Use o comando subs para realizar substituições diversas. Exemplos:

» syms x
» f = 2*x^2 - 3*x + 1;
» subs( f, {x}, {1/3} ) % x  1/3
ans =

2/9

» syms x y
» f = x + y;
» subs( f, {x, y}, {2,-3} ) % x  2, y  -3
ans =

-1

» syms x y m
» f = x + y;
» subs( f, {x, y}, {2, m} ) % x  2, y  m
ans =

m+2

Diferenciação Simbólica

Use o comando diff para realizar diferenciações. Veja alguns exemplos:

» syms x
» f = sin(x)^2;
» diff(f)
ans =

2*cos(x)*sin(x)
Introdução ao MATLAB 52

» syms x y
» f = sin(x)^2 + cos(y)^2;
» diff(f, y) % derivada parcial de f em relação a y
ans =

-2*cos(y)*sin(y)

Integração Simbólica

Use o comando int para realizar integrações simbólicas. Veja alguns


exemplos:

» syms x y
» f = x^2 + y^2;
» int(f, y) % integral indefinida de f em relação a y
ans =

x^2*y + y^3/3

» syms x y
» f = x^2 + y^2;
» int(f, y, 3, 5) % integral definida desde 3 até 5
ans =

2*x^2 + 98/3

Solução de Equações Algébricas

Use o comando solve para determinar a solução de equações ou sistemas


de equações. Veja alguns exemplos a seguir e note que ao definir a equação
utiliza-se o sinal (==). Caso o sinal (==) seja omitido, o lado direito da equação é
suposto nulo. Veja os dois casos a seguir

» syms x
» f = ( x^2 + 5*x == -6 );
» solve( f )
ans =

-3
-2
Introdução ao MATLAB 53

» syms x
» f = ( x^2 + 5*x - 6 );
» solve( f )
ans =

-3
-2

Nas equações com múltiplas variáveis simbólicas, pode-se especificar


para qual variável a equação deve ser resolvida. No exemplo a seguir a função
depende de x e y e sua solução é determinada em relação a y.

» syms x y
» solve ( 6*x^2 - 6*x^2*y + x*y^2 - x*y + y^3 - y^2 == 0, y )
ans =

1
2*x
-3*x

No exemplo a seguir mostra-se uma forma possível de representar e


resolver um sistema de duas equações e duas incógnitas.

» syms x1 x2
» f1 = ( x1*x2 + x2 == 3 );
» f2 = ( x1 - x2 == 1 );
» [ xx1, xx2 ] = solve( f1, f2, x1, x2 )

xx1 = xx2 =

2 1
-2 -3

A verificação da exatidão da solução pode ser feita com o comando subs,


atribuindo os valores numéricos das soluções encontradas nas funções.

» subs( f1, {x1,x2}, { xx1(1), xx2(1) } )


» subs( f2, {x1,x2}, { xx1(2), xx2(2) } )

ans = ans =

3 == 3 1== 1
Introdução ao MATLAB 54

Gráficos de Funções Simbólicas

O comando ezplot é uma das formas mais imediatas para se exibir o


gráfico de uma função explícita ou mesmo implícita. Veja os exemplos a seguir:

» syms x
» ezplot(x^3 - 6*x^2 + 11*x - 6)
» title('Função Explícita: y = x^3 - 6*x^2 + 11*x - 6')

Função Explícita: y = x 3 - 6*x 2 + 11*x - 6


100

-100

-200

-300

-400

-500

-6 -4 -2 0 2 4 6
» syms x y x

» ezplot( (x^2 + y^2)^4 == (x^2 - y^2)^2, [-1 1] )


» title( 'Função Implícita no intervalo [-1,1] ' )

Função Implícita no intervalo [-1,1]


1

0.8

0.6

0.4

0.2

0
y

-0.2

-0.4

-0.6

-0.8

-1
-1 -0.8 -0.6 -0.4 -0.2 0 0.2 0.4 0.6 0.8 1
x
Introdução ao MATLAB 55

Solução de Equações Diferenciais

Para ilustrar como usar o comando dsolve, considere a equação


diferencial ordinária de 1ª ordem com condição inicial y(0)  1 .

d 
 y (t )    y (t )
dt  

» syms x(t)
» f(t) = (diff(x) == -x);
» [xx] = dsolve(f(t), x(0) == -1)
xx =

-exp(-t)

Considere agora a equação diferencial ordinária de 2ª ordem com


condições iniciais y(0)  1 e y(0)  0 .

d2 
2 
y (t )   cos  2t   y(t )
dt  

» syms y(t)
» Dy = diff(y);
» y(t) = dsolve( diff(y, 2) == cos(2*t) - y, y(0) == 1, Dy(0) == 0 );
» y(t) = simplify(y);
» pretty( y(t) )

/ t \4
8 sin | --- |
\ 2/
1 - ----------------
3
Introdução ao MATLAB 56

Muitas vezes as equações diferenciais estão na forma de um sistema de


equações. Para ilustrar um caso desses considere o sistema a seguir com x1 (0)  1
e x2 (0)  0 .

d 
 x1 (t )   x2 (t )
dt  

d 
 x2 (t )   6 x1 (t )  5 x2 (t )
dt  

» syms x1(t) x2(t)


» f1(t) = ( diff(x1) == x2 );
» f2(t) = ( diff(x2) == -6*x1 -5*x2 );
» [xx1, xx2] = dsolve( f1(t), f2(t), x1(0) == 1, x2(0) == 0 )

xx1 =
(exp(-3*t)*(18*exp(t) - 12))/6

xx2 =
-exp(-3*t)*(6*exp(t) - 6)
Introdução ao MATLAB 57

Transformada de Laplace

Os comandos laplace e ilaplace determinam a transformada e anti-


transformada de Laplace, respectivamente. Veja os exemplos:

Função dada Comandos MATLAB

syms s t
F = laplace( 2*exp(-5*t) - 5*exp(-2*t) )
F = collect(F)
F=

(- 3*s - 21)/(s^2 + 7*s + 10)

syms s t
F = laplace( exp(-t)*cos(3*t) )
F=

(s + 1)/((s + 1)^2 + 9)

syms s t
f = ilaplace ( s/(s^2 + 4*s + 5) )
f=

exp(-2*t)*(cos(t) - 2*sin(t))

syms s t
f = ilaplace( 5/((s+1)*(s+2)^2) )
f=

5*exp(-t) - 5*exp(-2*t) - 5*t*exp(-2*t)


Introdução ao MATLAB 58

Transformada Z

Os comandos ztrans e iztrans determinam a transformada Z e anti-


transformada Z, respectivamente. Veja os exemplos:

Função dada Comandos MATLAB

syms k z
f = sin(k);
f (k )  sen(k ) F = ztrans(f, k, z)

(z*sin(1))/(z^2 - 2*cos(1)*z + 1)

syms z k
F = z / ( (z+0.2)*(z+0.5)*(z-1) );
f = iztrans(F,k);
disp('f(k) = ')
pretty(f)
z
F ( z) 
 z  0, 2  z  0,5 z  1 f(k) =

k k
20 (-1/2) 25 (-1/5)
------------ - ------------ + 5/9
9 9
Introdução ao MATLAB 59

1.14 Toolbox de Sistema de Controle

No Toolbox de Sistema de Controle, os modelos de sistemas Lineares e


Invariantes no Tempo (LTI) são representados por Objetos. Os objetos de
modelos são estruturas de dados e atributos que permitem a manipulação de
sistemas LTI com entidades únicas. Os objetos de modelos podem representar
sistemas escalares, ou seja, de entrada e saída únicas (SISO) e sistemas vetoriais
de entradas e saída múltiplas (MIMO), tanto de tempo contínuo como de tempo
discreto.

Os sistemas LTI podem ser especificados no espaço de estados (objeto


SS), por meio e funções de transferência (objeto TF) e modelos dados pelos
seus zeros, polos e ganho (objeto ZPK).

Função de Transferência

Uma função de transferência SISO é caraterizada pelo seu numerador e


denominador. Por exemplo, a função de transferência

s
F ( s) 
s 2  2s  10
é representada por um objeto TF que contém os coeficientes do polinômio do
numerador e do denominador:

» numerador = [ 1 0 ];
» denominador = [ 1 2 10 ];
» F = tf ( numerador, denominador )
F=
s
--------------------
s^2 + 2 s + 10

Continuous-time transfer function.

Matrizes de transferência (funções de transferência MIMO) são formadas


por elementos que são funções de transferência. Exemplo:
Introdução ao MATLAB 60

 s 
 s 2  2s  10   F ( s ) 
   1 
F ( s)    
   F ( s) 
 s 1   2 
 s  1 

» F1 = tf ( [ 1 0 ], [ 1 2 10 ] );
» F2 = tf ( [ 1 -1 ], [ 1 1 ] );
» F = [ F1 ; F2 ]
F=

From input to output...

s
#1: ---------------------
s^2 + 2 s + 10

s-1
#2: -------
s+1

Continuous-time transfer function.

Uma maneira talvez mais visual de definir uma função de transferência é


definindo primeiro a função “s”. Por exemplo, veja como isso seria feito para o
caso da função de transferência

s
F ( s) 
s 2  2s  10

» S = tf ('s');
» F = S / (S^2 + 2*S + 10)
F=
s
--------------------
s^2 + 2 s + 10

Continuous-time transfer function.


Introdução ao MATLAB 61

Zero-Polo-Ganho

Um modelo SISO pode ser caraterizado pelos seus zeros, polos e ganho.
Por exemplo, a função de transferência

F ( s)  5
 s  1 s  2 
 s  3 s  4 

é representada por um objeto ZPK por meio dos valores de seus zeros, polos e
ganho:

» zeros = [ -1 -2 ];
» polos = [ -3 -4 ];
» ganho = [ 5 ];
» F = zpk( zeros, polos, ganho )
F=

5 (s+1) (s+2)
---------------------
(s+3) (s+4)

Continuous-time transfer function.

Espaço de Estados

Um modelo SISO ou MIMO pode ser caraterizado pelas Matrizes A, B, C


e D da representação no espaço de estados. Exemplo, seja

dx
 Ax  Bu
dt
y  Cx  Du

em que,
Introdução ao MATLAB 62

 0 1 0 1
A 
3 1 0 
B
 2 
1 1 0 0
C 
3 0 0 
D
0 
é representada por um objeto SS pelas matrizes A, B, C, D:

» A = [ 0 1 ;-2 -3 ];
» B = [ 0 1 ; 1 0 ];
» C = [ 1 1 ; 0 3 ];
» D = [ 0 0 ; 0 0 ];
» sist = ss( A,B,C,D )

sist =

a=
x1 x2
x1 0 1
x2 -2 -3

b=
u1 u2
x1 0 1
x2 1 0

c=
x1 x2
y1 1 1
y2 0 3

d=
u1 u2
y1 0 0
y2 0 0

Continuous-time transfer function.

Tempo Discreto

Para criar modelos LTI de tempo discreto, simplesmente adicione um


parâmetro referente ao tempo de amostragem Ts (em segundos) aos objetos TF,
ZPK, e SS:
Introdução ao MATLAB 63

sist = tf ( num, den, Ts )


sist = zpk ( z, p, k, Ts )
sist = ss (A, B,C,D,Ts )

por exemplo, o comando a seguir cria um função de transferência de tempo


discreto com um período de amostragem de 0,1 segundos:

» G = tf( [1 -1], [1 -0.5], 0.1 )


G=

z-1
-------
z - 0.5

Sample time: 0.1 seconds


Discrete-time transfer function.

Uma maneira talvez mais visual de definir uma função de transferência de


tempo discreto é definindo primeiro a função “z” e o período de amostragem.
Por exemplo, veja como isso seria feito para o caso da seguinte função de
transferência para Ts = 0,1s.

z 1
G( z ) 
z  0,5

» Ts = 0.1;
» Z = tf ( 'z', Ts );
» G = (Z - 1) / (Z - 0.5)

G=

z-1
-------
z - 0.5

Sample time: 0.1 seconds


Discrete-time transfer function.
Introdução ao MATLAB 64

Dados do Objeto LTI

As funções TF, ZPK, e SS colocam todos os dados modelo numa


estrutura LTI. Para se extrair os dados de um objeto LTI utilizam-se os
seguintes comandos, onde Ts é o período de amostragem. Estas funções fazem
uma conversão de modelos automática (veja a seção a seguir):

[ num, den, Ts ] = tfdata (sist)


[ z, p, k, Ts ] = zpkdata (sist)
[ A, B, C, D, Ts ] = ssdata (sist)

O exemplo a seguir ilustra o uso desses comandos. Note que como o


sistema é de tempo contínuo, Ts retorna nulo indicando isso.

» zeros = [ -1 -2 ];
» polos = [ -3 -4 ];
» ganho = [ 5 ];
» F = zpk ( zeros, polos, ganho );
» [ A, B, C, D, Ts ] = ssdata (F)

A=

-3.0000 -2.0000
0 -4.0000

B=

2.8284
2.8284

C=

-3.5355 -3.5355

D=

Ts = 0
Introdução ao MATLAB 65

Conversão de Modelos

Para converter um objeto para um tipo específico de modelo LTI use as


próprias funções TF, ZPK, e SS:

sist_novo = tf (sist)
sist_novo = zpk (sist)
sist_novo = ss (sist)

O exemplo a seguir mostra como converter de espaço de estados para


zero-polo-ganho e função de transferência.

» sist = ss ( -2, 1, 1, 3 );
» zpk ( sist )

ans =

3 (s+2.333)
-----------------
(s+2)

» tf ( sist )

ans =

3s+7
-----------
s+2

Para a conversão do tempo contínuo para o tempo discreto utilizam-se as


funções específicas c2d e d2c, respectivamente. A sintaxe dos comandos é:

sysd = c2d ( sysc, Ts ) % Ts = periodo de amostragem (s)


sysc = d2c ( sysd )
Introdução ao MATLAB 66

Na conversão presume-se o uso de um segurador de ordem zero (ZOH).


Para usar um método de conversão diferente, deve-se especificar o método num
terceiro parâmetro de entrada:

sysd = c2d ( sysc, Ts, 'zoh' ) % Segurador de ordem zero


sysd = c2d ( sysc, Ts, 'foh' ) % Segurador de 1ª ordem
sysd = c2d ( sysc, Ts, ‘impulse’ ) % Invariância ao impulso
sysd = c2d ( sysc, Ts, 'tustin' ) % Aproximação de Tustin
sysd = c2d ( sysc, Ts, 'matched' ) % Equivalência polo-zero

sysc = d2c ( sysd, 'zoh' ) % Segurador de ordem zero


sysc = d2c ( sysd, 'foh' ) % Segurador de 1ª ordem
sysc = d2c ( sysd, 'tustin' ) % Aproximação de Tustin
sysc = d2c ( sysd, 'matched' ) % Equivalência polo-zero

Operações com Modelos

Os objetos de modelos permitem as diversas operações aritméticas.


Exemplos:

» sist = sist1 + sist2

» sist = sist1 * sist2


Introdução ao MATLAB 67

» sist2 = inv ( sist1 )

» sist = [ H1 H2 ]

» sist = [ H1
H2 ]

Resposta Temporal

Existem várias funções que permitem investigar o comportamento


temporal de sistemas LTI:
Introdução ao MATLAB 68

Resposta Temporal
impulse Resposta à função impulso unitário
initial Resposta à condição inicial
gensig Resposta ao gerador de sinal
lsim Resposta a uma entrada arbitrária
step Resposta ao degrau unitário

As funções step, impulse e initial podem gerar automaticamente um


horizonte temporal de simulação. A sintaxe associada a essas três funções é:

step ( sist )
impulse ( sist )
initial ( sist, x0 ) % x0 = vetor de condições iniciais

Exemplo:

» sist = [ tf ( 1, [1 1 1] ) , tf ( 1, [1 1] ) ]
» step ( sist )

Step Response
From: In(1) From: In(2)
1.4

1.2

0.8
Amplitude

0.6

0.4

0.2

0
0 2 4 6 8 10 12 0 2 4 6 8 10 12
Time (seconds)
Introdução ao MATLAB 69

» step( sist,10 ) % simula de 0 até 10 segundos

» t = 0 : 0.1 : 10 % vetor temporal a cada 0,1s


» step ( sist, t ) % simula em função do t especificado

» t = 0 : 0.1 : 10
» u = sin ( t ) % entrada particular
» lsim ( sist, u, t ) % simula para a entrada especificada

Resposta em Frequência 102

O quadro a seguir resume algumas das funções disponíveis para a análise


em frequência de sistemas LTI:

Resposta em Frequência
bode Diagramas de Bode
margin Margens de Ganho e de Fase
nyquist Diagrama de Nyquist
nichols Carta de Nichols

As funções podem gerar os valores das frequências para os quais a


resposta será calculada. A escolha da faixa desses valores é feita em função dos
polos e zeros da função. Para impor uma dada faixa particular de frequências
num interval [wmin, wmax], use a seguinte sintaxe.

bode( sist, { wmin , wmax } ) % Atenção às ‘chaves’

O exemplo a seguir plota os diagramas de Bode da função no intervalo


que vai de 0,1 até 10 rad/s
Introdução ao MATLAB 70

» sist = tf (1, [1 1 1] )
» bode( sist, { 0.1 , 10 } )

Bode Diagram
10

0
Magnitude (dB)

-10

-20

-30

-40
0

-45
Phase (deg)

-90

-135

-180
-1 0 1
10 10 10
Frequency (rad/s)

É possível também especificar um vetor particular de pontos com


espaçamento logaritmo, por exemplo, desde 10^(-1) até 10^(+1) e com 100
pontos:

» w = logspace( –1, +1, 100)


» bode( sist, w )

Resposta Numérica 105

Para se obter os valores numéricas das respostas temporais e frequenciais


deve-se usar as variáveis de retornos das funções. Veja alguns exemplos de
sintaxes a seguir:

[ y, t ] = step( sist )
[ ganho, fase, w ] = bode( sist )
[ real, imaginario, w ] = nyquist( sist )
Introdução ao MATLAB 71

O exemplo a ilustra mostra como criar gráficos customizados a partir dos


dados numéricos de respostas temporais e frequenciais:

» F = tf ( [1 -1], [1 0.1 1] )
» [ganho,fase,w] = bode(F)
» [ y , t ] = step(F,15)
» [ p , z ] = pzmap(F)

» subplot( 221 )
» semilogx( w, 20*log10(ganho(:))), grid on
» title('Diagrama de Bode de Ganho (dB)' )
» subplot(223)
» semilogx(w,fase(:)), grid on
» title('Diagrama de Bode de Fase (graus)')

» subplot(222)
» plot(t,y), grid on
» title('Resposta ao Degrau unitário')

» subplot(224)
» plot(z,'ro'), hold, plot(p,'bx'), grid on
» axis([-0.5 1.5 -1.5 1.5])
» title('Diagrama de Polos e Zeros')

Diagrama de Bode de Ganho (dB) Resposta ao Degrau unitário


40 1

20 0

0 -1

-20 -2

-40 -3
-2 0 2 0 5 10 15
10 10 10

Diagrama de Bode de Fase (graus) Diagrama de Polos e Zeros


200
1
100
0
0
-1
-100
-2 0 2 -0.5 0 0.5 1 1.5
10 10 10
Introdução ao MATLAB 72

Redução de Ordem

Recomenda-se usar a função mineral para se obter a mínima realização


de um modelo e forçar o cancelamento de polos e zeros nos objetos. O exemplo
a seguir mostra seu efeito cancelando o zero em -1 com o polo em -1 da função
T(s) de malha fechada.

» G = tf ( 1, [1 1] )
» T = G / (1 + G)

T=
s+1
-------------------
s^2 + 3 s + 2

» T = mineral ( T )

T=
1
----------
s+2

Lugar Geométrico das Raízes

Uma análise bastante comum nos problemas de controle é a determinação


da estabilidade e do desempenho de sistemas lineares em função de um dado
parâmetro. Este costuma ser um ganho, uma taxa de amostragem etc. Um caso
típico é o ajuste fino da sintonia de um controlador através do ganho. Desta
forma é interessante conhecermos a priori a influência deste ganho na resposta.
Temos duas possibilidades: (i) Simular o comportamento da saída temporal para
todos os valores possíveis do ganho; (ii) Inferir o comportamento da saída
através dos valores dos polos de malha fechada (admitindo que a resposta é
mais influenciada pelos polos que pelos zeros).

A opção pelo cálculo dos polos nos parece mais razoável mesmo com o
auxílio do computador. A resposta temporal poderá ser mal condicionada
(dificuldades numérica) e poderá ser difícil percebermos tendências e
propriedades. Uma dificuldade na avaliação da resposta por meio dos polos de
malha fechada é que as contribuições de cada polo não podem ser somadas.
Devemos estabelecer um critério de dominância e relacionar o comportamento
Introdução ao MATLAB 73

da saída ao comportamento destes polos dominantes. Para suprir tal problema


utiliza-se a simulação temporal na validação do projeto. O Matlab possui a
função rlocus que automatiza a construção do lugar das raízes a partir da
função de transferência de malha aberta. Exemplo:

k (s - 2)
r(t) C(t)
3 2
s + 2s + 3s + 4

» G = tf( [1 -2], [1 2 3 4] )
» rlocus( G)
»

Root Locus
10

4
Imaginary Axis (seconds-1)

-2

-4

-6

-8

-10
-3 -2.5 -2 -1.5 -1 -0.5 0 0.5 1 1.5 2 2.5
-1
Real Axis (seconds )
Introdução ao MATLAB 74

Interfaces Gráficas

O Toolbox de controle do MATLAB possui uma interface gráfica


denominada sisotool que permite o projeto gráfico iterativo de sistemas de
controle escalares (SISO) por meio de ferramentas como: Lugar das raízes,
Diagrama de Bode, Carta de Nichols e Resposta Temporal. A estrutura geral
admitida pelo ambiente de projeto possui quadro funções de transferência (F, C,
G, H) onde C e F são funções ajustáveis e representam o controlador e o pré-
filtro, respectivamente. A função G é relativa ao modelo da planta e H é o
modelo do sensor. A sintaxe do comando é:

» sisotool

r -->[ F ]-->O--->[ C ]--->[ G ]----+---> y


- | |
+-------[ H ]----------+

Outra dessas interfaces que é bastante útil na análise de sistemas de


controle é a denominada ltiview que permite todo tipo análise de respostas no
domínio do tempo e da frequência de sistemas LTI (step, impulse, lsim, initial,
bode, bodemag, nyquist, nichols, sigma, pzmap, iopzmap). A sintaxe do
comando é:

» ltiview

Você também pode gostar