remove inv()

inv(x) -> 1-x

Change-Id: If64591f4f3ce15eb487222f052fc4bd1bac97977
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/280316
Commit-Queue: Mike Klein <mtklein@google.com>
Reviewed-by: Mike Reed <reed@google.com>
This commit is contained in:
Mike Klein 2020-03-30 08:08:13 -05:00 committed by Skia Commit-Bot
parent 46de36f993
commit 47737a1233
3 changed files with 24 additions and 25 deletions

View File

@ -1257,16 +1257,16 @@ namespace skvm {
fn(src.r, dst.r), fn(src.r, dst.r),
fn(src.g, dst.g), fn(src.g, dst.g),
fn(src.b, dst.b), fn(src.b, dst.b),
mad(dst.a, inv(src.a), src.a), // srcover for alpha mad(dst.a, 1-src.a, src.a), // srcover for alpha
}; };
}; };
auto non_sep = [&](auto R, auto G, auto B) { auto non_sep = [&](auto R, auto G, auto B) {
return Color{ return Color{
add(mma(src.r, inv(dst.a), dst.r, inv(src.a)), R), add(mma(src.r, 1-dst.a, dst.r, 1-src.a), R),
add(mma(src.g, inv(dst.a), dst.g, inv(src.a)), G), add(mma(src.g, 1-dst.a, dst.g, 1-src.a), G),
add(mma(src.b, inv(dst.a), dst.b, inv(src.a)), B), add(mma(src.b, 1-dst.a, dst.b, 1-src.a), B),
mad(dst.a, inv(src.a), src.a), // srcover mad(dst.a,1-src.a, src.a), // srcover
}; };
}; };
@ -1281,7 +1281,7 @@ namespace skvm {
case SkBlendMode::kDstOver: std::swap(src, dst); // fall-through case SkBlendMode::kDstOver: std::swap(src, dst); // fall-through
case SkBlendMode::kSrcOver: case SkBlendMode::kSrcOver:
return apply_rgba([&](auto s, auto d) { return apply_rgba([&](auto s, auto d) {
return mad(d, inv(src.a), s); return mad(d,1-src.a, s);
}); });
case SkBlendMode::kDstIn: std::swap(src, dst); // fall-through case SkBlendMode::kDstIn: std::swap(src, dst); // fall-through
@ -1293,18 +1293,18 @@ namespace skvm {
case SkBlendMode::kDstOut: std::swap(src, dst); // fall-through case SkBlendMode::kDstOut: std::swap(src, dst); // fall-through
case SkBlendMode::kSrcOut: case SkBlendMode::kSrcOut:
return apply_rgba([&](auto s, auto d) { return apply_rgba([&](auto s, auto d) {
return mul(s, inv(dst.a)); return mul(s, 1-dst.a);
}); });
case SkBlendMode::kDstATop: std::swap(src, dst); // fall-through case SkBlendMode::kDstATop: std::swap(src, dst); // fall-through
case SkBlendMode::kSrcATop: case SkBlendMode::kSrcATop:
return apply_rgba([&](auto s, auto d) { return apply_rgba([&](auto s, auto d) {
return mma(s, dst.a, d, inv(src.a)); return mma(s, dst.a, d, 1-src.a);
}); });
case SkBlendMode::kXor: case SkBlendMode::kXor:
return apply_rgba([&](auto s, auto d) { return apply_rgba([&](auto s, auto d) {
return mma(s, inv(dst.a), d, inv(src.a)); return mma(s, 1-dst.a, d, 1-src.a);
}); });
case SkBlendMode::kPlus: case SkBlendMode::kPlus:
@ -1352,9 +1352,9 @@ namespace skvm {
// TODO: divide and check for non-finite result instead of checking for s == 0. // TODO: divide and check for non-finite result instead of checking for s == 0.
auto mn = min(dst.a, auto mn = min(dst.a,
div(mul(sub(dst.a, d), src.a), s)), div(mul(sub(dst.a, d), src.a), s)),
burn = mad(src.a, sub(dst.a, mn), mma(s, inv(dst.a), d, inv(src.a))); burn = mad(src.a, sub(dst.a, mn), mma(s, 1-dst.a, d, 1-src.a));
return select(eq(d, dst.a), mad(s, inv(dst.a), d), return select(eq(d, dst.a), mad(s, 1-dst.a, d),
select(eq(s, 0.0f), mul(d, inv(src.a)) select(eq(s, 0.0f), mul(d, 1-src.a)
, burn)); , burn));
}); });
@ -1363,15 +1363,15 @@ namespace skvm {
// TODO: divide and check for non-finite result instead of checking for s == sa. // TODO: divide and check for non-finite result instead of checking for s == sa.
auto dodge = mad(src.a, min(dst.a, auto dodge = mad(src.a, min(dst.a,
div(mul(d, src.a), sub(src.a, s))), div(mul(d, src.a), sub(src.a, s))),
mma(s, inv(dst.a), d, inv(src.a))); mma(s, 1-dst.a, d, 1-src.a));
return select(eq(d, 0.0f), mul(s, inv(dst.a)), return select(eq(d, 0.0f), mul(s, 1-dst.a),
select(eq(s, src.a), mad(d, inv(src.a), s) select(eq(s, src.a), mad(d, 1-src.a, s)
, dodge)); , dodge));
}); });
case SkBlendMode::kHardLight: case SkBlendMode::kHardLight:
return apply_rgb_srcover_a([&](auto s, auto d) { return apply_rgb_srcover_a([&](auto s, auto d) {
return add(mma(s, inv(dst.a), d, inv(src.a)), return add(mma(s, 1-dst.a, d, 1-src.a),
select(lte(two(s), src.a), select(lte(two(s), src.a),
two(mul(s, d)), two(mul(s, d)),
sub(mul(src.a, dst.a), two(mul(sub(dst.a, d), sub(src.a, s)))))); sub(mul(src.a, dst.a), two(mul(sub(dst.a, d), sub(src.a, s))))));
@ -1379,7 +1379,7 @@ namespace skvm {
case SkBlendMode::kOverlay: case SkBlendMode::kOverlay:
return apply_rgb_srcover_a([&](auto s, auto d) { return apply_rgb_srcover_a([&](auto s, auto d) {
return add(mma(s, inv(dst.a), d, inv(src.a)), return add(mma(s, 1-dst.a, d, 1-src.a),
select(lte(two(d), dst.a), select(lte(two(d), dst.a),
two(mul(s, d)), two(mul(s, d)),
sub(mul(src.a, dst.a), two(mul(sub(dst.a, d), sub(src.a, s)))))); sub(mul(src.a, dst.a), two(mul(sub(dst.a, d), sub(src.a, s))))));
@ -1387,7 +1387,7 @@ namespace skvm {
case SkBlendMode::kMultiply: case SkBlendMode::kMultiply:
return apply_rgba([&](auto s, auto d) { return apply_rgba([&](auto s, auto d) {
return add(mma(s, inv(dst.a), d, inv(src.a)), mul(s, d)); return add(mma(s, 1-dst.a, d, 1-src.a), mul(s, d));
}); });
case SkBlendMode::kSoftLight: case SkBlendMode::kSoftLight:
@ -1402,7 +1402,7 @@ namespace skvm {
// 3. light src, light dst? // 3. light src, light dst?
// Used in case 1 // Used in case 1
auto darkSrc = mul(d, mad(sub(s2, src.a), inv(m), src.a)), auto darkSrc = mul(d, mad(sub(s2, src.a), 1-m, src.a)),
// Used in case 2 // Used in case 2
darkDst = mad(mad(m4, m4, m4), sub(m, 1.0f), mul(7.0f, m)), darkDst = mad(mad(m4, m4, m4), sub(m, 1.0f), mul(7.0f, m)),
// Used in case 3. // Used in case 3.
@ -1411,9 +1411,9 @@ namespace skvm {
liteSrc = mad(mul(dst.a, sub(s2, src.a)), liteSrc = mad(mul(dst.a, sub(s2, src.a)),
select(lte(two(two(d)), dst.a), darkDst, liteDst), select(lte(two(two(d)), dst.a), darkDst, liteDst),
mul(d, src.a)); mul(d, src.a));
return mad(s, inv(dst.a), mad(d, return mad(s, 1-dst.a, mad(d,
inv(src.a), 1-src.a,
select(lte(s2, src.a), darkSrc, liteSrc))); select(lte(s2, src.a), darkSrc, liteSrc)));
}); });

View File

@ -504,7 +504,6 @@ namespace skvm {
F32 mad(F32 x, F32 y, F32 z) { return add(mul(x,y), z); } F32 mad(F32 x, F32 y, F32 z) { return add(mul(x,y), z); }
F32 mad(F32a x, F32a y, F32a z) { return mad(_(x), _(y), _(z)); } F32 mad(F32a x, F32a y, F32a z) { return mad(_(x), _(y), _(z)); }
F32 inv(F32 x) { return sub(1.0f, x); }
F32 negate(F32 x) { return sub(0.0f, x); } F32 negate(F32 x) { return sub(0.0f, x); }
F32 sqrt(F32); F32 sqrt(F32);

View File

@ -154,10 +154,10 @@ skvm::Color SkHighContrast_Filter::onProgram(skvm::Builder* p, skvm::Color c, Sk
} }
if (fConfig.fInvertStyle == InvertStyle::kInvertBrightness) { if (fConfig.fInvertStyle == InvertStyle::kInvertBrightness) {
c = {p->inv(c.r), p->inv(c.g), p->inv(c.b), c.a}; c = {1-c.r, 1-c.g, 1-c.b, c.a};
} else if (fConfig.fInvertStyle == InvertStyle::kInvertLightness) { } else if (fConfig.fInvertStyle == InvertStyle::kInvertLightness) {
auto [h, s, l, a] = p->to_hsla(c); auto [h, s, l, a] = p->to_hsla(c);
c = p->to_rgba({h, s, p->inv(l), a}); c = p->to_rgba({h, s, 1-l, a});
} }
if (fConfig.fContrast != 0.0) { if (fConfig.fContrast != 0.0) {