El raytracing es una técnica para obtener imágenes 3D generadas por ordenador. No consiste en retoque fotográfico, genera una imagen 3D desde cero. Raytracing es una palabra compuesta del arameo errr esto digo inglés, sus dos partes describen como funciona esta técnica. Para generar una escena 3D se pueden tomar varias aproximaciones dependiendo de la técnica que se usa, en este artículo veremos el raytracing y como hacer un motor de render que no será en tiempo real. El enfoque que pretendo tomar en este artículo es partir desde cero e ir incrementando el nivel de dificultad (como un juego) pero claro unos conocimientos mínimos de matemáticas, programación en C++ son imprescindibles para llegar al final. Lo que me ha movido ha escribir esto es la aparición de películas como Shrek o Final Fantasy, las dos creadas usando esta técnica de render llevada a la casi-perfección. Creo que cuando terminéis de leer esto podréis evaluar mejor el trabajo que hay detrás de una película de este tipo. También entenderéis mejor lo que hace una tarjeta aceleradora 3D ya que varios de los efectos del motor de render los hace una aceleradora por hardware en tiempo real.
El principio El mundo que nos rodea está compuesto de objetos sólidos, líquidos, gases y fuentes de luz (de varios tipos, unas que emiten luz en todas direcciones y otras solo en alguna). El raytracing modela el comportamiento de luz y su interacción con el mundo. Debido a la complejidad de líquidos y gases limitaremos nuestro campo de acción a los sólidos (opacos y transparentes) y a las fuentes de luz que emiten en todas direcciones. Lo primero que debemos imaginar es que tenemos un mundo o escena (consideraremos al mundo como una descripción geométrica limitada a unos cuantos objetos) y un observador o cámara (del que también tendremos otra descripción). Raytracing intenta modelar cómo vería el mundo el observador. Una forma de hacer esto sería seguir cada rayo de luz que emite cada fuente de luz y ver si va a parar al ojo del observador. Esto se podría hacer ya que el comportamiento de la luz es conocido pero computacionalmente es imposible ya que hay muchos rayos que el observador no vería o simplemente no interactuarían con el mundo. Así que lo que se hace es lo contrario, lanzar rayos desde el observador hacia el mundo y llegado un cierto momento calcular la luz que influye en ese rayo. En el caso de una película el observador sería la cámara y la escena el mundo. Otro punto a destacar es que tipo de cámara (observador) que usaremos, perspectiva o paralela. La verdad es que son distintas y trabajan de formas diferentes pero el resultado es muy similar, las veremos en detalle más adelante. Para empezar a realizar un motor de render lo primero es saber hasta donde queremos llegar y hacerlo progresivamente. Empezaremos con los objetos sólidos y modelaremos varios tipos, empezando por el objeto más sencillo, la esfera. Luego podremos ir añadiendo otros tipos de objetos: polígonos, cilindros, conos, curvas de Bezier, Nurbs... Si con esto no tienes suficiente se puede optimizar mucho el programa de raytracing llevándolo a entornos paralelos, programando por zonas mediante árboles, añadiendo texturas, efectos ufffff y muchas cosas más, si lo consigues puedes montar una empresa... Yo sinceramente lo hice en plan casero y programé las esferas, los polígonos y las texturas. |