Mire estas fotografías de escenas naturales, con uno de los canales RGB extraídos de ellas:
Fuente (con rojo): https://en.wikipedia.org/wiki/File:Altja_j%C3%B5gi_Lahemaal.jpg
Fuente (con verde): https://commons.wikimedia.org/wiki/File:2007_mather-lake_hg.jpg
Fuente (con azul): https://commons.wikimedia.org/wiki/File:Fox_01.jpg
Incluso sin uno de los canales, probablemente pueda distinguir qué colores se supone que son ciertas cosas, o al menos tener una buena idea si la reconstrucción del canal faltante es precisa.
Por ejemplo, aquí está la primera imagen con un canal rojo agregado nuevamente que es solo ruido aleatorio:
Esta imagen claramente no es una reconstrucción precisa del canal rojo. Esto se debe a que las fotos de la naturaleza generalmente no usan todo el espectro RGB, sino solo un subconjunto de "colores de aspecto natural". Además, los tonos de rojo seguirán ciertos gradientes que se correlacionan con los demás.
Su tarea es construir un programa que tome una fotografía a la que se le haya quitado un canal e intente aproximar la imagen original lo más cerca posible reconstruyendo lo que cree que es el canal perdido.
Su programa se puntuará según cuán cerca coincida el canal faltante con el canal de la imagen original, contando el porcentaje de píxeles cuyos valores de ese canal están dentro de ± 15 (inclusive) del valor real en la imagen original (donde los valores rango de 0 a 255 como en un canal de color estándar de 8 bits).
Los casos de prueba en los que se puntuará su programa se pueden encontrar aquí (archivo zip de 9.04 MB, 6 imágenes). Actualmente solo contiene las tres imágenes de ejemplo anteriores y sus originales, pero agregaré algunas más más adelante para hacer el paquete completo una vez que las haya hecho.
Cada imagen se reduce y se recorta a 1024 x 768, por lo que tendrán el mismo peso en su puntaje. El programa que puede predecir la mayor cantidad de píxeles dentro de la tolerancia dada gana.