[un/loquer] Agentes de calidad del aire
daniel gomez
danielgomezmarin en gmail.com
Jue Abr 13 10:47:09 UTC 2017
Hola
Ya estoy arreglando todos los datos "INVALID":
1. reviso que el primer dato no sea invalid. si es así, lo arreglo
devolviéndome desde el primer registro que no tenga ningún valor inválido.
1.1 lat y long se pueden predecir con la velocidad y el ángulo como decía
brol. así las corrijo. las demás simplemente las estoy copiando. pero creo
que se puede hacer mejor. lo pensamos.
2. una vez los primeros datos están correctos. reviso desde el principio
hasta el final los inválidos usando la misma metodología para predecir lat
y long basado en la velocidad y el ángulo. También, los demás datos que
quedan incompletos los copio simplemente.
hay un efecto gracioso de hacer la predicción de la posición de esta manera
(ver línea diagonal en donde parece ser la casa de Brol :) )y es que si la
velocidad antes de ser invalid era diferente de cero, los nuevos valores de
lat y long predichos vana a quedar movidos proporcionalmente a la última
velocidad y en la dirección del último ángulo que se había registrado.
pensemos en que esto se puede mejorar. para hacer más inteligentemente 1 y
2.
Entonces: ya no hay ningún dato invalid y con eso se hace el plot (ver
imagen adjunta).
@Brol y @fede:
no se si seguir o pegármeles a ustedes, porque siento que estamos haciendo
lo mismo :)
Me gusta mucho la leyenda que han puesto en el mapa! con un botón en cada
tipo de rango se podría visualizar las zonas que en algún momento han
presentado cierto tipo de rango. super útil :)
De todas maneras, el paso siguiente debería ser hacer el los filtros de
tiempo.
En ese caso veo que las herramientas que usan ustedes pueden ser mejores
porque ya tienen interactividad con botones y demás widgets. Los datos de
esos botones podrían llegar al .py o al .pyo y ahi hacer las consultas y
luego devolver los datos. Veo que leaflet es en javacript y aquí en una
búsqueda rápida veo como se pueden interfazar leaflet y python:
https://github.com/python-visualization/folium
podríamos mirarlo si hace falta y así vería más claro que cavamos dos
túneles distintos para encontrarnos en la mitad del camino (folium?)
yo sigo trabajando, pensando en esta idea de api que comentaba Brol en el
correo pasado:
"Inicialmente será de archivos planos y filtramos al cargarlos y ojalá
después que sea una especie de api a la que se le hagan consultas."
saludos!
El 13 de abril de 2017, 9:26, daniel gomez <danielgomezmarin at gmail.com>
escribió:
> mucho mejor!
> yo sigo en python haciendo lo que hablamos arriba. en este momento estoy
> trabajando en sanar lo datos "INVALID" como sugería brol.
> Tengo dos preguntas:
> - la velocidad del sensor es en metros por segundo?
> - a cuanto equivale un metro en latitud y en longitud? (esta seguro está
> en google)
>
> El 12 de abril de 2017, 23:32, federico lopez <fede2001 at gmail.com>
> escribió:
>
>> Aún sin implementar las buenas ideas que se han planteado en este hilo
>> hoy se hizo (brolin) esta versión del mapa con puntos graduados que empieza
>> a ser más útil que el mapa de calor, ahí ya se pueden consultar medidas en
>> horarios (y días) diferentes.
>>
>> http://www.daquina.io/vizAirePuntosGraduados/
>>
>>
>>
>> 2017-04-10 17:03 GMT-05:00 daniel gomez <danielgomezmarin at gmail.com>:
>>
>>> Hola
>>>
>>> Inicialmente será de archivos planos y filtramos al cargarlos y ojalá
>>> después que sea una especie de api a la que se le hagan consultas.
>>>
>>> Ya está leyendo desde la web.
>>> desde la dirección que me dió @fede:
>>> https://raw.githubusercontent.com/daquina-io/visualizacionCa
>>> lidadAire/master/data/points.csv
>>>
>>> estoy atento a que consolidemos un wishlist para irle trabajando.
>>>
>>> Por el momento estoy saltándome los datos "INVALID". Pero ya @brol nos
>>> mostró como podemos hacer la calibración de la velocidad con el course:
>>>
>>> El dato course es el ángulo (0 < course < 360) respecto al norte.
>>> Y con la velocidad y el tiempo del último punto se puede hacer una
>>> aproximación a la siguiente posición: x = v*t
>>>
>>> hoy le estuve pensando y hay algo:
>>> el primer dato por ejemplo es "INVALID" entonces no se puede sanar el
>>> dataset de atrás hacia adelante.
>>> de hecho los primeros datos son INVALID.
>>> en ese caso deberíamos buscar el primer dato que no sea INVALID.
>>> Una vez lo encontremos nos vamos devolviendo "sanando" el dataset hasta
>>> llegar a la primera medición.
>>> y apenas tengamos esos primeros corregidos nos vamos sanando los datos
>>> hacia adelante.
>>>
>>> también atentos a lo que diga @eliette sobre el sensor. para depurar esa
>>> medida.
>>>
>>> pego el "mapa" que hace en este momento
>>> :D
>>>
>>> El 10 de abril de 2017, 22:59, brolin <brolin108 at gmail.com> escribió:
>>>
>>>> Ey, una nota que estén animados con esto. Poco a poco lo iremos
>>>> afinando :D
>>>>
>>>> *Respondiendo a los approach para analizar los datos:*
>>>>
>>>> Yo creo que inicialmente debemos trabajar en disponer los datos de modo
>>>> tal como dice @dani:
>>>>
>>>> - día del calendario (osea día por año,mes,día)
>>>> - día de la semana (agrupar todos los lunes, los martes y así) para
>>>> poder comparar los fines de semana con los demás días.
>>>> - horas, para poder ver los momentos del día más críticos
>>>> - recorrido de un usuario
>>>> - todos los datos alrededor de un punto
>>>>
>>>> Inicialmente será de archivos planos y filtramos al cargarlos y ojalá
>>>> después que sea una especie de api a la que se le hagan consultas.
>>>>
>>>> E independizar el análisis de la consulta de los datos. Yo creo que
>>>> cada registro cuenta así contenga valores inválidos para algunos campos.
>>>>
>>>> Lo que guardamos realmente son recorridos entonces están íntimamente
>>>> relacionados con el tiempo. El mapa de calor que hicimos no es la mejor
>>>> forma para representar esto.
>>>>
>>>> El análisis del proyecto en python y lo que propone elitte con la
>>>> normalización en el tiempo, supone análisis por área territorial. Una
>>>> especie de binning maps
>>>> <https://duckduckgo.com/?q=binning+maps&t=vivaldi&iax=1&ia=images> e
>>>> incluso creo que faltaría
>>>> normalizar por el área territorial ¿de qué tamaño debería ser esta área?
>>>>
>>>> @Eliette, cuándo decís medir el volumen de aire es medir el flujo de
>>>> aíre que entra cada vez? cuándo voy a menos velocidad entra menos que
>>>> cuándo voy más rápido?, el razonamiento va por ahí?
>>>> esta es la información que hay del sensor http://www.sharp-world.
>>>> com/products/device/lineup/data/pdf/datasheet/gp2y1010au_appl_e.pdf
>>>>
>>>> De pronto de alguna manera mecánica sea posible que el sensor "chupe"
>>>> el aíre de la muestra que va a leer y llene su cavidad con aproximadamente
>>>> el mismo volumen, no se.
>>>>
>>>> Otra posibilidad, es analizar los datos con modelos basados en agentes.
>>>> No se mucho del tema pero lo bueno es que vamos a tener datos para hacer
>>>> experimentos.
>>>> Hay unos frameworks en python o en netlogo y teoría que se puede
>>>> revisar. Los enlaces que pego son lo primero que encontré al buscar por la
>>>> palabra "agent based model"
>>>>
>>>> https://www.amazon.com/Agent-Based-Models-Quantitative-Appli
>>>> cations-Sciences
>>>> https://www.youtube.com/watch?v=bjjoHji8KUQ
>>>> http://mesa.readthedocs.io/en/latest/
>>>>
>>>> Esta semana le voy a trabajar a tener una especie de api donde enviar y
>>>> recuperar los datos.
>>>>
>>>> Saludos
>>>> -
>>>> b
>>>>
>>>>
>>>> 2017-04-08 22:59 GMT-05:00 brolin <brolin108 at gmail.com>:
>>>>
>>>>> Así se ven los datos como flechas giradas según el course
>>>>>
>>>>>
>>>>>
>>>>> 2017-04-08 22:56 GMT-05:00 brolin <brolin108 at gmail.com>:
>>>>>
>>>>>> *Respondiendo a cómo predecir la próxima posición*: El dato course
>>>>>> es el ángulo (0 < course < 360) respecto al norte. Y con la velocidad y el
>>>>>> tiempo del último punto se puede hacer una aproximación a la siguiente
>>>>>> posición: x = v*t
>>>>>>
>>>>>> Esto yo no lo haría en el microcontroladorm si no en el servidor
>>>>>> cuando se envían los datos.
>>>>>>
>>>>>> 2017-04-06 2:30 GMT-05:00 daniel gomez <danielgomezmarin at gmail.com>:
>>>>>>
>>>>>>>
>>>>>>>>
>>>>>>> Creo que la señal del gps es muy sensible y ante árboles o techos se
>>>>>>> pierde, yo si tomo datos de las otras variables pero no se pueden ver en el
>>>>>>> mapa porque los datos gps son inválidos. La rutina puede ser almacenar en
>>>>>>> un buffer la última coordenada válida y con el course y la velocidad
>>>>>>> calcular la próxima coordenada si el dato es inválido.
>>>>>>>
>>>>>>>
>>>>>>> Si. Esta me parece mucho mejor. Cómo es el course? La última del gps
>>>>>>> con mezclada con los acelerómetros o las dos últimas del gps?
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>> Pues yo creo que es una combinación de todas, debería ser posible:
>>>>>>>
>>>>>>> - Descargarlos a un celular o un compu conectándose a una red que
>>>>>>> cree el esp (si tiene wifi)
>>>>>>> - Si tiene conexión a internet que envíe los datos a un servidor
>>>>>>> - Que avise si la memoria se está llenando con un led parpadeando
>>>>>>> - Partir los datos por días u otra manera mejor a evaluar
>>>>>>> - Otras que se nos ocurran
>>>>>>>
>>>>>>>>
>>>>>>> Todo suena muy bien.
>>>>>>> Yo no se nada de conectividad con redes en cpp y poco de cpp :P.
>>>>>>> Pero puedo apoyarte por televideo si vas a hacer una sentada próximamente.
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>> _______________________________________________
>>>>>>> unloquer mailing list
>>>>>>> unloquer at lists.aktivix.org
>>>>>>> https://lists.aktivix.org/mailman/listinfo/unloquer
>>>>>>>
>>>>>>>
>>>>>>
>>>>>
>>>>
>>>> _______________________________________________
>>>> unloquer mailing list
>>>> unloquer at lists.aktivix.org
>>>> https://lists.aktivix.org/mailman/listinfo/unloquer
>>>>
>>>>
>>>
>>> _______________________________________________
>>> unloquer mailing list
>>> unloquer at lists.aktivix.org
>>> https://lists.aktivix.org/mailman/listinfo/unloquer
>>>
>>>
>>
>> _______________________________________________
>> unloquer mailing list
>> unloquer at lists.aktivix.org
>> https://lists.aktivix.org/mailman/listinfo/unloquer
>>
>>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.aktivix.org/pipermail/unloquer/attachments/20170413/d3b2f6fb/attachment-0001.html>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: map_course.png
Type: image/png
Size: 119604 bytes
Desc: not available
URL: <https://lists.aktivix.org/pipermail/unloquer/attachments/20170413/d3b2f6fb/attachment-0002.png>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: Screen Shot 2017-04-13 at 12.13.59.png
Type: image/png
Size: 63232 bytes
Desc: not available
URL: <https://lists.aktivix.org/pipermail/unloquer/attachments/20170413/d3b2f6fb/attachment-0003.png>
Más información sobre la lista de distribución unloquer