Aurélien Pierre

Lecturas de teoría del color

¿Qué recursos se pueden encontrar en línea y en bibliotecas para ayudar a entender algo de teoría del color ?

Preámbulo

¿Qué es la teoría del color?

La teoría del color tiene 2 aspectos:

  • uno científico, históricamente vinculado a la física de la luz, pero ahora relacionado más estrechamente con la psicología, tratando de vincular señales físicas con estímulos perceptuales,
  • uno artístico, estudiando la semántica del color (que son en su mayoría culturales) y cómo juegan en la creación de sombras creíbles en pinturas o ambiente melancólico en fotografías y películas.

Cabe destacar que el lado científico también ha sido estudiado por artistas (como Munsell ). El campo mezcla nociones de:

Concepciones erróneas comunes

Esta página aborda la mayoría de los errores y malentendidos sobre Ansel que se pueden encontrar en línea.

Necesito ser un experto / ingeniero para usar Ansel

Mis videos  y mis publicaciones suelen contener tanto la parte del “cómo hacer” como la del “por qué/cómo”. El “por qué/cómo” suele ser técnico o incluso teórico, y está ahí para justificar el “cómo hacer”. Hay varias razones por las que doy ambos :

Rewriting keyboard shortcuts (accelerators) from scratch

GUI Usability

In my defining post, Darktable: crashing into the wall in slow-motion, I presented the trainwreck that the new “Great MIDI turducken” was. The purpose of this turducken1 was to rewrite the keyboard shortcuts system to extend it for MIDI devices.

To this day, I’m still mad about this enterprise of mass-destruction, here is a recap of he the reasons:

  1. it replaced in 2021 a keyboard shortcuts system that was pretty good, feature-complete, well tested, stable and coded in less than 1500 lines (comments included),
  2. …to add support for MIDI devices and PlayStation gamepads (!?!)…
  3. …but in my 2022 Darktable survey, one year after this new feature, over 1251 users who participated:
    • 81% of users didn’t have a MIDI device and didn’t plan to get one,
    • 2% didn’t even know what a MIDI device was.
    • 8% of users had a MIDI device but didn’t use it with Darktable,
    • 6% were considering maybe getting a MIDI device in the future,
    • 2% of users had a MIDI device they actually used in Darktable,
  4. the code was absolutely terrible, in terms of:
    • code quality: unlegible if/switch-case statements nested on 4 levels, in the middle of 1000-lines functions (I posted example snippets in my article),
    • code volume:
      • 3546 lines of code for Darktable 4.0,
      • 4397 lines of code for Darktable 5.0,
      • the increase in volume is a direct consequence of trying to fix bugs in an architecture that can’t be fixed because its complexity promotes more complexity. All that stems from the design, but solving issues created by complexity with adding more complexity is not a solution.
    • code complexity:
      • cyclomatic complexity :
        • 1088 for Darktable 4.0,
        • 1245 for Darktable 5.0 (details ),
      • cognitive complexity :
        • 1885 for Darktable 4.0,
        • 2098 for Darktable 5.0 (details ).
      • it is by far the most complex feature of the software, even though it does not operate on images. As a comparison, the second most complex feature is the EXIF metadata decoding, which has a cognitive complexity of 1348.
  5. it doesn’t decode key modifiers by design, but only deals with hardware key-strokes, which means:
    • “1” input from the numeric pad is decoded Keypad End,
    • “1” input from a French AZERTY keyboard is decoded Shift+&, or Shift+" on BÉPO,
    • you therefore need to duplicate all your number-based shortcuts for each way of entering a number, and be prepared for the shortcut settings window to not contain any actual number in the key combinations.
  6. the user-end design is absolutely terrible, with way too many actions and emulations to configure (“effects”), that are not even fully documented 4 years later (what is “ctrl-toggle” ? “right-activate” ?), and the shortcut configuration uses a weird split-window that doesn’t make any sense,
  7. the implementation is also terrible: the feature is aware of all the software GUI, and the software GUI is aware of the shortcuts code. There is no modularity here, and changing anything in the shortcuts code may have unexpected and undesired effect anywhere in the software.2 Just see the dependency graph below,
  8. several “shortcuts” (or MIDI bindings) can be attached to the same action, which means every user interaction has to lookup the whole list of available actions, inducing very inefficient shortcut handling, GUI lags in some cases and “unknown key combination” false positives in peculiar cases.
image
Non-decoded number keys and weird window splitting between "action" and "shortcut".
image

The dependency graph of src/gui/accelerators.c (Great MIDI turducken) before the rewrite. Guess why we call it “spaghetti code "… This makes it clear that there is a double-sided dependency between the accels code and the rest of the GUI code. This is a nightmare to maintain.

