1 / 18

Code Optimization Overview and Examples

Code Optimization Overview and Examples. Code Optimization. Why Reduce programmers’ burden Allow programmers to concentrate on high level concept Without worrying about performance issues Target Reduce execution time Reduce space Sometimes, these are tradeoffs Types

yorks
Download Presentation

Code Optimization Overview and Examples

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Code Optimization Overview and Examples

  2. Code Optimization • Why • Reduce programmers’ burden • Allow programmers to concentrate on high level concept • Without worrying about performance issues • Target • Reduce execution time • Reduce space • Sometimes, these are tradeoffs • Types • Intermediate code level • We are looking at this part now • Machine code level • Instruction selection, register allocation, etc.

  3. Code Optimization • Scope • Peephole analysis • Within one or a few instructions • Local analysis • Within a basic block • Global analysis • Entire procedure or within a certain scope • Inter-procedural analysis • Beyond a procedure, consider the entire program

  4. Code Optimization • Techniques • Constant propagation • Constant folding • Algebraic simplification, strength reduction • Copy propagation • Common subexpression elimination • Unreachable code elimination • Dead code elimination • Loop Optimization • Function related • Function inlining, function cloning

  5. Code Optimization Techniques • Constant propagation • If the value of a variable is a constant, then replace the variable by the constant • It is not the constant definition, but a variable is assigned to a constant • The variable may not always be a constant • E.g. N := 10; C := 2; for (i:=0; i<N; i++) { s := s + i*C; }  for (i:=0; i<10; i++) { s := s + i*2; } If (C) go to …  go to … • The other branch, if any, can be eliminated by other optimizations • Requirement: • After a constant assignment to the variable • Until next assignment of the variable • Perform data flow analysis to determine the propagation

  6. Code Optimization Techniques • Constant folding • In a statement x := y op z or x := op y • If y and z are constants • Then the value can be computed at compilation time • Example #define M 10 x := 2 * M  x := 20 If (M < 0) goto L  can be eliminated y := 10 * 5  y := 50 • Difference: constant propagation and folding • Propagation: only substitute a variable by its assigned constant • Folding: Consider variables whose values can be computed at compilation time and controls whose decision can be determined at compilation time

  7. Code Optimization Techniques • Algebraic simplification • More general form of constant folding, e.g., • x + 0  x x – 0  x • x * 1  x x / 1  x • x * 0  0 • Repeatedly apply the rules • (y * 1 + 0) / 1  y • Strength reduction • Replace expensive operations • E.g., x := x * 8  x := x << 3

  8. Code Optimization Techniques • Copy propagation • Extension of constant propagation • After y is assigned to x, use y to replace x till x is assigned again • Example x := y;  s := y * f(y) s := x * f(x) • Reduce the copying • If y is reassigned in between, then this action cannot be performed

  9. Code Optimization Techniques • Common subexpression elimination • Example: a := b + c a := b + c c := b + c  c := a d := b + c d := b + c • Example in array index calculations • c[i+1] := a[i+1] + b[i+1] • During address computation, i+1 should be reused • Not visible in high level code, but in intermediate code

  10. Code Optimization Techniques • Unreacheable code elimination • Construct the control flow graph • Unreachable code block will not have an incoming edge • After constant propagation/folding, unreachable branches can be eliminated • Dead code elimination • Ineffective statements • x := y + 1 (immediately redefined, eliminate!) • y := 5  y := 5 • x := 2 * z x := 2 * z • A variable is dead if it is never used after last definition • Eliminate assignments to dead variables • Need to do data flow analysis to find dead variables

  11. Code Optimization Techniques • Function inlining • Replace a function call with the body of the function • Save a lot of copying of the parameters, return address, etc. • Function cloning • Create specialized code for a function for different calling parameters

  12. Code Optimization Techniques • Loop optimization • Consumes 90% of the execution time  a larger payoff to optimize the code within a loop • Techniques • Loop invariant detection and code motion • Induction variable elimination • Strength reduction in loops • Loop unrolling • Loop peeling • Loop fusion

  13. Code Optimization Techniques • Loop invariant detection and code motion • If the result of a statement or expression does not change within a loop, and it has no external side-effect • Computation can be moved to outside of the loop • Example for (i=0; i<n; i++) a[i] := a[i] + x/y; • Three address code for (i=0; i<n; i++) { c := x/y; a[i] := a[i] + c; }  c := x/y; for (i=0; i<n; i++) a[i] := a[i] + c;

  14. Code Optimization Techniques • Strength reduction in loops • Example s := 0; for (i=0; i<n; i++) { v := 4 * i; s := s + v; )  s := 0; for (i=0; i<n; i++) { v := v + 4; s := s + v; ) • Induction variable elimination • If there are multiple induction variables in a loop, can eliminate the ones which are used only in the test condition • Example s := 0; for (i=0; i<n; i++) { s := 4 * i; … } -- i is not referenced in loop  s := 0; e := 4*n; while (s < e) { s := s + 4; }

  15. Code Optimization Techniques • Loop unrolling • Execute loop body multiple times at each iteration • Get rid of the conditional branches, if possible • Allow optimization to cross multiple iterations of the loop • Especially for parallel instruction execution • Space time tradeoff • Increase in code size, reduce some instructions • Loop peeling • Similar to unrolling • But unroll the first and/or last few iterations

  16. Code Optimization Techniques • Loop fusion • Example for i=1 to N do A[i] = B[i] + 1 endfor for i=1 to N do C[i] = A[i] / 2 endfor for i=1 to N do D[i] = 1 / C[i+1] endfor for i=1 to N do A[i] = B[i] + 1 C[i] = A[i] / 2 D[i] = 1 / C[i+1] endfor Is this correct? Actually, cannot fuse the third loop Before Loop Fusion

  17. Code Optimization • Will cover a subset of the techniques • Control flow graph • To facilitate data flow analysis for optimization • To facilitate loop identification • Data flow analysis • Reachability analysis, copy propagation, expression propagation • Constant folding • Liveliness analysis, dead code elimination • Loop optimization • Function optimization • Alias analysis (pointers) • Depend on the time, some topics may be skipped

  18. Code Optimization -- Summary • Read Section 9.1

More Related