Branchless Programming: Difference between revisions
| (13 intermediate revisions by the same user not shown) | |||
| Line 43: | Line 43: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== | ==Booleans== | ||
Multiplications by booleans can be used instead of switch statements. | |||
Rather than doing | Rather than doing | ||
< | <syntaxhighlight lang="cpp"> | ||
if age > 10 | if (age > 10) { | ||
x = | x += 10; | ||
else | } else { | ||
x = | x -= 10; | ||
</ | } | ||
</syntaxhighlight> | |||
you can do | you can do | ||
< | <syntaxhighlight lang="cpp"> | ||
x = x + (20 * (age > 10) - 10); | |||
// or | // or | ||
y = age > 10 | y = age > 10; | ||
x = x + 10 * y - 10 * | x = x + 10 * y - 10 * !y; | ||
</ | </syntaxhighlight> | ||
These are micro optimizations but they | Similarly, instead of doing | ||
<syntaxhighlight lang="cpp"> | |||
if (age > 10) { | |||
x++; | |||
} | |||
</syntaxhighlight> | |||
you can just write <code>x += age>10;</code>. | |||
These are micro optimizations but they could be useful for speeding up GPU shaders in some cases. | |||
In high-level programming languages such as Python, these tricks can actually slow down your code<ref name="branchless-slower-python">https://stackoverflow.com/questions/72118249/why-are-the-branchless-and-built-in-functions-slower-in-python</ref>. | |||
==Resources== | ==Resources== | ||
* [https://francescocirillo.com/pages/anti-if-campaign Anti If Campaign] | * [https://francescocirillo.com/pages/anti-if-campaign Anti If Campaign] | ||
* [https://code.joejag.com/2016/anti-if-the-missing-patterns.html Anti-If: The missing patterns] | |||
==References== | |||
<references /> | |||