Welcome Ansel GPT !

Anuncio

Después de finalmente conectar todo el sitio web y la documentación a un flujo de trabajo de traducción hermético (utilizando po4a sobre Hugo), que resulta utilizar el mismo conjunto de herramientas y lógica que la aplicación Ansel, se me ocurrió la idea de automatizar las traducciones vacías, primero a partir de los archivos de traducción del software, y luego a través de la API de ChatGPT, que hace un trabajo bastante justo al traducir la sintaxis de Markdown.

Escaneo de película

Película Negativo

Alain Oguse aprendió a imprimir fotografías con Claudine  y Jean-Pierre Sudre  a finales de los años 60, y pasó su carrera temprana en la fotografía comercial. Después de retirarse, comenzó a investigar cómo recuperar el grano fotográfico (haluro de plata) en escaneos digitales de negativos de película, encontrando la misma nitidez y calidad que tenía con ampliadoras de luz casi puntual en los años 70.

¡Bienvenido, documentación para desarrolladores!

Desarrollo

En diciembre de 2019, pedí que alguien se encargara de proporcionar paquetes AppImages  para Darktable. El beneficio obvio habría sido habilitar pruebas tempranas, antes del lanzamiento, de personas que no pueden construir el código fuente por sí mismas, con la esperanza de proporcionar comentarios tempranos y ayudar a depurar antes del lanzamiento. Esto nunca ha sido una prioridad, lo que significa que estaba bien tener una prisa antes y posterior al lanzamiento para corregir errores.

Balance(s) de blancos

Todos sabemos lo que es el “blanco”. Podemos imaginar una hoja de papel blanca. Sabemos que es blanca porque lo aprendimos. Pero si pones tu hoja de papel bajo el sol de verano, o un cielo nublado, o en casa con esas bombillas cálidas de la sala de estar, ese blanco cambiará de color. Podría perturbarte durante los primeros segundos, luego simplemente te olvidarás de ello: tu cerebro se adaptará. Pero, ¿a qué se adapta?

Solucionando problemas de color

Esto se aplicará tanto a Darktable upstream como a Ansel ya que comparten la mayoría de su pipeline de color. El siguiente procedimiento te ayudará a solucionar tus problemas de color, ya sea inconsistencia de apariencia entre exportación vs. vista previa, o entre pantalla vs. impresión, o entre 2 aplicaciones.

Configura tu escritorio adecuadamente

El problema inherente del color es que solo existe como una percepción, y esa percepción es altamente contextual y fluida. Si tomo cualquier parche de color y lo muestro sobre un fondo blanco, gris medio o negro, no parecerá el mismo a pesar de que un colorímetro confirmaría que es exactamente el mismo color. He construido una pequeña animación web para mostrar este efecto, mostrando cortes del espectro sRGB a tono constante, sobre la ligereza del fondo definida por el usuario: el libro de color sRGB .

Reparando la caché de la canalización y errores de hace 10 años

Desarrollo

Resumen de los episodios anteriores

  1. Between 2020 and 2022, Darktable underwent a mass-destruction enterprise, by a handful of guys with more freetime and benevolence than actual skills,
  2. In 2022, I started noticing an annoying lag  between GUI interactions with sliders controls and feedback/update of said sliders. For lack of feedback stating that the value change was recorded, users could change it again, thereby starting additionnal pipeline recomputes and effectively freezing their computer because stupid GUI never said “got you, wait for a bit now”.
  3. I discovered that pipeline recomputations orders were issued twice per click (once on “button pushed”, once on “button released” events), and once again for each mouse motion, but also that the GUI states were updated seemingly after pipe recompute.
  4. I fixed that by almost rewriting the custom GUI controls (Bauhaus lib). I thought that preventing reckless recompute orders was gonna solve the lag : it didn’t. Then, I discovered that requesting a new pipeline recompute before the previous ended waited for the previous to end, despite a shutdown mechanism implemented many years ago that should have worked.
  5. I fixed that by implementing a kill-switch mechanism on pipelines, following comments in the code from the 2010’s and internal utilities that may well have never worked. This did not always work because the kill order came often with a noticeable delay. Once again, the GUI lag was not fixed.

Reescritura de la herramienta de importación

Desarrollo Rediseño

Ansel hereda de Darktable su estructura de base de datos: los historiales de edición no destructiva se guardan por imagen en una base de datos SQLite, junto con metadatos y otros datos definidos por el usuario. Hacer que la base de datos reconozca nuevas imágenes se realiza a través de la “importación” de imágenes desde un disco o tarjeta de memoria. Ahí es donde entra en juego la herramienta de importación.

