-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathconfig.py
265 lines (227 loc) · 9.42 KB
/
config.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
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
'''
Archivo con configuraciones o parámetros
Este código se ejecuta solamente la primera vez que se importa este módulo,
entonces cuando main.py haga "from config import prm" el objeto "prm" se va a
crear. Cuando otro módulo como video.py haga lo mismo, en vez de crearse otro
"prm" se le va a dar una referencia al objeto creado previamente. De esta forma
todos los módulos pueden acceder a este mismo objeto como si fuera una variable
global
Tambien creo "default_prm" que mantiene los parametros por defecto, los
mantenemos ahí para tener como referencia y saber cuales cambiamos en "prm".
Este objeto no deberia ser modificado nunca
'''
class Parameters:
def __init__(self):
'''
Objeto que mantiene todas los parámetros o opciones
Objeto que mantiene todos los parametros configurables del programa,
permite tener todo en un solo lugar para luego cambiarlos durante la
ejecucion del programa
Tener en cuenta que algunos parámetros solo son leídos al iniciar el
programa, por ejemplo la resolución de pantalla. En esos casos hay que
cerrar el programa, cambiar el valor acá en este archivo y volver a
abrirlo
Mantiene el valor de cada parámetro y una descripción por las dudas.
Tambien mantiene un valor mínimo, uno máximo y un incremento para usar
cuando se cambia el valor usando el teclado. Ver video.py
'''
# Enumeración de valores posibles de prm['parallax_mode']
self.mode_2d = True
self.mode_3d = False
self.parameters = {
'camera_device_index': {
'descr': 'Numero de camara a usar para la deteccion de caras',
'val': 0, 'min': 0, 'max': 4, 'step': 1,
},
'face_detection_min_size': {
'descr': 'Tamaño minimo de cara detectada',
'val': 50, 'min': 5, 'max': 1000, 'step': 1,
},
'face_detection_min_neighbors': {
'descr': ('Cantidad de caras minimas a detectar para considerar '
'deteccion positiva'),
'val': 3, 'min': 1, 'max': 50, 'step': 1,
},
'face_detection_scale_factor': {
'descr': ('En cuanto agrandar tamaño de cara buscada en cada '
'paso de la deteccion'),
'val': 1.2, 'min': 1.05, 'max': 2, 'step': 0.05,
},
'px_per_cm': {
'descr': 'Algo asi como DPI pero en centimetros',
'val': 39.5, 'min': 10, 'max': 200, 'step': 0.5,
},
'camera_f': {
'descr': 'Parámetro f de la cámara',
'val': 400, 'min': 1, 'max': 1000, 'step': 2,
},
'camera_vertical_distance': {
'descr': ('Distancia vertical de la posición de la camara al '
'centro de la pantalla en cm'),
'val': 10, 'min': 1, 'max': 100, 'step': 1,
},
'eyes_gap': {
'descr': 'Distancia esperada entre los ojos en cm',
'val': 6.3, 'min': 5, 'max': 8, 'step': 0.1,
},
'filter_enabled': {
'descr': 'Si el filtro de Kalman está habilitado o no',
'val': True,
},
'filter_h': {
'descr': ('Valor usado en matriz H, mientras mayor es el valor '
'más filtrado se hace'),
'val': 0.000, 'min': 0.0001, 'max': 0.01, 'step': 0.001,
},
'filter_q': {
'descr': ('Valor usado en matriz de error de acción, mientras '
'menor es el valor más filtrado se hace'),
'val': 0.01, 'min': 0.005, 'max': 5, 'step': 0.005,
},
'filter_r': {
'descr': ('Valor usado en matriz de error de sensor, mientras '
'mayor es el valor más filtrado se hace'),
'val': 0.03, 'min': 0.0001, 'max': 0.5, 'step': 0.0001,
},
'filter_a': {
'descr': ('Valor usado en matriz A, mientras mayor es el valor '
'menos fricción tiene la velocidad'),
'val': 0.95, 'min': 0.7, 'max': 1, 'step': 0.0001,
},
'filter_v_threshold': {
'descr': ('Minimo de velocidad vertical en cm/s? para detectar '
'un salto'),
'val': 25, 'min': 10, 'max': 40, 'step': 1,
},
'filter_jump_timer': {
'descr': 'Minimo tiempo entre detección de saltos, en segundos',
'val': 3, 'min': 0.5, 'max': 10, 'step': 0.5,
},
'video_show_fps': {
'descr': 'Si mostrar FPS',
'val': False,
},
'video_show_prm': {
'descr': ('Si mostrar estos parametros para permitir '
'modificaciones'),
'val': False,
},
'scene_2d_sensibility': {
'descr': 'Mientras mayor es, más se mueven las cosas en scene_2d',
'val': 1, 'min': 0.2, 'max': 3, 'step': 0.1,
},
'scene_2d_alpha_per_sec': {
'descr': ('En cuánto aumentar o disminuir el alpha de un cartel'
'por segundo. El alpha va de 0 a 255'),
'val': 300, 'min': 50, 'max': 2000, 'step': 10,
},
'scene_3d_perspective': {
'descr': ('Si usar gluPerspective para pruebas en lugar de '
'glFrustum'),
'val': False,
},
'scene_3d_speed': {
'descr': 'Factor de velocidad de cartas en escena 3D',
'val': 0.4, 'min': 0.1, 'max': 2, 'step': 0.05,
},
'scene_3d_max_rotation': {
'descr': ('Máxima rotación de cartas en escena 3D, siendo '
'1 = 90° al llegar a la pared'),
'val': 0.3, 'min': 0.1, 'max': 2, 'step': 0.05,
},
'scene_3d_interval': {
'descr': 'Segundos que tarda en aparecer nueva carta',
'val': 4, 'min': 0.1, 'max': 10, 'step': 0.1,
},
'scene_3d_card_size': {
'descr': 'Tamaño de cartas, no tiene unidad, es a ojo',
'val': 0.2, 'min': 0.05, 'max': 1, 'step': 0.05,
},
'screen_auto_size': {
'descr': 'Si usar máximo tamaño de pantalla disponible',
'val': True,
},
'screen_w': {
'descr': 'Ancho de pantalla a usar si no es automático',
'val': 1920, 'min': 100, 'max': 10000, 'step': 10,
},
'screen_h': {
'descr': 'Alto de pantalla a usar si no es automático',
'val': 1080, 'min': 100, 'max': 10000, 'step': 10,
},
'parallax_mode': {
'descr': 'Cambiar entre modo 2D y 3D',
'val': self.mode_2d,
}
}
def __getitem__(self, key):
'''
Para acceder a los parámetros
Haciendo por ejemplo:
ancho = prm['screen_w']
'''
return self.parameters[key]['val']
def __setitem__(self, key, value):
'''
Para modificar los parámetros
Haciendo por ejemplo:
prm['screen_w'] = 1080
'''
self.parameters[key]['val'] = value
def __iter__(self):
'''
Para iterar sobre cada parámetro
Haciendo por ejemplo:
for index, key in enumerate(prm):
print('Opcion N° {}, {} = {}'.format(index, key, prm[key]))
'''
return iter(self.parameters)
def __len__(self):
'''
Para obtener cantidad de parámetros
'''
return len(self.parameters)
def index(self, index):
'''
Obtener nombre de parametro a partir de su índice
Usado en video.py. Ejemplo:
key = prm.index(2)
'''
for i, key in enumerate(self.parameters):
if index == i:
return key
def descr(self, key):
'''
Para obtener descripción de un parámetro
Haciendo por ejemplo:
ancho = prm.descr('screen_w')
'''
return self.parameters[key]['descr']
def increment(self, key):
'''
Usado por video.py para incrementar el valor usando el teclado
Si el parámetro es True o False se va a invertir, si el parámetro es un
número se va a aumentar el valor
'''
prm = self.parameters[key]
if type(prm['val']) == bool:
prm['val'] = not prm['val']
else:
prm['val'] += prm['step']
if prm['val'] > prm['max']:
prm['val'] = prm['max']
def decrement(self, key):
'''
Usado por video.py para disminuir el valor usando el teclado
Si el parámetro es True o False se va a invertir, si el parámetro es un
número se va a disminuir el valor
'''
prm = self.parameters[key]
if type(prm['val']) == bool:
prm['val'] = not prm['val']
else:
prm['val'] -= prm['step']
if prm['val'] < prm['min']:
prm['val'] = prm['min']
prm = Parameters()
default_prm = Parameters()