Compartilhar via


m3x4 - ps

Multiplica um vetor de 3 componentes por uma matriz 3x4.

Sintaxe

m3x4 dst, src0, src1

 

onde

  • dst é o registro de destino. O resultado é um vetor de 4 componentes.
  • src0 é um registro de origem que representa um vetor de 3 componentes.
  • src1 é um registro de origem que representa uma matriz 3x4, que corresponde ao primeiro de quatro registros consecutivos.

Comentários

Versões do sombreador de pixel 1_1 1_2 1_3 1_4 2_0 2_x 2_sw 3_0 3_sw
m3x4 x x x x x

 

A máscara xyzw (padrão) é necessária para o registro de destino. Modificadores de negação e swizzle são permitidos para src0, mas não para src1.

O snippet de código a seguir mostra as operações executadas.

 
dest.x = (src0.x*src1.x) + (src0.y*src1.y) + (src0.z*src1.z);
dest.y = (src0.x*src2.x) + (src0.y*src2.y) + (src0.z*src2.z);
dest.z = (src0.x*src3.x) + (src0.y*src3.y) + (src0.z*src3.z);
dest.w = (src0.x*src4.x) + (src0.y*src4.y) + (src0.z*src4.z);

O vetor de entrada está no registro src0. A matriz de entrada 3x4 está no registro src1 e os dois próximos registros superiores, conforme mostrado na expansão abaixo.

Essa operação é comumente usada para transformar um vetor de posição por uma matriz que tem um efeito projetivo, mas não aplica nenhuma tradução. Esta instrução é implementada como um par de produtos de ponto, conforme mostrado aqui.

m3x4   r0.xyzw, r1, c0   will be expanded to: 

dp3 r0.x, r1, c0
dp3 r0.y, r1, c1
dp3 r0.z, r1, c2
dp3 r0.w, r1, c3

Instruções de sombreador de pixel