Ir al contenido principal

Ultima entrega - Transformada "Haar"

Que tal para esta ultima entrega se nos encargo hacer un python que comprimiera una imagen y se nos dio como base la transformada de Wavelet.

El proceso a seguir para el desarrollo de este programa es el siguiente:

Diagrama de flujo.


Como se muestra en la imagen anterior, el algoritmo actúa en sobre un imagen(no importa el tipo) y mediante una serie de procesos obtiene la imagen comprimida.

Introducción

La comprensión consiste en sustituir una cadena de datos por otra mas corta cuando se guarda un archivo. Ciertos metodos son reversibles("lossless data compression"), porque permite la reconstrucción exacte de la original. Pero con otros("lossy data compression""), la información original solo se recupera aproximadamente, ya que se descarta una parte de los datos.

Pero ambos metodos intentan cumplir objetivos:

  • El código de compresión debe ser lo mas compacto posible que el original.
  • Eliminar toda o casi toda la redundancia existente en la imagen original. 

Foto tomada de:
http://tesis.bnct.ipn.mx/dspace/bitstream/123456789/5745/1/ALGORITMODECOMPR.pdf

Comparación entre los diferentes tipos de compresión.



Transformada de Haar

Propiedades

  • Lineal.
  • Real.
  • Muy rápida (de orden O(N)).


Se basa en una clase de matrices que cumplen

  • Son ortogonales (traspuesta = inversa).
  • Sus valores son 0 ó potencias de dos.

Distribución de pixeles


Linealidad 
  • Se basa en sumas, restas y divisiones
  • Supongamos 2 números a y b vecinos.
  • Transformada que sustituye a y b por su media(m) y su diferencia(d):

m = (a + b) / 2 
d = b - a


Idea

Si a y b estan cercanos almacenar su diferencia es mas eficiente. 

Algoritmo






Todas estas transformaciones sucesivas aplicadas a un vector se pueden ver de forma matricial:








Codificación 


Pruebas

*Todas la imagenes que se toman deben tener un ancho de potencia de 2, esto por la dimension de la matriz que usa los wavelet(por lo general es de 8*8).


Imagen de 128 * 128 pixeles





Detalles de los umbrales y su calidad reflejada en las imagenes.

Obviamente el resultado se ve aceptable aunque no es lo mejor; la calidad depende mucho del valor de umbral mientras mas pequeño sea la calidad de la imagen de conserva un poco mas pero su compresión no es del todo buena.

En la siguiente imagen su toma la imagen original, un imagen con umbral de 20 y la ultima con umbral de 300.

Observen como cambia drásticamente la calidad dependiendo de la memoria que ocupa en disco.




Imagen de 1024 * 1024 pixeles


Imagen original



Imagen con un umbral de 100



Propiedades de las imagenes



Referencias

http://compresiondeimagenes.wikispaces.com/9.+LA+APLICACI%C3%93N+DE+LA+TRANSFORMADA+DE+HAAR+WAVELET+A+IM%C3%81GENES+DE+TAMA%C3%91O+COMPLETO

http://www.redusers.com/noticias/wp-content/uploads/2011/06/paper4.pdf

presentacion

Comentarios

  1. En la evaluación hubiera sido bueno incluir tiempos de ejecución por imagen (no solamente todo el bulto). Tu método de compresión no es muy original, pero por lo menos usas matemáticas no triviales en ello. Van 6 por el programa y 7 por el reporte.

    ResponderEliminar

Publicar un comentario

Entradas populares de este blog

Pequeño Juego con LEDS y Dip Switch

Siguiendo con los mini-proyectos, lo que quería hacer originalmente era un tipo "candado" con push-button y LEDs, el objetivo seria, meter la combinacion de botones correcta y los LEDS encendería por un motivo practico, en forma de serpiente. El objetivo no cambio, pero por falta de "material" lo hice con un dip switch de X entradas(depende de que tan grande quieras la combinación). CONOCIMIENTOS(max. 7 estrellas): Electronica:     ★ ★ Programación: ★ ★ Juego de Combinación + LEDs El programa es un poco mas complicado que el mini-proyecto pasado , pero aun asi es basico. Guardamos las salidas de los LEDs en un arreglo, despues con los valores recibidos y comparados de los dip switch jugamos con los LEDś. Hardware Requerido (1) Arduino Uno (6) LED (8) Resistencias 330 Ω (1) Dip Switch Circuito Usamos las salidas del ARduino 2-7 para los LEDS Usamos la salida A5, A4 para el dip switch Para hacer prender los LEDS tienes que encontrar la

Tarea #5 - Codigo Hamming - Python

Codigo hamming Liga al repo Teoria segun wikipedia Antes de los códigos Hamming se utilizaron ciertos códigos detectores de error, como lo fueron el código linteing, pero ninguno llegó a ser tan eficaz como los de Hamming. A continuación se describen algunos de estos códigos. Paridad   La   paridad   consiste en añadir un bit, denominado   bit de paridad , que indique si el número de los bits de valor 1 en los datos precedentes es par o impar. Si un solo bit cambiara por error en la transmisión, el mensaje cambiará de paridad y el error se puede detectar (nótese que el bit donde se produzca el error puede ser el mismo bit de paridad). La convención más común es que un valor de paridad   1   indica que hay un número impar de unos en los datos, y un valor de paridad de   0   indica que hay un número par de unos en los datos. info. completa y un vídeo que me ayudo mucho para esta tarea: (TIENEN QUE VERLO - OBLIGATORIO) http://www.youtube.com/watch?v=xiDPFm9PeLU Impleme

Potenciometro + pushboton + led

Bueno, estos días he estado practicando con los ejemplos de la pagina de Arduino , algunos que me llamaron la atención los voy a compartir, por supuesto con modificaciones. Nivel de conocimientos: Electronica:        ★   Programació n :    ★    Potenciometro + push-boton = LEDintensidad El mini-proyecto es controlar la intensidad de un LED mediante un potenciometro el cual combinado con push-botton para prenderlo o apagarlo. Hardware Requerido (1) Arduino UNO (1) Potenciometro (1) Push-boton (1) LED (1) Resistencia 330 Ω Circuito Conectamos el LED al PIN 9 del Arduino Conectamos el PUSH_BOTON al PIN ANOLOGICO 0 (A0) Conectamos el POTENCIOMETRO al PIN ANOLOGICO 1 (A1) El funcionamiento del circuito es basico, mientras tengas pulsado el Push-Boton el LED se mantendrá encendido y con el pontenciometro controlas la intensidad del LED. Código Video