Era uma vez, limpar os buffers de cor e profundidade, na verdade, levava tempo. Fazer uma limpeza significava que a placa gráfica teria que percorrer todos os pixels do buffer de quadros e escrever um valor para ele.
Por esse motivo, os desenvolvedores de jogos descobriram que seria mais eficiente simplesmente assumir que cada pixel seria renderizado novamente. Eles desenvolveram muitas técnicas para fazer isso.
O buffer de cores é o mais fácil de ignorar. Menos fácil é o buffer de profundidade, porque seria poluído com dados antigos. Então, o que eles fizeram foi simples.
No quadro 0, eles renderizariam com um glDepthRange
(ou o equivalente D3D) de (0, 0,5) e usariam um glDepthFunc
de GL_LESS
(ou GL_LEQUAL
). Isso significa que o valor de profundidade mais distante que você obteria no buffer de profundidade é 0,5. Portanto, o maior valor no buffer de profundidade no final do quadro 0 é 0,5 (supondo que você tenha gravado em cada pixel).
No quadro 1, eles alterariam o alcance da profundidade para (1, 0,5). Observe que, nesse caso, o valor da profundidade próxima é maior que a profundidade distante. Mas eles também mudariam a função de profundidade para GL_GREATER
(ou GL_GEQUAL
), o que reverte o significado do teste de profundidade. Como o maior valor no buffer de profundidade é 0,5, tudo o que você escrever terá um valor maior que isso. Como o teste de profundidade foi revertido, isso efetivamente significa que tudo o que foi escrito no quadro 0 está agora mais distante do que qualquer coisa que possa ser escrita no quadro 1. No final do quadro 1, o menor valor no buffer de profundidade é agora 0,5.
E então eles repetem.
Em qualquer hardware fabricado desde 2003, isso não é mais uma otimização. De fato, é uma otimização negativa . Limpar o buffer de profundidade realmente torna o hardware mais rápido . Não mesmo.
Basicamente, o que acontece é que a limpeza de buffers não grava nada. Eles armazenam alguns bits nos caches da GPU que permitem ao sistema saber para que cor / profundidade foram limpos. Quando o sistema tenta gravar em uma linha de cache do buffer de quadros, não se preocupa em ler o que está lá, porque já sabe que é um campo em branco do valor de cor / profundidade clara. Se você tentar se misturar com o que está lá ou fazer um teste de profundidade, novamente, não há necessidade de ler: ele sabe qual valor misturar / testar com / contra.
Portanto, toda primeira leitura / modificação / gravação que você faz em cada linha de cache após uma limpeza é basicamente uma gravação. É grátis .
Além disso, ter um buffer de profundidade irregular pode funcionar contra o Hyper-Z / Hierarchial-Z / qualquer otimização de descarte de Z no hardware. Sim, sua cena funcionará contra essas opções à medida que você adicionar detalhes. Mas se o seu buffer de profundidade estiver irregular de renderizações anteriores, mesmo que esses objetos de segundo plano estejam em segundo plano, isso poderá afetar a eficiência das técnicas de descarte de Z. E isso não vai ajudar no desempenho.
Portanto, você nunca deve fazer essa técnica de reversão de profundidade nos jogos modernos.
Nota: O Jari faz um bom argumento em arquiteturas de renderização baseadas em blocos (como encontrado na maioria das plataformas móveis). Não limpar a profundidade também pode tornar as coisas desagradáveis.