FIC MATLAB 2017-1: mudanças entre as edições
(38 revisões intermediárias por 3 usuários não estão sendo mostradas) | |||
Linha 479: | Linha 479: | ||
=== Aula 9 === | === Aula 9 === | ||
{{collapse top| bg=lightblue | 03/Abr - Funções; Importação de dados | {{collapse top| bg=lightblue | 03/Abr - Funções; Importação de dados}} | ||
* Função definida pelo usuário no arquivo ''.m'' | * Função definida pelo usuário no arquivo ''.m'' | ||
Linha 487: | Linha 487: | ||
:* Exercício: Escreva uma função que retorna um vetor contendo os ''n'' primeiros termos da sequência de Fibonacci. | :* Exercício: Escreva uma função que retorna um vetor contendo os ''n'' primeiros termos da sequência de Fibonacci. | ||
:* (Livro - Exemplo 4.6-2 p. 186) Exercício: Escreva uma função que determina o tempo (em anos) necessário para que você acumule pelo menos VF (em dólares) em uma conta bancária se você depositar inicialmente V0 (em dólares) e mais P (em dólares) ao final de cada ano, com um rendimento anual de R%. | |||
:* ( | |||
:* Exercício: Fazer o ''plot'' de um sinal de tensão ''x'' tempo, como da figura abaixo, usando os conceitos da aula de hoje. | :* Exercício: Fazer o ''plot'' de um sinal de tensão ''x'' tempo, como da figura abaixo, usando os conceitos da aula de hoje. | ||
Linha 504: | Linha 502: | ||
:* Pelo comando ''uiimport'' | :* Pelo comando ''uiimport'' | ||
Exemplo: usar | Exemplo: usar [http://wiki.sj.ifsc.edu.br/images/8/84/Celular4g.txt Celular4g.txt], importar e trabalhar com as funções de matrizes. | ||
:* Padronizar para o formato que o Matlab reconhece os números: ponto (''.'') e ('',''); | :* Padronizar para o formato que o Matlab reconhece os números: ponto (''.'') e ('',''); | ||
:* Converter formato ''table2array''. | :* Converter formato ''table2array''. | ||
Exercício: com o arquivo | Exercício: com o arquivo [http://wiki.sj.ifsc.edu.br/index.php/Arquivo:Add_user.txt Add_user.txt] (Adições Líquidas de Aparelhos 4G das Operadoras no período), calcular a soma dos anos 2014, 2015 e 2016 (até o momento) por operadora e a soma e a média por período. | ||
* [[FIC MATLAB 2017-1/Aula-9|Códigos executados em sala]] | |||
{{collapse bottom}} | {{collapse bottom}} | ||
Linha 624: | Linha 625: | ||
:* Comando para aparecer a malha 3D em apenas um sentido com ''waterfall'' | :* Comando para aparecer a malha 3D em apenas um sentido com ''waterfall'' | ||
[[Arquivo:FIC_Matlab_Exercicios_plot.pdf|Exercícios]] | |||
* [[FIC MATLAB 2017-1/Aula-10|Códigos executados em sala]] | |||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 11 === | === Aula 11 === | ||
{{collapse top| bg=lightblue | | {{collapse top| bg=lightblue | 10/Abr - Aula de exercícios}} | ||
Aula dedicada à execução dos exercícios das aulas anteriores. | |||
* [[FIC MATLAB 2017-1/Aula-11|Códigos executados em sala]] | |||
<!-- | |||
Exercício (livro): Plote a parte imaginária ''versus'' a parte real da função <math>(0,2 + 8i)</math><sup>n</sup> para <math>0 \leq n \leq 20</math>. Escolha uma quantidade suficiente de pontos para obter uma curva suave. Rotule cada eixo e insira um título. Utilize o comando ''axis'' para alterar o espaçamento entro os rótulos dos ''tick-marks''. | Exercício (livro): Plote a parte imaginária ''versus'' a parte real da função <math>(0,2 + 8i)</math><sup>n</sup> para <math>0 \leq n \leq 20</math>. Escolha uma quantidade suficiente de pontos para obter uma curva suave. Rotule cada eixo e insira um título. Utilize o comando ''axis'' para alterar o espaçamento entro os rótulos dos ''tick-marks''. | ||
Exercício (1 - livro adaptado): A análise de equilíbrio determina o volume de produção para qual o qual o custo de produção total é igual à receita total. No ponto de equilíbrio, não há lucro nem perda. Em geral, os custos da produção consistem em custos fixos e custos variáveis. Os custos fixos incluem salários daqueles não diretamente envolvidos com a produção, custos de manutenção de fábrica, seguros, e assim por diante. Os custos variáveis dependem do volume de produção e incluem custos de material, trabalho e energia. Na análise a seguir, considere que nós produzimos apenas o que podemos vender; assim, a quantidade de produção é igual à quantidade de vendas. ''Q'' é a quantidade de produção, em galões por ano. | Exercício (1 - livro adaptado): A análise de equilíbrio determina o volume de produção para qual o qual o custo de produção total é igual à receita total. No ponto de equilíbrio, não há lucro nem perda. Em geral, os custos da produção consistem em custos fixos e custos variáveis. Os custos fixos incluem salários daqueles não diretamente envolvidos com a produção, custos de manutenção de fábrica, seguros, e assim por diante. Os custos variáveis dependem do volume de produção e incluem custos de material, trabalho e energia. Na análise a seguir, considere que nós produzimos apenas o que podemos vender; assim, a quantidade de produção é igual à quantidade de vendas. ''Q'' é a quantidade de produção, em galões por ano. | ||
Linha 640: | Linha 648: | ||
- O preço de venda é de 65 centavos por galão. | - O preço de venda é de 65 centavos por galão. | ||
Utilize esses dados para plotar o custo total e a receita ''versus'' ''Q'', e determine graficamente o ponto de equilíbrio. Para qual faixa de ''Q'' a produção gera lucro? | Utilize esses dados para plotar o custo total e a receita ''versus'' ''Q'', e determine graficamente o ponto de equilíbrio. Para qual faixa de ''Q'' a produção gera lucro? | ||
- Comandos ''gtext'' para colocar texto na figura com um clique e ''text'' para colocar texto em uma coordenada definida. | - Comandos ''gtext'' para colocar texto na figura com um clique e ''text'' para colocar texto em uma coordenada definida. | ||
--> | |||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 12 === | === Aula 12 === | ||
{{collapse top| bg=lightblue | | {{collapse top| bg=lightblue | 12/Abr - Processamento de imagens}} | ||
- | |||
[[Curso Matlab aplicado ao processamento de imagens - Aula 3]] | |||
- | [[FIC MATLAB 2017-1/Aula-12|Códigos executados em sala]] | ||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 13 === | === Aula 13 === | ||
{{collapse top| bg=lightblue | | {{collapse top| bg=lightblue | 17/Abr - Toolbox simbólico}} | ||
'''Básico''' | |||
* Comandos ''syms'' e ''sym'' | |||
* Comandos ''pretty'' e ''latex'' | |||
* Comando ''subs'' | |||
:* Valores via argumento da função | |||
:* Valores retirados do workspace | |||
* Comandos ''factor'', ''expand'', ''collect'' e ''simplify'' | |||
'''Cálculo''' | |||
* Comando ''limit'': Limites | |||
:* <math>\lim_{x \to 0} \frac{\sin(x)}{x}</math> | |||
:* <math>\lim_{x \to \infty} \left( 1 + \frac{1}{x} \right)^x</math> | |||
* Comando ''diff'': Derivada primeira, segunda, terceira, etc. | |||
: Comando ''int'': Integrais indefinidas e definidas | |||
:* <math>\int x^a dx</math> | |||
* Interlúdio: comandos ''assume'' e ''assumptions'' | |||
* Comando ''taylor'': Séries de Taylor | |||
* comando ''symsum'': Somatórios / séries | |||
* Outros: ''dsolve'', ''fourier'', ''laplace'', ''partfrac'' | |||
'''Solução de equações''' | |||
* Comando ''solve'' | |||
[[FIC MATLAB 2017-1/Aula-13|Códigos executados em sala]] | |||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 14 === | === Aula 14 === | ||
{{collapse top| bg=lightblue | | |||
{{collapse top| bg=lightblue | 19/Abr - Interface gráfica}} | |||
[[Curso Matlab aplicado ao processamento de imagens - Aula 2|Aula]] | |||
{{collapse top| bg=lightblue | Proposta de Interface gráfica}} | |||
<code> | |||
function varargout = Interface(varargin) | |||
% INTERFACE MATLAB code for Interface.fig | |||
% INTERFACE, by itself, creates a new INTERFACE or raises the existing | |||
% singleton*. | |||
% | |||
% H = INTERFACE returns the handle to a new INTERFACE or the handle to | |||
% the existing singleton*. | |||
% | |||
% INTERFACE('CALLBACK',hObject,eventData,handles,...) calls the local | |||
% function named CALLBACK in INTERFACE.M with the given input arguments. | |||
% | |||
% INTERFACE('Property','Value',...) creates a new INTERFACE or raises the | |||
% existing singleton*. Starting from the left, property value pairs are | |||
% applied to the GUI before Interface_OpeningFcn gets called. An | |||
% unrecognized property name or invalid value makes property application | |||
% stop. All inputs are passed to Interface_OpeningFcn via varargin. | |||
% | |||
% *See GUI Options on GUIDE's Tools menu. Choose "GUI allows only one | |||
% instance to run (singleton)". | |||
% | |||
% See also: GUIDE, GUIDATA, GUIHANDLES | |||
% Edit the above text to modify the response to help Interface | |||
% Last Modified by GUIDE v2.5 19-Apr-2017 19:45:52 | |||
% Begin initialization code - DO NOT EDIT | |||
gui_Singleton = 1; | |||
gui_State = struct('gui_Name', mfilename, ... | |||
'gui_Singleton', gui_Singleton, ... | |||
'gui_OpeningFcn', @Interface_OpeningFcn, ... | |||
'gui_OutputFcn', @Interface_OutputFcn, ... | |||
'gui_LayoutFcn', [] , ... | |||
'gui_Callback', []); | |||
if nargin && ischar(varargin{1}) | |||
gui_State.gui_Callback = str2func(varargin{1}); | |||
end | |||
if nargout | |||
[varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:}); | |||
else | |||
gui_mainfcn(gui_State, varargin{:}); | |||
end | |||
% End initialization code - DO NOT EDIT | |||
% --- Executes just before Interface is made visible. | |||
function Interface_OpeningFcn(hObject, eventdata, handles, varargin) | |||
% This function has no output args, see OutputFcn. | |||
% hObject handle to figure | |||
% eventdata reserved - to be defined in a future version of MATLAB | |||
% handles structure with handles and user data (see GUIDATA) | |||
% varargin command line arguments to Interface (see VARARGIN) | |||
handles.contador = 0; | |||
display(handles.contador) | |||
assignin('base','handles',handles) | |||
% Choose default command line output for Interface | |||
handles.output = hObject; | |||
% Update handles structure | |||
guidata(hObject, handles); | |||
% UIWAIT makes Interface wait for user response (see UIRESUME) | |||
% uiwait(handles.figure1); | |||
% --- Outputs from this function are returned to the command line. | |||
function varargout = Interface_OutputFcn(hObject, eventdata, handles) | |||
% varargout cell array for returning output args (see VARARGOUT); | |||
% hObject handle to figure | |||
% eventdata reserved - to be defined in a future version of MATLAB | |||
% handles structure with handles and user data (see GUIDATA) | |||
% Get default command line output from handles structure | |||
varargout{1} = handles.output; | |||
% --- Executes on button press in btnDesenhar. | |||
function btnDesenhar_Callback(hObject, eventdata, handles) | |||
% hObject handle to btnDesenhar (see GCBO) | |||
% eventdata reserved - to be defined in a future version of MATLAB | |||
% handles structure with handles and user data (see GUIDATA) | |||
%Incrementa o contador | |||
handles.contador = handles.contador + 1; | |||
display(handles.contador) | |||
%handles | |||
%Axis 1 | |||
hold(handles.axes1,'off') | |||
amostras = [0:1:1000]; | |||
if not(isempty(str2num(get(handles.edtFrequencias,'String')))) | |||
Freq = str2num(get(handles.edtFrequencias,'String')) | |||
onda = 2*pi*Freq*0.001*amostras; | |||
plot(handles.axes1,sin(onda)) | |||
grid(handles.axes1,'on') | |||
assignin('base','contador',handles.contador); | |||
assignin('base','hObject',hObject) | |||
% Update handles structure | |||
guidata(hObject, handles); | |||
if (get(handles.rbtCosseno,'Value') == 1) | |||
%Axis 2 | |||
plot(handles.axes2,cos(onda)) | |||
grid(handles.axes2,'on') | |||
elseif (get(handles.rbtTangente,'Value') == 1) | |||
%Axis 2 | |||
plot(handles.axes2,tan(onda)) | |||
grid(handles.axes2,'on') | |||
ylim(handles.axes2,[-2,2]) | |||
else | |||
errordlg('Selecione uma onda de saída!') | |||
end | |||
end | |||
% --- Executes on button press in rbtCosseno. | |||
function rbtCosseno_Callback(hObject, eventdata, handles) | |||
% hObject handle to rbtCosseno (see GCBO) | |||
% eventdata reserved - to be defined in a future version of MATLAB | |||
% handles structure with handles and user data (see GUIDATA) | |||
% Hint: get(hObject,'Value') returns toggle state of rbtCosseno | |||
set(hObject,'Value',1) | |||
set(handles.rbtTangente,'Value',0) | |||
% --- Executes on button press in rbtTangente. | |||
function rbtTangente_Callback(hObject, eventdata, handles) | |||
% hObject handle to rbtTangente (see GCBO) | |||
% eventdata reserved - to be defined in a future version of MATLAB | |||
% handles structure with handles and user data (see GUIDATA) | |||
% Hint: get(hObject,'Value') returns toggle state of rbtTangente | |||
set(hObject,'Value',1) | |||
set(handles.rbtCosseno,'Value',0) | |||
function edtFrequencias_Callback(hObject, eventdata, handles) | |||
% hObject handle to edtFrequencias (see GCBO) | |||
% eventdata reserved - to be defined in a future version of MATLAB | |||
% handles structure with handles and user data (see GUIDATA) | |||
% Hints: get(hObject,'String') returns contents of edtFrequencias as text | |||
% str2double(get(hObject,'String')) returns contents of edtFrequencias as a double | |||
% --- Executes during object creation, after setting all properties. | |||
function edtFrequencias_CreateFcn(hObject, eventdata, handles) | |||
% hObject handle to edtFrequencias (see GCBO) | |||
% eventdata reserved - to be defined in a future version of MATLAB | |||
% handles empty - handles not created until after all CreateFcns called | |||
% Hint: edit controls usually have a white background on Windows. | |||
% See ISPC and COMPUTER. | |||
if ispc && isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor')) | |||
set(hObject,'BackgroundColor','white'); | |||
end | |||
</syntaxhighlight> | |||
{{collapse bottom}} | |||
{{collapse bottom}} | |||
=== Aula 15 === | |||
{{collapse top| bg=lightblue | 24/Abr - Projeto}} | |||
:relógio analógico | |||
:dtmf | |||
:sudoku | |||
:jogo da velha | |||
:contar moedas | |||
:esteganografia | |||
:batalha naval | |||
{{collapse bottom}} | |||
<!-- | |||
Exercício (livro - 30 p. 259): Obtenha as plotagens de superfície e de contorno para a função <math>z = x</math><sup>2</sup><math>- 2xy + 4y</math><sup>2</sup>, mostrando o mínimo em <math>x = y = 0 </math>. | Exercício (livro - 30 p. 259): Obtenha as plotagens de superfície e de contorno para a função <math>z = x</math><sup>2</sup><math>- 2xy + 4y</math><sup>2</sup>, mostrando o mínimo em <math>x = y = 0 </math>. | ||
Linha 768: | Linha 905: | ||
- Comando ''flip'', representa o vetor de trás pra frente; | - Comando ''flip'', representa o vetor de trás pra frente; | ||
Exercício (livro - adaptado - exemplo 6.2-2 p. 278): A tabela a seguir fornece dados de crescimento de uma determinada população de bactérias com o tempo. Ajuste uma equação para esses dados, calcule o coeficiente de ajuste e estime o fluxo no tempo 18 min. Plote a curva escolhida. | Exercício (livro - adaptado - exemplo 6.2-2 p. 278): A tabela a seguir fornece dados de crescimento de uma determinada população de bactérias com o tempo. Ajuste uma equação para esses dados, calcule o coeficiente de ajuste e estime o fluxo no tempo 18 min. Plote a curva escolhida. | ||
Linha 797: | Linha 929: | ||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 16 === | === Aula 16 === | ||
Linha 830: | Linha 963: | ||
d) Suponha que os lucros sejam de $200, $500 e $100 para cada produto 1, 2 e 3, respectivamente. Encontre os valores de ''x'', ''y'' e ''z'' que maximizam os lucros. | d) Suponha que os lucros sejam de $200, $500 e $100 para cada produto 1, 2 e 3, respectivamente. Encontre os valores de ''x'', ''y'' e ''z'' que maximizam os lucros. | ||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 17 === | === Aula 17 === | ||
Linha 889: | Linha 1 023: | ||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 18 === | === Aula 18 === | ||
Linha 905: | Linha 1 040: | ||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 19 === | === Aula 19 === | ||
Linha 917: | Linha 1 053: | ||
{{collapse bottom}} | {{collapse bottom}} | ||
=== Aula 20 === | === Aula 20 === | ||
Linha 925: | Linha 1 062: | ||
{{collapse bottom}} | {{collapse bottom}} | ||
--> | |||
== Questões da turma == | |||
=== Exercícios Engenharia de Alimentos === | |||
[http://www.dima.uniroma1.it/users/lsa_adn/MATERIALE/FDheat.pdf] | |||
{{collapse top| bg=lightblue | Método explícito}} | |||
<syntaxhighlight lang=matlab class="mw-collapsible"> | |||
clear all; close all; clc | |||
alfa = 0.0000971; | |||
II = 10; | |||
N = 200; | |||
L = 0.3; | |||
tempo = 200; | |||
a = 20; | |||
k = 237; | |||
h = 85; | |||
Tf = -300; | |||
T0 = 20; | |||
% Cálculos | |||
deltax = L/II; | |||
deltat = tempo/N; | |||
fon = alfa*deltat/deltax^2; | |||
% Algoritmo | |||
% Convergência | |||
fon | |||
if fon < 0.5 | |||
T(1,1:II+1) = T0; | |||
for n = 1:N | |||
% i = 1 | |||
T(n+1,1) = 2*fon * T(n,2) + (1 - 2*fon)*T(n,1); | |||
% Outros casos de i | |||
for ii = 2:II | |||
T(n+1,ii) = fon*T(n,ii+1) + (1 - 2*fon)*T(n,ii) + fon*T(n,ii-1); | |||
end | |||
% i = II+1 | |||
T(n+1,II+1) = fon*(-2*deltax*h*(T(n,II+1) - Tf))/k + (1 - 2*fon)*T(n,II+1) + 2*fon*T(n,II); | |||
end | |||
end | |||
% Resultados | |||
figure | |||
surf(T) | |||
view(0,90) | |||
xlabel('x'); ylabel('t') | |||
</syntaxhighlight> | |||
{{collapse bottom}} | |||
== Projetos finais == | |||
* [https://github.com/clebercbr/RobotSimulatorMATLAB Projeto 1] | |||
* [[Media:FIC-MATLAB-2017-1-Projeto-2.zip|Projeto 2]] | |||
* [[Media:FIC-MATLAB-2017-1-Projeto-3.zip|Projeto 3]] | |||
* [[Media:FIC-MATLAB-2017-1-Projeto-4.zip|Projeto 4]] | |||
* [[Media:FIC-MATLAB-2017-1-Projeto-5.m|Projeto 5]] | |||
* [[Media:FIC-MATLAB-2017-1-Projeto-6.zip|Projeto 6]] |
Edição atual tal como às 10h12min de 13 de junho de 2017
1 Informações Básicas
Professores: Diego da Silva de Medeiros e Roberto Wanderley da Nóbrega
- Início: 06/Mar/2017
- Término: 15/Mai/2017
- Horário: Segundas e quartas, das 19h às 22h
Referência Básica: PALM, William J. Introdução ao MATLAB para engenheiros. Tradução de Tales Argolo Jesus. 3. ed. Porto Alegre: AMGH, 2013. xiv, 562, il. ISBN 9788580552041 Referência Complementar: MORAIS, V.. VIEIRA, C. MATLAB Curso Completo. FCA, 2013. 644. ISBN 9727227058
2 Conteúdos Abordados
2.1 Aula 1
06/Mar - Apresentação da disciplina, professores e alunos; Interface do MATLAB e operadores; Utilização básica (comandos help, clear, …); | |||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
2.2 Aula 2
2.3 Aula 3
13/Mar - Plots; Indexação de vetores e matrizes | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
![]() ![]()
![]()
![]() ![]() ![]() |
2.4 Aula 4
15/Mar - Aula de exercícios |
---|
Aula dedicada à execução dos exercícios das aulas anteriores. |
2.5 Aula 5
20/Mar - Endereçamento lógico; Concatenação de matrizes; Polinômios | ||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
![]() ![]() ![]() ![]() ![]() |
2.6 Aula 6
22/Mar - Texto; Entrada e saída; Estruturas; Células |
---|
![]() ![]() |
2.7 Aula 7
27/Mar - Operadores; Scripts; Controle de fluxo de dados | ||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
2.8 Aula 8
29/Mar - Switch; Estruturas de repetição |
---|
|
2.9 Aula 9
03/Abr - Funções; Importação de dados |
---|
![]()
Exemplo: usar Celular4g.txt, importar e trabalhar com as funções de matrizes.
Exercício: com o arquivo Add_user.txt (Adições Líquidas de Aparelhos 4G das Operadoras no período), calcular a soma dos anos 2014, 2015 e 2016 (até o momento) por operadora e a soma e a média por período.
|
2.10 Aula 10
05/Abr - Gráficos em 2D e 3D | ||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
[X,Y] = meshgrid(-20:0.5:20); R = sqrt(X.^2 + Y.^2) + eps; Z = sin(R)./R; mesh(X,Y,Z)
|
2.11 Aula 11
10/Abr - Aula de exercícios |
---|
Aula dedicada à execução dos exercícios das aulas anteriores.
|
2.12 Aula 12
12/Abr - Processamento de imagens |
---|
2.13 Aula 13
17/Abr - Toolbox simbólico |
---|
Básico
Cálculo
Solução de equações
|
2.14 Aula 14
19/Abr - Interface gráfica | ||
---|---|---|
|
2.15 Aula 15
24/Abr - Projeto |
---|
|
3 Questões da turma
3.1 Exercícios Engenharia de Alimentos
Método explícito |
---|
clear all; close all; clc
alfa = 0.0000971;
II = 10;
N = 200;
L = 0.3;
tempo = 200;
a = 20;
k = 237;
h = 85;
Tf = -300;
T0 = 20;
% Cálculos
deltax = L/II;
deltat = tempo/N;
fon = alfa*deltat/deltax^2;
% Algoritmo
% Convergência
fon
if fon < 0.5
T(1,1:II+1) = T0;
for n = 1:N
% i = 1
T(n+1,1) = 2*fon * T(n,2) + (1 - 2*fon)*T(n,1);
% Outros casos de i
for ii = 2:II
T(n+1,ii) = fon*T(n,ii+1) + (1 - 2*fon)*T(n,ii) + fon*T(n,ii-1);
end
% i = II+1
T(n+1,II+1) = fon*(-2*deltax*h*(T(n,II+1) - Tf))/k + (1 - 2*fon)*T(n,II+1) + 2*fon*T(n,II);
end
end
% Resultados
figure
surf(T)
view(0,90)
xlabel('x'); ylabel('t')
|