-
Notifications
You must be signed in to change notification settings - Fork 6
/
vldg_training.py
131 lines (100 loc) · 4.51 KB
/
vldg_training.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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
import sys, os
#Panda 3D Imports
from panda3d.core import Filename
from direct.showbase.ShowBase import ShowBase
from panda3d.core import loadPrcFile
loadPrcFile('./config/conf.prc')
#Custom Functions
from visual_landing.rl_worker import quad_worker
from visual_landing.ppo_world_setup import world_setup, quad_setup
from models.camera_control import camera_control
from computer_vision.cameras_setup import cameras
from environment.controller.target_parser import episode_n
from panda3d.core import WindowProperties
import argparse
parser = argparse.ArgumentParser(description='Child or Mother Process')
parser.add_argument('-c', '--child', action='store_true',
help='an integer for the accumulator')
child = parser.parse_args().child
"""
INF209B − TÓPICOS ESPECIAIS EM PROCESSAMENTO DE SINAIS:
VISAO COMPUTACIONAL
PROJETO
RA: 21201920754
NOME: RAFAEL COSTA FERNANDES
E−MAIL: COSTA.FERNANDES@UFABC.EDU.BR
DESCRIÇÃO:
Ambiente 3D de simulação do quadrirrotor.
Dividido em tarefas, Camera Calibration e Drone position
Se não haver arquivo de calibração de camera no caminho ./config/camera_calibration.npz, realiza a calibração da câmera tirando 70 fotos aleatórias do padrão xadrez
A bandeira IMG_POS_DETER adiciona a tarefa de determinação de posição por visão computacional, utilizando um marco artificial que já está no ambiente 3D, na origem.
A bandeira REAL_STATE_CONTROL determina se o algoritmo de controle será alimentado pelos valores REAIS do estado ou os valores estimados pelos sensores a bordo
O algoritmo não precisa rodar em tempo real, a simulação está totalmente disvinculada da velocidade de renderização do ambiente 3D.
Se a simulação 3D estiver muito lenta, recomendo mudar a resolução nativa no arquivo de configuração ./config/conf.prc
Mudando a resolução PROVAVELMENTE será necessário recalibrar a câmera, mas sem problemas adicionais.
Recomendado rodar em um computador com placa de vídeo.
Em um i5-4460 com uma AMD R9-290:
Taxa de FPS foi cerca de 95 FPS com a bandeira IMG_POS_DETER = False e REAL_STATE_CONTROL = True
Taxa de FPS foi cerca de 35 FPS com a bandeira IMG_POS_DETER = True e REAL_STATE_CONTROL = False
O algoritmo de detecção de pontos FAST ajudou na velocidade da detecção, mas a performance precisa ser melhorada
(principalmente para frames em que o tabuleiro de xadrez aparece parcialmente)
"""
camera_size = 84
mydir = os.path.abspath(sys.path[0])
mydir = Filename.fromOsSpecific(mydir).getFullpath()
frame_interval = 10
cam_names = ('cam_1', )
if child:
print('--------------------')
print('--------------------')
print('---CHILD PROCESS----')
print('--------------------')
print('--------------------')
f = open('./child_data/child_processes.txt', 'r+')
try:
lines = f.readlines()
last_line = lines[-1]
CHILD_PROCESS = int(last_line)+1
if len(lines) == 1:
f.write(f.read()+'\n'+str(CHILD_PROCESS)+'\n')
else:
f.write(f.read()+str(CHILD_PROCESS)+'\n')
except:
CHILD_PROCESS = 0
f.write(str(CHILD_PROCESS))
f.close()
data = open('./child_data/'+str(CHILD_PROCESS)+'.txt', 'w')
data.write(str(0))
data.close()
else:
print('--------------------')
print('--------------------')
print('---MOTHER PROCESS---')
print('--------------------')
print('--------------------')
f = open('./child_data/child_processes.txt', 'w')
f.close()
CHILD_PROCESS = 0
class MyApp(ShowBase):
def __init__(self):
ShowBase.__init__(self)
render = self.render
# MODELS SETUP
world_setup(self, render, mydir)
quad_setup(self, render, mydir)
# OPENCV CAMERAS SETUP
self.buffer_cameras = cameras(self, camera_size, frame_interval, cam_names)
# self.taskMgr.doMethodLater(60, trace_memory, 'memory check')
# COMPUTER VISION
self.ldg_algorithm = quad_worker(self, self.buffer_cameras.opencv_cameras[0], CHILD_PROCESS, child=child)
# CAMERA CONTROL
camera_control(self, self.render)
#WINDOW NAME
wn= 'Child process n.'+str(CHILD_PROCESS) if child else 'Mother Process'
props = WindowProperties( )
props.setTitle( wn )
self.win.requestProperties( props )
def run_setup(self):
a = 1
app = MyApp()
app.run()