Jump to content
Main menu
Main menu
move to sidebar
hide
Navigation
Main page
Recent changes
Random page
Help about MediaWiki
Special pages
Niidae Wiki
Search
Search
Appearance
Create account
Log in
Personal tools
Create account
Log in
Pages for logged out editors
learn more
Contributions
Talk
Editing
Constant folding
(section)
Page
Discussion
English
Read
Edit
View history
Tools
Tools
move to sidebar
hide
Actions
Read
Edit
View history
General
What links here
Related changes
Page information
Appearance
move to sidebar
hide
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
== Constant propagation == Constant propagation is the process of substituting the values of known constants in expressions at compile time. Such constants include those defined above, as well as [[intrinsic function]]s applied to constant values. Consider the following pseudocode: <syntaxhighlight lang="c"> int x = 14; int y = 7 - x / 2; return y * (28 / x + 2); </syntaxhighlight> Propagating x yields: <syntaxhighlight lang="c"> int x = 14; int y = 7 - 14 / 2; return y * (28 / 14 + 2); </syntaxhighlight> Continuing to propagate yields the following (which would likely be further optimized by [[dead-code elimination]] of both x and y.) <syntaxhighlight lang="c"> int x = 14; int y = 0; return 0; </syntaxhighlight> Constant propagation is implemented in compilers using [[reaching definition]] analysis results. If all a variable's reaching definitions are the same assignment - which assigns a same constant to the variable - then the variable will always have the same value, and can be replaced with the constant. Constant propagation can also cause conditional branches to simplify to one or more unconditional statements, if the conditional expression can be evaluated to true or false at compile time to determine the only possible outcome.
Summary:
Please note that all contributions to Niidae Wiki may be edited, altered, or removed by other contributors. If you do not want your writing to be edited mercilessly, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource (see
Encyclopedia:Copyrights
for details).
Do not submit copyrighted work without permission!
Cancel
Editing help
(opens in new window)
Search
Search
Editing
Constant folding
(section)
Add topic