forked from fvasc/calculo_numerico
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclass_separation_model_predator_pray.py
98 lines (67 loc) · 2.28 KB
/
class_separation_model_predator_pray.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# -*- coding: utf-8 -*-
"""
Spyder Editor
This is a temporary script file.
"""
import matplotlib.pyplot as plt
#Classe CONSTRUTORDEGRAFICO
class ConstrutorDeGrafico:
def __init__(self):
self.f, self.axarr = plt.subplots(2)
def adicionar(self, X, Y, T, m, tracejado):
n = 2**(5+m)
self.axarr[0].plot(T, X, tracejado, label='Aprox n = ' + str(n))
self.axarr[0].set_title('Titulo do gráfico')
self.axarr[1].plot(T, Y, tracejado)
def mostrar(self):
plt.xlabel('Eixo T')
plt.ylabel('Eixo X e Y')
plt.legend()
plt.show()
#Fim da classe CONSTRUTORDEGRAFICO
#Classe SIMULADOR
class Simulador:
def __init__(self, m):
self.m = m
self.X = []
self.Y = []
self.T = []
self.__simular()
def __simular(self):
#Dados iniciais
t0 = 0
tf = 30
h = (tf - t0)/(2**(5+self.m))
#Condicoes iniciais
x0 = 1
y0 = 1
#Lista dos resultados com C.I. adicionada
self.X.append(x0)
self.Y.append(y0)
self.T.append(t0)
#chamando metodo numerico
self.__metodoDePassoUnicoBidimensional(h)
def __metodoDePassoUnicoBidimensional(self, h):
n = 2**(5+self.m)
for k in range(0, n):
t_k1 = self.T[k] + h
x_k1 = self.X[k] + h * self.__eulerExplicito1(self.X[k], self.Y[k])
y_k1 = self.Y[k] + h * self.__eulerExplicito2(self.X[k], self.Y[k])
self.T.append(t_k1)
self.X.append(x_k1)
self.Y.append(y_k1)
def __eulerExplicito1(self, x, y):
return (x * 6.0 - (x * y * 2.0) )
def __eulerExplicito2(self, x, y):
return (y * (-2.0) + (y * x * 3) )
#Fim da classe SIMULADOR
def main():
construtorDeGrafico = ConstrutorDeGrafico()
sim1 = Simulador(11)
sim2 = Simulador(12)
sim3 = Simulador(17)
construtorDeGrafico.adicionar(sim1.X, sim1.Y, sim1.T, sim1.m, ':')
construtorDeGrafico.adicionar(sim2.X, sim2.Y, sim2.T, sim2.m, '-.')
construtorDeGrafico.adicionar(sim3.X, sim3.Y, sim3.T, sim3.m, '--')
construtorDeGrafico.mostrar()
main()