From b0f71e08f44a163ea5654f3b7cd170cfcc6f5b1b Mon Sep 17 00:00:00 2001 From: fp64 <106717720+fp64@users.noreply.github.com> Date: Mon, 3 Jul 2023 10:59:09 -0400 Subject: [PATCH] Simplify projective texcoord calculation As mentioned in https://github.com/hrydgard/ppsspp/issues/17613#issuecomment-1613583152 . --- GPU/Software/Rasterizer.cpp | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/GPU/Software/Rasterizer.cpp b/GPU/Software/Rasterizer.cpp index 73293da0f40c..b4f924e19af1 100644 --- a/GPU/Software/Rasterizer.cpp +++ b/GPU/Software/Rasterizer.cpp @@ -543,9 +543,7 @@ static inline void GetTextureCoordinatesProj(const VertexData& v0, const VertexD float wq0 = p * q0; float wq1 = (1.0f - p) * q1; - float q_recip = 1.0f / (wq0 + wq1); - float q = (v0.texturecoords.q() * wq0 + v1.texturecoords.q() * wq1) * q_recip; - q_recip *= 1.0f / q; + float q_recip = 1.0f / (v0.texturecoords.q() * wq0 + v1.texturecoords.q() * wq1); s = (v0.texturecoords.s() * wq0 + v1.texturecoords.s() * wq1) * q_recip; t = (v0.texturecoords.t() * wq0 + v1.texturecoords.t() * wq1) * q_recip; @@ -574,9 +572,9 @@ static inline void GetTextureCoordinatesProj(const VertexData &v0, const VertexD Vec4 wq1 = w1.Cast() * q1; Vec4 wq2 = w2.Cast() * q2; - Vec4 q_recip = (wq0 + wq1 + wq2).Reciprocal(); - Vec4 q = Interpolate(v0.texturecoords.q(), v1.texturecoords.q(), v2.texturecoords.q(), wq0, wq1, wq2, q_recip); - q_recip = q_recip * q.Reciprocal(); + // Here, Interpolate() is a bit suboptimal, since + // there's no need to multiply by 1.0f. + Vec4 q_recip = Interpolate(v0.texturecoords.q(), v1.texturecoords.q(), v2.texturecoords.q(), wq0, wq1, wq2, Vec4::AssignToAll(1.0f)).Reciprocal(); s = Interpolate(v0.texturecoords.s(), v1.texturecoords.s(), v2.texturecoords.s(), wq0, wq1, wq2, q_recip); t = Interpolate(v0.texturecoords.t(), v1.texturecoords.t(), v2.texturecoords.t(), wq0, wq1, wq2, q_recip);