Respuestas:
Los archivos JPG y PNG casi siempre serán más pequeños en el disco que en la memoria; necesitan descomprimirse sobre la marcha para adquirir datos RGB sin procesar, lo que requiere más potencia de procesamiento para la carga y más RAM después. Muchos motores modernos optan por almacenar el mismo formato en el disco que en la memoria, lo que lleva a archivos que tienen el mismo tamaño que los requisitos de memoria de la textura (pero también más grandes que PNG o JPG). RGB / RGBA y S3TC / DXTn / BCn son los formatos más utilizados, ya que se leen directamente en la memoria sin ningún procesamiento (las texturas DXT están precomprimidas).
Entonces, estos son los tamaños para diferentes formatos de textura comunes:
Si usa una imagen con mipmaps , la textura requerirá 4/3 de memoria. Además, el ancho y la altura de la textura pueden redondearse internamente para ser una potencia de dos en el hardware antiguo o menos capaz, y en un hardware muy limitado, también forzado a ser un cuadrado.
Más información sobre DXT: es una compresión con pérdida; Esto significa que algunos datos de color se pierden al comprimir la textura. Esto tiene un impacto negativo en su textura, distorsionando los bordes afilados y creando "bloques" en los gradientes; pero los beneficios son mucho mejores que las desventajas (si tiene una textura que se ve terriblemente mal en DXT, simplemente manténgala sin comprimir; las otras compensarán la pérdida de tamaño). Además, dado que los píxeles están comprimidos por bloques de tamaño fijo, el ancho y la altura de la textura deben ser múltiplos de cuatro.
Obviamente: depende del formato.
Tomemos una textura cuadrada de 256 por 256 píxeles. Si está sin comprimir de 32 bits con un canal alfa ( Color
en XNA), entonces toma 256 KB ( 256*256*4
bytes).
Los formatos de 16 bits (p. Ej . :)Bgr565
obviamente tendrán la mitad del tamaño: 128 KB .
Luego llegas a los formatos comprimidos. En XNA tienes DXT1, DXT3 y DXT5 (también conocido como Compresión S3 ). Este es un formato de compresión con pérdida. También es un formato basado en bloques, lo que significa que puede tomar muestras de él (porque sabe en qué bloque está un píxel). También es más rápido porque usa menos ancho de banda.
La relación de compresión de DXT1 es 8: 1 y para DXT3 y DXT5 es 4: 1.
Entonces, una imagen DXT1 de 256x256 es 32KB . Y DXT3 o DXT5 es de 64 KB .
Y luego está el mipmapping . Si esto está habilitado, esto crea una serie de imágenes en la memoria gráfica cada mitad del tamaño de la anterior. Entonces, para nuestra imagen de 256x256: 128x128, 64x64, 32x32, 16x16, 8x8, 4x4, 2x2, 1x1. Una textura con mipmapping es aproximadamente el 133% del tamaño del original.
La mayoría de las GPU solo pueden leer un formato de compresión muy específico. p.ej. BC *, DXT *, no formatos como png. Entonces, sí, es cierto en su mayor parte que un .png ocupará más espacio en la memoria de video que en el disco.
Las texturas se pueden almacenar comprimidas o sin comprimir tanto en la memoria de video como en la memoria del sistema.
Para texturas sin comprimir, la regla general es que ocupará la misma cantidad de espacio en la memoria de video que en la forma sin comprimir de la memoria del sistema.
Para texturas comprimidas DXT1. la GPU almacena 8 bytes para cada mosaico 4x4 en su textura. Los datos sin comprimir (a 8 bits por canal RGB) normalmente serían 4x4x3 = 48 bytes, por lo que es una relación de compresión de 6: 1. Para las texturas comprimidas DXT3 / DXT5, la GPU almacena 16 bytes por cada mosaico 4x4 en su textura. Esa es una relación de compresión ligeramente menor de 3: 1.
Hay algunas advertencias con texturas sin comprimir y comprimidas:
La mayor parte de la memoria se asigna en páginas (cuyo tamaño varía entre las GPU) de un tamaño fijo. p.ej. 4KB y, a menudo, eso no está subasignado y compartido con otros datos de gpu. Es decir. Si su huella de textura es más pequeña que el tamaño de la página, la huella en la memoria de video a menudo seguirá siendo el tamaño de la página.
Algunos gpus tienen requisitos de alineación muy específicos. En el pasado, algunas GPU tenían el requisito de que las texturas tuvieran una potencia de 2 en tamaño. Esto a menudo se requería para admitir una representación borrosa (ver Morton Ordering: http://en.wikipedia.org/wiki/Z-order_(curve )) para mejorar la localidad de acceso al tomar muestras de la textura. Esto significaba que las texturas de tamaños impares se rellenarían para preservar estos requisitos (generalmente, el controlador maneja este relleno). Si bien el orden de morton no se usa necesariamente en gpus modernos, todavía puede haber hinchazón para respaldar los requisitos específicos de la gpu.
Pueden existir múltiples representaciones de su textura en la memoria en cualquier momento, especialmente si está usando bloqueos de descarte en ellas. Esto puede aumentar el uso de su memoria hasta que la gpu ya no use representaciones (que generalmente se encuentran unos pocos fotogramas detrás del procesamiento de la CPU)
Si habilita mipmapping, los mips adicionales consumirán en promedio alrededor de un tercio del nivel base de mip. YMMV basado en las advertencias anteriores.
AFAIK es el ancho * alto * BPP de las imágenes, independiente si es PNG, JPG o BMP. No sé cómo se distribuyen DDS u otros formatos comprimibles.
Mip-mapping aumentará la necesidad de memoria de video para.
Mi conocimiento en este tema puede estar un poco desactualizado. He abandonado el 3D hace un tiempo.