Léxico de color

mapa mental
  raíz((COLOR))
    modelo de apariencia de color
      espacio de color uniforme
        cromaticidad
          U, V
          a, b
        claridad
          L
        delta E
      transformación de adaptación cromática
        iluminante
          índice de reproducción de color
          temperatura de color
      iluminación ambiental
      claridad de fondo
    dimensiones
      Munsell
        matiz
        croma
        valor
      sistema de color natural
        negrura
        saturación
        matiz
      CIE
        claridad
        brillo
        saturación
        croma
        coloridad
        matiz
    medida
      colorimetría
        trístimulo
          sensor
            criterio de Luther-Ives
            metamerismo
            rango dinámico
            ruido
            mosaico
              Bayer
              XTrans
              artefactos de cremalleras
          espacios
            rgb(RGB)
              HSV
              HSL
            LMS
              Yrg
            XYZ
              Yxy
                Yuv
                  Ych
            CYM
              CYMK
            primarias
              células cono
              LED
                ITU BT. Rec 709
                ITU BT. Rec 2020
                DCI P3
              tintas
      espectrometría
        espectro de luz
          longitudes de onda
          energía
      fotometría
        luminancia
    corrección
      perfil
        matriz
        tabla de búsqueda
        función de transferencia
      corrección de color
        CDL ASC
        mezclador de canales
        curvas
      balance de blancos

Translated from English by : ChatGPT. In case of conflict, inconsistency or error, the English version shall prevail.

Implementación del interruptor de apagado en la canalización

Desarrollo

He pensado, durante mucho tiempo, que había algún mecanismo de interruptor de apagado en la canalización de píxeles. El caso de uso es el siguiente:

  1. estás cambiando un parámetro del módulo,
  2. las vistas previas (la central del cuarto oscuro y la miniatura en el panel izquierdo, también utilizada para el histograma y selectores de color) recomputan su canalización para tener en cuenta ese cambio,
  3. una de las vistas previas termina de renderizar antes que la otra, y el resultado es obviamente no lo que querías,
  4. cambias nuevamente el parámetro del módulo, sin esperar a que termine la recomputación.

En ese caso, quieres eliminar todas las canalizaciones activas porque su salida no se utilizará y comenzar a recomputar todo de inmediato con los nuevos parámetros. Excepto que Darktable no hace eso, deja que la canalización termine antes de reiniciarla, y al observar los comentarios en el código fuente, parece ser una regresión bastante reciente y no el comportamiento originalmente previsto.

Des-darctableando los controles de GUI

Desarrollo

Darktable tiene su propia biblioteca de widgets de GUI, para sliders y comboboxes (también conocidos como menús desplegables o cuadros de selección), llamada Bauhaus (en el código fuente, está en src/bauhaus/bauhaus.c). Aunque usan Gtk como backend, Bauhaus son objetos personalizados. Y como muchas cosas en Darktable, personalizado equivale a podrido.

En 2022, noté redibujados parásitos y retrasos , al usarlos, lo que lleva a una experiencia de usuario frustrante: el redibujado del widget parecía esperar a que se completaran las recomputaciones del pipeline, lo que significaba que los usuarios no estaban realmente seguros de que su cambio de valor se registrara, lo que podría llevarlos a intentarlo de nuevo, comenzando otro ciclo de recomputación costosa, y congelando efectivamente su computadora durante varios minutos muy frustrantes de recomputaciones de pipeline intermedias inútiles.

Cambios en el soporte de distribución para el paquete Linux AppImage

Anuncio

Rawspeed (la biblioteca que proporciona los decodificadores para archivos raw de cámaras) ha dejado de dar soporte a GCC < 12. Como resultado, ya no puedo construir el AppImage en Ubuntu 20.04 (utilizando ejecutores de Github), sino que tengo que construirlo en 22.04.

Esto significa que cualquier distribución de Linux que tenga libc más antiguo que 2.35 no podrá iniciar los nuevos AppImages a partir de hoy. Esto no debería afectar a la mayoría de los usuarios que ejecutan distribuciones actualizadas en 2021 o más recientemente. Ubuntu 20.04 y otras distribuciones LTS/old stable (Debian stable) pueden verse afectadas.

Impresión

El flujo de trabajo referido a la escena promete una edición independiente del medio de salida. Normalmente producirá una imagen codificada en espacio de color sRGB con 8 bits, es decir, valores de código entre 0 y 255. Para simplificar, consideraremos aquí solo el caso de 8 bits. Los conceptos son los mismos en 16 bits, solo que el rango de codificación va de 0 a 65535, lo cual es anecdótico.

Explicando el rediseño de grupos de módulos en Ansel

