Logo
Pattern

Discover published sets by community

Explore tens of thousands of sets crafted by our community.

Compiler Optimization Techniques

20

Flashcards

0/20

Still learning
StarStarStarStar

Inline Expansion

StarStarStarStar

Inline expansion is similar to function inlining; it substitutes function calls with the actual code of the function to eliminate call and return overhead.

StarStarStarStar

Inline Caching

StarStarStarStar

Inline caching optimizes method calls by caching information about where to find object properties or method implementations, reducing the cost of subsequent lookups.

StarStarStarStar

Loop Fusion

StarStarStarStar

Loop fusion combines adjacent loops that iterate over the same range into a single loop, reducing loop overhead and improving cache performance.

StarStarStarStar

Function Inlining

StarStarStarStar

Function inlining substitutes a function call with the actual body of the function, reducing function call overhead but potentially increasing code size.

StarStarStarStar

Control Flow Graph Reduction

StarStarStarStar

Control flow graph (CFG) reduction simplifies the control flow graph of a program, combining or eliminating nodes and edges to reduce the complexity of the program's control flow.

StarStarStarStar

Common Subexpression Elimination

StarStarStarStar

Common subexpression elimination identifies and reuses previously computed expressions to avoid redundant calculations, saving time and resources.

StarStarStarStar

Loop Fission

StarStarStarStar

Loop fission divides a loop into multiple separate loops, each handling part of the loop's body, which can improve cache performance and parallelism.

StarStarStarStar

Loop Invariant Code Motion

StarStarStarStar

Loop invariant code motion moves code that computes the same result in every loop iteration outside the loop, reducing unnecessary repetitive computations.

StarStarStarStar

Induction Variable Simplification

StarStarStarStar

Induction variable simplification rewrites loop induction variables in a simpler form, which can lead to more efficient code by removing needless calculations.

StarStarStarStar

Tail Call Optimization

StarStarStarStar

Tail call optimization replaces certain function calls with a goto statement, saving stack space and avoiding the overhead of additional call and return instructions.

StarStarStarStar

Predicate Elimination

StarStarStarStar

Predicate elimination removes unnecessary conditional checks by proving that predicates are always true or false, streamlining control flow and avoiding unnecessary branching.

StarStarStarStar

Constant Folding

StarStarStarStar

Constant folding computes constant expressions at compile time rather than at runtime, reducing the number of instructions executed.

StarStarStarStar

Partial Redundancy Elimination

StarStarStarStar

Partial redundancy elimination removes expressions that are redundant on some but not all paths through a program, optimizing without losing program correctness.

StarStarStarStar

Peephole Optimization

StarStarStarStar

Peephole optimization performs local optimizations on a small part of the program, such as replacing inefficient sequences of instructions.

StarStarStarStar

Loop Unrolling

StarStarStarStar

Loop unrolling increases the body of a loop in order to decrease the number of iterations, potentially reducing loop overhead and enabling further optimizations.

StarStarStarStar

Dead Code Elimination

StarStarStarStar

Dead code elimination removes code that does not affect the program output, thus reducing code size and improving performance.

StarStarStarStar

Code Motion

StarStarStarStar

Code motion repositions code to a more efficient location, typically moving invariants out of loops to reduce the number of calculations.

StarStarStarStar

Strength Reduction

StarStarStarStar

Strength reduction replaces expensive operations with equivalent but less costly ones, often used in optimizing loop performance.

StarStarStarStar

Constant Propagation

StarStarStarStar

Constant propagation substitutes the values of known constants in expressions, simplifying the program and potentially enabling other optimizations.

StarStarStarStar

Register Allocation

StarStarStarStar

Register allocation assigns variables to machine registers to reduce memory access and improve execution speed by optimizing the usage of limited CPU registers.

Know
0
Still learning
Click to flip
Know
0
Logo

© Hypatia.Tech. 2024 All rights reserved.