Diseño

Si vienes de Darktable, puedes estar acostumbrado a esto en el cuarto oscuro:

image

mientras que Ansel te ofrece esto:

image

Esto no es accidental, y es hora de explicar por qué, y por qué esto no se extenderá con opciones de personalización.

Nuevas opciones de compilación para Linux

Desarrollo

Descubrí accidentalmente que el script de compilación de Linux usaba una compilación “package”, lo que significa que las optimizaciones de CPU están limitadas a las genéricas para producir binarios portátiles que se pueden instalar en cualquier plataforma x86-64. Por “usar”, me refiero a que la compilación del paquete no estaba explícitamente deshabilitada, así que estaba habilitada por defecto.

De todos modos, ahora está deshabilitada por defecto, ya que los paquetes reales (.exe y .appimage) no se construyen a través de ese script, que está principalmente destinado a ayudar a los usuarios. Para volver al comportamiento anterior, necesitarías ejecutar:

Diario de desarrollo #2: presentando a Chantal

Desarrollo

2022 fue tan malo en términos de correos electrónicos no deseados y ruido que comencé el Secretario Virtual , un marco en Python para escribir filtros de correos electrónicos inteligentes cruzando información entre varias fuentes para adivinar qué son los correos electrónicos entrantes y si son importantes/urgentes o no. Cuando hablo de correos electrónicos no deseados, también me refiero a notificaciones de Github, menciones en pixls.us (gracias a Dios cerré mi cuenta en ese foro estúpido), YouTube y correos electrónicos directos de personas que esperan recibir ayuda en privado.

Edición Básica

Aquí está cómo comenzar con la edición en Ansel, pasando solo por los pasos más básicos que deberían servirle bien la mayor parte del tiempo.

El video se grabó en Darktable 3, pero los mismos módulos y principios se aplican a Ansel.


Translated from English by : ChatGPT. In case of conflict, inconsistency or error, the English version shall prevail.

Entonamiento monocromo

Película Monocromo

Este artículo demostrará cómo realizar el entonamiento monocromo en imágenes digitales en Ansel, para emular la interpretación del color de los cianotipos, platinotipos, sepia y desarrollos de entonación dividida.

Paso 0: preparación global

Ajuste la exposición global y el blanco y negro de escena fílmica, como en cualquier otra edición. Consulte pasos de edición básica. Esta es nuestra imagen base, por Glenn Butcher:

image

Diario de Desarrollo

Desarrollo

Han pasado aproximadamente 3 meses desde que rebauticé ‘R&Darktable’ (que nadie parecía entender bien), en ‘Ansel’, luego compré el nombre de dominio y creé el sitio web desde cero con Hugo (nunca había programado en Golang antes, pero es principalmente código de plantilla).

Luego pasé un total de 70 h haciendo que los paquetes de compilaciones nocturnas para Windows y Linux funcionaran para entrega continua, algo que Darktable nunca logró (“puedes construirlo tú mismo, no es difícil”), solo para ver al rastreador de errores explotar después del lanzamiento (nada mejor que encadenar el sprint de pre-lanzamiento con uno post-lanzamiento para reducir tu expectativa de vida).

Darktable: estrellándose contra la pared en cámara lenta

¿Qué sucede cuando una banda de fotógrafos aficionados, convertidos en desarrolladores aficionados, se une a un grupo de desarrolladores de backend que desarrollan bibliotecas para desarrolladores y deciden trabajar sin método ni estructura en un software de la industria para usuarios finales, cuya competencia principal (colorimetría y psicofísica) se encuentra entre una licenciatura en fotografía y una maestría en ciencias aplicadas, mientras prometen entregar 2 versiones cada año sin gestión de proyectos? Todo eso, por supuesto, en un proyecto donde los fundadores y la primera generación de desarrolladores se movieron y huyeron?

El flujo de trabajo referido por escena

Ciencia Del Color Pipelines

En este artículo, aprenderá qué es el flujo de trabajo referido por escena, cómo lo usa Ansel y por qué beneficia al procesamiento de imágenes digitales en general.

Introducción

El flujo de trabajo referido por escena es la columna vertebral de la tubería de imágenes de Ansel. Es una lógica de trabajo que proviene de la industria del cine, porque es la única manera de lograr una composición robusta y sin fisuras (también conocida como alpha blending) de gráficos en capas, de los cuales dependen en gran medida las películas para mezclar efectos especiales generados por computadora con imágenes de la vida real. Para los fotógrafos, es principalmente para escenas de alto rango dinámico (HDR) (sujeto a contraluz, puestas de sol, etc.) que demuestra ser útil.

Search

You can also ask Chantal, the AI search engine.