An Investigation of trace cache organizations for superscalar processors by Mulrane, Edward, Jr
Rochester Institute of Technology
RIT Scholar Works
Theses Thesis/Dissertation Collections
11-18-2002
An Investigation of trace cache organizations for
superscalar processors
Edward Mulrane Jr
Follow this and additional works at: http://scholarworks.rit.edu/theses
This Thesis is brought to you for free and open access by the Thesis/Dissertation Collections at RIT Scholar Works. It has been accepted for inclusion
in Theses by an authorized administrator of RIT Scholar Works. For more information, please contact ritscholarworks@rit.edu.
Recommended Citation
Mulrane, Edward Jr, "An Investigation of trace cache organizations for superscalar processors" (2002). Thesis. Rochester Institute of
Technology. Accessed from
An Investigation of Trace Cache Organizations
for Superscalar Processors
by
Edward M. Mulrane Jr.
~oveD1ber18,2002
A thesis submitted in partial fulfillment of
the requirenaents for the degree of
Masters of Science in
Computer Engineering
Rochester Institute of Technology
PrimaryAdvisor: Dr. MuhaD1D1ad Shaaban, Assistant Professor
Advisor: Dr. Roy Czemikowski, Professor
Advisor: Dr. Ken Hsu, Professor
Release Permission Form
Rochester Institute of Technology
An Investigation of Trace Cache Organizations
for Superscalar Processors
I, Edward M. Mulrane Jr., hereby grant pennission to the Wallace Libraryof the
Rochester Institute of Technologyto reproduce mythesis in whole or in part, on
or after November 18, 2002. Any reproduction will not be for commercial use or
profit.
Edward M. Mulrane Jr.
)/-11-0.1......... _
Date
Abstract
Techniques such as out-of-order issue and speculative execution aggressively
exploit instruction level parallelism in modem superscalar processor
architectures. The front end of such pipelined machines is concerned with
providing a stream of schedulable instructions at a bandwidth that meets or
exceeds the rate of instructions being issued and executed. As superscalar
machines become increasingly wide, it is inevitable that the large set of
instructions to be fetched every cycle will span multiple noncontiguous basic
blocks. The mechanism to fetch, align, and pass this set of instructions down
the pipeline must do so as efficiendy as possible, occupying a minimal
number of pipeline cycles. The concept of trace cache has emerged as the
most promising technique to meet this high-bandwidth, low-latency fetch
requirement. This thesis presents the design, simulation and analysis of a
microarchitecture simulator extension that incorporates trace cache. A new
fill unit scheme, the Sliding Window Fill Mechanism is proposed. This
method exploits trace continuity and identifies probable start regions to
improve trace cache hit rate. A 7% hit rate increase was observed over the
Rotenberg fill mechanism. Combined with branch promotion, trace cache hit
rates experienced a 19% average increase along with a 17% average rise in
fetch bandwidth.
Contents
Abstract i
Table ofContents ii
List ofFigures v
List ofTables vii
Glossary viii
Acknowledgments & Trademarks xiv
1 Introduction 1
1.1 Motivation for Trace Cache and Instruction Pre-processing 1
1.2 Organization of Thesis 2
2 Background 3
2.1 Emergence of the Superscalar Processor 3
2.2 Tasks of SuperscalarProcessing 5
2.3 Issue Policies 8
2.4 Processing of Control Transfer Instructions 13
2.5 Elements of the Instruction Fetch Subsystem. 19
2.6 The SimpleScalar SimulatorArchitecture 26
3 Trace Cache Schemes 29
3.1 Concept of aDynamic Trace 29
3.2 Rotenberg Trace Cache 30
3.3 Path-based Next-trace Prediction 33
3.4 Branch Promotion and Trace Packing 37
3.5 Fetch Address Renaming 39
3.6 PartialMatching and Inactive Issue 40
3.7 Trace Preconstmction 41
3.8 BlockCache 44
3.9 Cost Regulated Trace Packing 46
3.10 Selective Trace Storage 47
3.11 Fill Unit Optimizations 47
3.12 AnAlternate Approach to Filling the Trace Cache 50
3.13 Additional Related Research 51
3.14 Trace Cache Implementation: The Pentium 4 53
4 SimulatorExtensionDesign 55
4.1 Existing Superscalar Simulator 55
4.2 Motivation forUtilizing an Object-OrientedExtension 57
4.3 Modifications to simadoraerSource 57
4.4 High Level Design 59
4.5 Component Level Classes 60
4.6 Qeational Level Classes 62
4.7 Helper Level Classes 63
5 Implementation and Results 65
5.1 Simulation Strategy. 65
5.2 Benchmarks Used 67
5.3 Multiple Branch Predictors 69
5.4 Rotenberg Trace Cache 74
5.5 Trace Cache Associativity 77
5.6 Reassociation 80
5.7 Branch Promotion 81
5.8 Alternate FillMechanism 85
5.9 Trace Continuityand Probable EntryPoints 87
5.10 The SlidingWindowFill Mechanism&Fill Selection Table 89
5.11 Combining Trace Cache Schemes 94
5.12 Other Simulated Schemes 96
5.13 Side Effects Associated with Trace Cache 98
6 Conclusion 100
6.1 SummaryofWork 100
6.2 Difficulties Encountered 101
6.3 Recommendations for Future Work 102
References 104
AppendixA - Trace Cache ExtensionHeader Files
Appendix B - Kernel Benchmark Source Files
in
Appendix C - Benchmark Input Sets
AppendixD - Example SimulatorOutput File
IV
List of Figures
Number Pag;
2.1 - Functional ProcessorModel 5
2.2 - Issue PolicyDesign Space 8
2.3 - Methods for Flandling Issue Blockages 9
2.4 - Shelving 1 1
2.5 - Design Space Outline of Tomasulo's Algorithm 13
2.6 - Local (PAg) Predictor 17
2.7 - Gshare Predictor 17
2.8 - General Combined Predictor 18
2.9 - Fetch Subsystem Components 21
2.10 - MGAg Predictor 23
2.1 1 - Collapsing Buffer 24
2.12 - Branch Address Cache 25
2.13 - Design Space Outline of simotdorder 28
3.1 - Static ProgramOrder versus Dynamic Execution Order 30
3.2 - Example Trace Cache Segment 31
3.3 - The Rotenberg et al Trace Cache 32
3.4 - Combining Trace Predictor 34
3.5 - HashedHistoryRegisterEntry 35
3.6 - DOLC Index Generation 35
3.7 - Static Code and Corresponding Preconstruction Graph 42
3.8 - Extended Pipeline Model 44
3.9 - Conventional versus Blocked-Based Trace Cache 45
3.10 - Register-to-registermove optimization 49
3.11 - Rotenberg Fill versus the Fill Policyof [20] 51
4. 1 - SimatfurderPipeline 56
4.2 - Uniform Trace CacheModel 59
4.3 - UML Diagram of the Abstract Component Classes 61
4.4 - UML Diagram of the Abstract Component Classes (cont.) 62
4.5 - UMLDiagram of the Creational Level Classes 63
5.1 - Multiple Branch Predictor Accuracy. 72
5.2 - Fetch Bandwidth Increase vs. m 73
5.3 - PredictionAccuracyvs. m 73
5.4 - Average Trace Cache Segment Length 74
5.5 - Fetch Bandwidth after Incorporating Trace Cache 75
5.6 - Trace Cache Hit Rate 76
5.7 - Trace Cache Speedup 76
5.8 - Distribution of Trace-Terminating Conditions 77
5.9 - Hit Rate vs. Associativity 78
5.10 - Utilization vs. Associativity. 79
5.11 - Speedup vs. Associativity 79
5.12 - Average Fetch Bandwidth vs. Branch Bias Threshold 82
5.13 - Speedup vs. Branch Bias Threshold 82
5.14 - Speedup Comparison ofBBTOrganizations 84
5.15 - Speedup using Branch Promotion 85
5.16 - Hit Rate forAlternate Fill Scheme 86
5.17 - Unique Traces Added 86
5.18 - Speedup UsingAlternate Fill Scheme 87
5.19 - Fill Unit Example 88
5.20 - The SlidingWindowFill Mechanism 90
5.21 - Hit Rate for SWFM using various FST Thresholds 93
5.22 - Speedup using the SWFM/FST 93
5.23 - Hit Rate Increase for Combined Scheme 94
5.24 - Fetch Bandwidth Increase forCombined Scheme 95
5.25 - Decrease in Branch PredictionAccuracyfor Combined Scheme 96
vi
List of Tables
Number Page
3.1 - Trace Cache Limitations and Solutions 33
5.1 - Base simoutankrparameters 66
5.2 - Benchmark Set Utilized 68
5.3 - Average Basic Block Sizes 69
5.4 - Reasssociation Statistics 81
5.5 - Resulting Example Traces 88
5.6 - Conditions forAdjusting the iraoejailPointer. 91
5.7 - Number ofUnique Traces Added using SWFM/FST 92
Vll
Glossary
Block Cache: Structure that stores basic blocks, which are referenced by the
trace table in a cost reduced trace cache scheme.
Branch Address Cache: An alternate fetch mechanism aimed at improving
fetch bandwidth.
Branch Address Prediction: A generic term for any technique that provides a
target address for an instruction before it is decoded/evaluated.
Branch Bias Table (BBT): A structure used in branch promotion that records
the number of successive taken/not-taken directions for a particular branch.
Branch Direction Prediction: A generic term for any technique that provides
the branch direction for an instruction before it is decoded/evaluated.
Branch Flags: Bits indicating the direction of each conditional branch within a
trace.
Branch Mask A field indicating the number of conditional branch within a
trace.
Branch Promotion: A scheme that identifies strong taken/not-taken branches
and removes them from the consideration of the dynamic branch predictor.
Branch Target Buffer (BTB): A table that returns a branch target when
indexed with the address of a control transfer instruction. Serves as a Branch
Address Prediction method.
Collapsing Buffer An alternate fetch mechanism aimed at improving fetch
bandwidth.
Combined Predictor: A technique that allows various types of predictors to be
utilized in tandem, recording the method that proves more accurate for individual
branches.
Vlll
Control transfer instruction: Anyoperation that alters the sequential execution
of a program (jumps, conditional branches, subroutine calls and returns).
Cost-reduced BBT: Similar to the Merged BTB/BBT with the exception that
onlytaken targets & bias values are recorded.
Cost-regulated Trace Packing: A fill unit scheme that only permits full trace
packing under certain conditions in a trade off between resource consumption
and trace continuity.
Decoded Instruction Queue (DIQ): Internal structure to the decode/issue
stage that buffers decoded instructions prior to being issued to the dynamic
scheduling mechanism.
Degree of Speculativeness: How far down the pipeline a speculatively
executed instruction is allowed to proceed.
DOLC: "Depth, Older, Last, Current". A strategy to generate an index value
from a set of history register entries.
Dynamic Execution Order The order in which instructions are processed as a
program executes.
Effective Issue Bandwidth: Howmany instructions on average are issued per
cycle.
Extended Pipeline Model: Abstraction of a processor from the perspective of
three independent pipelines: Pre-processing, Fetch/Decode and Execute.
Fall-through Address: The address corresponding to a not-taken result for a
trace-terminating branch.
Fill SelectTable (FST): Identifies probable entrypoints bymamfcuriing a count
for everyPC accessed by the core fetch unit.
Full BBT: The implementation of a BBT as an independent structure in
hardware.
Functional Processor Model: An abstraction that models a processor as a
number of sequentially linked subsystems.
IX
Global (GAg) Predictor A branch predictor that utilizes a global history
register indexing into a pattern history table.
Gselect Predictor Functionallysynonymous to the GAg Prediction scheme.
Gshare Predictor A predictor that merges (XOR) the global history register
with the current PC to form an index into a pattern history table.
Inactive Issue: A trace cache technique that effectively implements predication
of traces.
Instruction Dispatch: In the context of shelving, when an instruction is
clisseminated to a functional unit for execution from a shelving buffer.
Instruction Fetch Queue (IFQ): Structure that separates the fetch stage with
the decode/issue stage where fetched instructions are buffered.
Instruction Issue: In the context of shelving, the point at which an instruction
is decoded and sent to a shelving buffer.
Instruction Predecoding: A method that associates additional bits that
provides extra information (such as instruction class) to each I-Cache entry. This
allows for earlydecisions to be made within the pipeline.
Intrablock Branches: In the context of the collapsing buffer, branches that are
predicted taken with a target address within the same cache line.
Issue Policy: The collective techniques that govern the manner in which
instructions are issued.
Issue Rate: Howmany instructions are capable of being issued per cycle.
Level of Speculativeness: The maximum number of speculative branches that
mayexist in the machine (in-flight) at anytime.
Local (PAg) Predictor. A branch predictor that utilizes a 2-level table structure
(per-address and pattern history table).
m-constrained: Implies that the maximum number of basic blocks (m) has been
reached for a particular trace.
Merged BTB/BBT: The combined BTB and BBT structure. Both taken and
not-taken branch targets & bias values are recorded.
MGAg Predictor Amultiple branch prediction extension of the GAg Predictor.
Forms mpredictions by iteratively accessing the pattern history table.
^-constrained: Implies that the maximum number of instructions (n) has been
reached for a particular trace.
Partial Matelung: A trace cache technique that allows a hit to occur if only a
few branch flags match the prediction.
Path-Based Next Trace Prediction: A prediction scheme coupled with the
trace cache that replaces traditionalmultiple branch prediction.
Pattern History Table (PHT): An element of branch predictors that stores
entries consisting of previous branches outcomes as sattirating counters.
Per-Address Table (PAT): An element of a per-address (i.e. PAg) prediction
scheme that is indexed by the PCvalue to produce an index into the PHT.
Probable Entry Point A fetch address that starts a trace that is likely to be
encountered again as a PCvalue over the course of execution.
Read-After-Write (RAW) Hazard: Condition occurring when one instruction
reads from a location that was the write target of a previous instruction before the
value is available.
Reassociation An instruction pre-processing technique that optimizes
instructions with immediate operands that follow each other sequentially or are
separated bya branch.
Register Renaming: A technique that eliminates false data dependencies within
a dynamic schedulingmechanism
Register Update Unit (RUU): A mechanism that combines the techniques of
dynamic scheduling (shelving, renaming and reordering) into a single hardware
structure.
Rename Buffers: An allocated entry for an instruction that has been renamed.
Dependent instmctions will internally refer to this entry rather than the
architectural registers.
XI
Reorder Buffer. A common mechanism that provides in-order commit for
machines that utilize out-of-order issue/execute.
Return Address Stack (RAS): Amechanism that pushes subroutine CALLs to
a stack, a pops RETURNS off. Serves as a Branch Address Predictionmethod.
Selective Trace Storage: A technique that eliminates redundancy between the
I-Cache and the trace cache.
Shelving Buffers: A generic structure that holds instructions as part of a
shelving scheme as theyawait dependency resolution.
Shelving: A generic term for the mechanism that decouples instruction issue
from dependency resolution.
Sliding Window Fill Mechanism (SWFM): A fill unit scheme that exploits
trace continuityand probable entrypoints. It is pairedwith the Fill Select table.
Speculative Execution: Proceeding to fetch, issue and execute instruction along
an assumed path prior to evaluation of a branch.
Static Program Order The layout of a program in I-Cache cache as structured
by a compiler.
Superscalar The ability of a processor to issue more than a single instruction
per cycle.
Trace Continuity: A property belonging to a sequence of traces that can be
fetched back-to-back over multiple fetch cycles.
Trace ID: The value that uniquely identifies a trace segment. Often this is the
address of the first instruction in the trace.
Trace Packing: The idea of filling trace cache lines irrespective of basic block
boundaries.
Trace Precons truetion: A method that generates trace segments for a region
before execution reaches the location byutilizing the idle fetch stage resources.
Trace Table: In the context of the Block Cache, the structure that replaces the
traditional trace cache by storing references to blocks rather than explicit
instructions.
xu
Trace TargetAddress: The address corresponding to a taken result for a trace-
terminating branch.
Trace Terminating Condition A condition that must exist to finalize a trace in
the fill buffer and force a segment to be written.
Trace: A finite "snapshot" of the dynamic execution order of a program.
Uniform Trace Cache Model Flow diagram from which the trace cache
simulator extension was designed. Represents a modularization of the specific
tasks of the trace cache.
Write-After-Read (WAR) Hazard: Condition occurring when one instruction
writes to a location before a previous instruction reads from the same location
Write-After-Write (WAW) Hazard: Condition occurring when one instruction
writes a location before a previous instruction writes to the same location
resulting an inconsistent state for other instructions in between.
xui
Acknowledgments & Trademarks
The author wishes to acknowledge Dr. Muhammad Shaaban, Dr. Roy
Czernikowski and Dr. Ken Hsu for serving as advisors to this work Thanks is
given to Brad Virkler and Eric Majewicz for providing some of the scientific
application kernels utilized as benchmarks.
Tentium 4" is a trademarkof the Intel Corporation.
xiv
Chapter 1
Introduction
Trace caohe has emerged as a promising rmhanism to achieie Ugh-hanckM), lamlatency
instructionfetch ofmultiple, nonrcont^ious basic blocks. This chapter states the rrxtkntion
anting trace caohe research andoutlines die organization (fsubsequent chapters.
1. 1 Motivation forTrace Cache
For superscalar processors, an increase in issue width results in a significant
performance gain if the majorityof available issue slots are utilized every cycle. If
this is not the case, the under-utilization of issue slots is characterized as
horizontal waste. Several hardware methods that exploit instruction level
parallelism have been proposed to minimize this waste, including out-of-order
issue and speculative execution. These ILP related optimizations effectively
boost instruction execution bandwidth. To sustain an increase in execution
bandwidth proportional to issue width, the schedulable pool of instructions must
remain robust. This implies that the instruction fetch bandwidth must be at least
equal to the number of instructions issued per cycle. Traditional superscalar fetch
mechanisms can provide a set of instructions up to, and including, a single branch
instruction. Furthermore, it has been stated that the average basic block size is
five instructions for general-purpose code [1]. As superscalar widths extend past
the current four-way implementations of today, it is evident that the instruction
fetch bandwidth has the potential to be a major bottleneck within the pipeline.
Several mechanisms have been proposed to fetch past basic block boundaries,
including the branch address cache and collapsing buffer. The most promising
though has been the trace cache.
In addition to providing a solution to increasing fetch bandwidth, trace cache
allows for dynamic optimizations in the stream of instructions that are delivered
down the pipeline. This has the advantage of reducing execution and scheduling
overheads by eliminating redundant operations and minimizing instruction
dependencies.
Incorporating trace cache can the effect of substantially increasing the average
number of instructions per cycle that a superscalar machine can complete, which
in turn decreases the execution time required for running a particular application
- the basic goal of anyarchitecture related enhancement.
1.2 Organization ofThesis
This thesis will identify some various trace cache and instruction pre-processing
schemes that were examined using an extension to an existing mircoarchitectural
simulator.
First, an overview of the modern superscalar processor is presented as
background theory in Chapter 2. Specifically, design space topics for
instruction issue, the core fetch unit and alternate fetch mechanisms are
examined. The SimpleScalar toolset, used as the basis for simulator
extension, is described.
Chapter 3 is devoted to presenting some trace cache schemes currently
proposed and implemented.
The object-oriented design of the trace cache simulator extension is
explained in Chapter 4.
Chapter 5 entails discussion of simulation results for various schemes and
parameter variations. The Sliding Window Fill Mechanism is introduced
as a new scheme to improve trace cache hit rates.
Conclusions are made in Chapter 6, along with difficulties encountered
and recommendations for future work
Chapter 2
Background
This chapter sets the stagefor discussion cftrace cache in the context cfthe modern supercalar
processor. Topics such as instruction issue, the corefetch unit andalternatefetch rrechanism are
examined The SimpleScalar simulator is presented and classified using the desigp, space
established in tfefdlowng sections.
2.1 Emergence of the Superscalar Processor
Over the past few decades, the field of processor design has been marked by
continuous evolution and improvements. Prior to the 1980s, performance
accelerated at an approximate rate of 1.35 times per year. This growth was driven
largely by technology improvements, including the integrated circuit and the
microprocessor. Since then, architectural advancements along with steady gains
in process technology have lead to performance rate increases of over 1.5 times
per year [2]. The adoption of RISC instruction set architectures (or RISC
processor cores), pipelining, and dynamic scheduling have all been important
milestones in the development of microarchitectures. One of the most
substantial gains since the early 1990s has been multiple, or superscalar,
instruction issue. The simple motivation to utilizing superscalar issue is to
process instmctions in parallel, thereby increasing the number of instructions
executed per cycle (IPC) and decreasing the execution time of a given program
The fundamental concept that allows for concurrent execution is instruction level
parallelism. Unfortunately, the level of parallelism able to be extracted from a set
of instruction is limited by a number of factors, or dependencies. Dependency
relationships can be classified into three groups: data dependencies, name
dependencies, and control dependencies [2].
Data, or true, dependencies between instructions are the most
straightforward. If the result of instruction i is required as a source operand to a
subsequent instruction;', then; is data dependent on i and must wait for its result
before executing. This corresponds to a read-after-write (RAW) hazard within
the processor pipeline.
Name dependencies (false dependencies) can be further separated into anti-
dependencies and output dependencies. An instruction; is anti-dependent on a
preceding instruction i if ; writes to a location that is a source operand of i.
Similarly, output dependence exists if both instructions i and; write to the same
location. These name dependencies correspond to write-after-read (WAR) and
write-after-write (WAW) hazards respectively.
The final type of dependency that hinders the extraction of instruction level
parallelism is control dependence. An instruction ; is dependent on control
instruction i if it cannot be moved before instruction i such that it is no longer
controlled by the outcome of the branch. Likewise, instruction i is dependent on
control instruction ; if it can not be moved after instruction ; such that it is
controlled by the outcome of the branch.
While not exclusive to superscalar design, the effect of hazards on performance
become most prevalent as issue rates exceed a single instruction per cycle. To
circumvent the restrictions to parallel execution that these dependencies cause,
mechanisms must be incorporated in a superscalar processor. While many
miroarchitectures are based on the simplicity of RISC ISAs, the overhead
required to minimize the effect of dependencies add a fair amount of design
complexity. In further elaborating these mechanisms, is convenient to establish a
functional processor model. This abstraction consists of a number of
sequentially linked subsystems: Fetch, Decode/Issue, Dispatch, Execute and
Reorder/Commit. The link between the fetch and issue subsystems is the
instruction fetch queue (IFQ). Within the decode/issue subsystem is the
decoded instruction queue (DIQ). The remaining subsystems are linked
implicidy, dependent on the scheme. To avoid obvious bottlenecks, the
bandwidth (rate) of each stage should be roughly equal [1]. The next section
provides an overview of the latter 4 subsystems. The fetch unit will be treated to
more rigorous detail in Section 2.3, as it provides the basis for later discussions on
Trace Cache.
Implicit Link
Dispatch -A Execute
-v
Reorder/
Commit
-. J
Figure 2.1: Functional Processor Model
2.2 Tasks ofSuperscalar Processing
The decode/issue, dispatch, execute and reorder/commit subsystems collectively
are concerned with performing the tasks of superscalar processing, which can be
subdivided as follows [1]:
ParallelDecoding
Superscalar Instruction Issue
Parallel Execution
Instruction Reordering
Exception Processing
The first task is to decode the set of instructions that has been passed down
the pipeline from the fetch unit. In the traditional scalar processor, dependency
checking is combined with instruction decoding to ensure that all source
operands are available before an instruction is issued. A superscalar processor
treats these two instruction-processing tasks independendy, as they may be
decoupled within the pipeline. In addition to requiring additional resources to
decode multiple instructions simultaneously, interdependencies among the set of
instructions being decoded must be flagged for consideration during instruction
issue.
Two aspects comprise the task of superscalar instruction: Issue Rate and
Issue Policy. The issue rate, or issue width, of a processor indicates howmany
instructions are capable of being processed from the DIQ per cycle. One should
note that this value is distinct from effective issue bandwidth: how many
instructions on average are being issued per cycle. The issue policy aspect
encompasses a sizeable design space, outlined in Figure 2.2. At this point it is
appropriate to make a distinction between the terms issue and dispatch. An
instruction is issued after it has been decoded. Dispatch occurs when an
instruction, along with the appropriate operand values, is disseminated to a
particular functional unit for execution. In a simple pipeline issue and dispatch
are one in the same: An instruction either proceeds to execute or is blocked after
being decoded. The issue/dispatch distinction is required in the superscalar case
for reasons that will soon be apparent.
Parallel execution is a matter of hardware resources. Multiple execution units
(EUs) are required to maintain a bandwidth equal to that of the rest of the
system. Aspects of functional units such as multiple-cycle latencies and pipelined
versus non-pipelined operation are considerations that are inherent in the other
subsystems and need not be addressed in the context of parallel execution
Instruction reordering is a task concerned with mamtaihing the sequential
consistency of instmction execution. Advanced issue policies necessitate the
explicit control of instmction retirement such that the architectural state of the
processor remains valid. The reorder buffer (ROB) is a common mechanism
that accomplishes instmction reordering. Often implemented as a circular buffer,
each issued instmction is appended in-order at the tail of the ROB. The reorder
buffer is related to aspects of the issue policy and is linked with rename buffer
deallocation, mentioned in the next section. Modem machines utilize reordering
to enforce a strong processor consistencymodel and precise exception handling
[!]
2.3 Issue Policies
There are four main aspects to classifying the issue policy of a superscalar
processor [1]. First is whether speculative execution is utilized, a topic that will
be addressed in Section 2.4. Second is how issue blockages are handled.
Regardless of how the rest of the issue policy is implemented, blockages can
occur via data and/or structural hazards. Four possibilities for this scheme exist:
fixed window/in-order, fixed-window/out-of-order, sliding window/in-order,
and sliding window/out-of-order. The issue window affects how instructions in
the DIQ are processed each cycle. A fixed window scheme will treat a set of
instructions as a unit, proceeding to the next set onlywhen every instmction in
the current set has issued. A sliding window considers for issue the w-most
instructions at the head of the queue, effectively re-adjusting itself every cycle. If
an in-order issue scheme is employed, an instruction at the head of the DIQ that
is blocked will inhibit any other instmction from issuing. An out-of-order
scheme will allow instructions beyond a blocked instruction (within the window)
to issue if possible. A graphic description of the four possible window and
in/out-of-order combinations is shown in Figure 2.3.
The third aspect of a superscalar issue policy is how data dependency checking is
handled. The blocking issue approach (i.e. wait until all dependencies are
resolved) is standard among scalar and first-generation superscalar machines.
This method is restrictive in that it is subject to, and limited by, the issue blockage
schemes described above.
1. Issue Blockages
a. Issue Window
L Fixed
ii. Gliding
b. Issue Order
i. In-order
ii. Out-of-oider
2. Name dependence Handling
a. RegisterRenaming (orNo Register Renaming)
L Scope
ii. Layout ofRename Buffers
1. Types
a. MergedArchitectural andRename RegisterFile
b. Separate Rename Register File
c. ReorderBuffer
d. DRIS/RUU
2. Number of reorderbuffers
3. Accessing reorder buffers
a. Associative values
b. Mapping Table
iii. Operand fetch policy
1. Issue Bound
2. DispatchBound
iv. Rename Rate
3. Unresolved control dependencyHandling
a. Speculative Execution (orNo Speculative Execution)
L Desiffi Space tfCorttd TransferIrstmaions
4. DependencyChecking
a. Decouple instruction issue and dependencycheck - Shelving (orBlocking Issue/No Shelving)
L Scope
ii. Layout of shelving buffers
1. Reservation Stations
2. Group Station
3. Central Station
4. DRIS/RUU
iii. Number of buffer entries
iv. Number of input/outputports
v. OperandFetchPolicy
1. Issue Bound
2. Dispatch Bound
vl Dispatch Scheme
1. DispatchPolicy
a. DispatchOrder
L In-order
ii. Out-of-order
b. Selection Rule (applicable for out-of-orderdispatch)
c. Arbitration Rule (applicable for out-of-order dispatch)
2. DispatchRate
3. Operand AvailabilityChecking
a. Direct Check of Scoreboarding Bits
b. Checking of explicit Status Bits
4. EmptyShelvingBufferTreatment
a. Bypassing
b. No bypassing
Figure 2.2: Issue PolicyDesign Space [1]
IssueWindow-
Cycle 1
Cyde2
Cycle 3
a) Fixed Window/In-order
0
_0(^
0
0
b) Fixed Window/Out-of-order
= Blocked Instruction
@ mmai
c) Sliding Window/In-order
| 0 QB,
b) SlidingWindow/Out-of-order
Figure 2.3: Methods for Handling Issue Blockages
A more attractive solution is one that decouples instruction decode from issue,
deferring most dependency resolution to the later stage. Genetically termed
shelving, the mechanism to achieve this dependency resolution has various
layouts and design options itself. Shelving buffers consist of one or more
entries to which instructions are issued.Only until all dependencies are resolved
may an instruction be dispatched from the shelving buffer to an appropriate EU.
The number of buffer entries, and the layout are implementation specific. If a
separate set of shelving buffers precedes each EU, the buffers are commonly
referred to as reservations stations. Buffers can also service multiple EUs of the
same type (group stations) or a single buffer may exist for all functional units
(central station). When instructions are issued to a buffer, the available source
operands can be retrieved from the register file and stored in the shelving buffer
entry. Likewise, operands may be fetched upon dispatch, leaving the shelving
buffer entry to store only the register identifier. Which operand fetch policy is
used often correlates to how operand availability checking is handled. All
shelving schemes utilize a structure called a scoreboard. This can be visualized as
a single bit extension to each register file entry indicating the availability of that
value. When an instruction is issued (or in some cases dispatched) the
scoreboard flag for the destination register is marked to indicate the value is not
available. An instruction that has finished execution will reset the appropriate
scoreboard bit. Subsequent instructions that are issued check the scoreboard bits
for each of their source operands. A dispatch bound fetch policy entails a direct
check of the scoreboard bits every cycle to determine if source operands are
available. An issue bound operand fetch policy includes explicit availability flags
for each source operand in the rename buffer entries. Upon issue, these explicit
status bits in a newly allocated rename buffer entryare set to correspond with the
value of the respective scoreboard bits. If an operand value is not available, the
operand field in the rename buffer entry is set to the register identifier. Using a
common data bus scheme, instructions that have finished execution provide the
result value to not only the register file and scoreboard, but to each shelving
buffer. If the identifier of the result matches that of any source operand that has
been marked unavailable, the buffer entry is updated with the operand value and
the explicit status bit is modified to reflect the availability.
Once both source operands are available, and no WAR orWAW hazards are
detected for the instruction (a step eliminated by the soon-to-be-discussed
process of register renaming), it is ready to be dispatched to an available EU. The
dispatch policy determines how instructions are selected once they are ready.
This also includes whether or not multiple instructions may be dispatched from
the same shelving buffer in a single cycle. Similar to the issue rate, the dispatch
rate determines how many possible instructions that are ready for dispatch may
be disseminated per cycle. It has been found that it is optimal for this rate to
slightly exceed the issue rate to account for multi-cycle latencies associated with
non-pipelined EUs. One interesting optimization that can be made is bypassing
empty shelving buffers. Normally, if an instmction is issued to an empty
10
reservation station and is free of dependencies, it will be recognized as a
candidate for dispatch in the following cycle and sent to an EU. Bypassing saves
a cycle by forwarding the instruction to the EU direcdy, performing issue and
dispatch in the same cycle [1].
Dispatch
(Dependency
Check)
EU
Shelving
Buffer
f \
Dispatch
(Dependency
Check)
-A
-v
EU
Figure 2.4: Shelving
Shelving alleviates the problem ofRAW hazards from impacting the performance
of superscalar machines, but still leaves WAR and WAW hazards to contend
with., The last aspect of the supersclar issue policy addresses these hazards.
Incorporating a technique known as register renaming can internally eliminate
false dependencies. Like shelving, one can avoid addressing the layout specificity
of a variety of register renaming schemes by genetically referring to rename
buffers. When an instruction is issued, a rename table is accessed. This
associates architectural register identifiers to entries in the rename buffer. For
some implementations, a single register identifier may have multiple table
associations, in which case a
"latest" bit will be set for one of these entries.
11
Accessing the rename table occurs in two steps. First, both of the source register
identifiers are used to index the rename table. For schemes that allow one-to-
manymappings, the entrywith the
"latest" bit is accessed. If an entryexists, the
associated table value (rename buffer entry ID) replaces the source identifiers of
the instmction. Secondly, a new location in the rename buffer is provided for the
destination operand, and is associated with the destination register identifier via a
freshly allocated entry in the rename table. This will overwrite any prior entry
with the same destination register as the index, or set the "latest" bit for the new
entry. The values provided by the rename table will become those used
throughout the dispatch and execute stages for the instruction. During
execution, each instmction will refer to a unique destination location; therefore
checking for WAR and WAW hazards becomes irrelevant. This renaming
prevents instructions from being held from dispatch because of output and anti-
dependencies. Deallocation of rename buffer entries is often tightlycoupled with
the mechanism that preserves the sequential consistency of instruction execution.
In the case of the reorder buffer, renamed registers are committed to architectural
state when an instruction reaches the head of the ROB. The associated rename
buffer entry is copied to the explicit architectural register and the rename buffer
and table entry deallocated, or the rename register is mapped as the current
architectural register, deallocating the previously mapped rename buffer entry
[1,3].
For the purpose of explanation, treating shelving, register renaming and
reordering as separate processes with independent resources is convenient
Though in many implementations, these mechanisms are tightly coupled (as has
already been alluded in describing the process of rename buffer deallocation).
Tomasulo's algorithm, a popular example of dynamic scheduling, is an example
of how both shelving and renaming are often presented and implemented
together. The rename buffers of the Tomasulo approach are implicit in the
12
operand value fields of the reservation stations. Figure 2.5 outlines Tomasulo's
algorithm from a design space perspective.
The combination of all three mechanisms (shelving, renaming and
reordering) is realized in approaches such as the as DRIS [1], or RUU [4]. In the
case of the RUU (Register Update Unit) a circular buffer that resembles a reorder
buffer also serves the role of central reservation station with implicit rename
registers and associative rename table (tag unit). While the organization of such
an implementation may seem confusing, it should not obscure the purpose
behind the undedying mechanisms.
Scalar decoding/Issue Rate of 1
In-order issue
Speculative Execution
Register Renaming
o Rename registers integrated as operand value fields in reservation
station entries.
o Mapping Table Access Each register is associated with a tag
value (one-to-one).
o Issue Bound Operand Fetch Policy
Shelving
o Multiple entry shelving buffers (reservation stations) for each EU
o Issue Bound Operand Fetch Policy
o In-order dispatch
o Explicit status bits for operand availability checking
o No shelving buffer bypassing
Figure 2.5: Design Space Outline ofTomasulo's Algorithm
2.4 Processing ofControlTransfer Instructions
The previous section showed how advanced superscalar processors address the
limitations of true data dependencies and false name dependencies. The issue of
control dependencies will now be discussed as a prerequisite to describing the
13
fetch subsystem and trace cache. Control transfer instructions (often generally
termed branch instructions) consist of five basic types: direct jumps, indirect
jumps, subroutine calls, subroutine returns, and conditional branches. These
should all be familiar to the reader in the context of assembly level code. From
the perspective of the ISA conditional branch instructions can be implemented
in two distinct ways. Result state branches depend on the outcome of a previous
instruction to set a condition code register that is implicitlyused to determine the
direction of a branch. Direct check branches provide the operands to compare
and the branch target as a single self-contained instruction [1]
The question often associated with control transfer instructions is: How can
a seemingly straightforward set of instructions pose a problem in superscalar
processing? When executing a sequence of instructions, the PC of the
subsequent instruction following a branch operation is dependent on the
evaluation of that branch. In a scalar pipelined architecture, this implies that a
branch direction must be indicated to the fetch stage by the following cycle to
avoid stalling the pipeline. For a superscalar architecture, this branch direction is
needed in the same cycle to be able to continue to fetch beyond a given control
transfer instruction in a fetch block. As architectures become increasingly
superscalar and superpiplined, the limitations due to control dependencies
become increasinglypronounced. Fortunatelymechanisms have been introduced
to deal with the "branchproblem"just as they have for the other classes of
instmction dependencies.
Branch processing can be considered in terms of branch detection, treatment
of unresolved conditional branches, and accessing the branch target path. [1] The
first of the processing steps, branch detection, can be handled at various points in
the pipeline. If no special changes are made, detection occurs as each branch
instruction is decoded. This also means that instmctions continue to be fetched
along a sequential path until the branch is decoded in a later stage. The obvious
disadvantage to this scheme is the instructions that are "blindly
fetched"
after the
14
branch maynot be along the correct control path. The sooner a control transfer
instruction can be detected, the better. To this end, branch detection integrated
with the fetch stage is optimal
Once a branch is detected, itmust be evaluated. This especiallyholds true for
conditional branches, indirect jumps and subroutine returns. Unlike branch
detection, this step cannot be arranged such that zero latency exists between
branch evaluation and fetching of the next instruction. This presents two
options: The first, and decisively less attractive option is to stall until the branch
in question is evaluated (blocking branch processing). The second is to continue
executing instructions as if the branch direction was known. Proceeding to fetch,
issue and execute instructions along an assumed path prior to evaluation of a
conditional branch is known as speculative execution. If a speculatively
executed path proves to be correct after the branch is evaluated, those
instructions are promoted to a non-speculative state and can be safely committed
(thereby changing the architectural state of the system). The control instruction
has been correctly predicted in this situation. If evaluation of the control
instruction yields a different target then that starting the speculative path, then
those instmctions along the speculative path must be canceled and fetching must
resume along the correct path. This constitutes a misprediction. Some
quantitative measures of speculative execution are the level of speculativeness
and the degree of speculativeness. The maximum number of branches that
may be executed speculatively at any given time (the number of unresolved
branch instructions "in-flight") is the level of speculativeness, while the degree is
how far down the pipeline speculatively executed instructions are allowed to
proceed. [1]
The key factor of speculative execution is utilization of a branch prediction
scheme that will yield high accuracy and a lowmisprediction percentage. Branch
prediction can be fixed, static or dynamic. A fixed prediction scheme will always
15
choose a taken or non-taken path regardless of the branch. A static scheme
involves encoding the branch prediction within the instruction This prediction is
generated by the compiler based on inferred branch behavior. Dynamic branch
prediction is the most accurate, and most complex of the three forms of
prediction. Hardware is utilized to retain state information pertinent to control
instructions. This may be, but is not limited to, individual branch histories, the
direction of the last n branches or a combination of both. Various methods for
performing dynamic branch prediction exist and onlya few are presented here.
In early studies of branch prediction, Smith proposed the simple bimodal
predictor that mamtains a historyof specific branches as a two-bit table entry [1].
Single level prediction, of which bimodal is an example, has the limitation of
considering each branch without correlation to a specific patterned behavior.
Yeh and Patt addressed this in proposing a two level predictor. Such a predictor
uses the lower bits of the branch address to index a table of n history bits. In
turn, these history bits index a bimodal table of length 2n. The branch prediction
is based upon the entry in the bimodal table. Once a branch has been evaluated,
the history bits of the first table are updated by slufting the current result into the
table. The bimodal table is then updated based upon this new history index.
This specific strategy is termed a local predictor, or in a later paper presenting a
taxonomy of two level predictors, a PAg scheme [5]. A visual representation is
provided in Figure 2.6.
The historypattern is indexed solelyby the current branch address in the PAg
predictor. Another predictor considers instead the history of the most recent
branches collectively. This method is aptly referred to as the global predictor or
GAg predictor. The history of the most recent branches is recorded in a single
global history shift register. This has the advantage of choosing a prediction
based upon the association ofmany independent branches [5].
16
PC
History Bits
Index 0 1 ... n
0000
-f 0001
0002
Bimodal
Index 0 1
History
Pattern
0000
0001
0002
2
-* Prediction
Figure 2.6: Local (PAg) Predictor
The gselect predictor, proposed by Pan, So and Rahmeh realizes such a
combination by appending the global history to thej lowest bits of the PC.
Another method of combining prediction, gshare, uses the XOR function to
merge the global history register with the current PC [7], shown in Figure 2.7.
History Sh
0 1 ... n
ift Register Bimodal
Index 0 1
MM / 0000
0001
0002
"1 ' *
l l l 1
X
* Prediction
/^
PC )R/ *\ At
xXORy 2
y V_.
Figure 2.7: Gshare Predictor
The final method of dynamic branch prediction discussed here is the
combined predictor. Proposed by McFarling, this technique allows different
branch predictors to be used in tandem, and the best result to be chosen based
upon past performance of the specific branch being predicted. A generalized
scheme is shown in Figure 2.8. Accuracy counts for each of the individual
predictors are recorded separately. These separate fields can be appended to the
branch target buffer. Depending on the correctness of predictor n, the respective
17
accuracy count is incremented or decremented accordingly. A priority encoder
chooses the scheme that has been most accurate and provides this output as the
final prediction. McFarling has noted that using combining branch predictors in
this manner provides prediction accuracy up to 98.1 percent [7].
Branch TargetAddress Buffo-
PC T BA BTA PAC EuC
PriorityEncodet
- Prediction
Figure 2.8: General Combined Predictor
Closely associated with branch prediction is the task of accessing the branch
target as early as possible when processing a control transfer instruction.
Predicting the direction of a branch alone is still only half of the information that
is required to fetch instructions along a speculative path. In the case ofpredicted
taken conditional branches and direct jumps, the fetch address is known only
after the instruction is decoded. For indirect jumps and subroutine returns, this
fetch address is often evaluated even later in the pipeline. Again, mechanisms
have been introduced to provide a branch address prediction (versus a branch
direction prediction as explained above). The branch target buffer (BTB) or
more precisely, the branch target address buffer (BTAB) is an example [1]. The
PC of each instruction being fetched serves as an index into a table. If the entry
is valid and there is a tag match, it serves as an indication that the instruction is a
branch, and the target address is provided Such a scheme can serve as a simple
implicit branch direction predictor as well. Implicit branch direction prediction
18
methods relyon the presence (or lack of) a table entry to indicate a taken (or not-
taken) prediction.
For mdirect jumps and subroutine returns the issue of branch address
prediction is complicated by the fact that branch target itself relies on the
dynamic state of a program Branch address prediction for subroutine calls will
be one of the topics addressed in the next section.
2.5 Elements of the Instruction Fetch Subsystem
Trace cache aims to improve the bandwidth of instmctions delivered from the
instmction fetch stage in wide issue superscalar processors [10]. This section will
provide background on the traditional instruction fetch stage for superscalar
machines, and why it proves to be inadequate for increasingly wider issue
architectures.
The instruction fetch subsystem of a superscalar processor has the following
core components:
Program counter
LI predecoded instmction cache
Branch target buffer
Return address stack
Branch direction predictor
Branch target logic
Among these six, the program counter is simplest. Unchanged from the most
basic architecture, this register holds the next fetch address from which the
instmction cache is accessed.
At the top of the memory hierarchy for anyprocessor is the first level cache.
For scalar designs, there is no particular advantage to either a separate (Harvard)
or unified LI cache design. Superscalar machines utilizing instruction
predecoding favor separate instmction and data caches. The I-Cache is
19
interleaved, i.e. 2 consecutive cache lines can be accessed. This allows retrieval of
a set of instmctions the size of an entire cache line regardless of where the initial
instruction lies in the cache. The necessary interchange, shift and mask logic to
realize this is assumed to consume a negligible (or at least acceptable) delay time
within a single cycle [10]. Predecoding entails the incorporation of a predecode
unit between the second-level cache and the LI I-Cache. As lines are written to
the I-Cache a number of bits (between four and seven based on recent
implementations) are appended for each instruction. These bits can be used to
indicate instmction class, resource requirements, and even possibly the branch
target address [1]. For this thesis, predecode bits are assumed to provide a
distinction between the various control transfer instructions.
The branch target buffer plays an important role in i<aentifying branch targets
early in the pipeline, as described in the previous section. The organization of
this structure can vary in associativity depending on implementation, though is
often two or four-way set associative. Conditional branches and direct jumps are
stored in the BTB. Alongside the BTB, the Return Address Stack (RAS)
provides a mechanism to help predict the target address for subroutine returns.
The stack depth is set; usually eight proves to be sufficient in most
implementations. For every subroutine call (jump-and-link) instruction
encountered, the address of the subsequent sequential instmction is pushed onto
the stack When a subroutine return is encountered, the topmost address is
popped and used as the branch address prediction. The RAS increases the
accuracyof subroutine returns considerably, though there are situations when the
RAS mechanism can become corrupted, resulting in address mispredictions. This
can occur if the RAS overflows, orwhen certain sequences of instructions along a
mis-speculated path are fetched. While these RAS misses do not affect the
correctness of program execution, they impact performance as would a branch
direction misprediction
20
Branch prediction can be implemented as any of the various schemes
discussed in the previous section. For each instruction fetched, the branch
predictor is accessed simultaneously with the BTB and RAS. The branch target
logic serves as the glue between these units to determine the set of instructions
that will be passed down the pipeline and how the PC should be set for the next
fetch cycle. First, the predecode bits are examined to determine the control
transfer operations within the cache line. The first branch in the sequence will
terminate the set passed to the IFQ. If this branch is a jump (direct, indirect,
subroutine call) the PC will be set to the corresponding address generated by the
BTB. Similarly a subroutine return will utilize the address generated by the RAS.
The target address of conditional branches depends on the branch direction
prediction. A prediction of taken will set the PC to the BTB generated address, a
not-taken prediction will simply set the PC to the address of the next sequential
instruction.
Predecoded &
Interleaved
I-Cache
'
Mask/
Interchange/Shift
Figure 2.9: Fetch Subsystem Components
21
How does the core fetch unit described above hinder performance in a wide-
issue superscalar machine? Formost code, the percentage of branch instructions
is between 10% and 20%. This equates to a basic block size of between 5 and 10
instructions [1]. As the issue width of architectures exceed 4 instructions per
cycle, it becomes obvious that not only is extracting parallelism beyond a basic
block crucial, but instmctions must also be fetchedbeyond a single basic block per
cycle. In an effort to resolve this problem, a series of revisions and alternatives to
the fetch method just described are presented next.
Revision 1 - Fetching PastPredictedNot-Taken ConditionalBranches
The first revision to the fetch subsytem is one that partially alleviates the single
basic block fetch limit by targeting conditional branches that are predicted not-
taken. Since the I-Cache is interleaved, a set of instructions the size of a full
cache line can be retrieved every cycle. When a conditional branch is
encountered, it is possible that the prediction will be not-taken. If this is the case,
there is no cache limitation to fetehing instructions beyond the branch and
including themwith the set of instmctions thatwill be appended to the IFQ. Ifm
conditional branches are to be predicted per cycle, then up to m + 1 basic blocks
maybe fetched in the same cycle if all branches are predicted not-taken. Changes
must be made to the BTB and predictor for this modification. Since it is now
required that more than one branch target be accessed per cycle, the BTB must
be interleaved to allow parallel accesses. Similarly, the branch predictor must
now be able to handle multiple predictions per cycle. Just as there are many
approaches for single branch prediction, several variations to multiple branch
prediction have been proposed. The scheme that will be considered here is an
expansion of the GAg single branch prediction method. Called an MGAg
predictor, the components remain the same (a global history register of width k
and pattern history table of t entries) though multiple predictions are made via
22
iterative access of the PHT up to m predictions. The access constituting the first
iteration is made in the same fashion as the basic GAg predictor. The result
becomes the prediction for the first branch. The second access is made using the
k1 most resent bits of the GHR This provides a base index into the PHT. An
additional offset (0 or 1) is added to this index depending on the result of the first
prediction (NT or T). The prediction for the second branch is then determined
from the bimodal entry indexed by this newly computed index. The next
iteration uses k 2 bits of the GHR to determine a base index, and an offset
value of 0, 1, 2 or 3 depending on the combined prediction of the previous two
branches (NT/NT, NT/T, T/NT or NT/NT). This continues until m
predictions have been made [8]. A graphical representation of the MGAg
predictor is shown in Figure 2.10.
Pattern History
Table
Global History Register
k-i
k
=0
select
Secondary
Branch
Prediction
_Primary Branch
Prediction
Figure 2.10: MGAg Predictor [8]
While this revision manages to improve the fetch bandwidth over the
original, there still exist shortcomings.
Statistics indicate that conditional
branches consist of 66% of all control transfer instmctions, of which only 25%
are evaluated not-taken [1]. Therefore, approximately 83% of all branches (those
that are taken) still manage to limit the rate of instructions
passed down the
23
pipeline. The next two methods provide different approaches to overcoming the
restriction posed by predicted taken conditional branches and jump instructions.
Revision 2a CollapsingBuffer
The collapsing buffer [8] improves the fetch subsystem further by considering
intrablock branches. These are branches that are predicted taken, but only
constitute a short hop within the current pair of cache lines accessed in the
intedeaved I-Cache. The branch target logic must be expanded to determine
such intrablock branches and communicate this to the collapsing buffer following
the interchange/mask logic of the I-Cache. The collapsing buffer removes
instructions that fall between intrablock branches and their target so that the
result is a series of basic blocks that can be appended direcdy to the IFQ. The
collapsing buffer is illustrated below in Figure 2.1 1.
fetch
addreas.
BRAKCHTARGETBUFFER
leeway Interleaved
1
LOGIC
MULTIPLE
BRANCH
PREDICTOR
wild insmictlrxre pit rector
Line SLaj (6 [nsmictions
Iw-.ooooooo/iiiMotiu
raider
address
Myta#fl I
* 1
branch 2-Wa; ' Im erleaved
Instri ctfe n Cache
Line Size m 16 Instmctions
I I I I I I ft I.I I II I I
J iaterttock
branch
lNTmCHANOB/MASK
I
3-
HX I i i ' i i m I f I I l l l M I I
uwuUi'Y.i mm ^P
rrinAi^ixnni!FPKli
X to decoder
Figure 2.1 1: Collapsing Buffer [8]
24
Revision 2b BranchAddress Cache
Another approach that enables multiple basic blocks to be fetched per cycle is
the branch address cache approach [9]. Required for this scheme is a ?-way
intedeaved I-Cache (versus the two-way version utilized thus fir). Presented as a
two-stage implementation, the branch address cache is first accessed with the PC
address. The BAC acts as an expanded BTB in that it returns information
pertaining to the branch targets. But unlike the BTB that returns a single target
address for a particular branch, the BAC returns a series of branch targets,
arranged as a tree that provides all possible taken/not-taken targets for m
branches. Using m results from the multiple branch predictor, the appropriate
branch targets are chosen. The second stage retrieves the blocks from the
intedeaved I-cache, then interchanges/aligns the group to pass to the IFQ. The
BAC approach is illustrated in Figure 2.12.
BRANCH ADDRESS CACHE
II
bill'
del I Irlct I I I Irfflc^
Mil Baiter
ronlro! Logit
Predictor
select logic >-t
c
= i 3wediditins
OJ 0j (eg- 1 1 i)
address calculaiion logic
TTT I
bank adtkctJM Utchcs
INTERLEAVED INSTRUCTION CACHE
in., i*,,SSJLLLlliliri
c; <; 0
Figure 2.12: Branch Address Cache [9]
Both schemes presented in the second revision of the fetch subsystem have
drawbacks as well. The collapsing buffer and branch address cache are fairly
25
complex, and would reqiiire multiple cycles in a hardware implementation. This
adds to the latency required for instruction fetch. Cache bank conflicts may also
occur when the cache line holding the initial fetch address resides in the same
bank as successive lines. Scalability is an issue for the BAC (each entry requires
2m branch targets) while the collapsing buffer can only fetch across a pair of cache
lines. Trace cache schemes resolve these problems, providing the fetch
subsystem with a instmction supplymechanism that provides both low latency
and high bandwidth. Chapter 3 provides a thorough discussion of trace cache
and associated instruction pre-processing optimizations. The next section
introduces the SimpleScalar simulator in the context of the functional processor
model
2.6 The SimpleScalarSimulatorArchitecture
The simulation work for this thesis was based on the third version of the
SimpleScalar tool set. SimpleScalar provides a fairly comprehensive functional
model for investigating various aspects of a microarchitecture. Included with the
standard distribution are a handful of simulators. The simulator of interest to this
study was simoutorder, a detailed superscalar model that supports out-of-order
issue and execution [11, 12]. To place the theoretical background of this chapter
in perspective, this simulator will be described in context of the functional
processor model.
The native target ISA of the SuperScalar tools is PISA which is largely based
on MIPS-IV with a few exceptions (no branch delay slot, expanded load/store
instructions, a square root instruction and 64-bit instmctions). Included with the
simulator is a compiler, linker and other support tools that target the simulator
instmction set. The out-of-order simulator is based on flexible parameters for
decode, dispatch and commit widths. The size of the IFQ is also adjustable.
Instructions are consumed from the IFQ in-order, with a sliding window the size
26
of the decode width. The issue mechanisms is based on the register update unit
(RUU) [4]. This approach combines the discrete tasks of shelving, register
renaming and reordering into a single structure that is realizable in hardware.
One will recall that the RUU is arranged as a circular buffer. The value for the
number of RUU entries is variable, and is set as a simulation parameter. The
functional units that allowparallel execution are divided into 5 classes, integer and
floating point ALUs and multipliers and a load store unit. The number of
arithmetic EUs and number of load/store ports unit are all adjustable. Bydesign,
the RUU enforces strong sequential instruction consistency and precise interrupt
handling.
The simoutorder fetch unit encompasses all aspects of the fetch subsystem
illustrated in Figure 2.9 (Section 2.5). The BTB can be configured with different
size and associativity values. Likewise, the number RAS of entries can be set.
Predecode bits are implied, and are utilized by the RAS when identifying
subroutine calls and returns. Several schemes are available for branch prediction.
The method utilized in generating base results (for comparison against results
utilizing the trace cache extension) is a two-level local predictor (PAg). The level
of speculative processing supported by simoutorder is unbounded (no limit to the
number of unresolved branches in-flight) and the degree of speculation extends
through instmction execution. Figure 2.13 outlines the simulator architecture in
the design space of the functional processor model.
27
Superscalar issue/decode. Issue rate set via parameter.
In-order, slidingwindow consumption from IFQ
Speculative Execution
o Unbounded level of speculativeness
o Degree of speculativeness through Instruction Execute
Register Renaming
o RUU layout
o Rename registers integrated as operand value fields in RUU
entries.
o Associative rename table (tag unit).
o Issue Bound Operand Fetch Policy
Shelving
o RUU layout (serves as central reservation station)
o Issue Bound Operand Fetch Policy
o Out-of-order dispatch, loads/stores take precedence, oldest-first
selection otherwise
o Explicit status bits for operand availability checking
o No shelving buffer bypassing
Figure 2.13: Design Space Outline of sim-outarder
28
Chapter 3
Trace Cache Schemes
BuildingcffthebaokgriundofChapter Tisa, this chapter introduces the trace cache bypresenting
tarious schemes that haw beenproposed Dynamic instructionpre-processing cptinizations are
alsoexplored The sole trace cache implementation, thePentium4sExeaaionTrace Cache, is
mentionedat doe conclusion cfthe chapter.
3.1 Concept of a Dynamic Trace
Before exploring the specifics of various trace cache schemes, it is necessary to
first precisely define a trace. Standard I-caches stores instructions in static
program order. This layout is the result of the compiler translation of high-level
code to the operations that comprise the ISA of the processor. For sequences
that don't contain branches, the dynamic execution order is the same as the
static program order. Of course code also contains control transfer instmctions
that introduce non-sequential program flow. This causes the dynamic execution
order to deviate from that of the static program order. A trace is finite piece of
this dynamic execution. The fundamental concept behind trace cache is storage
of these
"snapshots"
of previous execution. When processing returns to these
points in the program, the stored traces can be utilized in overcoming the basic
block fetch limitation explained in Section 2.5.
29
Static Program Order
A: ADDIU R14,R31,#1
BEQ R2,R14,<B> (1)
ADDIU R21,R21,1
B: SLTU R2,R8,R17
BNE R2,R31,<C> (2)
ADDUI R8,R8,#1
C: LW R2,0(R8)
ADDUI R1,R1,#1
ADDUI R2 , R2 , #3
BNE R2 , R3 , <D> (3)
ADDIU R8,R8,#1
D: J R31
Dynamic Execution Order
(Branches > T, NT, T)
A: ADDIU R14,R31,#1
BEQ R2,R14,<B> (1)
B: SLTU R2,R8,R17
BNE R2,R31,<C> (2)
ADDUI R8,R8,#1
C: LW R2,0(R8)
ADDUI R1,R1,#1
ADDUI R2,R2,#3
BNE R2,R3,<D> (3)
D: J R31
Figure 3.1: Static ProgramOrder versus
Dynamic Execution Order
3.2 Rotenberg Trace Cache
Rotenberg, Bennett and Smith proposed one of the first trace cache designs in
1995 [10]. As presented in their paper, trace cache supplements the usual
instmction cache by storing individual traces of dynamic instruction streams.
Each line of the trace cache contains up to n instmctions, and at most m basic
blocks. The maximum number of basic blocks within a trace cache line is
constrained by the throughput of the multiple branch predictor (MGAg). The
reason behind this constraint is the number of conditional branches in a trace
cache line cannot exceed the number of parallel results from the predictor to
which comparisons are made. Over the course of program execution,
instructions that are retired are added to the fill buffer of the trace cache. When
the number of instructions or basic blocks in the fill buffer meet n or m
respectively, the group of instmctions is added as a new line to the trace cache.
An example trace cache line is shown in Figure 3.2. In addition to the instmction
stream, additional information is recorded. Branch Flags indicate the path
30
followed by each conditional branch within the trace. Since a variable number of
branches could occur within a trace, a Branch Mask field must also be provided,
indicating the number of branches (with a maximum ofml) and whether the
trace ends in a branch. Two addresses are also stored, pointing to the next
execution point following the last instruction of the trace. One is the Fall-
through Address (corresponding to a not-taken result for a trace-terminating
branch) and the other the Trace Target Address (corresponding to a taken
result.) If the last instruction in the trace is not a conditional branch, both
address fields point to the cache line starting with the next sequential instruction.
In addition to the constraints n and m, an indirect jump or subroutine return also
terminates a trace.
Ill 11,1 X
Tag Branch Branch Fall-through Target Instructions
Flags Mask Address Address
Figure 3.2: Example Trace Cache Segment
During instruction fetch, the trace cache is accessed in parallel with the I-
Cache. When program execution presumably returns to an instruction that starts
a cache line, the branches within the trace cache line are referenced with the
results of the multiple branch predictor. If the predicted branch directions match
each of the entries in the Branch Flags field, then the entire trace cache line can
be fetched. If the predictions do not match the trace, then blocks are fetched
from the instruction cache, and the trace cache line will be updated with the new
stream of dynamic instructions.
Returning to the alternate fetch mechanisms that were introduced in the
previous chapter, one can note the distinct advantages of the trace cache over the
branch address cache and collapsing buffer approaches. The trace cache does not
require any I-Cache modifications beyond the two way interleaved organization
of the basic fetch unit. In addition, there exist no possibility for bank conflicts
31
that negate performance gains. The latency of the trace cache when fetching
instructions is minimal; no critical path logic for interchange, mask or alignment
of instructions is required. Finally, the fetch bandwidth provided by the trace
cache is a substantial improvement over the core fetch mechanism, as will be
shown in the simulation results ofChapter 5.
Despite the vast improvement over other alternate fetch mechanisms, the
trace cache design presented above is limited by a few factors. In fact,
Rotenberg, Bennett and Smith [10] suggest several additions to the general trace
cache strategy that would yield better performance. One aspect of the scheme
that can be improved is how frequentiy and inftequendy visited traces are
maintained.
FETCH
AQDKKSS INSTRUCTION LATCH ADDRESS
23
TRACE CACHE
iWSiftdi la/gcl
mLfcOt; logic:
UNE-RUL BUFFER
i 'm pt-cd Id ion.-
from
PREDICTOR
-~<\:
i lustrutiiOfl*
CORE FETCH UNIT
BiSTRCACHE
H
rn.
' ( maskflrncrsltiingcfrhitr J
' a instructions
I MUX /
INSTRUCTION' LATCH
Figure 3.3: The Rotenberg et al Trace Cache [10]
Solutions include judicious trace selection (only committing traces that have been
executed a minimum number of times) and a victim trace cache (storing recendy
displaced traces such that they could easily be recovered if needed.)
32
Table 3.1 presents a set of general limitations, and corresponding solutions
that were subsequendy proposed. Many of these schemes will be discussed in
this section.
Limitation:
Solution:
Maximum number of conditional branches within a Trace
Cache line.
Path-Based Prediction
Branch Promotion/Trace Packing
Section
(3.3
(3.4)
Limitation:
Solution:
Trace Cache indexed byaddress of the first instruction;
No multiple paths.
Fetch address reriaming (3.5)
Limitation:
Solution:
Trace Cache Miss Rate
PartialMatching /Inactive Issue
Trace Preconstruction
(3.6)
(3.7)
Limitation:
Solution:
Storage/Resource Inefficiency
Block-based schemes
Cost-regulated trace packing
Selective trace storage
Pre-processing/Fill unitOptimizations
(3.8)
(3.9)
(3.10)
(3.11)
Table 3.1: Trace Cache Limitations and Solutions
Overcoming theMaximum NumberofConditionalBranches within a
Trace Cache Line
3.3 Path-based Next-trace Prediction
The trace cache design presented above incorporated explicit multiple branch
predictions to determine the next trace. Jacobson, Rotenberg and Smith found it
possible to improve the next-trace prediction accuracy by 26% via path based
trace prediction [13]. Rather than use the individual predictions from a multiple
branch predictor, a predictor based solelyon the trace path historydetermines the
next trace. The trace cache is indexed via a combination of trace history and the
33
address of the first instruction in the trace. In contrast to the use of the starting
address of the trace alone, this scheme inherendy allows for multiple paths (path
associativity), as suggested in [10]. The path-based trace predictor scheme
incorporates a primary correlated trace predictor and a secondary predictor. The
secondary predictor is included so mispredictions are reduced from "cold
starts"
(when the path history has not yet been established) and aliasing in the correlating
table. A block diagram of the combining trace predictor is shown in Figure 3.4.
HISTORY REGISTER
[Hashed B) | [ttestted ID 1 1Hashed IP | Inched7p~U-
^
.
^ ^
Prediction
Figure 3.4: Combining Trace Predictor [13]
The primary predictor stores a path history of the previous n traces as a series of
hashed history entries for each trace. Each entry is formed from a 36-bit Trace
ID consisting of the PC for the starting address in the trace cache line along
with
up to six bits encoding the conditional branch outcomes within
the line. The
hashing function is illustrated in Figure 3.5.
34
12 bits 2 bits 2 bits
Remaining LSB ofRemaining LSB of
Cond Branch Identifiers
Cond. Branch LSB
Figure 3.5: Hashed History Register Entry
From the series of entries constituting the history register, an index into the
correlating table is formed. Taking a few bits from the history entries generates
this index. The most recent entry in the history register is given the most weight
in contributing to this index. The second most recent is given a slighdy lower
weight, while older history entries each contribute the least number of bits. This
generation mechanism is shown graphically below in Figure 3.6. The term
"DOLC" has been established as the name for this method, each letter
representing an element of the scheme. Depth is the number of entries, not
including the last history entry. Last and Current correspond to the second most,
andmost recent history entries. Older entries constitute the remaining entries.
D
D back H> 3 back ID 2 back ID 1 back ID CurretrtlD
Cbils
XQR
'Width bits
INDEX
Figure 3.6: DOLC Index Generation [13]
The indexed location in the table provides the Trace ID of the predicted next
trace. If this prediction is found to be correct further down the pipeline, then a
two-bit saturating counter for the table entry is incremented by one. Otherwise,
the counter is decremented by two for a misprediction. If the counter is equal to
35
zero after being decremented, the Trace ID for that entry in the correlating table
is updated to the actual trace. Additionally, if a prediction is incorrect, the
specuktive entry in the history register is replaced by the hashed history entry of
the actual trace.
If an index into the primary correlating table yields an entry that is unrelated
(due to aliasing or "cold starts'') the
"prediction" has a low percentage of being
correct. This is unfortunate, as a conditional branch prediction in a similar
scenario would still offer a 50/50 chance of being correct. To compensate for
this potential downfall, a secondary predictor is incorporated and a tag field is
added to the correlating table. The index value into the secondary table is the
hashed history entry of the current trace (the "C" value). When an entry in the
correlating table is updated, the least significant ten bits of the preceding entry are
stored as the tag bits. When a prediction via the correlating table is made, the tag
field of the associated table entry is compared to the current entry in the history
register. If the corresponding ten bits match, then the primaryprediction is used.
Otherwise the entry stored in the secondary table is chosen. Regardless of what
table the prediction was chosen from, both samrating counters are incremented
or decremented respective to the correctness of each prediction. When the four-
bit counter of the secondarypredictor saturates (i.e. the next trace always follows
the current) updates of the correlating table cease. This avoids clutter of the
primary table, further reducing aliasing. The reason that Jacobson, Rotenberg and
Smith chose a four-bit counter (decremented by eight on a misprediction) was to
"avoid giving up the opportunity to use the correlated predictor unless there is a
high probability that a trace has a single
successor"[13].
Two additional (rather esoteric) mechanisms can be added to the combining trace
predictor. A Return History Stack (RHS) can be provided to augment the
performance by taking advantage of the fact that the control flow of a program is
tighdy correlated before and after a subroutine call. The trace history may not
36
capture this behavior though, as the trace history of the called subroutine will
interfere. Thus, when a trace contains a subroutine call, a copy of the History
Register is saved on a separate hardware stack. When a trace that ends in a return
is encountered, the entry at the top of the RHS is popped. The most recent
Hashed IDs contained in this entry replace the oldest IDs of the current history
(the most recent IDs in the HistoryRegister are preserved.) It is noted that the
RHS provides a way to balance the control flow history prior to the subroutine
call and the historyof the subroutine itself.
The second mechanism that can be added to the basic trace predictor is the
Alternate Trace Field. By adding this field to the Correlating Table a "second
guess"
can be made at the same time as the regular prediction and be issued
inactively (see Section 3.3). The alternate field is updated when the regular
prediction is incorrect. When the samrating counter is non-zero the alternate
field is updated with the actual next trace. When it is zero, the displaced primary
prediction is moved to the alternate field. The alternate path must be issued such
that results are not visible to those executing along the path of the primary
prediction. Pending the outcome of the branches, the instructions along the
alternate path are canceled if the primary prediction or neither prediction was
correct. If the alternate prediction proved correct, execution will continue along
that path.
3.4 Branch Promotion and Trace Packing
Two additional techniques for improving trace cache effectiveness are examined
in [15]: Branch Promotion and Trace Packing. Branch promotion exploits
the fact that over half of conditional branches tend to be strongly biased during
execution. By identifying these branches in hardware, they may be treated as
statically predicted. These
"promoted"
conditional branches are marked via a
single bit flag, and are associated with a taken or not-taken path. When the fill
37
unit writes a cache line, the promoted branches are not included in the normal
branch mask and flags fields. Thus, the predictor is alleviated from the overhead
of storing the branch history for a promoted branch. This decreases aliasing
within the predictor. If a static prediction proves incorrect (such as the final
iteration of a loop) the machine is backed up to the end of the previous block and
restarts along the correct path. The structure that decides to promote a branch to
static prediction is the bias table. This table is a simple sanitating counter indexed
by the branch address (with tag compare.) The counter is incremented when the
result of the branch is the same as the previous outcome. The fill unit will check
the bias table against conditional branches in the retired instmction stream If the
count is greater than threshold value, the branch is promoted in the fill buffer. If
the outcome of a promoted branch contradicts the static prediction twice in a
row, the branch is demoted, and the branch bias table entry is cleared. Demotion
upon two consecutive mispredictions was established to avoid the final iteration
of a loop from demoting an otherwise strongly biased branch. Likewise, if the
branch bias count falls below the threshold (the result of an alternating series of
taken/non-taken results) the branch is demoted.
Patel et al note that in addition to reducing the volume of branches required
to be output by the predictor, it could be possible to implement a single
aggressive combining predictor (versus a less accurate multiple branch predictor)
in an eight-wide machine. This is because the overwhelming number of trace
lines would simplyhave only a single branch needing a dynamic prediction.
The idea of trace packing involves filling a trace cache line irrespective of fetch
block boundaries. Hence if a block is larger than the space available in the
pending cache line of the fill unit, the fetch block will be split. After filling the
pending line, the remaining instmction will start a new line in the fill unit. For a
dynamic sequence of instmctions, this method implies there could exist many
segments that contain redundant trace information. For example, consider a
38
sequence of three basic blocks (A B, and Q that are encountered in a loop (i.e.
ABCABG..). The blocks are sized such that two whole blocks could fit in a
segment, yet all three would not. A scheme that treats blocks atomically would
produce three cache lines: AB, CA,BC If trace packing were used, the segments
would be split such that a much greater amount of trace cache storage would be
needed. In the above example, Patel et al showed that for block sizes of 8, 6 and
8 instructions for A, B and C respectively, eleven segments would be created.
This results in a loop that is dynamically unrolled: the maximum number of
instmctions will be fetched per cycle throughout the multiple iterations. Trace
packing increases the delivered fetch rate because a larger percentage of segments
utilize the maximum number of instruction slots. This comes at the cost of
redundant storage that increases the cache size requirement. It is stated in [15]
that branch promotion and trace packing are complementary techniques,
providing a 17% effective increase in fetch bandwidthwhen combined.
AllowingMultiple Path in the Trace Cache - Renaming the Fetch
Address
3.5 Fetch Address Renaming
The Rotenberg scheme allowed a single trace with a unique fetch address (index
value) to occupy the trace cache. Apre-existing trace with the same fetch address
as a new trace would be simply overwritten. This can lead to consistent trace
cache misses and thrashing of the trace cache if multiple paths with the same
suiting address occur frequendy in the dynamic execution of a program The
generic solution to this problem is to provide a hashing function that generates
trace cache indices, or Trace IDs, based on various inputs. The path-based
prediction scheme makes use of fetch address renaming. The renamed trace ID
consists of the fetch address concatenated with the branch flags. The mechanism
39
that generates the renamed trace IDs for this scheme also serves as the prediction
mechanism (Figure 3.4). This allows the trace cache to remain a direct mapped
structure while still providing the advantage of retaining multiple paths.
Improving the Trace Cache Hit Rate
3.6 PartialMatching and Inactive Issue
Friendly, Patel and Patt explored two techniques for improving the performance
of trace cache: PartialMatching and Inactive Issue [14]. Partial rmtehing, as
suggested in [10] can cause a match in the trace cache even if only the first few
branch predictions correspond. This requires target and fall through addresses
for each branch in the trace. Inactive issue presents a variation on partial
rnatehing by essentially implementing predication of traces. Instead of discarding
portions of a trace cache line that do not match the outcome of the multiple
branch prediction, the entire line is issued. The blocks that do not match the
prediction are referred to as inactive. Though these inactive instructions issue,
their results are not visible to instructions executing along the speculative path
determined by the multiple predictor. Inactive issue requires additional logic in
the issue/scheduling mechanism so in-flight instructions that are inactive are
differentiated from those that are along the primary path. If the outcomes of the
multiple branch predictions are correct, the inactive instmctions are discarded.
Though if the predictions prove incorrect, some of the correct path has already
been issued and possibly executed though the inactive blocks, and can be
promoted to active status.
40
3.7 Trace Preconstruction
Trace preconstruction, discussed in [19], is a proposed technique to reduce
trace cache miss rates, and is somewhat analogous to instmction prefetehing.
The extinguishing factor between the two methods is that traces are not an
explicit part of the memory hierarchy (as are instmction blocks) and therefore
must be preconstructed versus prefetched from a lower level of the hierarchy. A
fundamental observation allows the preconstruction rrjechanism to be
incorporated into a design that utilizes trace cache: While instructions are being
provided via the trace cache, the slowpath of the fetch unit is idle. The resources
that constitute this slow path are the traditional branch predictor, the instruction
cache and the trace constructor. The goal of the preconstruction algorithm is to
build probable traces prior to the point where they are utilized. Determining
these traces is achieved by identifying regions of code that will be encountered
later in the course of normal execution. There are two possible types of regon
startpoints. The first is an instruction following a subroutine branch (jump-and-
link.) This represents code that will be executed subsequent to the subroutine
return. The second type of region start point is an instruction following a
backward branch. A sequence of static code before a backwards branch
represents a loop. After the closing branch is evaluated not-taken (following the
final iteration), flowwill continue at the next instruction.
When encountered, the region start points are pushed onto a startpoint stack.
If a start point is identified, but matches the entry at the top of the stack, the
duplicate is not pushed. A duplicate of this nature would indicate a loop
encountering the closing branch over multiple iterations. The top entry of the
stack is popped when the preconstructor is ready to begin working on a new
region. This preconstruction effort involves a breadth first traversal of all
possible paths, resulting in a set of possible traces. The region start point is used
as the first entry in a worklist of trace start points. These trace start points differ
41
from region start points in that they identify where traces within the region may
begin. Figure 3.7 shows a directed graph representation of static code and the
resulting preconstruction regions and traces.
A
* \
-TBr2 \
r
\
*Brl
-J3r3
\iMP
START POINT: JAL Brl
4^
Static Code Graph Preconstructed Regions and Traces
Figure 3.7: Static Code and Corresponding Preconstruction
Graph [19]
After block a, a subroutine branch is encountered The address following this
JAL is pushed onto the start point stack. Assuming that the slow path hardware
resources are available, the preconstructor generates a set of traces for the region.
These traces might be <h,if> and <h,i,i> (assuming a non-packing fill unit). The
two corresponding trace start points recorded in the worklist are the starting
address of block i, and the address following block/ To reduce the potential
number of paths widiin a region, highly biased branches are followed through
their dominant direction only. Jacobson and Smith note that a trace construction
scheme that utilizing pure trace packing is likely to defeat trace preconstruction,
as it would be unlikely that the actual trace path would align with the region start
points. A heuristic of allowing an even multiple of instructions past a block
terminating branch (a variation of cost-regulated trace packing) is proposed.
Preconstruction for a region will terminate under one of three conditions. If
the processor catches up (Le. execution reaches the region of code) then the
42
preconstructor moves onto the next region identified in the start point stack
Each preconstruction region is allocated limited resources; if these resources are
consumed, no further preconstructed traces for that region are generated. The
preconstruction effort is also bounded by indirect jumps (subroutine returns), as
the target is unknown in the static context.
The implementation of trace preconstruction utilizes buffers to avoid
pollution of the trace cache. When the trace cache is accessed, the trace
preconstruction buffers are accessed in parallel If the particular index into the
trace cache misses, though the entry is found in the preconstruction buffer, then
that trace is moved into the trace cache. Similarly, the trace cache is referenced
before inserting a preconstructed trace in the buffer. If the trace exists, then the
redundancy of inserting into the preconstruction buffer is avoided. If the
preconstruction buffers are organized in a set associative fashion, the replacement
policy is governed by the region from which the traces were constructed. When
execution catches up to a preconstructed region, it is termed the actiie region. No
traces in the buffers are replaced if they are from the active region. The
preconstruction buffer replacement policy then gives precedence to traces from
newer regions. A small separate buffer records the most recent regions from
which traces were preconstructed. If one of the same regions is again identified
in the start point stack, it is skipped to avoid redundant processing.
Two hardware implementation optimizations are suggested in [19]. One is
the use of a small prefetch cache. Since instmctions within a region are used in
multiple preconstructed trace segments, it is advantageous to have a small (256
instruction) cache to avoid the latency associated with accessing the instruction
redundantly. Allowing this prefetch cache to be fully associative, and not
allowing replacment once a cache has been assigned a segment effectively
contains the preconstruction effort for a region by halting once the prefetch
cache has been filled. After the prefetch cache is full, the cache is invalidated,
and preconstruction starts with a new start point off the stack. The second
43
optimization involves incorporating multiple parallel trace preconstructors, each
one able to work from a different trace start point, be it from a single or from
multiple regions.
Jacobson and Smith report performance of the trace preconstruction
mechanism in terms of total size of traces. This includes both the trace cache and
trace preconstruction buffers. For many programs, there is a distinct tradeoff
between allocating the available space resources between the two entities. As a
possibility for further investigation, dynamic portioning of the trace
cache/preconstruction buffer is suggested. The most significant advantage to
preconstruction is when paired with pre-processing enhancements, such as those
discussed in [16] or in the next section.
To conclude this section, a unique approach to modeling trace cache
enhanced systems is mentioned. This extended pipeline model [19] considers a
processor from the perspective of three independent pipelines: The instruction
pre-processing, fetch/decode, and execution pipelines. The entity that decouples
the pre-processing from the fetch/decode portion is the trace cache, much like
shelving decouples issue from dispatch and execute.
Pre-processing
Trace
Cache Fetch/Decode Execute
Figure 3.8: Extended Pipeline Model
ImprovingStorage andResourceEfficiency
3.8 Block Cache
The schemes of the last few sections proposed enhancement to a design based on
a
"traditional"
trace cache. Black et al suggest a design that involves separating
44
the trace cache entity into a Trace Table and Block Cache [17]. A diagram
representation of this scheme, compared with a traditional trace cache, is shown
in Figure 3.9. The Block Cache, replicated w times, stores basic blocks at unique
locations. A re-named identifier indexes each block in the replicated table. This
method is similar to the one used in the correkting and secondary tables of the
path based prediction scheme of [13] (versus the by-address indexing scheme
used in [10].) The trace table is similar in purpose to the traditional trace cache
entity, but instead of storing traces expliciuy, the trace table stores a sequence of
block cache indices, along with some additional information. A trace table read
proceeds as follows: First, the block ID and branch history are hashed to form
the predicted next trace ID. The trace ID serves as an index into the trace table.
The block IDs from the trace table entry are retrieved from the block cache.
Because the individual blocks are stored without respect to any trace order, they
must be aligned when retrieved to form the group of instructions send to the
decode unit This instruction collapse is directed by a set of steering bits included
with each Block ID within a trace table entry. This step adds some additional
overhead to the critical path of the fetch stage (handled in the traditional trace
cache by the fill unit) Black et al. state that the collapse/alignment step may be
efficiendy implemented in hardware and its addition would not add appreciable
latency.
tiace_irj
U I U J I HI III
Trace Cache
Feted Buffer
Completion
Conventional Trace Cache Blocked-Based Trace Cache
Figure 3.9: Conventional versus Blocked-Based Trace Cache [17]
45
When instructions retire, they are captured in order by the fill buffer. When a
conditional branch is encountered or the physical block size limit is reached, the
block fetch address (the address of the first instruction in the buffer) is compared
to the entries of the rename table. If an entry already exists, then the fill buffer is
simply flushed. Otherwise, the block fetch address is inserted into the set-
associative, tag-checked rename table (LRU replacement pohcy) and the block is
wntten to the location in the block cache referenced by the assigned Block ID.
The newly allocated block can already exist in traces in the trace table. If one of
these traces is issued as a next-trace prediction, the block re-identified with the
Block ID will be erroneously issued. This case is handled as a misprediction.
Traces are formed via the unit, recording the sequence of Block IDs, and are
subsequendy inserted into the trace table.
The motivation behind implementing the Block Cache is to avoid redundant
storage of basic blocks in multiple traces. With ideal branch prediction, it is
claimed that a IK block cache achieves the same performance of a 32K
traditional trace cache. The next section suggests another optimization geared at
eliniinating storage redundancy between the I-cache and trace cache.
3.9 CostRegulated Trace Packing
A modified trace packing scheme adds a fill unit constraint: If the number of
unused instruction slots is greater than or equal to half the size of next block to
be written to the fill buffer, or, the last branch in the fill buffer has a backwards
displacement of 32 or fewer instructions, trace packing is used. Termed cost-
regulated trace packing, this allows space at the ends of segments that would
otherwise be un-utilized to be filled. Small loops benefits from this dynamic
unrolling. At the same time, space is conserved and trace alignment is improved
(compared to full trace packing) [15].
46
3.10 Selective Trace Storage
Ramirez et al propose a scheme to avoid redundancybetween the instruction
and trace cache through selective trace storage (SIS) [18]. Combined with a
compiler optimization called software trace cache, they show that a 128 KB trace
cache can be reduced to 2 KB and retain performance while lowering
implementation cost. The redundancy targeted in this scheme is sequences of
fetch blocks that exist contiguouslynot only in the trace cache, but also statically
in the instruction cache.
Fetching multiple contiguous blocks from instruction cache in a single cycle
has been shown to be fairly straightforward (Reusion One of the fetch unit
Chapter 2, Section 5). When fetching a set of instmctions whose branches are all
predicted non-taken, no efficiency is gained by accessing the trace cache over the
instmction cache. Such a trace (with no taken branches) is referred to as a blue
trace, fomirez et aL state that blue traces account for over 70% of program layout
for floating point and 40% for integer applications (16 instruction fetch width).
Software trace cache can increases the percentage for integer applications to 50 to
88%. Storing blue traces in the trace cache is allocating duplicate segments,
possibly exacting a segment which contains predicted taken branches. Adding logic
to the fill unit can recognize blue traces and simply ignore them when writing to
the trace cache, alleviating the load on the trace cache substantially. Red traces
(those constructed by the fill unit containing predicted taken branches) are stored
in the trace cache as before.
3.11 Fill UnitOptimizations
Four optimization mechanisms are proposed by Friendly et al in [16] that can be
incorporated with the fill unit of the trace cache. These constitute the first of the
instmction pre-processing techniques that are examined. Placing extra logic in
the fill unit does not hinder the fetch efficiency, as it is outside the critical path of
47
the fetch mechanism. Also, it is shown that the fill unit latencyhas little effect on
performance, negligibly impacting the measure of fetch instructions per cycle
when varied from 1 to 10 cycles.
The first fill unit optimization is to flag register-to-registermove operations. This
allows the register renaming mechanism to simply map the destination
architectural register to the physical registerwhich contains the data of the source.
The advantage is that no resources (i.e. functional units) are occupied by the
instruction. This is accomplished in an architecture that implements a reorder
buffer. An entry for the move instruction is added to the tail of the reorder
buffer. If the source operand (architectural) of the move operation is identified
as
"busy" (Le. a previous instruction is waiting to commit its result) then a
physical register with that result has been allocated. The value field of the reorder
buffer entry will point to this physical register, or if the source was identified as
not "busy", the physical register identified by the architectural state will be used.
The illustration in Figure 3.10 is based upon the code sample:
1) ADDI R1,R31,#3 0
2) ADDI R2,R31,#44
3) ADDI R1,R1,#5
4) ADD R2,R1,R31
The final instmction implements a register-to-register move by adding zero to the
source RI and storing the result in R2. The first two instmctions are committed
by the time the third instruction is fetched. Since no in-flight dependencies exist,
the third instruction can be assigned a ROB entry (entry 1), issued and dispatched
immediately. The fourth instmction, tagged as a register-to-register move in the
trace cache, is not issued in the usual fashion. It is neither placed in a reservation
station, nor handled by a functional unit. Instead it is allocated a reorder buffer
48
entry (entry 2), and points to the physical register allocated for the result of the
third instruction (Figure 3.10a).
Physical
RegislEis
Physical
Registers
Figure 3.10: Register-to-registermove optimization
The state of the system after instructions 3 and 4 are committed is shown in
Figure 3.10b and 3.10c respectively. Dotted entries or physical register represent
thosewhich have been released to the available resource pool.
The second fill unit optimization is similar to a common compiler optimization.
Called reassociation, it involves a series of immediate instructions such as:
ADDI R2,R1,#4
ADDI R3,R2,#4
and substitutes ADDI R3, RI, #8 for the second instruction. This eliminates the
data dependency between the two instructions. The advantage of this fill unit
optimization over the compiler is that reassociation over block boundaries can be
performed.
49
The third optimization presented is similar to reassociation in that it removes data
dependencies between a pair of instructions. By adding the ability to perform
scaled adds to the functional unit (i.e. slladd z , y, x, i, described in RTL as
z <r- (x << i) + y) the second instruction of the sequence
SLLI R2,R1,#1
ADDI R3,R2,R4
can be replaced with slladd R3 , R4 , ri , #4 . Friendly et al state that the
additional logic required for a scaled add instructionwould be minimal andwould
not be a contributing factor to the critical path of the functional unit. As a
conservative measure, the shift amount is limited to three.
In a superscalar processor, it is likely that the execution pipes will be clustered.
This implies that the result of an instruction will be available to dependent
instructions within the cluster the cycle immediately following execution
Because of implementation constraints, the result is not available globally until a
certain delay. The fill unit can alleviate this cross cluster delay penalty by
indicating the functional unit cluster to which the instructions should be issued.
In addition to the single bit used for register-to-register move flag, four bits are
required for each instruction within a segment to convey the order/EU steering
information.
3.12 AnAlternate Approach to Filling the Trace Cache
Prior to the initial Rotenberg paper on trace cache, a US patent was filed for a
DynamicFlowInstruction CacheMemory Organizedaround Trace Segments Independent of
VirtualAddress Line [20]. Described is a mechanism that closely approximates
the trace cache concept (published a year later). One interesting aspect of this
pioneering design is the fill unit policy. The Rotenberg scheme entails flushing
50
the fill buffer to the trace cache once the maximum number of instmctions ()
ot basic blocks (m) has been reached. The next instruction to retire will be
added to the empty fill buffer as the first instruction of a future trace. The fill
method described in [20] differs by committing a trace line when n or m has
been reached, then discarding the frontmost (oldest) basic block from the fill
buffer and shifting the remaining instructions to free room for newly retired
instructions. If effect, every new basic block encountered in the dynamic
instruction stream causes a new trace to be added to the cache. This fill
mechanism can be implemented as a circular buffer. Figure 3.11 provides a
visual comparison between the Rotenberg et al approach and the method
derived from [20,21].
-Fill Buffer-
V^/A Block2
Time
B2^^
Trace
Cache
v^r///. B**...l:,
a) "Rotenberg et
al" Fill Policy b) Alternate Fill Policy
Figure 3.1 1: Rotenberg Fill versus the Fill Policy of [20]
3.13 Additional Related Research
To conclude the discussion of background theory, this section briefly identifies
other areas that are closely related or derived from trace cache research.
51
Two mechanisms to Determine the next trace were mentioned in this chapter:
Multiple branch prediction using an extended GAg predictor (MGAg), and path-
based prediction. Several other prediction schemes, especially of the explicit
multiple branch variety have been proposed. A two level scheme that utilizes m
sets of two-bit counters for each PHT entry is mentioned in [22] and [23]. A
variation involves storing
2m
sets of two-bit counters arranged in a tree structure
(similar to that of a BAC entry) [22]. These provide straightforward extensions
that can be applied to a per-address scheme such as PAg, or the aggressive gshare
single branch predictor. The drawback (especially for the 2m version) is poor
scalabilitywith increasing values of m
Rotenberg et al propose a novel architecture in [24]: The Trace Processor.
This architecture is organized around the trace cache and treats the trace as the
basic unit of processing. The complexity required to overcome ILP limitations in
superscalar processors is ekminated in the trace processor by "distributing
execution resources based on trace boundaries" and applying path-based
prediction. By incorporating multiple functional units (that are essentially basic
superscalar processors), traces are distributed as atomic units. Intra-trace
processing utilizes resources (registers, shelving and rename buffers, etc.) widiin a
functional unit, leaving only inter-trace resources to be allocated on a global scale.
Further discussion on trace processors is beyond the scope of this chapter, the
reader is encouraged to refer to [24] and [25] formore detail.
The concept of trace cache has brought the realm of instruction
optimizations to the dynamic, hardware-based level. The Instmction Path
Coprocessor (I-OOP) is a unit that optimizes blocks of instructions according to
its own programmed behavior. The I-COP has its own instmction set, allowing it
to be extremelyversatile and extensible as a dynamic instruction preprocessor. In
addition to being able to perform trace optimizations (such as those discussed in
Section 3.5), the I-GOP can direct data prefetch for the I-Cache and
52
preconstruction for the trace cache. Papers that present further background and
implementation specifics for the I-COP include [26] and [27].
Patel and Lumetta propose a framework (rePLAY) for dynamic program
optimization that closely resembles the structure of the trace cache. The notion a
frame is central to this framework, defined as a dynamic instruction stream with a
single entryand exit point. Under a usual set of assumptions, one would identify
a frame as synonymous to a basic block The distinction is made when utilizing
branch promotion. Strongly biased branches are replaced with an ASSERT
instmction. If anASSERT instruction "fires" during execution (Le. the promoted
branch is mispredicted) then the entire frame is canceled. Frames can span
multiple lines in the frame cache, providing the opportunity to optimize sequences
of instmctions that far exceed the cache segment size of 16 instmctions. After a
frame is assembled, an entire host of optimizations can be performed irrespective
to the boundaries formed by the ASSERT statements. It is claimed in [28] that a
specific sequence of 136 instructions was reduced to 41 after the frame was
processed by the optimization engine. The techniques incorporated in the
optiriiization engine draw from classical compiler optimizations, extended basic
block optimizations and software-based dynamic optimizations, all of which are
referenced in [28].
3.14 Trace Cache Implementation: The Pentium 4
To date, the only hardware implementation to utilize a trace cache is the Intel
Pentium 4 (Willamette) processor. Information published concerning the utilized
scheme is limited, though some broad details have been made available [29]. The
trace cache of the Pentium 4 replaces the level one I-Cache completely (versus
co-existing, as is assumed in most research). The scope of how the trace cache is
used in the context of the larger microarchitecture is also interesting. Standard
approaches in modem machines executing the X86 instmction set have been to
53
convert the cumbersome QSC instmctions to an internal RISC equivalent (Intel
terms these uops). Since the overhead of the QSC->RISC translation is costly,
the trace cache stores the decoded uops instead of the X86 instructions. A single
trace cache line can accommodate 6 uops, with a total cache size of 12,000 uops.
The branch prediction hardware includes a 4096 entryBTB, a 16 entryRAS and a
"highly advanced"prediction unit that is not elaborated further. A separate
microcode ROM allows X86 instructions with a complex uop decoding to be
represented in the trace cache with a single "placeholder" op. When one of these
placeholder ops is encountered, it is used to index the microcode ROM to
retrieve the corresponding sequence of uops to be passed down the pipeline.
Intel's motivation to utilizing trace cache seems to be twofold: First the trace
cache provides an efficient mechanism for fetehing across basic blocks, as has
been thoroughly discussed. Secondly, the trace cache is a suitable structure for
storing decoded uops in the context of a decoded instruction stream This
second aspect may even overshadow the first, as the overhead ofX86 translation
is extensive. Being able to fetch instmctions
"behind"
these decoders whenever
possible is akin to the performance benefits of avoiding mispredictions.
54
Chapter 4
Simulator Extension Design
A largeportion of researchfor this thesis wis peifcnmdtiajurKtiond simulation This section
describes theprocessor simulator usedas a startingpomt, andhowthe trace cache extension wis
tncorporated Object-oriented C++ wis used to implement the extension for reasons cf
flexibilityandextensibility The three leid dass design (Creational, Component andHdper) is
explained in doe context ofthe Uni/brm Trace CacheModi.
4.1 Existing Superscalar Simulator
Any proposed microarchitectural improvement is first verified through
simulation. As part of the research for this thesis, several trace cache schemes
were tested using a custom-designed extension to an existing simulator. The
functional simulator used as a starting point was simoutorder, which models a
superscalar, out-of-order issue pipelined CPU. The pipeline is broken into 6
stages: Fetch, Dispatch, Issue, Execute, Writeback, and Commit. The fetch stage
retrieves instmction and adds them to the instruction fetch queue (IFQ).
Multiple instructions are fetched each cycle until one of three conditions becomes
true: 1) the maximum number of instmctions per fetch cycle has been reached,
2) the IFQ is full, or 3) a hit in the BTB occurs. The dispatch stage removes
instmctions sequentially from the IFQ, decodes the instmction and allocates a
new entry in the RUU. After all dependencies for an RUU entry have been
resolved, the instmction moves to a functional unit for execution. After
executing, the instruction is marked complete and the result is broadcast through
the RUU to update the state of any dependent instmction. In the commit stage,
the simulator traverses the RUU in reorder buffer fashion. Starting at the head,
55
any instmction marked complete is retired and the associated RUU entry is
deallocated. This traversal continues until an instmction is encountered whose
result is still pending. A diagram the simoutorderpipeline is shown in Figure 4. 1.
Figure 4.1: SimaaotderVipe]m[32]
The six pipeline stages are each implemented in code as seperate functions. The
main loop of the simulator (sim-main) is structured as follows:
ruu_init ()
for (;;) {
ruu_commit () ;
ruu_writeback ( ) ;
lsq_refresh( ) ;
ruu_issue () ;
ruu_dispatch() ;
ruu_fetch ( ) ;
}
Calling the functions associated with each stage in a reverse order allows for
proper synchronization between stages, modeling the data availabilityof a system
that latches the output from each stage on a periodic clock edge. The simulator
was written using procedural C in a manner that utilizes a multitude of file-scope
variables. The next section provides motivation for implementing the trace cache
simulator extension in object oriented C++; an approach that sharply contrasts
with the design of simoutorder itself.
56
4.2 Motivation forUtilizing anObjectOriented Extension
The primary goals associated with the design of the trace cache extension were
flexibility and extensibility. More than one trace cache scheme was examined,
therefore the extension needed to accommodate various data structures and
organizations. Similarly, the simulator extension needed to be able to easily allow
new schemes to implemented and tested, preferably without modifying code
outside the defined framework These goals of extensibility and flexibility were
achieved by establishing interfaces. From one aspect, the trace cache presents a
set of virtual classes from which an individual looking to implement a new
scheme would simply inherit. The extension also presents an interface to the
sirn_outorder simulator by abstracting trace cache operations (lookup, update, etc.)
via virtual base class methods. These methods are called from a select fewpoints
in the simoutorder code, establishing a solid separation of datapath and trace cache
logic.
Implementing the simulator extension in C++ provided the means to fulfill the
above goals in an object-oriented design. Several object-oriented principles such
as encapsulation and polymorphism were heavily utilized. The simulator
extension also made use of creational and relational design patterns. Not onlydid
this approach provide extensibility and flexibility within this project, but
established a platform for further expansion that should be intuitive for any
individual with a background inOO software design.
4.3 Modifications to sim-outorder Source
A conscious effort to introduce as fewmodifications of the simoutorder source file
was made. Most of the code related to the extension is resident with the
framework of the object-oriented design. The few modifications to the sim
outorder source code (renamed simte) are limited as follows:
57
Addition of trace cache related options and statistics using the
SimpleScalar options/statistics databases (see [33] for more details).
Top-level initializations of the multiple branch predictor, core fetch unit,
and trace cache related components.
Modified fetch stage (mu_fetch) that incorporates trace cache lookups
(tc->fetchTraceSegment () ) and core fetch unit lookups
(fu->fetchInstructions ()). The CoreFetchUnit replaces the
existing fetch stage as it more accuratelymodels the Revision 1 design of
Section 2.5. Multiple branch prediction lookups (mpred->lookup ( ) ) are
performed prior to trace cache/core fetch unit accesses.
Addition of fields to fetch_rec and RUU_station structures.
Accommodates specific information, such as Predict ionTokens, that
must be "piggybacked" along with instmctions as they precede though
the pipeline.
Identification of instmctions that missed in the BTB such that the
multiple branch predictor can be updated appropriately (ruudispatch).
Call to mpred- >speculativeUpdate ( ) provided in dispatch stage.
Hook to tc->retireInstruction() and fu->retireInstruction in
the commit stage (ruucommit). Initiates all back-end operations (fill
unit, predictor updates, etc.).
Clean up on mis-speculation that deallocates memory associated with
"piggybacked" information for instructions that are canceled.
General deallocation of trace cache components upon sunulation
completion.
58
4.3 High Level Design
The simulator extension was designed to accommodate trace cache schemes with
a fair amount of complexity in a modular fashion Using this approach, schemes
ranging from the simple Rotenberg Trace Cache (Section 3.2) to the more
complex Path-Based Next Trace scheme (Section 3.3) could be implemented
within the same uniform template. A block diagram of this model is illustrated in
Figure 4.2.
Uniform Modeling of
Trace Cache
Fetch
-Address-*
(PC)
History
Unit
History
Unit Input
Renamer
Input
Renamer
0
RonarrM
raw.
Trace
ID
Trace
ID
Renamer
1
Renamer
n
Trace
ID.
Trace ID
Selection
Logic
Control
_i_
Trace ID
Selector Trace
ID
Multiple
Branch
Predictor
m Branch Predictions
Trace
Generator
Trace
Tabto
Predicted
Trace
Replacement
Trace
Retired
-Instruction-*
Stream
Fill
Unit
Figure 4.2: Uniform Trace CacheModel
This Uniform Trace Cache Model served as the basis for the class structure in
C++, which can be divided into a three level design. The first level comprises the
interface to the modified sim-outorder source and classes associated with the
59
creational pattern. The second encompasses the component classes, each roughly
corresponding to a block in the above diagram The diird set consists of helper
classes that include encapsulated data representations and exception classes. The
remainder of this section provides an overview of each of the three design levels.
4.4 Component Level Classes
The set of component classes that form the interface (virtual base classes) from
which scheme-specific implementations can be derived from consist of:
HistoryUnit
Renamer
TracelDSelector
TraceGenerator
FillUnit
Predictor
Collectively, these constitute the abstract component dosses. Using these interfaces,
the top-level TraceCache class directs the tasks of lookups and updates. The
polymorphic functions of the underlying concrete component dosses are called and
perform the scheme specific tasks related to that component. This process is
best illustrated by a code snippet from the lookup method of the TraceCache
class:
for ( RenamerVector: : iterator iter = ) ;
iter != ;
iter++ ) {
ren_in = (
fetch_jpred_PC, *iter ) ;
( *iter ) ->setCurrentTraceID( ren_in ) ;
}
trace_id = &( )
trace = & ( ( *trace_id ) ),-
For schemes such as those using Path-Based Prediction, more than one technique
can generate an index into the trace table. The design of the simulator extension
provides for this by allowing multiple Renamers. In the above code, the for
60
loop polls each of these renamers with the appropriate input data provided by the
HistoryUnit. The TracelDSelector utilizes an Observer pattern [34] to
choose the appropriate ID to be forwarded on to the TraceGenerator. When
the TraceCache is constructed (described shortly) the renamers are registered
with the TracelDSelector. The selectTracelD method of the
TracelDSelector chooses the index value used to access the
TraceGenerator. Each of the component classes contain references to the
TCLogger class that acts as
"writer"
class for outputting the various configuration
and simulation result data. The UML descriptions for each of the abstract
components are illustrated in the following diagrams (Figures 4.3 and 4.4).
Component Classes
f>ure virtual*?
Predictor
<-getWidth(j
/lookup (}
+ge tPrediozi onTokens ()
-t-newTokent)
f-specalativeUpdate ()
f-apda te {)
+i spredic tRecover (J
?r
i__.
pure virtual?:*
Renamer
+ge tCurrentTraceZD (J
+se tCurrgn tTracelP <}
RotenbergRenamer
T
MPAgPredictor <<purra virtual
TracelDSelector
+selectTraceID()
-|TraceGenerator
RotenbergTracelDSelector
Figure 4.3: UML Diagramof the Abstract Component Classes
61
Component Classes
i
pure virtual**
HistoryUnit
pure virtual**
FillUnit
tqenara teRanamarlnput <> /drain ()
+enqueueInstruction()
i
1
| RotenbergHlstoryUnit 1
M/
<<pure virtual?*
TraceGenerator
hlookupTrace ()
+addTrace (}
+ge tlfextFe tchAddress ()
+<7e tPredi ctionTokensO
I
| RotenbergRenamer
Figure 4.4:
i
i
onent Classes
RotenbergTraceGenerator
UMLDiagram of the Abstract Comp
(cont.)
4.5 Creational Level Classes
The abstract components define a set of methods that establish a uniform
interface for accessing the trace cache. The concrete classes derived from the
abstract components are aggregates of the TraceCache class. In addition to
being the top-level structure that provides an interface to the modified sim
outorder source file, TraceCache serves as the Client in an Abstract Factory
creational pattern [34]. This design pattern alleviates the TraceCache class from
requiring knowledge of the specific scheme being implemented. Anyscheme that
realizes the abstract components must also provide a concrete implementation of
the TraceCacheFactory and TraceCacheConnector. These classes hide the
logic that create and establish the interconnections between concrete instances of
the trace cache components. When an instance of the TraceCache class is
instantiated, the Factory and Connector are passed as arguments to the
62
constructor. Simply calling the create methods of the Factory followed by the
check and connect methods of the Connector return polymorphic references to
the concrete components. A UML description of the TraceCache and the
associated classes consisting of the abstract factory pattern is provided in Figure
4.3.
Creational Pattern
pure virtual
TmceCacheFactoty
-*-_Qptlona; QptiongMa.p
+parseOpZ3.ons (}
+ini tializeFactoryf)
+cre&teHstoryl7nit ()
+cre* teRenaaer&O
+createTraceZI>SGlector()
f-createTraoeGeneracorO
i-createFillVnxz()
T
pure virtual / friend of TraceCaohe
TraceCacheConnector
* to: TraceCache
r-setTraceCachdr)
+ohaakCompoaents()
+aonoectCoaiponents ()
%get<Com-pon-ent> ( )
singleton
RotenbergTCF
TraceCache
r-_factory: TraceCacheFactory *
4- connector: TraceCacheConnector *
r-eoaatractor I)
H-desrtruGtor 0
H-fetchTraceSeqmant t i
<<s ingLeton
RotenbergTCC
F^ure 4J: UMLDiagram of the Creational Level CJasses
4.5 HelperLevel Classes
The final level of the object-oriented design comprises helper classes. Serveral
data types that form the basis of a trace cache implementation are encapsulated in
class form, all of which derive from the common TraceCacheData interface.
These include instruction, Address, Trace and derivatives of
PredictionToken. These classes convey data between components and act as
primitives for storage structures within the concrete component implementations.
Classes such as Instuction provide usefull methods for classifying and identifying
the data (i.e. isDirectJump, or promoteBranch). Others simply assume a role
similar to the Momento pattern [34] by externalizing state information that is
carried down the pipeline (predict ionToken). Classes that are also included as
63
helpers include exception classes (invalidOptionException,
InstructionNotAddedException, etc.) and basic Interfaces (outputable,
Printable). These help establish a strongly typed object-oriented design.
64
Chapter 5
Implementation and Results
This section analyzes the results from simulations that examine mrious aspects of trace cache
organizations. A newfiU unit scheme, the Sliding WindowFillMechanism is presented This
method exploits trace continuity and identifies probable start regions to improve trace cache hit
rate. A 7% hit rate increase wis observed over doe Rotenbergfill mechanisrn Together ititb
Branch Promotion, trace cache hit rates experienceda 19% aierage increase along inith a 17%
awrage rise infetch bandwdth.
5.1 Simulation Strategy
A progressive sirnulation strategy was used for investigating trace cache as an
extension to wide-issue superscalar processors. Many of the individual
simulations build upon results and conclusions drawn from prior trials. To begin,
the benchmark set was run on the simoutorder simulator as exists in the
SimpleScalar distribution. This established baseline performance results to which
subsequent trials were compared. Specifically, all speedup metrics are expressed
as:
, IPC of Target Scheme
Speedup =
IPCof Base Simulator
The simoutorder parameters that were used in the simulation are given below in
Table 5.1. Parameters that are not listed (such as latencies and penalties) were
assigned default values by simoutorder. The sizes of the IFQ, RUU/LSQ, the
widths of the decode, issue and commit units, and number of EUs are generous.
These large values generally alleviate the problem of bottlenecks within portions
of the pipeline that are not directly related to fetch bandwidth. Also, the sim
65
outorder default for the I-Cache line size was doubled to help in approximating
(albeit, not perfecdy) the behavior of an interleaved cache as described in
Revision 1 of Section 2.5.
Investigation of trace cache schemes was preceded by an examination of
multiple branch prediction performance. Variations of two different methods
were studied, as will be discussed later. Simulation of trace cache schemes
proceeded as follows:
Rotenberg Trace Cache [10]
" Trace Cache Associativity
Reassociation as an Instruction Pre-processing Technique [16]
Branch Promotion [15]
An Alternate FillMethod [20]
A new approach to the trace cache fill unit, the SlidingWindow Fill Mechanism,
is proposed and simulated. To conclude the simulations, a combination of
schemes that yielded favorable results was examined.
Simu'U Value
Decode/Issue/CommitWidths 16
IFQ Entries 128
RUU/LSQ Entries 512/256
IntegerALUs/Multiplication Units 16/4
FP ALUs/Multiplication Units 16/4
LI I-Cache
Size (lines) 1024
Line size 32
Associativity DirectMapped
Branch Predictor
PAT entries 1024
PATwidth (bits) 10
PHT entries 1024
BTB
Entries 512
Associativity 4-way
RAS depth 8
Table 5.1: Base simoutorderparameters
66
5.2 Benchmarks Used
The benchmarks chosen represent a variety of modern computational problems
while possessing the benefits of relatively compact sizes and short run-times.
The latter aspect was important to this study, as several trials were run to gain a
perspective on a variety of schemes and organizations. To do so within a
reasonable amount of time using available resources, it was desired that a
simulation run complete within the span of a few hours. Ten programs
constimted the benchmark set. Table 5.2 presents a description of the
benchmarks, the input sets, the respective type of computation that each is
characteristic of and the percentage of time that each took to complete on
average. This last statistic is indicative of the size of each program Appendix B
contains source code listings of the first five programs. The source for gzip is
freely available under the gnu license, and is included in larger integer benchmark
suites such as SPEQnt. The two JPEG programs and the input image were
taken from the MediaBench suite [30]. The benchmark performing the Fast
Fourier Transform was taken from a suite (LvliBench) designed to benchmark
embedded-type applications [31]. Appendix C provides further details on the
input sets and parameters used.
Before continuing on to present and analyze various result related to trace
cache, this section concludes with a basic statistic for each of the benchmarks.
Table 5.3 presents the average basic block size for each program, as measured
using the unmodified simoutorder simulator.
67
Benchmark:
'.Name
". ' Description
Input
2 ' Set
Computation Ikun-time,
Fraction
roots
Finds root of a nonlinear equation
via Bisection, Secant and Newton's
methods.
internal
Scientific
Kernel
1.1%
solve
Computes the root approximation
for a polynomial function using the
bisection method.
solve.in
Scientific
Kernel
0.8%
integ
Finds the approximate value for the
definite integral of f(x) using
Simpson's rule and the Trapezoidal
rule.
integ.in Scientific
Kernel
1.0%
lag
Lagrange interpolation of a set of
data points, and returns the value of
function at x.
lag.in Scientific
Kernel
0.3%
matrix Matrix multiplication mdl/md2
Scientific
Kernel
0.6%
gzip
File compression using Lempel-Ziv
coding
Thesis
Proposal.doc
Integer 26.8%
djpeg JPEG image decompression testimg.jpg Multimedia 17.6%
cjpeg JPEG image compression testimg.ppm Multimedia 24.4%
fft
Performs Fast Fourier Transform
on n random sinusoids samplingm
times.
n=4, m=128
Embedded/
DSP
10.1%
inv fft Performs the inverse FFT n=4, m=128
Embedded/
DSP
17.3%
Table 5.2: Benchmark Set Utilized
68
Benchmark Ayetage Basic B|ock Size i
roots 7.12
solve 6.83
integ 5.00
lag 5.66
matrix 5.05
gzip 5.79
djpeg 19.65
cjpeg 11.50
fft 6.19
inv fft 6.24
Table 5.3: Average Basic Block Sizes
5.3 Multiple Branch Predictors
As discussed previously, a trace cache that is based on conventional branch
prediction (versus next-trace prediction; see Section 3.3) requires a predictor that
can supply up to m branch predictions per cycle. Multiple branch predictors are
often extensions of established single branch prediction schemes. This is true for
the two varieties that are examined in this thesis: the MGAg and MPAg
predictors. The MGAg predictor is an extension of the GAg global predictor
that accesses the pattern history table in an iterative fashion to generate m
predictions (Section 2.5). The MPAg predictor is a straightforward derivative of
the PAg per-address scheme, where mpattern histories are stored per PHT entry
(Section 3.13). Both schemes were implemented using non-speculative updates
and pattern history tables (PHT) of 1024 entries. The MGAg scheme utilized a
10-bit wide global history register, while theMPAg scheme used a 1024 entryper-
address table (PAT) with 10-bit wide entries.
In a design, the branch predictor needs to be considered with regard to the
rest of the architecture. Bandwidth, update policy, table sizes and entry widths
constitute a few of these considerations, though one important issue made itself
69
apparent while forming the simulator extension. This issue entails how direct
jumps are handled in the context of the branch predictor. The two options that
exist are to include direct jumps as part of the prediction history, or to exclude
them. The decision relies on two aspects of the fetch subsystem, one involving
the core fetch mechanism, the other regarding the trace cache. Discussion of the
core fetch unit aspect will be covered first.
For direct jumps to be excluded from the predictor history, they must be
explicidy recognized during instmction fetch. To achieve this jump detection, use
of pre-decode bits is needed, or a "jump
bit" for each BTB entry is required.
This allows the next fetch address to be set to the corresponding BTB target so
that instruction fetch continues from this point the following cycle (since there is
no doubt that an unconditional direct jump will always be taken, and will always
have the same target address). Inclusion of the jump instmction in the predictor
history is not required, as the predictor is not consulted when a direct jump is
identified.
In the case where direct jumps are not explicidy recognized by the core fetch
unit, the predictor must include jumps in its history. A BTB lookup will convey
the fact that the instruction is a control transfer operation that has evaluated
taken in the past, but not the type of control operation (conditional branch or
direct jump). Therefore the branch direction returned by the predictor is simply
associated with the instmction. This implies that direct branches can be
mispredicted (assigned a not-taken direction). Over the course of execution, the
direct jump will establish a strongly taken behavior that should be reflected in the
pattern history. Unfortunately interference, or aliasing, within the predictor
could defeat this expected behavior.
The second aspect to deciding whether direct jumps are included in predictor
history is how the trace cache is implemented - with or without branch
70
promotion. For the standard Rotenberg scheme, direct jumps are treated as
conditional branch instructions and are included as part of the branch mask and
branch flag fields within a trace. When the trace cache is accessed during
instruction fetch, both the fetch address and the predictor results are utilized in
determining a hit or miss. Specifically, the multiple branch prediction is
compared with the branch flags (which indicate direct jumps as well as
conditional branches). Therefore the predictormust include jumps as part of the
branch history for this reason. If branch promotion is utilized, direct jump
instmctions can always be considered strongly taken and can automatically
(without consulting the branch bias table) be promoted. This alleviates the
predictor from storing direct jumps.
To summarize the above, the multiple branch predictor stores history
information for direct jumps if: 1) pre-decode bits (or the equivalent) are utilized
to identify direct jumps explicitly, and 2) the trace cache utilizes branch
promotion. In a machine that does not make use of trace cache, only the first
requirement needs to be satisfied.
With the above discussion in mind, four predictor configurations were evaluated:
MGAg including direct jumps, MGAg excluding direct jumps, MPAg deluding
direct jumps andMPAg excluding direct jumps. The predictors were assessed in
the context of the Revision 1 core fetch unit of Section 2.5. The parameters for
PAT and PHT sizes are listed in Table 5.1. These simulations do not incorporate
trace cache, but rather establish the best multiple branch prediction scheme that
will be coupled with the trace cache in later trials. Figure 5.1 shows predictor
accuracy (percentage of correctly predicted branches) for each of the
configurations.
71
Accuracy Percentages for MGAg and MPAg Multiple Branch Prediction Schemes
100%
95%
90%
2
O
c
g
T5 85%
Q.
o 80%
c
2
m
75% -fc
70% +
nil
nil
DMGAg w/ Jumps
MGAg w/o Jumps
OMPAg w/ Jumps
?MPAg w/o Jumps
roots solve integ lag matrix gzip djpeg cjpeg fft inv_fft
Figure 5.1: Multiple Branch PredictorAccuracy
From this graph it is evident that the MPAg scheme generally outperforms the
MGAg predictor. These results are consistent with a similar trend seen for the
single branch predictor counterparts. For subsequent simulations, the
appropriate MPAg corifiguration (including or excluding direct jumps) will be
used. As a final note concerning theMGAg Predictor: It maynot excel from an
accuracy standpoint, though the MGAg Predictor's utilization of resources is
superior to the MPAg version, as the table size requirements are constant as
prediction bandwidth increases. This provides a scalable alternative for larger
values of rathatmay be desirable in implementations that are space constrained.
To conclude this section concerning multiple branch prediction, two graphs are
presented that demonstrate an observable trend as the maximum bandwidth
value m increases. First, fetch bandwidth improves, as the set of instmctions
fetched can span increasing numbers of multiple basic blocks. At the same time,
prediction accuracy decreases, as
"deeper" branch levels are inherently less
accurate since they are dependent on the accuracy of the preceding branch.
These opposing trends are shown in Figure 5.2 and 5.3. One can expect these
72
trends to be more pronounced with the introduction of trace cache, as instruction
fetch over multiple basic blocks is no longer constrained to not-taken branches
(as is the case with the Revision 1 core fetch unit.)
nno
n
m
c -0.20
Q. -O.AO
u
2
-Ofin
<
r -oho
o
T3
O-
-1.00
OJ
-1.20
CC
O
-1.40
CD
-1.60
Fetch Bandwidth Increase vs. Values ofm
(MPAg Predictor, Excluding Direct Jumps)
m=2 m=3
Branch Prediction Bandwidth
Figure 5.2: Fetch Bandwidth Increase vs. m
Decrease in Prediction Accuracy vs.Values ofm
(MPAg Predictor, Excluding Direct Jumps)
VS?*
"^N
-^22 .
:
., :'.:'. '/.'
~>f<2^*
VV'- ""-^^l '
2 !
^V^V. ,. j _
'
.
'
- V: mc fflslH
1... ..- ~
.
:
... fjk
m = 2 m = 3
Branch Prediction Bandwidth
Figure 5.3: Prediction .Accuracyvs. m
-roots
-solve
-
-integ
-lag
-matrix
-gzip
<-JP<sij
-fft
inv_ffl
73
5.4 Rotenberg Trace Cache
With the multiple branch prediction scheme established, simulation proceeded
with an investigation of the basic Rotenberg et al trace cache as proposed in [10]
and described in Section 3.2. The trace cache was sized to be roughlyequivalent
to that of the LI I-Cache when using a trace segment length of 16 instmctions.
Three configurations were examined by varying the values of n (rnaximum
number of instructions per trace) and m (maximum number of
branches/predictor bandwidth). Values for each are as follows:
= 16, m = 3
n = 20,m = 3
n = 20,m = 4
These configurations will hereafter be identified as 16/3, 20/3 and 20/4
respectively. For the later two, the decode, issue and retire widths of the pipeline
were increased to 32 to accommodate the larger maximum value of n. Several
aspects of the trace cache were drawn from the simulations, the first being the
average length of segments added (Figure 5.4).
Average Trace Cache Segment Length Coresponding to Parameters n and m
20.00
g 18.00 -
co
t 16.00
c
fj 14.00 -
g
12.00 '
jz
f1 10.00
CJ}
_1
E 8.00
6.00
CO
21 4.00 ;
2 ;
< 2.00 j
0.00
i "SJHSi
J i2i41 i B
1 1 m
\m 11 1 Ira
Qn=16, m=3
n=20, m=3
Q n=20, m=4
roots solve integ lag matrix gzip djpeg cjpeg fft invjft
Figure 5.4: Average Trace Cache Segment Length
74
From the above, we can see that the trace cache is capable of supplying well over
10 instmctions per cycle. Figure 5.5 shows the change in the average fetch
bandwidth experienced when combining the trace cache with the core fetch unit.
Fetch Bandwidth Change Coresponding to Parameters n and m
S 5.00
o
4.00
1.00
/~""\ ~ !
#
2^~*-^fZ-"^2^---^5^
^P=~
22rv
J^
? roots
- solve
-A integ
-*< lag
-3K matrix
- gzip
I djpeg
qpeg
fft
inv fft
CoreFU(m = 1) TC(n=16, m=3 ) TC(n=20,m=3) TC(n=20.m=4)
Figure 5.5: Fetch Bandwidth after Incorporating Trace Cache
In general, fetch bandwidth increases with greater segment lengths, though
decreases when the prediction bandwidth is changed from three to four branches
per cycle. Exarnihing the trace cache hit rate (Figure 5.6) can provide insight into
this fetch rate decrease. For a trace cache hit to occur in the Rotenberg scheme,
the current fetch address (PQ must match the first instruction (trace ID) of the
indexed segment and the branch flags must match the generated prediction.
Without storing individual trace target and fall-though addresses for each basic
blockwithin a trace, partialmatching cannot be implemented; an "all or
nothing"
situation exists for trace cache hits. When the maximum number of branch
instructions able to be included in a trace segment increases, the likelihood of a
full match between the branch flags and generated prediction decreases. The
result of a reduced trace cache hit rate is that the core fetch mechanism supplies a
higher percentage of total instmctions at an inherently lower bandwidth.
75
Trace Cache Hit Rate Coresponding to Parameters n and m
70.00
Dn=16, m=3
n=20 , m=3
Dn=20, m=4
roots solve integ lag matrix gzip djpeg cjpeg fit invfft
Figure 5.6: Trace Cache Hit Rate
Figure 5.7 shows a speedup comparison (over the base simoutorder IPQ of the
three configurations tested.
Speedup Coresponding to Parameters n and m
SCore Fetch Unit
n=16, m=3
On=20, m=3
On=20, m=4
roots solve integ lag matrix gzip djpeg cjpeg fft invfft
Figure 5.7: Trace Cache Speedup
As expected from the fetch bandwidth results, 20/3 provides the best overall
performance in most instances, though requires a 25% increase in trace cache size
76
over 16/3. To further elaborate on Figure 5.7, it is helpful to look at some
statistics involving the trace- tenninating condition Three conditions have the
potential to finalize a trace in the fill buffer and force a newsegment to be written
to the trace cache:
The maximumnumber of instructions has been reached (n-constrained)
The maximum number of branches has been reached (rnconstrained)
An indirect jump has been encountered
Figure 5.8 shows the distribution of these three conditions for each of the
benchmarks.
Profile ofTrace Terminating Conditions
Dindirect jump
max n reached
dmaxm reached
roots solve integ lag matrix gzip djpeg cjpeg fit invjft
Figure 5.8: Distribution ofTrace-Terminating Conditions
Comparing Figure 5.8 with Figure 5.7 shows that programs that exhibit a high
percentage of n-constrained traces (such as the two JPEG benchmarks) will
benefit from longer trace cache segments.
5.5 Trace Cache Associativity
The Rotenberg scheme implements a direct mapped trace cache. Aside from the
usual effects of aliasing, a drawback is that only one trace with a particular Trace
77
ID can be stored at the same time. Consider a set of dynamic paths that can
consist of basic blocks A, B, Q D and E. Traces "ABC and "ADE" are both
frequently encountered during program execution and are equally valid. A
direcdy mapped trace cache would displace "ABC as soon as "ADE" was
finalized and moved from the fill buffer. The next occurrence of "ABC would
similarlydisplace "ADE". This trace thrashing can hinder the trace cache hit rate,
which will affect the fetch bandwidth. Bymaking the trace cache set associative,
multiple paths with the same Trace ID can be stored. This comes at the cost of
implementing a set-associative cache structure, which requires additional
selection, fill and replace logic, alongwith greater power consumption.
In the simulations, both a two-way and a four-way set associative trace cache
were simulated. The replacement policy used was least recendy used (LRU).
Figure 5.9 compares the change in hit rate among the different associativities.
Trace Cache Hit Rate vs. Associativity
90.00
80.00 Jl
~1
10.00
J~l
DAssoc. = 1
Assoc. = 2
OAssoc. = 4
roots solve integ matrix gzip djpeg cjpeg inv fft
Figure 5.9: Hit Rate vs. Associativity
Trace cache utilization also tends to improve with increases in associativity
(Figure 5.10). Utilization is measured by the number of traces that remain invalid
at the conclusion of a simulation.
78
Trace Cache Utilization vs. Associativty
100.00
c 95.00
ID
"
E
O)
CD
<n
~ 90.00
t
c
o
Jj 85.00 -{J
5
75.00
-r
-
. [ r f -
"
.
': - i : ^
BAssoc. = 1
Assoc. = 2
DAssoc. = 4
roots solve integ lag matrix gzip djpeg cjpeg fft invfft
Figure 5.10: Utilization vs. Associativity
The final speedup results using the set associative trace cache organizations is
shown in Figure 5.11.
1.80
1.60
1.40
1.20
1.00
0.80
0.60
0.40 -
0.20
0.00 J
Speedup vs. Trace Cache Associativity
roots solve integ lag matrix gzip djpeg cjpeg
Figure 5.11: Speedup vs. Associativity
OAssoc. = 1
Assoc. = 2
QAssoc. = 4
inv fft
This graph presents speedup data that is not as conclusive as one would expect.
Results varied, as several prediction accuracies decreased along with the trace cache
79
hit rate and fetch bandwidth increase. In general, it seems that trace cache can
benefit from multiple associativity. Though subsequent simulations will utilize
the basic direct mapped organization due to the mediocre speedup results of
Figure 5.11 coupled with the increased complexity of irnplementing a set-
associative structure in hardware.
5.6 Reassociation
As described in Section 3.11, reassocation [16] is one of the dynamic instruction
pre-processing techniques that can be incorporated in a processor that utilizes
trace cache. Since the fill unit is outside the critical path of the main pipeline,
adding logic to perform these optimizations has a negligible effect on
performance. At the same time, such optimizations have the potential to
improve both fetch and execution bandwidth.
Instructions that were considered for reassociation in the simulation included
ADDI and ADDUI operations that followed each other sequentially (see code
example of Section 3.11) or were separated by a direct jump or conditional
branch. It was found that the number of occurrences of reassociable instructions
within the dynamic instruction stream was rriinimal. Table 5.4 shows both the
number of instmctions encountered by the fill unit that were reassociated, as well
as the number of reassociated instructions fetched from the trace cache. For all
benchmarks, the effect of incorporating reassociation was barely, if at all,
reflected in the IPC Therefore, future simulations did not incorporate the pre
processing technique, as the fill unit overhead does not justify the insignificant
performance gains.
80
Benchmark JNfumbet of Instruction '<
Reas^oicated
'Number ofReassociated
Instructions Fetched
roots 12 7
solve 30 15
integ 13 0
lag 9 0
matrix 0 0
gzip 2 1
djpeg 20 10
cjpeg 8 0
fft 513 155
inv fft 1025 5
Table 5.4: Reasssociation Statistics
5.7 Branch Promotion
The trace termiriating conditionmhas the potential to limit traces to a length that
falls short of the maximum number of instructions able to be accommodated by
a segment. This restricts the fetch bandwidth and results in trace cache storage
inefficiency. One technique that aims to alleviate this problem is branch
promotion [15]. Discussed in Section 3.4, branch promotion regards branches
with strong taken, or not-taken behaviors as statically predicted, leaving the
hardware predictor to only consider branches that exhibit reliance on dynamic
path history. The branch bias table (BBT) is the structure that records individual
bias counts (how many times a branch has been taken or
not-taken). Upon
reaching a bias threshold, a branch is promoted.
The first simulation set of this section is concerned with establishing an optimal
branch bias threshold The initial bias value was set at 8, and was increased by
powers of two for each trial, ending at 256. The next two figures (5.12, 5.13)
81
shows the resultant fetch bandwidth and speedup (over the base simoutorder IPC!)
corresponding to each of the 6 branch bias thresholds.
Average Fetch 6 andwidth vs. Branch 6 ias Threshold
32 64
B ranch B ias Threshold
Figure 5.12: Average FetchBandwidth vs. Branch Bias
Threshold
Speedup vs. Branch Bias Threshold
2.00 T
32 64
Branch Bias Threshold
256
Figure 5.13: Speedup vs. Branch Bias Threshold
82
As expected, fetch bandwidth increases with more aggressive branch promotion
(lower bias thresholds). Setting the bias threshold too low will cause frequent
promoted branch mispredictions. This will have the effect of "confusing" the
dynamic predictor, as branches are constantly being promoted and demoted, in
turn polluting the history tables. Examining Figure 5.13, one can observe that
threshold values between 16 and 64 tend to result in the best performance. A
branch bias threshold value of 32 was chosen for subsequent simulations.
The second set of simulations related to branch promotion investigates the
organization of the branch bias table. As described in [15], the branch bias table
is a separate stmcture in hardware that stores the bias count and the direction of
the previous branch outcome. This straightforward implementation of the BBT
will be referred to as a full branch bias table.
One will note that the BBT is similar to the BTB in that entries are indexed
via branch address and utilize tag checking to ensure a hit. This observation
introduces an alternate BBT organization: The Merged BTB/BBT. By
confining the BTB and BBT, hardware space can be conserved. This requires
that the merged BTB/BBT provide multiple accesses per cycle, as branch target
addresses must be retrieved in the fetch stage, branch bias entries must be
supplied to the fill unit, and both BTB and BBT information must be updated
when instmctions retire in the commit stage. The disadvantage to this
organization is that both taken and non-taken branches must be stored. The
traditional BTB stores only branches that have previously evaluated taken, as
storing not-taken targets is redundant. This is no longer is valid with the
introduction of the combined BTB/BBT structure, as any particular branch can
be strongly biased in either direction and requires a table entry.
The final variation on branch bias table organizations is the Cost-reduced
BBT. Similar to the merged BTB/BBT, both tables are implemented as one
hardware structure. The difference entails reintroduction of the stipulation that
83
only taken branches are stored. This excludes branches that are strongly not-
taken from being promoted, as no branch bias information is recorded for not-
taken branches. This drawback is compensated by improved BTB performance,
whichmirror that provided by a stand-alone BTB.
Figure 5.14 shows the resultant speedups from each of the three branch bias
table organizations. As expected, the full BTB performs the best, as both tables
are implemented as separate stmctures. Between the merged BTB/BBT and
cost-reduced schemes, it seems that the later provides better performance since
BTB hit rates are not sacrificed via redundant storage of not-taken branches.
Branch Bias Table Organization Comparisons
2.00
1.80
1.60
1.40
1.20 -|
1.00
0.80
0.60
0.40
0.20
0.00
O Full BBT
BTB/BBT
OCost-reduced BBT
roots solve integ lag matrix gzip djpeg cjpeg fft inv_fft
Figure 5.14: Speedup Comparison ofBBTOrganizations
With perspectives on branch bias threshold and bias table organization, we can
now compare the use of branch promotion with the results obtained in Section
5.4 for the Rotenberg trace cache. Figure 5.15 shows the substantial speedup
obtained using branch promotion with a full branch bias table and a branch bias
threshold value of 32. The first three benchmarks (roots, soke and integ) along with
the FFT related computations benefited the most from branch promotion,
yielding a maximum speedup of 79%. The average speedup among the ten
benchmarks used was 29%.
84
Speedup Comparison
(Rotenberg Trace Cache vs. Trace Cache with Branch Promotion)
1Rotenberg TC
I Branch Promotion
roots solve integ lag matrix gzip djpeg cjpeg inv fft
Figure 5.15: Speedup using Branch Promotion
5.8 Alternate FillMechanism
The aim of the techniques presented in the next few sections is to improve trace
cache hit rates by rnoclifying the way traces are created and filled to the cache.
The first of these techniques is the Alternate Fill Scheme that is explained in
Section 3.12. This method is best described as a "tnmcate-and-shift" approach to
the fill unit. Instead of completely flushing the fill buffer after a new trace is
committed to the trace cache, the front-most basic block is eliminated, and the
trace is shifted. Newly retired instmctions are added to the end of the partially
filled buffer, and the Trace ID is set to that of the instmction following the
truncated block.
Figure 5.16 shows the change in trace cache hit rate experienced when the
alternate fill scheme is employed. These results are seemingly contrary to the
above stated goal: To improve the trace cache hit rate. A comparison of the
number of unique traces added (Figure 5.17) provides a partial explanation.
85
Trace Cache Hit Rate forRotenberg and Alternate Fill Schemes
I . r 1
MS ;,:;. B '"/! wkW ": :lS ' H
IRotenberg Fill
IAlternate Fill
roots solve integ lag matrix gzip djpeg cjpeg fft inv_ffl
Figure 5.16: Flit Rate forAlternate Fill Scheme
Number ofUnique Traces Added forRotenberg and Alternate Fill Schemes
250000
200000
S 150000
? roots
solve
O integ
a lag
matrix
Ogzip
djpeg
?cjpeg
fft
inv fft
Rotenberg Fill Alternate Fill
Figure 5.17: Unique Traces Added
Since a unique trace is added for virtually every basic block encountered, the
number of traces committed is almost double that of the Rotenberg approach.
Despite the reduced hit rate, the performance is largely equivalent to the scheme
evaluated in Section 5.4 (Figure 5.18).
86
Speedup Comparison
(Rotenberg vs Alternate Fill Mechanisms)
]Rotenberg Fill
Alternate Fill
roots solve integ lag matrix gzip djpeg cjpeg fft inv_fft
Figure 5.18: Speedup Using Alternate Fill Scheme
5.9 Trace Continuity and Probable Entry Points
This section serves as a segue to the next by explaining two attributes of traces
segments and trace cache: Trace Continuity and Probable Entry Points. The
issue of trace continuity is best explained byway of example. Consider a set of
basic blocks (A, B, C, D and E) that constitute a dynamic path free of indirect
jumps. Each block is sized such that two blocks can occupy the fill buffer
without exceeding either the n or ^constraint. Three blocks will not fit in the
buffer though, as the number of instructions occupying the buffer will reach n
before the entire third block can be added. This will result in a finalized trace that
ends with a sequential instruction (opposed to a control instmction). If such a
trace begins with blockA, it will be followed by block B and the start of block C
(identified as "CI"). Similarly, if the remainder of block C appears independent
of CI, it will be identified as "C2". Figure 5.19 illustrates the fill process for both
the Rotenberg andAlternate fill schemes.
87
-Fill Buffer-
Time
Block
A
Block
B
Block
C2
Block
D
Trace
Cache
Block
A
Block
B
a) "Rotenberg et al" Fill Policy b) Alternate Fill Policy
Figure 5.19: Fill Unit Example
Table 5.5 lists the resulting traces generated for each scheme above.
Rotenberg Fill Policy Alternate Fill Policy
A-B-Cl A-B-Cl
C2-D-E1 B-C-Dl
CD-El
DE
Table 5.5: Resulting Example Traces
The issue of trace continuity becomes evidentwhen the PC returns to the start of
Block A. In either scheme, the trace A-B-Cl is fetched from the trace cache and
passed down the pipeline. The PC will then be set to the address of C2. The
Rotenberg scheme will generate another hit (C2-D-E1). The trace cache
implementing the alternate fill scheme will experience a miss, as it does not store
88
traces beginning with instmctions that dynamically follow sequential instructions.
The Rotenberg method therefore provides better trace continuity. It should also
be clear that trace continuity is applicable onlywhen dealing with re-constrained
traces. If a trace is terminated byway of the ^constraint or indirect jump, the
Trace ID of the subsequent trace will start a basic block, which does not pose a
problem for either fill approach. Revisiting Table 5.16 and 5.18, we see that
benchmarks consisting of traces that are largely n-constrained (a/peg is a good
example; See Figure 5.8) are subject to decreased performance using the alternate
fill scheme. This is a result of poor trace continuity.
Despite its deficiency in maintaining trace continuity, the alternate fill scheme
does excel at generating traces at probablyentrypoints, or region start points. As
discussed in the context of fetch preconstruction in Section 3.7, these points
begin regions of code that will be encountered later in the course of normal
execution. Probable entry points always start on basic block boundaries; also the
manner inwhich the alternate fill scheme generates traces.
5.10 The SlidingWindow FillMechanism & Fill Selection Table
The previous section identified two trace properties that the fill unit should take
advantage of. The first is to maintain trace continuitywhen faced with a series of
one or more n-constrained segments. The second is to identify probable entry
points and generate traces based on these fetch addresses. A solution proposed
in this work that satisfies this dual requirement involves a new scheme that
incorporates a Sliding Window Fill Mechanim (SWFM) and a Fill Selection
Table (FST). This section proceeds with a description of the FST followed by a
description of the SWFM. A presentation and comparison of results is
presented afterwards.
89
The concept of the fill selection table is fairly straightforward. Every cycle, the
PC address that the core fetch mechanism encounters (following a trace cache
miss) is identified as a probable entry point. These addresses are stored in the
FST. An FST entry consists of an address tag, a valid bit and a counter. Each
time a fetch address is encountered by the core fetch unit, the count value of the
associated entry is incremented. The fill unit will also allocate or increment the
count of a FST entrywhen an n-constrained trace is constructed and added to the
trace cache.
The Sliding Window Fill Mechanism that is paired with the FST is an extension
of the alternate fill scheme examined in Section 5.8. The difference is that instead
of
"truncating-and-shifting''
an entire basic block, single instmctions are trimmed
one at a time. The SWFM is implemented as a circular buffer. Pointers are used
to mark the current start of a potential trace segment (tracehead) the final
instmction of a potential trace segment (traceJail) and the point at which retired
instmctions are added to the fill buffer (pextjnstruction).
trace head
trace tail
next instmction
Figure 5.20: The SlidingWindowFillMechanism
90
When a retired instmction is added to the fill buffer the nextjnstruction
pointer is incremented. At the same time, the potential trace segment bounded
by the trace head and tracejail pointers is considered for addition to the trace
cache (as described shortly. The tracejail pointer is then adjusted according to
the following table.
Fill Buffer Condition Resultant fra<l;e_tail Value
IsControlInstruction ( trace tail ) ==
FALSE
Next-n-instr
( IsConditionalBranch ( trace tail ) | |
IsDirectJump ( trace tail ) ) &&
( IsConditionalBranch ( trace head ) | |
IsDirectJump ( trace head ) )
Next-m-instr
Trace-tail ==
trace head
Next -m-instr
(otherwise) trace tail (no change)
Table 5.6: Conditions for Adjusting the traceJailPointer
Next-n-instr is expressed as the following conditional statement:
trace_tail = ( trace_tail - trace_head ) < n 1 ) ?
trace tail + 1 : trace tail
Next-minstrcan be describedwith the following algorithm:
while ( ( trace_tail - trace_head ) < n 1 ) {
trace_tail++;
if ( trace_tail == next_instruction )
break ;
if ( isControl Instruction ( trace_tail ) )
break;
The last step in updating the state of the fill buffer is to increment the traceJoead
pointer.
From an implementation standpoint, this may seem to be a difficult task;
independently the SWFM would generate as many traces as there are retired
91
instructions! The value of the SWFM is realized when paired with the FST.
Before filling a segment to the trace cache, a FST lookup using the trace ID is
performed. If a corresponding entry exists, the count is compared with a defined
threshold value. If this count meets the threshold, then the segment is added to
the trace cache, and the FST entry is cleared. Otherwise, the state of the fill
buffer is updated as described in the previous paragraph, effectively discarding
the lead instmction. One final task of the fill buffer is to allocate or increment
the count of an FST entry for any address that follows a n-coristrained segment
that gets added to the trace cache. In summary, the SWFM/FST combination
identifies, constructs and fills traces starting with fetch IDs that have been
previouslyencountered or those that immediately follow n-constrained traces.
To observe how the sliding window fill mechanism with FST affects the trace
cache hit rate, a set of simulations were performed in which the fill selection
threshold value was adjusted. The threshold value of the FST has a substantial
effect on the number of unique traces added. Table 5.7 compares the number of
traces added for each of the six FST threshold values. Figure 5.21 shows the best
trace cache hit rate is obtained using a value of two or three (two was chosen for
the remainder of the simulations
1> 1 1benchmark
; rr\ _ ,| ...;:.:.: Tzi T3 T=4 ^P-^-Q T=16
roots 25,725 4, 828 2,121 1,828 837 327
solve 19,308 2,856 1,579 1, 058 444 237
integ 11,480 1,968 1,013 708 303 144
lag 16,269 2,609 1,149 800 360 172
matrix 6,829 1,622 803 567 326 238
gzip 56,020 16,274 11,214 7,784 4,728 2,496
djpeg 327,289 25,265 15,770 11,488 5,297 2,344
cjpeg 303, 101 39,720 24,436 18,703 8,666 4,500
fft 334,094 48,395 23,438 17,495 6,313 2,228
inv fft 653,229 82,096 37590 26, 158 10,167 3, 068
Table 5.7: Number of Unique Traces Added using SWFM/FST
92
Trace Cache Hit Rate Using the Sliding Window Fill Scheme and the FST
80%
? roots
M solve
-X integ
H lag
matrix
gzip
4 djpeg
qpeg
fit
inv fft
Thrshld = 1 Thrshld = 2 Thrshld = 3 Thrshld = 4 Thrshld = 8 7Tirshld = 16
Figure 5.21: Hit Rate for SWFM using various FSTThresholds
Exaniining Figure 5.22, one can observe that the average speedup value for a
processor utilizing trace cache and the SWFM offers notable improvement.
Among the benchmarks, the average speedup increase over the Rotenberg fill
mechanismwas 4% with an average trace cache hit rate increase of 7%.
Speedup Comparison
(Rotenberg vs. Sliding Window Fill Mechanism)
DRotenberg Fill
SW/FST
matrix gzip djpeg cjpeg inv fft
Figure 5.22: Speedup using the SWFM/FST
93
5.11 Combining Trace Cache Schemes
To conclude the presentation of results, two trace cache schemes that provided
favorable results were combined: Branch Promotion and the SlidingWindowFill
Mechanism Intuitively, these schemes seem to cornpliment each other, as the
SWFM excels at generating relevant traces, while branch promotion increases
trace segment utilization by reducing the number of traces that are prematurely
terminated by the /^constraint. The expectation that the merged scheme would
increase trace cache hit rate along with the fetch held true, as figures 5.23 and
5.24 illustrate. For both metrics, the combined scheme outperformed branch
promotion and the SWFM when implemented separately. The average hit rate
increase over the Rotenberg scheme for this combined scheme was 19%. The
fetch bandwidth improved, on average, 17%. over the Rotenberg scheme.
Hit FtateAmong Trace Cache Schemes
80%
70%
60%
or 50%
40%
30% =
20%
O Branch Promotion
SWFM/FST
DCombined
roots solve integ lag matrix gzip djpeg cjpeg fft invfft
Figure 5.23: Hit Rate Increase for Combined Scheme
Judging from these favorable results, one would expect the speedup to follow a
similar trend. The average number of instructions that retired per cycle was
hindered though by a reduction in branch prediction accuracy. As Figure 5.25
shows, the prediction rate diminished significandy for several benchmarks with
94
Fetch Bandwidth Increase Among Trace Cache Schemes
6
o
5
s
4
5 o
3
3Branch Promotion
SWFM/FST
OCombined
roots solve integ lag matrix gzip djpeg cjpeg (ft inv fit
Figure 5.24: FetchBandwidth Increase for Combined Scheme
Branch Prediction Accuracy Among Trace Cache Schemes
95%
3- 90% -|
CO
o
u
c 85%
o
V
'TJ
6r bo%
75%
70%
Branch Promotion
SWFM/FST
OCombined
roots solve integ lag matrix gzip djpeg cjpeg fft invfft
Figure 5.25: Decrease in Branch Prediction Accuracy for
Combined Scheme
the dual introduction of branch promotion and the SWFM This resulted in IPC
values that showed no improvement over the Rotenberg trace cache using branch
promotion. Were a more aggressive branch predictor utilized to resolve this
95
decrease in branch prediction, the substantial improvement in fetch bandwidth
would be reflected in the overall processor speedup.
5.12 OtherSimulated Schemes
A few trace cache schemes were simulated that produced less-than-favorable
results. Three are discussed here, along with reasoning that explains the mediocre
outcomes. The first of these schemes was an attempt to implement simple fetch
address renaming (Section 3.5). This involved storing traces by combining
(XOR) the fetch address and the branch flags field to form the trace ID - Trace
lookup was accomplished by combing the next fetch address with the m results
from the multiple branch predictor. Compared with other schemes investigated,
the resultant hit rate was extremely low (under 10%). The justification for this
poor hit rate involves the difference in computing the index when traces are
stored versus when they are retrieved in the fetch stage. When a trace is
committed from the fill buffer, only the branch flags that are valid (i.e. those that
correspond to the branch count) are combined with the fetch address to form the
trace ID. Since the fetch unit has no information about the number of
forthcoming branches in a trace, the trace ID is formed by combining all m
prediction bits with the PG These extraneous bits that were not present when
fonning the trace tend to throwoff the fetch stage when indexing the trace table.
The second scheme implemented that did not perform well was Selective Trace
Storage (Section 3.10). This was a simple addition to the fill unit that discarded
traces that did not contain taken branches rather then filling them to the trace
cache. As described in [18], this scheme is based on the assumption that the core
fetch unit is as effective at supplying sequential basic blocks from the LI I-Cache
(fetching beyond non-taken branches) as the trace cache. Hence, storing these
traces that duplicate the static program order is redundant. It was found that this
96
reduced the average trace cache hit rate to below 10%. This exposed some
shorteomings in the LI I-Cache utilized in the simulations. Despite doubling the
line size, the cache was not truly interleaved as specified in [18]. This, along with
miss penalties associated with the I-Cache resulted in a core fetch unit that not
equal in performance to the trace cache when fetching beyond not-taken
branches. This performance skewwas evident in the speedup results.
The last scheme that was investigated but did not perform well when simulated
was Path-Based Next Trace Prediction (Section 3.3). This failed the using the
simulator for a couple of reasons. First, the scheme as described in [13] states
that the "history register is updated speculativelywith each new
prediction"This
requires that mispredictions be resolved in the commit stage by restoring the state
of the history register prior to the prediction and appending it with the hashed
trace ID of the correct trace. Considering the trace cache independendy, this
seems straightforward. Yet when combined with core fetch unit, some
difficulties arise. When fetehing from the core fetch unit, there is no way to
generate a trace ID speculatively, since no trace yet exists generate one.
Therefore in this situation, appending the history register must be deferred until
the commit stage when a trace has been assembled. In the meantime,
instmctions may be fetched from the trace cache resulting in speculative updates
that will be appended immediately to the history register. A recoverymechanism
would seeminglybe very complex in this situation. The solution to this problem
when implementing path prediction was to defer all updates until the commit
stage, which may inherently decrease the accuracy of the scheme. After
implementing this modified version of the scheme, the hit rate observed was
poor. Further investigation of this method is warranted, especially as an
alternative prediction method for trace cache utilizing the SWFM
97
5.13 Side Effects Associated withTrace Cache
Aside from the difficulties encountered with the implementation of three
schemes as explained in the above section (fetch address renaming, selective trace
storage and next-trace prediction), a few other caveats deserve mention
Introduction of the trace cache seems to affect the performance of some of the
fetch unit components in a negative fashion The multiple branch predictor and
return address stack are two examples. As described in Section 5.11, the
observed hit rate and fetch bandwidth increase were also accompanied by a
decrease in multiple branch prediction accuracy. One can claim that the trace
cache places more pressure on the multiple branch predictor than the core fetch
unit. Since the trace cache has the inherent ability to fetch beyond taken or not-
taken conditional branches, a greater number of predictions per cycle are utilized.
This implies that more predictions originate closer to the rit level and have
higher probabilities of mispredction. The aggregate prediction accuracy is driven
down and the performance penallydue to misspeculated paths increases.
The trace cache also has a side effect influencing the RAS. Consider the
following situation. A speculative RETURN is fetched (i.e. a preceding branch
has not yet evaluated). In the fetch cycle following the RETURN either 1) a hit
occurs in the trace cache and the segment is passed down the pipeline, or 2) a
miss occurs in the trace cache and the core fetch unit begins fetches the
appropriate blocks. The sequence of dynamic instmctions is:
BRANCH
RETURN
BRANCH (taken)
BRANCH (taken)
CALL
98
Assume the MBP predicts both branches after the RETURN taken In the first
case, the entire sequence would be fetched over the span of two cycles. The
CALL would overwrite the stack location of the speculative RETURN. In the
second case it will take four cycles to fetch the same sequence (each predicted
taken branch terminates a fetch block). This situation manages to avoid RAS
corruption, since the likelihood of the mispredicted branch being detected (in
turn flushing the pipeline and adjusting the PC) before the CALL is encountered
in the fetch stage is better. This specific example illustrates how the increased
fetch bandwidth reduces the RAS accuracy, a trend noticed over the course of
simulation.
99
Chapter 6
Conclusion
Trace Cache has been shovtn to be an ideal mechanism to sustain thefetch bandwidth required
for high issuewdthprocessors. The theory, designand resultspresentedaspart ofthis thesis are
summarized in this chapter. Some difficulties tioatwre encounteredare explained Tocondude,
suggestionsforfuture work imd-ting trace cache and doe Sliding WindowFillMechanism are
offered
6.1 Summary ofWork
The work performed for this thesis established several results and conclusions
based on various trace cache schemes. The first, and most basic, is that trace
cache proves to be an optimal low latency, high bandwidth fetch mechanism for
wide issue machines. With the exception of one, all benchmarks showed a
marked improvement in fetch bandwidth utilizing the methods examined in
Sections 5.4 - 5.11. Research which started as an investigation of existing
schemes, evolved into a series of fill unit revisions aimed to improve the hit rate
of the trace cache. The motivation was to introduce a mechanism that could
intelligentlyproduce sequences of traces that started at probable entrypoints and
maintained trace continuity. The product of these successive revisions was the
Sliding Window Fill Mechanism, which was tightly coupled with the Fill Select
Table. These mechanisms demonstrated an ability to increase the trace cache hit
rate by a notable amount. Paired with branch promotion, the hit rate improved
byaverage of 17%, resulting in an average fetch bandwidth increase of 19%.
100
A note on implementation complexity of the SWFM is warranted. To provide
multiple accesses per cycle, the FST can be implemented as an interleaved and/or
multi-ported structure. Typically, only a trace per cycle would be committed to
the cache. The SWFM has the potential to generate multiple traces per cycle. A
queue mechanism would need to be implemented to account for this. Since the
fill unit is outside the critical path of the processor, and fill latencies have been
shown to have a negligible effect on performance [16] this is acceptable. The
complexity of the SWFM is moderate, but compared with the requirements for
trace cache in a wide issue machine should prove to be feasible.
6.2 Difficulties Encountered
This project extended over a period of several months, during which a host of
challenges were encountered, most ofwhich were overcome. As with any sizable
research endeavor, the goals and focus evolved over this period. Comparing the
results with the initial proposal provide an indication of this shift in direction.
After observing the aspects of the Rotenberg and the Alternate fill mechanism,
emphasis was placed on developing a new method that combined the benefits of
both. This proved, in the author's opinion, to be of greater value than simply
researching existing methods as was proposed initially.
Aside from the difficulties and caveats encountered with a few aspects of the
implementation as explained in Section 5.12 and 5.13, a few additional points
deserve mention. Understanding the organization of SimpleScalar required
overcoming an initial learning curve. The majority of the simulator is coded
using a strictly procedural approach, which provides a stark contrast to the
understandability and mamt^iinability of object-oriented programming. The
drawback to implementing the extension using OO techniques was realized
during initial simulation runs involving the trace cache. The class structure of the
extension increased simulation run times, in some instances over four times the
101
time required for the base simoutorder simulator. In retrospect, some computation
intensive prograrnming techniques (R'lTl, use of STL structures) could have
been avoided to alleviate this issue.
6.3 Recommendations for Future Work
This thesis established a strong foundation for fumre projects involving
microarchitectures that incorporate high bandwidth fetch mechanisms. Some
areas that would be worthwhile to pursue have alreadybeen hinted at throughout
this thesis. A few include:
Further investigation of the nature of the inverse relationship between
trace cache hit rate/fetch bandwidth and multiple prediction accuracy
(Section 5.11).
Incorporating a multiple branch prediction scheme that yields better
prediction accuracy. This would benefit the combined scheme described
in Section 5.11. Implementing a path-based prediction scheme is an
option that was examined (Section 5.13), though certainly warrants
further investigation.
Improving the core fetch unit to support a truly interleaved I-Cache,
thereby allowing a valid assessment of schemes such as Selective Trace
Storage.
Strearnlining the trace cache extension to improve simulation run times.
This would allow a comprehensive assessment of the SWFM and
associated techniques using a complete benchmark suite, such as those
provided bySPEC
In conclusion, this thesis examined trace cache from a variety of perspectives.
The simulation and analysis of established schemes led to the proposal of a new
102
fill unit method that exploits trace continuity and identifies probable start regions
to improve trace cache hit rate. Through simulation, it has been shown that this
scheme increased hit rates by an average of 7% independently, and by an average
of 19% when combined with branch promotion. The combined scheme also
yielded a 17% increase in fetch bandwidth. These results demonstrate that the
Sliding Window Fill Mechanism can contribute to the overall performance of a
processor that utilizes an aggressive trace cache scheme.
103
References
[1] D. Sima et al. Advanced
Computer Architectures: A
Design Space Approach.
Addison-Wesley, 1997.
[2] D. A Patterson and J. L.
Hennessy. Computer
Architecture: AQuantitative
Approach. 2nd ed. Morgan
Kaufmann, 1996.
[3] J. E. Smith and G. S. Sohi. "The
Microarchitecture of Superscalar
Processors". Proceedings cfthe
IEEE, vol 83, pp. 1609 - 1624,
1995.
[4] G. S. Sohi. "Instruction Issue
Logic forHigh-Performance,
Interruptible,Multiple Functional
Unit, Piplelined Computers".
IEEE Transactions on Computers,
vol 39, pp. 349 - 359, 1990.
[5] T.Yeh andY.N. Part. "A
Comparison ofDynamic Branch
Predictors that use Two Levels of
Branch History". Proceedings ofthe
20thA nnual InternationalSymposium
onComputerA rtbitecture, pp. 257 -
266, 1993.
[6] S. Panetal. "Correlation-based
Branch Prediction". Twdfih
A nnual InternationalPhoenix
Conference on Computers and
Cxnvnmcations, pp. 210 - 216,
1993.
[7] S. McFarling. "Cbrnbiriing
Branch Predictors". WRL
TechnicalNote TN-36, Digital
Equipment Corporation, Western
Research Laboratory, 1993.
[8] T. Conte et aL "Optimization of
instmction fetch mechanisms for
high issue rates". Proceedings ofthe
22nd InternationalSymposiumon
ComputerArchitecture, pp. 333-344,
1995.
[9] T.Yeh etaL "Increasing
Instruction Fetch Rate via
Multiple Branch Prediction and a
BranchAddress Cache".
Proceedings ofthe 7thACM
International Conference on
Supercomputing, pp. 67 - 76, 1993.
[10] E. Rotenberg et aL "Trace
Cache: a LowLatencyApproach
to High Bandwidth Instruction
Fetching". Proceedings cfthe 29th
A nnual IEEE/ACM International
SyrrposiumonMicroarxhitecture, pp.
24 -34, 1996.
104
[11] D. Burger and T.M Austin.
"The SimpleScalarToolset,
Version 2.0". wunv.simplescaiar.com
[12] T.MAustin. "SimpleScalar
Hacker's Guide".
www.simpkscalar.com
[13] Q. Jacobson et al. "Path- Based
Next Trace Prediction".
Proceedings cj the 30thAnnual
IEEE/ACM International
SympcsiumonMicrmrthitecture, pp.
14 -23, 1997.
[14] D.H Friendlyet aL "Alternative
Fetch and Issue Policies for the
Trace Cache FetchMechanism".
Proceedings cfthe 30thAnnual
IEEE/ACM International
SympaiummMicroarchitecture, pp.
24 -33, 1997.
[15] S. J. Patel et aL "Improving
Trace Cache Effectiveness with
Branch Pomotion and Trace
Packing". Proceeding ofthe 25th
Annual International Symposiumon
ComputerArchitecture, pp. 262 -
271, 1998.
[16] D. H Friendlyet al. "Putting the
FillUnit toWork Dynamic
Optimizations for Trace Cache
Mcroprocessors". Proceedings of
doe31stA nnual IEEE7ACM
International Symposiumon
Microarchitecture, pp. 173 -181,
1998.
[17] B. Black et al. "The Block-based
Trace Cache". Proceedings ofthe
26thA nnual International
Symposiumon ComputerA rtbitecture,
pp. 196 -207, 1999.
[18] A Ramirez et aL "Trace Cache
Redundancy Red &Blue
Traces". Proceedings oftheSixth
InternationalSymposiumonHigh-
Perforrmnce ComputerArchitecture,
pp. 325 -333, 2000.
[19] Q. Jacobson and J. E. Smith.
"Trace Preconstruction".
Proceedings ofthe
27*Annual
International SymposiumonComputer
Architecture, pp. 36 - 46, 2000.
[20] A Peleg and U. Weiser.
"Dynamic Flow Instruction
CacheMemoryOrganized
around Trace Segments
Independent ofVirtual Address
Line". US Patent number
5,381,533, Intel Corporation,
1994.
[21] P. W. Lee et al. "Exploring the
Trace Cache Design Space".
Graduate Project, Stanford
University, 2000.
[22] S. J. Patel et aL "Evaluation of
DesignOptions for the Trace
Cache FetchMechanism".
IEEE Transactions en Computers,
vol. 48, pp 193 - 204, 1999.
[23] Y. Xie andM Wang. "Multi-
Branch Prediction". Graduate
Project, Carnegie Mellon
University. 1999.
105
[24] E. Rotenberg et aL "Trace
Processors". Proceedings cfthe30th
A nnualIEEE/ACM International
SynposiummMicrmnhitecture, pp.
111-120,1997.
[25] Q. Jacobson and J. E. Smith.
"Instruction Pre-Processing in
Trace Processors". Proceedings cf
theFifth IEEE International
SymposiumonHigh Performance
ComputerArchitecture, pp. 125 -
129, 1999.
[26]Y.OiouandJ.P.Shen.
"Instmction Path Coprocessors".
Proceedings of"the 27thAnnual
InternationalSymposiumon Computer
Architecture, pp. 270 - 281, 2000.
[27] Y. Chou et al. "PipeRench
Implementation of the
Instruction Path Coprocessor".
Proceedings ofthe 27thAnnual
InternationalSymposiumon Computer
Architecture, pp. 147 - 158, 2000.
[28] S. J. Patel and S. S. Lumemtta.
"rePLay AHardwire
Framework forDynamic
ProgramOptimization".
TechnicalReport CRHC-99-16,
UnkersityofIllinois TechnicalReport,
1999.
[29] G. Hinton et al. "The
Microarchitecture of the Pentium
4". Intel TechnologyJournal, Ql,
2001.
[30]GLeeetal. "MediaBench: A
Tool for Evaluating and
SynthesizingMultimedia and
Cbmmunications Systems".
Presented atMicro 30, 1997.
[31] M R Guthaus et aL "MiBench:
A free, commercially
representative embedded
benchmark suite". IEEE 4th
AnnualWorkshop onWorkload
Characterization. 2001.
[32] D. Burger and T.M Austin.
"The Simplescalar Tool Set,
Version 2.0" Unkersitycf
Wisconsin-MadisonComputerSciences
L)epartment TechnicalReport # 1342,
1997.
[33] T.M Austin. "SimpleScalar
Hacker's Guide".
www,simplescalar.com.
[34] E. Gamma et aL Design
Patterns: Elements ofReusable
Object-Oriented Software.
Addison-Wesley, 1995.
106
Appendix A
Trace Cache Extension Header Files
** Abstract Interfaces **
Main/Creational Classes
TraceCache
TraceCacheFactory
TraceCacheConnector
CoreFetchUnit
Component Classes
HistoryUnit
Renamer
TracelDSelector
TraceGenerator
FillUnit
Predictor
Data Classes
HistoryToken
Predict ionToken
Trace
Instruction
Address
TraceCacheData
Helper/Exception Classes
TCDefs (#defines)
TCLogger
Outputable
Printable
LookupTraceException
Instrue tionNotAddedExcept ion
InvalidOptionException
TraceCacheException
et
<H
0
H
VH
O
01 Ul3
O
q in oj
01
J5
0 HO J- CJ
Pi H *-J 13 <d>H TJ tj - -H CJ
(0 0) QJ Jh O
> oi q QJ Q,
m q bi
01
o
QJ nj o bi <u id
X! 0, O O 43 u
AJ -H O XJ
U] in xj -u CJ a
QJ 0 -U 3 QJ 01
q AJ O, O u
ui O vU nj id
*h tt O E-i
H
o
^ o o
m QJ hU QJ QJ 01
4J U O O 43 01
U) QJ nj qj -U id
QJ H <*H JH
O *J Ct] a
4J U TJ q UJ -u Vj c
1 01 q O -u p QJ
O 0) & CO
o id
u u m JJ
a i Sh - u 01
0 J3 QJ CD O U TJ - &S qq TJ id u 43 43 q 4q c uj
U O u HI 'H
CJ
o <U
_J
" CJ O C id
-H JJ d oi t] O 43 JJ o CJ
u CJ q Tj - -u CJ u
v"J o <D q -u - (Cl 01
3 M 01 01 QJ 43 <a o 4-l * CJ >H
M <N 01 01 u O TJ 4-i Q) o id o
U c c o flj QJ 4J "r- 4J * u H *J
Ul ^r -H -d 1J in 01 O -H 43 o 3 U CJ
<U ^> IW UJ u 4J -u c o in
4^ 3 o & *W 0 01TJ 01 01 01 01 !h o 01 q
o a a H 0 QJ QJ QJ 4j 0 01 * rH >H J3 q
& o ^. ^ i -u 43 CQ O 45 45 CJ JJ c o SJ o-^ ^ id o O 4-1 u q O 4J Q o c 4J o u CJ
o <N e SJ o 3 c qj u q
Qj U U to q
id o -H JJ CJ 2> >SJ *S a 3 QJ Jh 01 Ct, o 3 * ho X Q 43 JJ QJ q qj <m oj o JJ 01 0 n SH o u .
.*> * A U SJ O Ul 4-J O 'M -U O o QJ QJ QJ J3 j3 XI U Jh o oj
Uh O
X its
3
O
(0 13
0
(TJ
QJ
Ci, 0) QJ nj
1= Jh 1h QJ QJ
QJ
"n
q q
o o
q
o
o o
id id
u
jj
Jh
OJ
0]
01
hj sj q
oi CJ o
01 <N J3 <D 0 U 0 O in 45 43 3 c q_ CJ o QJ tn a oj i qq o o s J3 !h U U O (J( OOu o 01 01 fc bi Q 0h v_
o bl o q tig = O U -H (0 CJ CJ QJ o-H flj CN o *J A U 0 rH Vj id id U ^
sj a 'H 43 id o -H 0 *J A si ja Eh q u u O o q
o id s X fa o c *J a 3 o 0] 01 EH fn o Eh o
? e *~i rl 1 a D -r4 B r-l M 43 43 o ft W H oj q q "H 01M > g g tH XJ -C 43 C 43 0 b a 01 4J 4J 0] - o o SJ SJSJ (U M HI fl u o CJ p W C H U -H 4J (0 Q. q 0) 0] -H -H 01 l p"1 fl In o o n 4J >, u a ti
11
i-( *H Q) -h q jj A~i J3 "rl 0J
q Cj q : < 4J u u M H O a a 01 CJ Jh E Hh U U Oi CJ l<
O id o ^H o u s S CD (k. o s a D tn QJ <j 3 -H 3 QJ QJ id 01 CJ 3cj Cj H H a u o 0 *j a o o w o u TJ 1 ui bi TJ
JJ 0] CJ CJ 1 P f01 1 H O u *i a M w (3 rH J ^ ^ id q QJ ^ s QJ oi X 0) 01 SHq cj
o id 2
SJ 3S 3o u u OO H U UX K IH H -H \ \ O01 H fe; Q <r; ^ a; *j; &1 CJd fei Q a;
Q. >h oi q 4 & u ^ X X X X X X X X X X X X X X H \ \ \ \ \ \
St. K 1-1 1 f id 4-1 X X X X X X X X X X X X Wl? \ \ \ V. X V
03
<D <p o HI o a u
<u d> d TJ a TJ TJ TJ TJ c 0 d xi E-i
"0 c 3 3 ^ 3 3 3 3 3 ? 3 3 3 0
0 TJ
-H H rH rH rH HHHH rH M rH r* W -H
(j <w O u u O o u u u C o o u 01 rH
O
It
<M 0 C A c A fi a a c P a 0 B id ^N N \ N ~s \ V -H a -H H -H *W H -H -H -H -H -H H ^H rH 3
N \ \ *x \ S. V. : =tt= 4t 4t 4t = :#:# # # S* * U ft
CJ
4)
U
id
u
&
HO-
qj
4J
-H
O.
O
O.
3
O
H
>H
2
01
4J
r-H
M
m
01
IU
w
uj
1
0)
b.
ci
cfl
c;
-H
O
Sm
o
o
Ul
01
M
0
Jh
O
4J
0
3
U
jj
01
u
0
^H
01
u
q
"rH
O
D,
u
"rH
a
01
o
"2
0
Jh
OQ q N 01 M 3CN 6 o M 01 ftj ui 01
\ o H 0. bi 0 Ul
o U & c jj 43 <t)
Cj M 01 id QJ q U -~\ N
X TJ t3 D t) TJ TJ CO TJ iQ U a jq TJ TJ 43 QJ jj o Jh
CN QJ <U in (U QJ QJ QJ IU 3 01 CJ QJ QJ TJ TJ TJ O TJ 1 TJ QJ TJ a Tj oo 4J 4J u ij Jj u u U *J XI u U u QJ QJ QJ cfl QJ QJ I*i QJ T3 01 QJ JJ
o
I>1
01 <Q 1h t-i U 4J O jj QJ jj jj q u JJ CJ
CN q Si oi tH o QJ CO QJ QJ <,*
tJ O H rH fn CJ", U Cj CO IO 4J C"H c rn a CJ QJ *H -H **H
on tn rn 0"| IT) -sp OJ ^T io u rn H fN a Ui O H C3 IX CJ CN 0 Ul .Jh r^ Vh QO
o A . TJ Ai -. Id 5 M Ul t-H *H CN (0 -H O CN 'M in 0) CN QJ
o Ul l ^1" IX O 0 0 t-H io in H Ch 0] .. m Eh h u - -q
~H tu
43
O
o ** H c^ <* 43 ^
-. u q
CN io -a
-. 01
o In
OJ
t^ c-t
Ul
QJ
iN m r*i
4J
QJ
Ul Eh
43
M TJ
en q
CN
ui
cd Ol
in
C U"l JJ
. ON CN) CN v-o lO QJ 0 >o o U 00 J5 n *H H
. 4J 01 CJ . fCJ l O .. 4J
(Q M <N O w <-H Ei -h M O Id rH 4J M O M 'M ui to c*i ui JJ CO ON <t) [^ 0. cn >m
O 0} u H 0 O *-1 Q, tN 1 QJ *-t oi M rH o 4;
00 * ^ CQ T~) CN QJ in ui cj vo 0\ 0 CO C*1 O bi Jh V*H Jh H >H jj
QJ Qj CV) * S <*1 bi o q m W O 0 O o "1 tx 3 Ul 3 rn o H CO QJ Q o o O vo
43 <U
u q
qj -s
o \ -k X 11 x . X q X OJ TJ X \ \ Uh X X <N 4^ CN TJ CN u <N ^ M ^ cn Jj rn SJ CN 4q
(TJ
Jh
</> o 01 OQ oo rrj <x> -X QJ r^ Cv (Q c-.. sj tX "o X X X X 0 X O X 0 s CJ X O
,_, (U T-i O Ul o Si o o n O o id o 3 o o vo 0] Vo TJ Vo QJ vo VO QJ ui Ql isl 01 * 3
> \ tn \ \ d) \ o \EtQ, X N X SJ X X o QJ o q o q Q JJ p f= o q O S O Ul
01
u
cn *a fN N K "N c\ q *j CN <N T) tN 01 CN CN X tn X ij X q X HH X X q X d X
0 5
^TJ
-H
QJ
4 o 01 O
o
O -H o 'a o O QJ a o Q O O O CN C CN CN 0 <N r C\ JJ (N 0 CN o CN QJ
s o Cf} O O **H o QJ O M b. o
O id O bi o O O (tj CS 0] o tj Q u o q O o o cj 0 0
> QJ CN 0) CN H (N X <N 4J CN 4J . <N <N <N 3 CN CN O 4^ o q o QJ O TJ O QJ o QJ o 01 0 rrj
Q>
o 3
e 01 <0 o 01
01
lH
01 fl CN O CN 0 CNH 43CJ CN -U cn q0 CN g IN o CN "*HJh
" 3 i 1 TJ <>, tn CO 3 IX .L) vo QJ lO TJ O
';3> tj in bi <N a <~H o !s JJ r10 U]
, & m r"5 QJ
9-
o
O *~i o f-( SH M TJ H u rH QJ U H m m tn rH ^ M o\ 0 oo 0, i^ o vo Ih Ui E ^* o <n O <N *J
H TJ 3 OJ -H u 73 U TJ a 0 m c o QJ 2 O 01 01 - q<0- &1 e j o H rH M Q, H TJ HO.I, >-H D, -H ^ rH | H *-( <H w Q, M 0 *-H M 0 *-, CJ ^H 0 *H -H
ffl >, c; 3 QJ u <u n U 0 0] 1 Id Id
q u Q H q q Ul q 0) q q q 01 c 01 q C QJ s q 3 q q TJ 5 P q iS d >H q TJ
8
o
0 Qi 0 O in o <0 0 bi QJ o u O oi 0 0 0 X 0 01 O TJ o e-t o QJ O Eh 0 1>H o tn O QJ
q
o
H H OJ 'H OJ "H xi m O H 01 H H w H -H H H 3 H -H *H 43 H H H ^ "H
CI Ul SH U] 45 01 1 Ul TJ QJ 01 jq 01 -0 01 01 01 bi Ul Uh Ul O 01 TJ 01 T3 01 01 CQ TJ W a 01 a 01 *4H
H
SJ
0} bi *H H o -H 4J H x; M Q) O H u M 01 H H H 3 "r1 'C1 -H M QJ --H QJ '^ H V J 'r1 01 -H CU H *H
3 CJ o 3 * > *M t> ^ ^ 4J :> tj nj t> In ^ Tl > rH > 43 > bi t> In > TJ > t) t> q ^ TJ ^ a > o > TJ
c a Q, 0 ^ 01 (U 01 <U
3 <u TJ Q) TJ 1h QJ 3 oi 'a 01 H QJ QJ QJ 3 QJ QJ TJ QJ TJ QJ -H Q> TJ 0) a 01 o 0) 0
"H to- OS * a; fl 0$ Et. K. a. ftj ^ Eh t^ &. a; ! 04 ^ ft; Q a; H a; *c ft; : ft; ti ft; *^ a; c V < ft; e
-OH h 01
Q) 4$ JJ o "C
-H U CJ 01 ^
h a o 01 HI
&< ^ u Q K
XXX
XXX
\ X \ X \ XXX \ \ XXX X X X X X X X X \ V. V V N. \ s X X X X X X X X \ X X X X X X X X X X X X X X ~s \ N. \ XXX
N. N. \ X. \ XXX v -v XXX X X X X X X X X V N \ N \ X s X X X X X X X X \ N X X X X X X X X X X X X X \ \ \ \ XXX
0o
tn
id
Pi
o
.q
Cl
q
01 m
q In
01 JJ
-*
o n
u o
q U SJ
0 01 01
C
0
M 01- 01 q 01 01
TJ q C q q
01 o o 01 ci n
>h q q q q q u
Q,-"- tn c
3
n
< i
oi 01 ,q
01 q q
SJ OJ n o n
q 0) 01 H "rH Id
01 vh q SJ SJ
N3 SH Sh Oi PJII)
tn TJ u 01 CI 01
in 0] X
<C S! m t Isl
si
O
Eh
q
a
a
oi
SH 45
D, CJ
01 01
p "J
SH -H
>H
2
a:
q
o oj
H 01 -rH
rl 3 01 01
biTj
* &
"S S! i
ii
\ \ o
. \ \ Eh
3
&
id
E
U
0
<sh bi
q q
M H
4J
CJ
1h
HH S
H
CJ u
01
0. HH
01
"
CJ i,
SJ "rl Q)
3 SJ Jh
O 01 4J
O 0) 01 01 01
q q q q
oi o o 5 o
B c q q q
oi - q q
SJ oi -. o o
q 01 0) -rH -ri
01 -h q sj sj
g 'n U U 0,3 M 3 01 CO
bi "a sj oi o
U o oj oi x
( Sj e, ^ eq
&
CO
&
01 g 3 ^ ^ ^ -v
01 Id O 01 01 01 0)
sj oj q q q q
h in hi o o o o
in sj q q q q
& oi Eh ^- -- ^
<0 0]
oi - q q
sj oi .. o o
q 01 oi -h -h
01 -ri q SJ SJ
*H >H >H Q,
3 -H 3 01 01
bl TJ SJ 01 CJ
SH O 01 0] X
< s; a- < m
in'
cj
O 0)
a "D q
01 01 CJ
SJ SJ SJ
id 01
O CJ 0-H 01
H "H SJ
o o 01 iioi oi H
01 oi o q
Id Id CJ
D,
01 01 01 h
if #1 rB o
Eh Eh Eh O
\ \ \ s
\ \ \ \
JJ -H <l) U
c tn <d -
3 - J 3 4J
W TJ QJ -H
OJ
q
c
0
>, U -H en q
>h a) I I 3
CJ O E (D |
-O 3 O CJ .-H1
w q to id r i
* 3 rl QJ U U -H
u C Jj Jh jj o
(0 o H O O jj
&i a q jj jj nj
QJ QJ D Jh
43 43 43 q CD
U CJ o ID > CO q j->
rd rd Jj >,1jO
Jh m
-H
CJ o
OJ fcl o e
j-j fd u
qj :=>
u o (J ^H
rd rd Jj w j: rd rd ^H
u u O -H 1H Jj -h
Eh Eh CJ X e^ E-< Cm
sti
o
id
u
<D
u
d
n
tri
01
3
q io
sj q
o
u
o oi
U J5 oi oi
q q
o o
q q
Eh
01
u .q
01 CJ
*1 J
01 1=
S
p "aEh 01
r?
M
0. -H
Ol id
H O
Q
Cs, <U
H CJ
D, SJ
tf -rH
0. J5
a
q
-. 01
oi q
sj o
o q
^ -
o q
a 13, jj, c I
JJJJS
o u u u fd
jj jj jj jj Jh
XJ
44 IM 4-1 "JH Q,
Jh Jh
T3 ,q <-a ^ tn
id u -H
i jj jj jj m
g c a a>u w -H 3
s -
1 TJ N
-H
TJ 01
4) JtJ
JjSf-rl
gig
a c fi
0 0 0
O CJ CJ
oi to
P qcj -h
id w
CJ Ol
ffl >H "rH
U D, sj
SJ CJ
S 3
a id >h
q oi -sj
oi sh oi
i sj q
* 1 "rH
3 01 -^ ^ ^ -^
In Vh 01 01 01 01
q q q q
o o o o
a q q q
1h 0] 01
J) Ufl
Oh -rH Eh
0 rn
01 rH
a io
q cj
01
g
rrj JJ
01
CJ1^-N
q oi
h \ tn
QJ Q, fd
43 nj jj
t Jh uj
m
ju nj tj
q o
qj q u
Jh QJ
Jh -S TJ
3 i
o
TJ 43
Q] fJJ LJ
CJ M
CO *"H tn
Jh <tl q
u rj-n
q sj xi
q ID
3 co
O
Eh
O
o-i
tn
q
H
01
Q
a
q
oi
r) 01
CJ J5
r-H SJ
F qCU. M
q cu m cd oj oi
oi q r-H q q q
o a o o o
oi q S? q q q
m ^- lij. ^- ^- v_
o 0J
Cl q >h
-q
Cl HH
B oi --
q
Vh Lt -q
Ul 3 CJ
SJ SJ
01 01 0)
bi O- Hh
01 01
u oi -. o o
b. -u SJ OJ
01 0]
m ^ i
q oi oi
oi -h q
B "M >H
"H S! 05 hs;
oi oi
q q
o o
-H "rH
SJ SJ
>H ft
01 01
CJ
X
SH
01 tl
5 0]01
-? IJ
SJ 01 -
q 01 oi
5! ;" PB 1h >h
01 oi
q q
o o
h -ri
SJ SJ
U Q,
-. -i _. 0) oi
bi *a sj oi cj
*H 5 01 01 X
i; Si cc $ m
id >H
lH 01 CJ
Tl B co
Tl s; q
-H
O V \ N \ \
s> \ N. N. \ \
o0
Ol
id
Pi
<D
A
O
Id
CJ
tD
V
id
SH
Q
bi Cj
q Q,
-H TJ TJ
SJ SJ <J J5 01 01
O D, In O .q TJ jh
q 01 id u CJ 01 CJ
CJ sj OJ SJ XJ SJ
TJ Cl 0] Hh 01 CJ 01
rH Id HH SJ HH
TJ 01 01 01
0 CJ .q 01 HH
Ol HJ Id SJ 01 0}
pH Vh XJ 01 SJ
H B JJ .q Cj II 01
O CJ q fl q
01 O 01 sj
q >h .q oi U q
sj Ej J5 Tj
q
,
in 01
oi bi 01 SJ SH .Q SJ
0) 3 01 01 o
B q CJ B q TJ "rH-n q Id -H * 01 CJ
SJ QJ u SJ TJ SJ O
SJ rH O 01
0-H 01 >SH TJ id E oi
sj a taO r> 01 O
Id J3 Cj O In 01
* -q SJ Q, SJ Q, >H
X X X X X XXX
X X X X X XXX
a
X X a
X X H
Oi
a
o
a
o
a -o -
01 01 Tl
A Xi 01
cj cj ,q
SJ SJ u
01 01 SJ
HH 4H fll
IJW
01 TJ
01 01 CJ
A sj o
CJ O 01
a e oi
J3 5. n
I
"
I
a tn oi
fi fi c
o o o
t-l
r-H1H
\s
S 5o o
q q
01 01 -rH "rH
SI SJ
HH 1H H ft
"rH 3 01 01
Tl SJ 01 Cj
01 X
S3. 0-J < sVj
X X X X X
X X X X X
rH ft
Id o
3 U
SJ #
SH "rH c
'C H n o^ SJ
01
HO -H
a sj
01 U ft
IH q 01
3 ct SJ CJ
", rH a x
SJ
ft s y
01 Cl 0 o
q -H
o 01 -^ *J
'rH q SSJ SJ
ft O TJ
01 -H -rH
01 01 01 01 01 01 01 JJ <-i
11 W q q q q u #2u SH Cl 11 Cl Cl o
Id id q q q q q oj a
ft ss, 01 M
u
id
q ft
Cl oi 01 $
rH 01 q q a o
SJ SJ oi (l Cl rt U
Ui q 01 oi "rH "rH o a
-H 01 q SJ SJ > SJ
rH HH rH IH ft
oi II *rH 3 01 01 rH
M Ml 'Cl SJ 01 Cl id
01 in 01 X
S; q ^ ^ oj i; oj. sj
!h
HX X X X X X X X X
X X X X X X X X X >
&
In
ft
rU^-.-
O QJ
m q q q q
Jh o o o o
q q q q
-s co - q
jj jj m - o
Q, q ui -h
-H "H tJ JJ
Jh E **h in Jh
O 3 -h 3
oi bi*a JJ cfi
Jh .O en
Q ^ hS; ft; ( t
3 &
!
o
id ft
ft. <2
01 T)
rH Id
id >
rf c
SJ M
01 S"rH 01
IH g
I -rH 01 01
: o q q
i a, o o
i q q
- ** ^- ^-
01 O]
q q
- o o
Ol -H -H
q sj jj
In Sh a,
3 -rH 3 01 01
bl TJ sj 01 o
In o 01 oi St;
<SJ Sj ft. nj [q
M
SV a
O 01
SJ O
01 X
-h a
X c
01 o
SJ -H
id sj
SJ >
H C
t-
O 3
SJ O
Cfl u
-H JJ
3- jj
55
X X
01 01 "H 01
q fi o q
o o ft o
q q fi
-- ^- *% *-
ft q oi w -ri
-H 0) -H q sj
In B "M -H U
CJ 3 -H 3 01
01 biTJ -SJ 01
01 In O 01 Ol
q <sj o. n; i
id p.
c oi
oi u
a. x
01 w
SJ C
id O
01 -rH
H SJ
CJ ft
o
TJ
o id
sj >
CJ C
0, 01
X jj
hi CJ
Id
n TJ O
01 01
SJ SJ 01
H CJ
rH U id
rH 01 In
csj r
O -H bi
q bi
CN >H M q
CN O U "rH
HH OJ 01
HH
^ 01 HH Id
X CJ -H ft
CO m TJ X
o <sh bi
X U U q
!
01 _
SJ HH
q
jj oj
cj q
id id
O >H
01 M
id S;
u
Eh TJ
u
- fd
tj a
N TJ
< It)
TJ cj
rH
M- 01
25
O CJ
SJ 3
CJ TJ
as
SJ
^
CJ 01
rd 01 0]
SH Ol M
SJ 01 01
01 id TJ
XI rH o
Si CJ B
TJ 01
01 q
-<3i 01
>,CN TJ
in X X
o vo bi
sj q q
Cj X -H
Id CN TJ
Cs, Q TJ
OJ O fd
JJ <N
co 1h
H O
X SJ
Vsj Cj
i
<N O
CN SJ
CJ QJ
JJ D,
Jh -h -h
o U sh
01 XJ SJ CJ
-H SJ q Ol
-rH 3 O 01
ss, t O Q
O Ol-H
01 JJ
CJ rH i
; o > TJ
j to
, <o- a; sj
o S>
01 TJ
"rH 0J
s> tj
01 TJ
o. *:
H OJ
oi bi
rt q
t. fd
Ol Jq
05 ti
CN M
Hl tl
CN M
rx TJ
-1 fi
X fd
X o
CN SJ
O fd
O IH
CN 01
S
vo O
> TJ
01 TJ
in JJ
m a
ftl
rH
u o
O ft
CJ 3
3
>h q
SJ 01
oi JJ
01 a
a
01
Ol 01
rH fd
CJ ~l
CJ
01
01 TJ
id 01
JJ S>
H
rH Sh
fd 01
3 TJ
cn JJ
tx TJ
rH 01
oS
in 3
X u
Ul 01
o 1h
O CJ
in q
oi
U
SO 01
HH
H 01
>H
q
O TJ
H 01
oi bi
h q
:> io
01 JJ
ft; ti
SO 01
o bi
X fd
<N 01
Q 01
o 0)
N B
<N
H
X
IN Ol
o q
Q O
IN "H
rH 01
Sh
q fd
O ft
H
01 TJ
H 01
> TJ
01 TJ
ft. Id
bl
IN O
-H
SH
q
O -H
i- H
01 q
ft, H
xxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxx
fi
0
-H
41
"i", HJj =
>H J" JJ O
PS U X
O O o u u
Jj SJ o tlEh Eh
O O Osl O
<< < SJ CO Id = -H
b b. -H . H SH A SJ
X X
B jj co o -a
p W fi sj CJ
>i IH Q -H TJ
U CO H O fi -Hy y
A
rlcl
Cn
a O | 1 PH
H H A SJ S O CJ rH CO
y y M A 01 fi ffl fd rH >
a SH tI m H U -H fiS m Eh Eh h H
H2i V V X E C
eg id 1 O O I 8 0
iJH TJ TJ
0 C 3 3 3 3 3 3 3 3
r-l H rH H rH rH rH H
c < O 0 O 0 CJ CJ O CJ
vu a a C fi fi fi fi C
-rl Tl -H -H H J-Hnl-J-rl
* * =st= * 4H= St SSr St 4* *
01 Cl
n :~l
"H In 01
> SJ q
Cl o
H 01 q
&
o
ft,
01
JJ
in
bi
>H
X X X X X X
X X X X X X
CO 01 rH
V Up,
>H H q o rH
Q o fd 01 SJ -H
H SJ
Cj u
3
SJ
CJ 2 ft. SJH
01 01 o U 01 01 01 J3CJ rH JJ .. H CJ q u - Cj tl
fd 01 u o s- ro 0) O o rH f3 o
jV Cll 01 SH CJ SJ fd >H H
Eh
Q
rH II
01
01
sh
Eh
Cl
id ii
lH
3
SJ
Eh H
*H
II
01 H tn 3 OJ H 01 -~ >H 01 ft.
q a ft q c f JJSJ 01
CJ
m a
01 o
SJ 01
Cj
oi c
o o
i> SJ 01
CJ
c
o
0 id CJ -H u 0 id 01 -rH 01 O Id -H
SJ id sj
u a
0
SJ
SJ
Eh
CJ SJ
id ft
SH
3
sj SJ
a
M Eh Ol fd u H Ol ft U SJ 01
01 01 01 CJ >H OJ 01 IH CJ 01 01 -h rj
SJ JJ SJ X 01 SJ q 01 X -u JJ C x
q SJ td ft] q q SJ JJ (a SJ q SJ D
H oi a OJ H id c -H H rH C
o O u o CJ 0 0 OJ o q 0 O rH O
ft SJ O rH
SJ
01
Cj
ft SJ
O SJ rH
ft SJ H -H
ft. SJ
fd U
01
* a
o
id
Ih
fd H
01 *
H
H
10 H
01
HI ft
SJ O
01 u U TJ Eh 01 SJ TJ ft. 01 SJ fd TJ
q q O -H 01 q q tJ rH 01 q q 01 -H
SH 01 01 "rH 01 01 SJ rH SJ 1h 01 01 -H 01 01 O rH SJ rH 01 01 01 01 rH rH
3 q q 0 q q CJ id id 3 q q 0 q q sj id m 3 q q 0 q q CJ id
SJ o 0 ft o 0 01 > 01 SJ o o ft o 0 id > 01 SJ o o ft o 0 >
01 q q cj q rH C U 01 q q u a 1h 01 q q q C
a; *c 01 M
Ol
o
CJ ft; < 01 M
[J
01
CJ ft. < H
SJ
H
q M c o q -
0 01 oi 01 3 o oi 01 01 3 o 0] 01 D 3
H 01 q q U 0 H 01 q q CJ 0 H 0] q q rH O
SJ SJ o o id u SJ SJ oi O o rd U SJ SJ 01 0 o rH U
ft q 01 01 H --H U JJ ft B 01 01 H H U JJ ft q 01 oi H h H Jj
H CD H q SJ SJ tH *J -H 01 h q SJ SJ Eh SJ H 01 -H q SJ SJ ft. SJ
In HH fi >H ft M B n In >H ft >H E HH u u ftrj H 3 01 01 rH oi CJ H 3 <u 01 t-t oi CJ H 3 01 01 rH
01 bit) SJ 0] CJ td 1 01 bi TJ
SJ 01 0 rd 01 biTJ SJ 01 CJ d
01 u O 01 01 X 3 01 rH a 01 01 X 3 01 lH O 0) 01 ,x 3
q C Sj a- j ft. SJ
U
rH
s; Q *. Sj a; c ft! SJ
u
fe; Q <t SJ ft. "JJ ft! sj
U
-rHX X X X X X X X XXX X X X X X X X XXX X X X X X X X
X X X X X X X X > XXX X X X X X X X > XXX X X X X X X X >
-rH Cl
SJ 01
ft CJ
Tl Cl Id
01 >H
SJ Eh
Cl
01 X
sJ X Tl
0 fi
SH 41
U --- *t
0id
01
a &
hX
0 TJ
Ol q
JJ id
O
01
q -q
O CJ
-H irj
SJ CJ
-H
TJ 01
q Cj
1h 01
ft JJ
O 01 QJ 01
hh a q q
U sj o o
oi oi q q
ft. jj *- -
q 01
01 "H
B H
bi
q
01
s
8
01
CJ
01 o
JJ -H
SJ SJ
01 01
q q
o o
q q
11 SJ ft
q B 1)
01 O SJ
q CJ 01
01 0 Sh
sj ft 01 CJ
a E, JJ q
01 0 SJ o
c O cj
o SJ SJ
H O Cj 01
R 01 01 JJ
o
o q
SH >H ft
H 3 01 01
bi TJ
SH O
ft; SJ
CJ
cS
01 01 01 01 01
q q q q q
o o o o o
q q q q q q
3 -H 3 01 oi
bi TJ sj oi cj
>h o oi x
C J5J a; <c m
f
01 u
Vh 01
o,6
TJ fd
1> Id
O TJ
u
ft 01
q
01 O
SH 01
O Cj
Cfl 0)
01 CJ
01 id
CJ In
CJ Eh
>H JJ
01 sj
01
r,
01 sj
JJ
0]
01 0]
q
o
o
8
01
JJ 01
O q
id to
O >H
HI r-H
a
td SJ
u
Eh TJ
In
.. Id
TJ S
H TJ
Co, b)
I
JJ 01
3 JJ
O -H
JJ *J
& O
01
01 q
P SCJ o
fd Cj
Cj sh
01 01
CJ SJ
id q
eTh
OJ
bi
q
bi
q
tj -
01
sj o
q
- - JJ
JJ co
-
oi bi
q
TJ -H
q JJ
01 fd
q
oi oi
q
oi o
SH
o in
SJ CN)
O X
01 tx
o JJ
X CJ u
O CN oi
Cj o 01
01 C3 q 10
JJ CN O fd
CJ -H XI
td sj
CJ en id OJ
01 - 01 JJ
CJ rn U sj
fd CJ
>< "
~
fi
Eh O TJ -H
-H 0J
. .. CO HH SJ
i bi "ri 'si oi
: o > tj -h
i >J oi cj x
: v> o; Sj oj
TJ oi
oi q
sj o
vo tn
o q
- *H
CN bl
IN 3
JJ
-rjt 01
IN TJ
X X
vo bi
o fi
-rj, -H
01 HH
H -H
5> TJ
01 O
OJ SJ
O O
tn -h
X 01
SO -H
Q IS
X OJ
CN In
*N "H
q
rH -H
1> 01
01 .q
a; B
H 01
SH
q
O -H
H fd
01 -H
-H SJ
t -H
01 q
sj q oi >
J 3 o 01 OJ
ft, ; CJ Q oj
xxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxx
XX
x a B
an B ^JJ
'-"'
CJ CJ JJ n
c O M 0
5 z SJ JJ 41 O SJ
H CJ 41 u
o o a SJ co id 01
cj o o -H c rH SH JJ c
P.X AO C JJ 01 COp ol fi sjflUfl JH
MHOI!
oi < to
SJ 3 CJ O rH
c
o
CJ CJ SJ O
eld
CO 01 01
ft, JJ JJ
H H CO CJ CJ
CJ CJ u 01 fi J rH fd id
XX
0
o
-H 01 U U -H
S X Eh Eh ft.
CJ
01
o
0)
v. set-.. CJfd uid
eg fl O 1 1 1 u u
SH CO Tl TJ TJ TJ TJ TJ H Eh -
S <* 3 3 3 3 3 3 oTJ ^1 rH H H rH H rH 0] 0] Tl
fi <SH O U CJ CJ CJ 0 0] 01 rH
HH C9 fi fi fi fi H C id
SHH TJ H rl ^h! -H -ri rH
*t *t *fc St * St 4t St cj a
01 01 01 01 01
q q q q q
o o o o o
q q q q q
Q ( ^ a; c 6j
xxxxxxxxxx
XXXXXXXXXXl
In
01
sj
q
H
11 U
ft 01
. SJ
01 oi q
JJ q -h
C) O o
fd -h ft
Cl
01 o 0)
111 1) 01 JJ
JJ fd q Cl
Cl fi q m
Id rn o o
Cl CJ 0)
0) 01 0
Cl JJ 0) id
fd SJ In U
SH H Eh 01
Eh
SJ
01
SJ & 01 O
III 01 oi JJ q
01 CO
q
o
>H Eh =
-H oi
SJ JJ Cf]
ft q oj
-H 01 -h
In B *h
01 Cl
B 01 biTJ
01 1h O
Q C S;
XXX XXX
XXX XXX
J3 SH
= JJ JJ
JJ JJ
a cj
SH -H SI CO
a jj i jj
a o g o tn
a K -H 1 SJ
o
j
o
Eh
TJ
3
a o A
co m co co
O O O o
4* 4t =St 4t
JJ
q
JJ
CJ
H cj o
Sh
O
CJ .
01
43
JJ
jj TJ sJ o A
jj
Jh
Q,
q
tn
01
Ul
Ul
rd
JJ TJ
01 JJ
JJ u
sj fd
CJ
Id
H 01
1 <H
Eh N
q CJ Oi Jj 01 trj vh3 q 01 SJ t cj (jj 0]
p, 2
O 4J
a
id
H 0,
fd
oi u
H
TJO
JJ
<*H
Jh
O
CJ
45
"H
bi
CJ
Eh
-H Cj
o O
3 SJ
01
q
43 rrj
tJ N
01
01
rd
01
JJ
SJ
CJ
H
O1 JJ
SJ
JJ
q 01 -H SJ TJ Jj O
co. 9
U W
1
01
JJ HJ
01
lH g-H ft) JJ
TJ
q
JJ JJ SJ ft Jh "I J-J V
Jh
43 SJ O <H O) q TJ
H JJ jj CO 0] to
q tj *J q o CJ H --H Jhu ui sj, fiJ"1 3 fiO 3 TJ Q
t= Jh -q
3CQ ~H Jh TJ SJ SJ JJ Jh A <a 0Di 01 H CJ CJ 43 Jh 1 43H
JJ
U
a I -Tj
SJ a,
% CJ
JJ
45
-H *"H O jj 01 ISH -H 4; U u jj
S 'M
JJ TJ
TJ 3 -H 43 JJ fi Q. 0 q"H 5 CJ TJ CJ ft 01 -H q Ul &, m **h 0 <d
TJ Ul ^H SJ <H JJ fd q b< jj'*H CJ 01 1 O .01 JJ O *-H O H e 3
i-H q s
H
tn
q fd u 01 43 n Cj O 3 43 *H 0} 3 01
<d ^
"H jj Jh
jj 1 <d-rH U] _^ q0) id 01 lH e JJ0 -H Jh43 q 30jj
3
O
jj q
O
JJ in *
43 J3 JhO JJ fisj J5 JJSJ oSJ 43 -HOh ^ 3Jh t! Jo e-q 0 S3Pi CJ fd OJ jj jj CJ JJ -H jj 01 U Jh JhJJ 3 O J Jh 1 CJ 01 0) fl H JJ u U) Q) QJ vij 5:3 Jh 01 JJ Jh O Ul 3 N-H N TJ ui M 0 q *-'
EhO jj o 43 -x JJ 43 fd Jh p Q, o SJ 01 q 3 -x JJ <0 TJCQ H jj JJ QJ u CJ H jj In -H 01 >H 01 01 01 H U Jh E <U 0 Si M rCJ H. JhCJ <a TJ q
* s q q q -rH W 43 ui SJ SJ q SJ fi q q C Oh 3 q q q q -H u 3 O ~1 2;
-iH O "H TJ O 0 o o TJ 01 01 rH o 01 o o o D SJ JJ o o 0 0 -a JJ fJjJJ<H OJ
rH VJ *i Jh O q q q q q m JJ T3 01 3 q^ 01 ,q q q 01 q q 4: ..; q O QJ fd 43 H43 " o D, Uh m ^- ^~ s Jh H A v Q B Q CJ bi K Eh *- Jh lH a. <*h O & Q3 Ph CQ -rl SJ Oi
0.
q
o 1 01 jj
q
O 01 0]
01
ft,
01
q
O 01 01
jj
q
0
*H 01 q q -rH H 01 q q SH -H q q -H 01
jj jj jj Ul 0 o q SJ SJ 01 o o O jj jj ui - 0 0 Jj jj
-H Q, E 01 H H p ft q 01 oi -h -h CJ Ql OJ -H H Qi qq H q JJ JJ J3 H 01 H q sj sj 'H H q ** JJ Jh H
5 Jh ^H Jh Jh P< u >H HH 1h In ft Jh VJH Jh Jh O. O Jh
43 cj h 3 QJ JJ Cjj CJ H 3 01 01 0] O -H 3 QJ jj QJ CJ
CJ 01 bi TJ JJ 01 Cj 1 01 bi TJ SJ to CJ rd B 0] bi tj XJ Ul CJ CJ e UJ bJJ 8. Jh fi U) X En 01 h O 01 oi X 3 id 1h O to ><, -, 1 fd in!^ Q " -El K, ^ &1
o
jj Q ( J" ft; c bj. SJ
lH
-H
VJ Q ^ SI ft; ^ 3 TJ
Jh
s Q ^
XXX X X X X X X X X X XXX X X X X xxxx XXX X X X X X X X XXX XXX X X
Jh XXX X X X X X X X X X u XXX X X X X xxxx > XXX X X X X X X X On XXX XXX X X
Si
CJ (J,
q
o
CJ
u 01
m JJ
SJ 11
01 fd
0
01
SH Cl
Id fd
ft
FH
01
N JJ
n 01 ci Tl
01 1 01 HJ 01
SJ JJ SJ SJ
co sj cn Jh
bi
In
01
JJ
g
TJ 4J
u
Sj,
fi 3
CJ
01
01 T)
TJ 01
0, i
JJ 0}
H "H
i3H
o
JJ sj
CJ CJ
SJ -H
,01 TJ
Oh 01
In
01 ft
SH
O JJ
O Cj
q
01 id
-q fi
Eh jq
SJ -H CQ
3 sj q
JJ Q, O
lH -rH -H -H
' O If H 01
01 JJ SJ CJ "H
rn sj q to >
H 3 O OJ 0)
ft, t Cj q a;
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
" ' " " ' - xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
1
J3 01
o q
sj rd
01 lH
t, -H
01 3
CJ TJ
u
fd
TJ S
H TJ
ft)
0 n -h mi H CN V, TJ rn id vo tj, OJ O SJ M TJ SO JHj 0 tvi N"
- q 01 C3 H co X N id rH TJ Mi In 10 rH n
o\ vo fd CN IN vo O SJ
00 ol
- "H - SJ d -. g
t-H H J^ CN ft Q rH 0 id fx H Oh to 01 tx to ii CO tx to
CJ C? H rH OJ rH 0 H ft rH TJ >H . H 01 rH rH
<0- QO * vo 01 sji a. H vo o\ O SH bi q h 01
CN * "H B rH Eh rn rH O O 00 JJ 00 CX 3 CO 3 Ml 01 h q O CU oi OO
> X * X X sn X . X X 01 O CO IN CN Jj CM TJ IN CN id CN in H rH
- O 0 q 0 01 OQ . c--. rx 01 X X X X X X 01 X ft X bi X X
4h ^ rH O rH -H 0 to 0 0 id IX sj vo vo 01 Vo TJ VO M vo B vo 0 vo Vo
. X bi X "H X X 01 X X O 3 0 0 01 0 q O 01 0 0 0 In 0 0
JJ <H u CN SJ IN . CN X IN CN TJ X ft X X bi X id X 9 X CJ X ft X X
-H Q 01 a 0 H3 q O -H Q 0 q CN sj CN cn q CN IN S CN CJ <N <N IN
q 0 O] a B 0 0 Q HH 0 0 rd C3 3 0 01 0 rd co 01 0 01 0 fd O q O CO
tl C\| CN 0 CN -H CN X CN IN O O 0 01 a jj 0 q O B 0 o H 0 0 q
4q e SH SJ 01 01 sh CN CN SJ CN CJ <N O CN CN O CN CN 01 IN O
O ft CJ 01 01 01 01 01 H CJ SJ J< 01 H
JJ in bi H cn 3 CN SJ rH SJ O bl O TJ V, SJ H Vh >H 01
*-H O H JJ rH IH H fd rH id H bl o\ id oo ft C-* 0 vo ft to SJ M- 0] in p IN bi H -H
b, . r-H CJ . SJ TJ TJ O lH 3/ - q - 0 fd OJ s 0 >
H h q H 01 H ft <H ft H H -H Eh H rH M H ft H SJ H bi rH rH u H 01
Jh N fd q tf 3 SJ tn B 01 q TJ ft Sh
0 q jj q fi q H q q fi 01 q O q q q q 3 q q 01 q 01 q q
O 0 D, 0 JJ 0 O lH 0 U O 01 O Eh 0 H 0 01 0 TJ O TJ 0 jj 0 3 0 q 0 -h
H -H h 01 -H 01 H 01 H H H bi -H 3 H -H J1 H Cl -H q H H H Id
- 01 TJ CO fi co JJ to q 01 TJ 01 TJ 01 bi 01 O 01 TJ 01 j- 01 01 -H 01 01 -H
bi -h H 01 ri 0 H SJ H SJ rH 01 -H Oj H 3 H "H H 01 H O H Cj H SJ H J< -H sj
O > * > X & "sh > >H > SH > TJ r- TJ i. A r- lH j> TJ > s S> 01 > q ;> lH ^> -H*1 * 01 *H 01 01 01 3 01 3 01 TJ 01 TJ OJ 01 01 td 01 TJ 01 01 -H 01 0 01 P 01 q
<o- a; k a; ft. a; jj OJ ft, a; ft, Oh C 0J < OJ Q 0- ^ OJ C a; a; oj SJ OJ Cj oj S 0, tn
z z
XX
CJ o
Eh Eh
U K
ft, ft,
XX
o o
ll
CM HO
4J V p
TJ 41
s
0) 01
fi fl
O, H
CO fi
TJ -rl
fl 44
XXXX
xxxx St St
tl II 0 o
TJ TJ TJ TJ
3 3 3 3
fi H H rH
OOOO
q a c q
-H -H -rl -H
fl
<H
O
o
Ol
Pi
o
H 01
01 oi q oi oj
5 S . S So o
Eh
h
B oi
M JJ
0] SJ
01
h q
ft o
B .
h bi
u q
H
sh TJ
q q
JJ oi o
SJ Q, -i
H 01 J HJ
01 TJ ft 1h
tJTj
BOl TJ
O rn OJ ftj
,fi JJ -H
HH td 4 ||
SJ td 0]
01 sj o
Id 01 | JJ
H id oi 3
JJ -H td
JJ "H q
JJ JJ o
CJ H I -rH
5HHSI
m 3 m cj
It'll 3 3
JJ
,
"H fi
U | sj
01 O 01 CO
q M q -v
Jh 01 JJ -h 01
3 -h id q
sj jj q oi o
01 id 0) JJ q
aj sj | Eh *-
Tj
TJ
3
q
01
q
vS
q
01
jj
q
In
HH
0J 01
5 S o,O O 3
q q m
jj
Eh
TJ
01 JJ
q
01 01 01
S S 5o o o
q q q
oi oi
oi - q q
SJ 0] .. o o
q oj co -h -h
oi -h q sj u
B h fi 1h ft
3 -H 3 01 01
biTJ SJ CO Cl
In O OJ tfl X
* Jg oj c co
o
o
JJ
o
01 -H
q sj
>H lH
H 3 01 01
biTJ
fi
C 55 i
SJ SJ to - o O
0, q oi 0] -h -h
h oi -h q SJ SJ
fi B Oh Ih 1h ft
CJ 3 -H 3 01 01
01 bl TJ sj oi CJ
oi u o oi oi X
Q >; Sj a; ; ftq
01
rH
JJ
id
Eh
id
TJ
9
CS
a
0) Id O 01 01 01 OJ
sj 01 q q q q
h u oi o o o o
>h sj jf. q q q q
& CO Eh ~- >- ~- ^-
B
oi - q q
sj to o o
q oi oi -h -n
oi -h q SJ SJ
ECU In In Q,
H 3 01 01
TJ sj oi Cl
H O 01 01 X
C Sj ft; j fij
ft
o
&
TJ
TJ
01 O 0) 01 01 01
01
rH
4J -JJ q
01 Eh ^-
q q
o o
q fi
q oi to -h -h
bitj SJ cj
SH p oi oi x
C Sj d; < m
- TJ
TJ OJ
01 01
W Ul -H
01 -H e
-rH - - R *J
| (U r-H - 1 1
rH 43 4J -H e JJ JJ
rH U fd fd 3 CO (/}
H jj TJ, JJ (3 q c1 - J J<H 43 43 43
-rH -H
- 1 1
43 4J I CJ U J .W jU
CJ rH 3 iJ JJ JJ 01 01
td -U H QJ OJ QJ fd fd
U -H h 11 1-1 HI f-H rH
H CT
I
Ul 0]
-a
rH * 4J JJ O W O
TJ jj & 43 ^ t -JJ .JJ US tj
IK I 43 43 -rl U -rt
lEcj uwjjujjjjjjjj a
-OfiJidrdqQJcqqqqq
HE OUp'W-H-rl-rl-rl-rl 3
TJ
H - - - JJ
S . a) ai tu m >
| Tj N 0] NH-
-H (d -H |
TJ 01 43 01 rH
O Q, J I l-H r-*
O W CT JJ JJ -H CJ
I'M X X | ->i
TJ 43 -H O
| O | JJ 4J 43 J
rlJJrJjJOe
3 3 TJ TJ (0 -H
Jh vh jh ,h rH CJ
*bfi JJ
JJ -3 -JJ TJ 6 * |
(- -H X
JJ JJ JJ I ffl JJ CJ
fl fi q tj C c h
rl -rl -H g P -H JJ
JJJ *J *J *J JJJ *l 41
ffl oi co ta ro oi
01 01
bi -h
q TJ
fi fl fl
OOO
oo-
e fl fl fl
OOOO
o o o o
sj -h sj q
TJ -H
ft sj
Eh
JJ
CJ
q
01
sj -.
id
TJ
3 TJ
H
U ,'
- -H SH
SJ TJ 01
01 >
G O
H CJ
sJ 01
sil I U
01 I
CJSIJi
o fd u
h tj id
sJ p, sj
cj 3 ol
SJ.
sj 01
01 lH SJ
c a fl
H J H
JJ
sj
Cn
TJ
1
01 01 01 01 01 c
3 fi q q q II
01 o o o o H
? J JJ c SJ
3
u
SJ
01 01 01
q q CJ
to - o o H
01 CQ "H -H JJ
h q SJ SJ t)
"H Ih u ft SJ
H 3 01 01 01
TJ sj 01 Cl HI
O 01 0) X
Sj oj t; ft] TJ
-rl
X X X X X X O
X X X X X X !>
01 01 M 01 rH OJ
U 01
CJ JJ
Id Eh
01
SJ O]
q oi
01 'H
H
^
biTJ
fi
.2
fd q
n. Cl
q
<
oi
q
Cl
H
q SJ
fi >H
3 01
SJ 01
01 01
OJ <
TJ
q 01
*H 01
q
TJ 3
01 q
SH 3
01
SJ bi
q q
3 -H
O SJ
CJ Id
q CJ
01 o
rH
01 H
01
JJ 01
n
sj
0
q
TJ
CO sh
q U O
rH Q
01
JJ VH 01
0 O
a U,
o In >HX
H
SJ
01 3 CO
ft q
01
3 SJ 3 01 J<
U q c JJ o
SJ 3 SJ SJ
Id q Cl
M fi -q H
U 3 Cj 'n
SJ SJ
01 OJ 01 U
bi OJ VM ft
ft, n
TJ
X X TJ
X X hi;
SJ 01 - o o
q oj co -h -r,
cu -h q sj sj
B H In U Q,
3 -H 3 0J oj
bl Tj sj to CJ
In O 0) to X
UJ Sj OJ <u ft)
xxxxxxxxxxxo
xxxx\x\\xxxj>
X X X X X X
X X X X X X
p0
ll
o
0)
14
Pi
4J
-H
1
O
JJ
0
fc
<D
u
o
V 03 01Eh 3
Jh n rH
0 fd
rH jj 01 Cl >
0 O JJ 01 0 01
"rH SJ N to 'tl H
H Tl -H CO rH J-l
JJ to rd id
IT) Jh 01 SJ JJ SJ
Q< JJ JJ H 01 01 01
3
SJ 01 01
4; JJ JJ v. Id
0 0 SH TJ id id JJ H
q CJ Cl D U Ll SJ JJ
SJ
Jh JJ 01 id to to 01 JJ
4} CJ H H rd td td
q JJ CJ -H -H H U
<1) rd rd O JJ JJ JJ td
In SJ In
TJ t3, JJ CO JJ JJ JJ JJ
TJ *>H 01 rg CJ CJ
ri* JJ SJ Id
01 td Id
q rH
id H
rd JJ q fi fi >H 3
01 S J O JJ JJ JJ ft.
rH
X X <H XXX X X
rH X X
v3
XXX X
01 Cl
0, 01
Cl in
-H
Ul n
Eh q
ft] H
X X
X X
C - oi Jh
3 rl 01 sj
O -H -H C
ci tj e - -
1 linn
w
01
- </l Ol t/1 01 01 rH
Oi rd rd rd 3 TJ Jj
rd -H -H -H 01 rH id
UJJlJlllO 1-
IIIIII 0]
m e JJ TJ
^ && 01JJ 01.. 01
.. OJ
TJ In
& SJ SJ 0] CJ -on
01 -H
CJ (J 01 -. ~ SJ 01 01 o Jj 01 U SJ
JJ ft] ft] 01 TJ TJ C 1 N CO SJ o H 01
q 01 01 u 01 OJ 3 CQ -H 01 | rH SJ U
w rH rH a H U 0 td oi td to 1 01 1
01 JJ JJ TJ ft a cj H 1 1 fd CJ U CQ
rH O] id rd < S JJ JJ JJ SJ SJ -H SJ SJ 1 8-
43 Ol Eh Eh 1 1 1 1 ^ **. A, JJ, 1 0] 01 O
rd u rH rH Ol 01 V 1 1 1 1 CJ ft 1
Eh TJ SJ o 0 rd rd ft * * H o u
CO
(0
TJ fl O
c -ri jj
0
JJ
-H -H
Ol Ol a U
0
OJ
01
rH U
01
H
1 "H
Jj TJ
a d s
03
o
44
CO
SJ sJ
CJ 1
Jj
CJ
JJ
rd
01
bi
SJ
Id Vi 43CJ
01 -H TJ -H
TJ1
01 Eh 01 SJ
CQ
rd
rH s TJ
01
01 U 41
CQ
td 41 SJ SJ
01
td
o
rJ
CO
Sir.
rt a fl H fl fl fl H CJ X X X 0 0
u a 41 0, Jj -rl in -d -rl -H m Eh X X X H rH o
o
X
X
-rl
TJ
fl
a
0Pi
oi
3
Wh
sh o
01
JJ q
Ol
o
-HJ
SJ Ih
CJ 0
1
4J
3 tn
3
&
i-H
fd 01 ^0 a oi
3
4J
Jh ss JJ IH rt]u a
3
o 1
01
II
*r? o 3 01 01 Ih tJlt td SJ
sj to & g* 01rH SJto oi-H
Jh
Id -H
Cl JJ to
H
oi n
H
HH SJ
3 01 to SH OJ fl 3 jj
.P" JJ 10 01 01 01 0 bi ftCJ 3 ji! S 4J O o JJrd O TJ td H 3
JJ y j? TJ q lH - O3 Ol > id u 01 Vh
& Cj Ol fi a tj OJ 01
Lq rd sh JJ Ol TJ CJ JJ Cn
H iH D, CJ 01 oi fd CO SJ oJh Eh SJ q
SJ . J SHSJ O r-J|
9
q
S to sj U SJ <j
W oi
!> oi SJ
O
SJ
id sj
SJ 01 Eh 01
JJ
^ 01 H
id TJ SH
Id HH
Q Vh OJ
CJ
q
01 TJ fi 01 01 sll 01 JJ 01 u
SJ to fd 9 In SJ Jj bi SJ Vh
1 q S 3 q u bi 01 -n tn
fi Vh JJ SJ O OJ H 01 01 fd oi o 01 Oh 01 01 01 01 Di
q q JJ 01 3 Cl q o q q CJ CO J 01 0) q q fi q O
o o -H q SJ 4J 01 01 o ft o o 01 01 SJ SJ U o o 3 0 ,J
q 01 0) 01 JJ -q c: q o u 01 OJ q q q q o
% tn o;
vu SJ Eh <* td TJ
n tj
CO oi >: = H
Eh <
o q q Jh
01 01 JJ 0 01 oi 4J 41 o 01 01
q q CO H to q q a a H 01 q fi &i
o o -H SJ SJ to o o c fl SJ SJ tQ o o Oi
*H "H W ft q 0) oi H H O 0 ft fi 01 oi H H o
Jj JJ H 01 H q S-l SJ o o -H 01 "H q SJ SJ J
* P< SH B M Ih U ft rH B VH fi SH ft JJoi o H 3 01 OJ rH oi CJ 3 -H 3 01 01
01 CJ (0 B to biTJ SJ to o td CQ bi TJ SJ 01 CJ CQ
oi X 3 .TO 01 Sh O 01 01 X 3 01 Vh O 01 01 3< &, jj V? Q * SJ OJ :<[ !U SJ sv? Q C ::: QJ U TJ
Jj u -H
XXX -rH XXX X X X X X X X X X H XXX X X X X X X X 0
XXX > XXX X X X X X X X X X > XXX X X X X X X X >
o
jj
a
&
&
TJ
&
In JJ
01 ft
ell
Jh O
bi
Vh
01
VH
O rH
" 3
to Sg
TJ S
H TJ
SJ -H
3
SH^
- O SH lH
01 JJ Sj O -rl
rH sj q to >
H 3 O 01 01
ft, ; tj Q bj
0h E
Vh
01
SJ I
q TJ
H
td
01 01
JJJ SJ q
SJ TJ TJ TJ 3 TJ TJ In TJ
01 01 01 JJ 01 01 3 01
bi SJ SJ SJ H SJ SJ SJ SJ
q Vh 0J
-h 01 SJ u
q in H TJ vo SJ CO IX CN
H CO H O vn fd CO CN O CN
VH - JJ 01 . SJ
OJ tx IX SJ vo TJ O 4J CO CN
TJ in CO OJ
- B
SO 01
SJ
CN id
.. SJ
HJ SJ
3
VT
01 vo vo CO 01 to oj vo ft CN
CO H to rH - CO -H H ft -H ,q CN
fd 01 SJ CJ
on!
H
H CN bi tn oj o\ o -H U tx
CJ Ol. ri q IN 01 CO CO CN TJ tN OJ rn
X id X - X 01 X
VO 3
X
M P- oo JJ tx rx Id vo TJ vo
fd CO CJ O H CO o q co q CO
3 JJ X X f X TJ X fd X 01 X
SJ CN TJ CN 3 CN q CN CN OJ CN
tn SJ o 01 O SJ o id CO 01 CO OJ CO
"H -H CO SJ O SH CO o q CO SJ co q
!> q CN id tN -H IN V, CN O CN id CN O
ti rH > 01 H Vh H
01 N 01 bi SJ QJ CQ
lH i7 vo Vh to 01 VT tn tn ft cn q rH *H
3 o lH o O 0) P
a, SJ rH TJ rH 3 rH J H ft rH tjl H 01
to 01 ft SJ Vh
H q CO q q 01 q r2 q TJ q
aj o Id O TJ o 01 O TJ O CO O -H
q H JJ H 01 H H "rl -H h td
o to 1 CO > 01 TJ 01 TJ 01 Vvj 01 "H
h to bi H JJ g Q rt 01 H 01 H -H
H 4J
sj q o > SJ
01
!> TJ > TJ > TJ > -H
ft o j 0J to OJ TJ OJ TJ 01 o 01 q
H "H o, OJ a. a; a; a; U OJ C OJ JJ a; h
o
Vh
ft.
01
i>
n 11
01
SJ
Vh
rn Tl
rn 01
bl
X q
H rd
JJ
11
i
H
Tl
i Mi q
> rH Id
x
jj vo >,
1-1 Vh
Vh X 1)
Cl IN SJ
SJ O 01
id CO
u IN JJ
01 o
q Eh
01 Ml n
ti n
SJ rH rn
3
Hi q 'Cl
q Cl 0)
H H
01 <SH
h
f, t. TJ
i oj SJ
- o u
C ] J.J ti., oi
rvj to
-. JJ >
CO
vo o\ 3 O CO
H "& IN
CO H In OH.
rn Vh CN
X X 0J TJ X
vo vo b q cn
Q CO fd fd CO
*"- fi . X
CN 01 0, IN
O co a; Vh o
O Jh CO 01 O co q
<N O CN SJ JJ CN o
jj Id CQ
O fi a 0]
n 3 CN 01 JJ rH "H
Jh - q p >
rH OJ
bi TJ Vh
q q 'a q
O TJ O TJ id
rH QJ -H fQ
0] TJ 10 CQ TJ IQ -H
H SJ
1> TJ t> !> TJ > "H
TJ 01 01 TJ 01 q
-X t OJ OJ < OJ H
xxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXXXXXXXXXXXXXXXXXXXXXXXXXX
to JJ
01 ^
TJ SJ
to Cl
CO 01 01
to to "n
to oi JJ
M ro O
CJ rn
Cj 01
OJ JJ
to TJ SJ
id 01
JJ > Ol
H 01
~l in SJ
fd 0} rd
3 TJ Cj
" SJ
Vh Vh
O
H
01 r| O
rH t> rd
JJ Vt q 01
id 0 id 0 TJ
SJ SJ h X
3 CJ tQ SJ 01
ft 3 01 Cj >H
SJ Vh TJ 3 O -^
3 sj -H Vh 01 Vh 01
O 01 > sj q SJ cj
01 O 0] o CO O
JJ CJ TJ V, 01 ^ 01 qc H o, TJ Ct ^
id JJ rH
s 41 * Jj
aw JJ fl 3 q
Q a ft O
K f O HD e >J b JJ H to
H H rH JJ JJ O JJ SJ SJ oi
z z
IS d ui V, usj u tn fi to
U
CD
Ol
SJ
H
ft
H
v.
q
01
01 CQ
h q
vh fi
X X 3 CO CO O 6
a o u 4i a tj C oi Cl H 3
CHrS
0 13 B 0] bi Ti sj
41 a tj a fl sj
0
Id 01 Vh n oi
01 01
H H
3 U TJ -H CO
OfHHjSK
CJ
Eh
!h rj H Sj aj
ss a B . C C C E JJ X X X X X X X1 I Ul X X X X X X \
0J 41 0 0 O tg -H
ish CO TJ TJ TJ TJ TJ TJ X "
S B 3 3 3 3 3 3 uTJ -H H H H rH rH H ca -h
fl VH O CJ U CJ 0 U W rH
44 CO fl fl fl fl a fi ^5rl TJ -rl -H -H ^1 M -H
*t= * st ss ss- -tt +t 4t o a
vIn
43
JU
TJ
01
CQ
JH
01
JJ
g
Vh
Vh
. -^ 3 ^ ^
q q
o o oj
C fi JJ
*- ^- Eh
s so o
q q
ft
-H
SH
q 01
01 "H
E VH Vh
01
to
01 to
<C 53 OJ q Cl sj
3
Vl ft, CJ
oi q 01
aM CJ
q Vh Vh
01 OJ Eh
H
01 "S SJ
3 oi q
JJ o
3
SJ ft
SH 4J U q
j- Sh 01 SJ
0 JJ 01 3
01 SJ q o,
In 01 sJ q
SJ CQ
ft id 0) 0
SJ SJ SJ Vh
CQ rd 01
t) Clsj o 01 ui
01 q -H sj q
tl 01 rn q oi
fd Vh id H Vh
Vh Vh 01 0
Eh 3 TJ ft 01
SJ cj JJ
q TJ tl sj
0) 0} q H
fi JJ ro
rd 01v. 4J
3 SJ SolCl 01 3 q q fi
4J Q,TJ M o o o
01 01 t? Ol q q q
01 Ol "H
q
J d
0 CO CQ
H CQ - q q
SJ sj to - o o
ft q 01 01 HH -H
-H 01 "H q si si
Vh Vh Vh Vh ft
01 CJ P *H 3 m 01
5 to &TJ 4J to CJVh O
Q s isj o; tj oj
o
rH
I
Q
01
JJ
-^ u
01 SJ
rH 01
H
HH SI
3
bi vl,
11
rH n
^- o
01 01
u JJ
oi q
JJ 01
sj v,
tu
Ol VH
01 01
sj Vh
01
Ol ij
q q q q
o o o o
q q q q
-H sj SJ to .. o O bl
tl ft C 01 01 "rt "H O
> -h oi -h q 41 -u J
U B 'h fi fi ft sj
rH oi CJ 3 -H 3 01 01 01
td
,*
CO bl TJ SJ 0] CJ 01
-1 01 Vh Q 01 CO X
SJ & Q o; SsJ OJ *! ft) TJ
V,
H X X X XXXXXXX 0
> X X X xxxxxxx >
o
Vh
ft
Tl Vh
01 O
SJ VH
H 01
H Cl
0
rx SH
vo Vh
01
bi
q
JJ 01
fi
v, to
01 U
S *i
tj a
H TJ
</v ftq
H 01
H TJ
- O
x JJ
SO 4J
.. tJJ
VO Ej
$. CO SJ
, cn Vh
JJ -H
TJ 3
OJ JJ
CO Id
CO -H
CJ
OA o
ft
TJ id
fi
- O
CD JJ
q co
. _ o tu
ft, j tj Q
fi ft
oi q
a; o tj
H oi
.... to >
CQ C3I-H O
q o f> 6
O ij 01 01
Htnmcr;
to
"3
01
a;
o to
H
01 TJ
V J!> TJ
01 TJ
a; -m
td
-1 rH 01
CN n >N Cl
X X rd
vo n vn Vh
CO q CO h
X rd X SJ
IN IN q
o CO
CO q CO Vt
IN o IN Vh
ft
to TJ to Oh
43
n I.
H (0
Cl
o
(^ Q) o
<N () '^
ftl
o Jh <*
*h rH IN
X
vo J3 in QJ
o JJ o hi
N X ft,
* IN 01
Cl o 01
Cl M o m
H <N b.
Cl h,
^ fd f*l u
Vh JJ
01 ft
a fi
o o
-I
V, o
t "
bi
fi q
> q
OJ -H
K. SJ
* TJ
01 TJ
a; tj
S- TJ
01 o
oj sj
q oi q TJ
O TJ O 01
H H CJ
CO TJ co id
'rt M
r> T) > ft
01 TJ 01 01
OJ t aj oj
jj sd
a =
o a jj
.H JJ
JJ tl U
J OJ
SJ CJ Ol
a j
~
a o
4J td
> *
OJ *
oj *
^ -H
01 q
OJ H
3 Vh CJ6 Eh Eh
9 to 41
TJ TJ TJ
9 3 3
H H rH
oi JJ
01 s
a SJ
01 Cl
0] 01 01
01 oi "l-l
rd JJ
rH Id 0
O IH
CJ 0)
01 JJ
01 TJ SJ
id 0J
jj :> 01
H 01
H Vh SJ
rd 01
3 TJ Cj
SJ
Vh 1h -H
-H O rH
S-
Vh q 01
O id o 'tl
SJ "H X
CJ CQ SJ
3 OJ CJ rs
Vh TJ 3 cV^
sj H In 01 Vh 01 01 01
01 j. sj q u q q q
O to Cl CQ O Cl o
a lH OJ fi 01 q q q
Oh TJ
q
Q --
01 01
oi q q
oi o o
ft q 01 0] TH H
H 01 H fi 1 1 SJ
v. t- "4H V, Vh ft
Cl "rl 3 01 01
01 bi TJ sj CJ
01 Vh O 0) 01 X
'< Q : Si OJ ( vq
X X XXX X X X X X X
X X XXX X X X X X X
xxxxxxxxxxxxxxxxxxxxxx
X\XXXXXXXXXXXXX\X\XXX\ If
<M
O
0
J
Pi
01
jj
Cn ft
01 01
CJ JJ
01
CJ
to 01
fi Vh
01 -^ -^ ,01 -^ -^
01 01 In 111 01
q q oi q q
oj q q fi Cft; %_ . ^ -w
SJ Vh O O O O
-^ -^ Ml
01 01 Ol
q q U
CQ CQ
q q
o o
to -h -h
q sj sj
Vh Vh ft
3 -H 3 01 01
bl Tj sj to CJ
>H ? 01 CQ X
a; Jg oj ( ft]
i "4
q
O
H Ol .
SJ SI tQ
ft q oj
H 01 -H
01 "H "H
CJ SJ sj
V, Vh ft
bi TJ -u to o
Vh 01 to X
U S3 a; ; fci
oi
in
u
0
JJ
o
<D
H
ta
a
H
(D
O
id
rl
E4
X -H
HH
H
Vh O
O ft
bi
Vh q
JJ
Vh
01
01 01
Ol fi
C| id
H Vh
OJ M
2 *
Eh TJ
Vh
. rd
TJ
H TJ
ov ft!
01
JJ
HH
OJ
TJ
CO CO
to Vh
rd O
H SJ
CJ CJ
01
H rH
id 01
3 CQ
SJ
fi p
01
OJ CJ
Vh id
3 V,
Q. SJ
fi s
;
.fi
to
01
Q
H 01
H TJ
- O
ex XJ
CO SJ
- OJ
vo B
Hjj. rH
> tn si
. CN 01
JJ x 01
. K *
Vh co
O X -h
SJ CN rd
Cj o 3
01 co sj
H CN Vh
01 -H
!9 *rj cn
01
01
CJ -H 3
P r. *fi fi
Eh O TJ
H 01
- CO i>
i bi-H o
O i> B
q 01 CO
OJ OJ
CU
TJ sj
01 3
SJ JJ
-H
V,
vo SJ
CO SJ
CN TJ
co fi
CO fd
CN
Vh
h bi
h bi
o
*H iJ
SJ
q 01
fc. TJ
01 TJ
OJ "CJ
Q TJ
H ft
3
^
bl
q q
o -h
*h tn
to bi
H 3
> JJ
OJ 01
OJ Q
CN to
CN 01
-. bi
CN fd
CO c
co bi
CN -H
to
\ TJ
o
H JJ
CO Vh
H O
s> c
01 -H
OJ SJ
vo oj
H ft
co ft
o
H ft
CO TJ
-H 01
^ TJ
01 TJ
OJ J
co q
rH 01
X In
to 01
CO HH
X 01
CN fi
q
H 0J
o;
q
O TJ
H 01
CO bl
rt q
> id
01 JJ
a; o
01 TJ
H 0)
> TJ
01 TJ
o; c
rn Jh i^ Jh
> TJ
(.1 o (0
m
X X 43
vo Jh m
o o to
u \ O
CN ti cn a.
tl (ii Q
o ^ O 0
CN Jh CN) JJ
o; bi
q sj q o
O 0) o -h
h h
to CO TJ
H OJ -rH QJ
> TJ > TJ
01 TJ
oj SJ OJ <U
XXXXXXXXXXXXXXXXXXXXXXXXX
xxxxxxxxxxxxxxxxxxxxxxxxx
Vi JJ
X X id
o o 41 Vh
H EH td 01
CJ CJ P sft] ft! ID c JJ
J sJ JJ JJ U
U fcl O Vh 01
0] O] A fl u CO ir;
p p JH cj g n
H H O co i m
H H 41 u 3 0 Vh
CJ CJ O a c j II
XX J lH OIH cjH SJtl
-I*. V C c c 01>
o
SH Q TJ TJ TJ TJ 44
CO fl 3 3 3 3 01
TJ ~H H H H H Tl
fl 14 Cl O O tl 01
44 fO fi fi fi fl grl TJ H -rt -H -H
41= 41= 44= 41= =H= ir SJ
01 JJ
tQ TJ SJ
JJ > 01
"-1
rn Vh
01
SJ
d 01
rH 3 TJ 11
43 SJ II
fd Vh Oh rH
JJ h o
3 ^
a Jh C 01
jj O rd O n
3 jj H s
O
3
CQ SJ
01 0 *
CJ Jh TJ 3 o
rH jj rt Vh 01 Vh 01 01 01
rH U] 0. sj q sj q q q
43 O tQ 1) to o o o
3 TJ Vh 01 q 01 fi q q
Pi a, TJ
q
tj
Jh 0 CO oi
H oi q q
SJ 01 - o o
ft q 01 0] -H H
H 01 q sj 4 1
^H Vh H VH fi v, n,
cj 01
Ul 5 CO bi'n si to tiQ OJ Vh 11 01 CQ X
M i? J : Jh OJ tj OJ
xxxxxxxxxxx
xxxxxxxxxxx
n
M<M
0
H
B
0
Ol
"i
fi3 in jj 0]
O (0 -H
hh jj a
to
3
o
'2
01
fi
ft
Pi 8 o1
CO Jh
CO 0)
A! JJ 43
fi
rH
o
o e u
O
oi
01
2
fi
o
ft
bi
q
H
O Jh
3
H
B
TJ
H
|
01
JJ
SJ
q
o
SJ to CJ 01 o Jb 3 NJJ It fd JJ
M
SJ
to
OJ
TJ
g
JJ
Cfl CJ
V
1
t
th
y
g
i
rd
JJ
fd TJ
TJ
TJ
TJ
-H
3
TJ
0J
01
id
JJ
O
. H t> o Q TJ rd JJ 01to 01 H O 01 fi d Jh CO IICO CQ "r-|
W Xj.
-15
.
'" H JJ 43 O to H QJId sj 01 sj v, SJ o - Jj o (0 > V, JJJ
H
CJ
CO O CJ ft SJ rd o <0 SJ S TJ 01
*-H H q to oi 01 to U Jh TJ ti
01
to
Cj
43
TJ JJ
:> iq
(0 o Vh cj Vh H ll 01 .^ Jh rd O
3
JJ
sj x
TJ tl
rJ q
O
fd -H
CJ
id
O
(0
o 3
a JJ 01
o
JH
Jh 0] 01 TJ sj o iH <d bi Vh Jh II CJ 01
"? to jj q 01 -H & q 3 sj jj SJ . OJH
In u
91 CQ
t id sj n] q 01 01 SJ o JJ 0} OJ 01 Vh CO"-' H JJ Vh b Cl ft 4J -rH Jh 43 01 to si CJ T toCQ
.
" - 3 ro td 01 a jj H jj JJ 4q iH rd TJ
rH
3
JJ
Tj rj
O
h
3
01 O 0]
CJ U
si Vh
01 sj
fi psi X
a a
o
>
0
SJ jj JJ si fi
CU ft
rd nJh hh *-h 0. id TJ 3 Vh ftj 0 u jj O jj * TJ JJ a
fd 2 u -1 It II Cl 01 TJ 01 X Jh SJ o JH q 3 0 jljj
N
(Q SJ to CJ oi JJ 01 Cl pq 3 q .X SJ3 q id o H SJ "rl fd a 0 01 u CJ 0) 0 01 aa o (0 O TJ U id JJ sh U CJ U (Q Cl Jh fd SJ JJ o SH jj
jj JJ *H X ! to 01 HH H Eh aJ rrj Jh q o Jh 01 SJ M
43
3
Cj 01 U 0] pJh to CQ IQ o o Cl ft Jh U jj 01 Eh ft, SJ [iH3 Si i Jh Eh 01 CO -H Id oj 3 h ^ CJ Sh Jh SJ CO 0 ss JJti Jh TJ 3 -v O o 0, > TJ B Vh q -^ ft-^ J< a a fd <d 01 "V ~> X q si X0 u jj '2 Jh Jh JJ 3 V B SI H 01 01 01 o 3 3 Jh Vih 43 5 Vh CO 01 q OJ OJ-rl -H 01 u q jj q q q rd ^ Vh x to fi q O 5 ^ ^i
a
01 q jj q q U tj 3 rn q q q q s
44 rH o Ul o oi O O 0 Jh o SI SJ 01 01 O 01 O >J O O TJ Vh o o o rd si SJ rH o o 01 o o JJ
a 43 TJ fi q q C q o 01 "rH HH JJ f! fi JJ n O O TJ TJ Reg q q Jh 01 01 id q q jj C q
3
a
a. a ^- ci X_ ^_ X_ q H OJ JJ N SJ Eh v_ Eh -- < .-H J <d *Z U 1Tj
to OJ o Eh Cn
ta Ul
ftl q q q rd q CO
A 0 r o 01 0] o o to to 5 o to u o CO 01
O JJ Jh H Ul -- s s fd H W q q o o -H 01 q q rH H 01 q q JhH a O SJ JJ 0) > o o Sh SJ sj to o o rd Jj jj SJ CO - o c O SJ SJ 01 o o TJ
H" O H M JJ ft q 01 -H "H Eh ft q OJ CO -H -H U 43 a q 0] -H O ft q 01 01 H -H TJ
JJ SJ Eh 0 fd -H -H q ^ ^ i H 01 -H q si sj Eh JJ H 01 h q jj L 43 H 01 "H q SJ SJ <
0 a t Jh Vh E HH >h Jh Q, Vh B "h fi fi ft Jh **h Jh Jh a Vh HH fi fi ft
-rl 3 a Cl 2 "^ 3 CJ 3 -H 3 01 01 rH oj O H 3 rH oi CJ H 3 01 01 i-H
O TJ J* o q 01 biTj JJ 01 CJ fd 1= 0] bi TJ sj to o rd t= to TJ 4J CO 0 rn 1 01 biTJ SJ CO CJ fd0 >J 01 * CO x 3 J5 01 fi S OJ CQ x 3 iP Vh 0 CO X 3 01 Vh ,0 01 oi X 3M M 3Lh o Q ^ s; oc n: [,( jj Q < S OJ >! tq JJ ^ Q ^ :--; "-; ^ &-1 JJ fe; Q m Sj K - jjEh IV Jh Jh Jh Jh
J*j SI St C T u X XXX XXX X X X X -H XXX XXX XXX X X X X -H X XXXX XXX X X -H X xxxx X X X X X X -H
fd X XXX XXX X X X X > XXX XXX XXX X X X X > X XXX X XXX X X > X xxxx X X X X X X >
ii
a a 0 Jh
TJ TJ TJ TJ H
0
jj
3 3 3 3 I
H H rH rH Ol -r>
0 0 O tl 01 r-
ed fl fl a c fd X
rl
0
rl -H h -w
=M= =t4= 41= 44= u a
a
<D
o
0
0
tj
rl
HA
ri TJ
01
SJ
TJ
4J
CN
fN
VO
CN
C*l
H
X
H
TH
X
*N
O
Q
01
g
fd
0
01
Cl
Id
v,
SJ
Vh
O
Oh
01
CJ
,m
VH
Vh
01
SJ
q
01
01
s
o
Eh
CN JJ
4J
TJ TJ q
o
TJ TJ JJ
3
TJ TJ TJ
01
TJ
01 TJ 01 TJ TJ T3 TJ TJ TJ TJ
IX jj jj jj jj jo. jj SJ SJ 01 Cj 01
H
bi
q
h
q
CN
CN
a,
u
O
H
TJ H TJ
H
Jh
Vo JJ
in jj CN
in vo .
rH -
CO
CO
sj to
Eh
o\ bi
Jj
H
JJ
tx
jj
vo
JJ rfl
u
Jj
Q
JJ
o
SJ
X
> -r| - 0 . to <* u in in in <N CN *-H rn
0h Vo Q Jh CN 4J. in i-H Vo rj. OJ CO OJ .. - -q
43 01
TJ
fN ^
jj
in jj
- aj
in tj
..
(*1 -H O 01
X
cn sj
-. Id
vo 4J
rn q
IX
<3 CN
OQ
Q
Cl CJ
*-H (0
- O
03
cn tH n
0
vo vo ^
rH
O JJ f*1 X -H -H CO SJ
CQ O M bi o fo fH M CO Hh H oi kO 4J CN vo vo cn o, CO X V,
4J 01
id 01
*/> "H ft -H O CN H *H CN O f\ *H H 0J
a Cl * Jo TJ C> JJ o\ O rn 00 ix tn to B a. ~ 1 TJ
iS H V, ^. rH O O CN O 0 O CN CN 3 CN 3 X <n n CO H fi Eh
X
vo Q o rd
q q
fd
O Jh
-c
0 3
Cl O
SJ -q
X Ht X 4J.
OO JJ
X 01
IX -
X CO
IX 0]
X X
vo
X JJ
vo X
X TJ
VO
*h -q
X JJ
<-h
X X
CO H
X
o
X
rn
X
rn 01
X JJ
H Id
id V,
3 01
si q
Vh 0J
H bl
0J Q o O rd o o CO CQ CO TJ VO "rH vo vo H vo vo si Vo in vo
Jh
o
jj
X
CN
o
bi
Id
CQ
X
<N
o r-|
X -H
CN -d
O 3
X
CN TJ
o q
X
CN
O
X
CN
O
X 0)
CN bl
o fi
x q
N id
CO
X
CN TJ
Q
X
CN 0
o
X
CN
bi
o
Jh
o
X
CN
O JJ
cn a
o
X
CN
Q
X
CN
CO to
X Cj
CN OJ
is;
M
Eh TJ
r0 o 0] Q fd O JJ o m O O CO CO rd co to O Q qj o a Q o O o CO x x
Jh CN 01
B
CN 3
Jj
cn Jh
H
""
Vh
CN CN
jj
IN JJ
O
cn q
o
O JJ
CN cfl
O Jh
CN Eh CN q
O
CN
01
01 cn H CN
o
CN
co o
CN sj X X _
u OJ g
Co-
Ol
Jh > 0 H *H S
oo 0
' 1
*H 01
CJ,
o
Jh
a
o o 43
- (0
TJ
H TJ
01 CJ
Vh id
3 fi
rx
H
bi
0
rH
vo
fH 2 tnrH
- Jh
* bl
*H bl
0
rn CN tJ
H Q|
3
rn Vh
rH O
q
CO u
rH ft
o
CJ
C^ O
- CO
rx
H
vo
Cj
s*
bi
<n 01
bi
bi
N rd
si rH
<a- &J a, sj CJ
EH
H
t
H 01
V,
rH 3
q
^
*H ^
Jj
H -H
bi
H -H
B
rH ft <H CO
fd
rH
Jh
H 1 M H qfd H qoi rH bi Wr. \9
q
0
3 q q q q q q 3 q q q q q tj q 4^ q JJ q o a u JVl
0] - ! ft
O TJ o 01 o o -h 0 tQ 0 TJ o io O TJ o Sh o q o 0 O o Cl 0 -H a o 3
Vh q H H "H H h bi H 3 H -h rH H -*H h b H H H a ft] a
01 01 Tl s 01 Tj to bi co tn 01 O 01 TJ to bi 01 JJ 01 q U] 0] (0 0] Jh CO Vh 01 TJ CJ CJ *j
JJ *rH
3 JJ
01 tJl
q o
o ^
2 * H "H 0
CJ
o; ft;
-H
> TJ
-H 3 H 3 H -H
> V,
H 01
0- Tl
h q
^ fd
H
^- -H
H
>
jj
Jh '2 tn H -H > 0q -H Oq H 01> TJ XX 3o
In -H -ri
OJ
oj
*
a;
TJ TJ
a; *tj a; Q 03 Q
01 id
oj fe
Ol TJ
OJ <
.q
03 0 o; q 03
3
fci <! 2 ft; o; -H03 SJ 03 HB 01 TJoj ; *." c
0 m Jh d (9
V.c; u tj -H VW U
mij q I-* s fl 3
*H 3 O 0 -H rH
sH-HOCi 03 ti HH O
X X *
X X *
Sv. X X \ \ X XXX xxxxxxxx X X XXX xxxxxxxxxx XXX X X X X S X X X X X X X X X X X X X X
(M
-H TJ
(3
^H
^ X X X X X XXX xxxxxxxx X X xxxxxxxxxxxxx XXX X X X X X X X X X X X X X X X X X X X * *= *=
> q u
01 rd V,
01 * ^ tl 01fi O Eh SJ rt
3 Eh Q, I] 0)
ft q S 01 ii
O J>J
H O
:> o
Fh
Ol SJ O q rl
q CJ "I 01 ci
0) H X -H
X TJ 0 ci SJ
Cl 01 SJ Jh
tH fi fi -rl
q o, rn Cl n
ti rH -H 01
h 01 01 Vh
SJ JJ Cl Cl Ph
II SJ H SJ
-H SI 'n 01
ci oi co 01 rn
01 q id 01 fi
fi fi rn q 01 Ul ss, 01 01
u, 3 0) q U q q
SJ SJ 01 X Cl Cl 01 Cl Cl n
01 01 JJ Cl q q JJ fi q 0
bi QJ sj
fi
o
SJ tn
to oi
SJ
CJ
01
>
H to q q 01
SJ SI oi Cl ci M
ft q til oi H H O
01 h fi SJ H
fi HH fi fi ft
01 CJ H 3 01 01 rH
oi
01 bi Tj SJ 01 Cl Ol
01 fi Cl 01 01 X -1
S; Q ; Si OJ ft] sj
tn ft
01 01
o JJ
id sj
Eh 01
CJ
Oi q
JJ 01
sj V,
01
CQ VH
CQ 0)
sj V,
01 01 01
q q q
o o o
q fi q
oi tj *- *- ^-
h to q q
sj si co o o
D, q oi to -h -h
H 0J -H fi SJ Sj
Vh E hh Vh Vt ft
U 3 -H 3 0J 01
to bl TJ sj CQ 0
01 In O 01 01 X
Q ( SJ OJ ^ ft)
X -H
rl
HH
0
H
0 0
tx oSJ
id
Pi TJ01
TJ
g
itrd
8
H Ct,
-H
JJ
b
H
rH OJ
i CJ
1"
q fi
o
fi
01
o
bi
3
Vh
O SJ
H
II Jh fi
q
*h
Q.
TJ
v2
b>
jj
3
"rl
sj 01
h jrj
TJ si
S U
H
4J
Jh
jj
U]
jj
3
Ol
o
rH
|
Jj
3
S
H
JJ
g
3
CJ
rH
rd
3
01
JJ
SJ
O VV,
Cl O
biTJ
q
CJ
3
fi
SJ
01
CO
q
-rH
JJ
&
3
O 1
(JJ
CJ
SJ
II
3
O
tjq
"H
SJ
fi
"2
0
SI
q e
q
H
TJ
q
o
-H
aj
-H
*H
Jh
jj
to
Ol
o
rH
|
2
jj
o *ri JJ -rl 01 jj HH Jj tj
Eh01
Vh
H
SJ ^0? fiH 3 bi 3 SJ|Cj
Jh
3 Cj tl JJ Vh SJ U o
Sh
JJ
O, 3 4J SI 01 jj H 3 Si
fi
u fi
SJ 4J S 3 fi COq O e(0
3 "H
q CQ HI 01 M \3
Jj
Jh
-q
jj
o
h
SJ
q
h
OJ V) JJ
. sh si si
fi td CQ q
U 43
<0 JJ
in
Ol
o
X
*2 42 CJ TJ OJ ft o o JJ o 1CO 3 TJ 3 01 sj Ef Qj SJ ri Jj CJ
SJ01
TJ S fiSJ fiH CO p JJH O 41 OJ JJo Ehfi *H 01 SJ bi Cj 2 Cj3 &3 N q 01 01 -d fi q Jh qft u o H fi fi id 8 JJ 43 Qj VhJJ -H 01 Vh 01 fi 0] bi JJ Jh 01
H * CJ . II 3 rd B OJ rH 01 -^ -~ q bi -^ -^v OiOJ q b 43 -H 01 3 bi 0 oh oi oi H o 01 h-4 (U qj 01 01 Olq "H M JJ 5 1 q q & to tu bi oi q q q q ?o. CO <u q q q q Oo ?
&hJ -h 1*1
o o TJ fi -H TJ fi o 3 b o 3 jj JJ Jh O O o o Jvj
JJ
-rH
Vh
TJ 5 -5
q
-ri
(d
g TJ SJ SH fito si trj H)H V_ ^_ 5 -S & to
. -5 5<rj ^_ >- q fi
CJ
Eh
tn
o
q Jh q 1tj q TJ q q Vh o
01 rH o to ui 0 to oi o to 01 01 jj
q rH "H CO - q q a -H oi q q *J "rH 0] -- q q 01 1o -H JJ SJ CQ - o o -H SJ SI CQ -. o o H JJ JJ w - o o Ol
-H &, Q. q 01 to H -H ;? ft q oj to -H -H O D, C cn -H *H o *SJ J -H co -h q jj jj "H Oi -h q JJ JJ > -H -h q SI SJ J
& Jh B *M fi * 9* fi B vvh q Jh 0, Jh e hh q fi ft SJ iH01 f-\ 0) b a "r3 3 rH oi CJ 3 -r| 3 rH oi Cj 3 -H 3 01 OJ 01O cd B to bl TJ sj CO O td 1 to bi TJ si uj O fd e CO biTJ JJ to CJ 01 Oi JJrX 3 fl fi fi oi to X 3 0J fi .O 01 to X 3 fd Jh O 41 CQ X Cn "Hft] jj 1? Q < Sj oj tj ij sJ % Q <; sj oj ^ Cq JJ fc; O < ^ ':: UJ ft! TJ o qJh Vh u H j ti
X X -H xxxx XXX XXX -H X XXX XXX XXX XXX -ri xxxx XXX \ \ \ d o f\
x\> xxxxx XXX XXX > X XXX XXX XXX XXX > xxxx XXX XXX!. TJ Eh f*
0
41
"H
rtn O SH
0 X -rt
41 X TJ
U
flrJ
O
Vfl
C
0
0 *~* 44=
H
H
H
b
o>
-t
TJ
JJ
<-H
cn
H
<N
*H
n
X
03
43
O
rd
O
CJ
rd
U
JJ
43
JJ
Jh
O
*J
CJ
*H
Jh
jj
q
43 TJ
01
SJ
SJ
H
!
0
SJ
01
5.
O
Jj
Jh
O
jj
0]
b,
q
rd
J3
O
Jh
Vh
01
&
fi
ft
Vh
O
is,
fi
O
SJ
b
3
fi
SJ
01
01
T3
01
to
Id
rH
CJ
01
-H
&
o
-H
o
ft
bi
q
01
3
q
01
to
01
to
fd
M
CJ
JJ
0
f-1
43
o
43
o JJ TJ XI TJ 3 TJ TJ TJ fd TJ TJ TJ CQ 73 jj
X jj 01 01 Jj 0J Jh 43 01
CN bi SJ JJ SJ H JJ SJ jj JJ jj jj JJ -Q ^ CO
o q Vh q 0 -H
o ri -i 01 sj H Jh JJ
CN q
*H
*n H TJ
rH O
00 vo
vo
SJ
fd
in
<~i
o
vo
cn C3
cn jj
rn TJ
q
cn
rn
Id
3 TJ
<0
o HH 'v - JJ . CQ 3 rd SJ O
<~i
TJ
H X SJ
vo 01
fi to
to
TJ
01
vo
fi
Q SJ
CN fd
cn to
** q
vo
rn ,.
IN
fi
Vh Hh
O
rH
~i
fi
0]
CN vo6
CO
SJ
ro X
SJ
vo oj
- H -. o
H "H
Jh
vo
"^
v-i
^
q
(0
t> CQ <H - ft CO "H M H ft CN hh (N <0 M jj fi 0 ro 0 TJ
fd ft JJ CJ O ^ "C q SJ ri X
4J H tn n vo Cfl 0 CO CO 3 X x ^. X H ^r 43 Cl 01 JJ P
- 0 \ CN 01 *H CO CO CN CN TJ ^ Ul T~i H b H m 3 01 b \
-J q CO - X - X X tQ X X X X Jh X Q, X 4J Vh TJ 3 -v C?
-H (0 H Cl to tx X X Id vo VO TJ vo b vo VO vo 3 SJ H Jh Jh
5 ^ fO oi- X O -H o CO o co q ? o jj o Jh o ft to t> jj q jj q qS ^ 3 - CN X x m X X TJ X X fd X X **H X b X jj 01 o CO O CO o o
*-H 3 jj jj > O -H <N 3 N CN q CN CN cn Jh cn fd CN jj CN JJ 3 TJ fi q q q
-i S; Jh -h O HH O JJ Q o id O. CQ CO CQ o U O Jh O P a O a, TJ ^~ q
*H -h q jJ CN X cs Jh o CO Q 01 co q Q 3 o 'a o Jh o q c ti
&, TJ S 3 CO cv, -n CN U] CN fi CN SJ CN O cn b CN l CN CN o JJ JJ o u
Jh SJ > OJ rd -H b jj q H 4= 41 -rH q
- io *H H O JJ JJ bi TJ SJ o 01 CO a JJ 41 0 * r-H O CO
TJ 5 Jh -h q *H (0 o, 00 (0 X bi vo a to a -* cn Jh <N O ft '2 O ^1 tl JJ 43 10 qH TJ 3 -H S - TJ - Jh - TJ 0 3 o rH 'H w, Tl i: & 0 3 SJ JJ to b
</> cq Oi *H H ff Q, fi 3 H Q, H J *H H ft >-H f\ H HH ^H O fi Jh J J 41 o 5 R n ft ft q CO -hrH 3^ Q< :? SJ bi (0 S8 Eh Eh JJ O u >< 0 0 H "H q jj
H q q q q 01 q q q 3 15 ^, q tj q ^ q H H 0 fi O Is O a In HH Jhto -. ft. O Jh O TJ O Jh o CO 0 *H o TJ o 'b b b Eh 0 -H ii -rl O 0 B oi Cj "H 3Jh q -H H -H H *H bi H H H 43 H H fd O 4J TJ 4J o o jj B 01 bi Ti JJ too o CO 43 to t. Ul 43 CO TJ CO bi 01 TJ to bi 0) 0] to TJ CO H j j 0 a 0 0 0 j -rH Jd 01 Jh o CO
u -h oi bi -r( JJ H O H JJ H 01 -H 3 H 01 r, q " '3 ' '2 JJ j j Vh C Vh -rt H CJ q fe; Cl q; IS a; *S3 JJ q 0 ^ Jh > Jh J> TJ > -Q > TJ ^ nj ^ q > a -H H H Eh H 0. X Eh Eh D
Q a O s^ 3 3 01 TJ 01 01 TJ 43 'rH a q ft. ft., C E B X X X X X \ \ \ \
U H "H H ov a; ft, n; o; 03 &, a; C o; Q OJ C Oi O 03 U* 03 hI 03 H 1 1 rH X X X X X X X \ \
0 Jh Jh 01 0 0 0 0 0 0 -H
43 JJ Cj H M 0 TJ TJ TJ TJ TJ 13 Uh
-H JJ q co > O B 3 3 3 3 3 3 u
H 3 O 01 TJ -H rH rH rH H H r-l to -H
&< q. O Q oj fl "H a a a a CJ O CO H
X X XXX X X xxxxxxxxxx XXX X X XXXXXXXXXX X X X X X X
44 0
H TJ rt -rl
a e
H -rl
fl
H
fl
H
(d
^H 1
X X XXX X X xxxxxxxxxx XXX X X xxxxxxxxxx X X X X X X 4t= 44= 44= 4*= 44= =tt= 44= 41= CJ a
01
rH 0
J3 rH
id JJ
sj id
3 SJ
ft C
U -H
3 Vh
O 0,
s= M
JJ ST O
JJ Eh
0 * B
rH 0 JJ O
JJ rH t|
0 Jj SJ
lltilO
JU OH
0, C Vh TJ
4) tI TJ 0
3 Vh tj Vh
O 0. < 0,
0 0 0 0
TJ TJ TJ TJ VH
3 3 3 3 0
rlrlHH Tj
O O O O 0
fl fl c c a
rt -H -rt -H S
IS" SS" 41- 41- SJ
rl O U
SJ -rt -rt
CJ rH rH
r, -9 flTJ 3 3
oj o, a
9 TJq
0
Jh 43
SJ
q ae qo
3 tf o to TJ -rt
0
Cl
H
43
b
0 SJ
JJ O
0] 'ri
X fi O -rt TJ
CJ O ft rt 0
X
o
H
SH
^
bi H 3 D,cj JJ
b
rt
in cO -rt
SJ to
O 3
HH
O
SI
01 JJ
0 b
,
fi
en CQ
sj CD
V, oh 0 q
1 fd 0 0 Vh 0
n JJ - JJ rt
h CO JJ SJ
1 oi 3 In 0 idJJ JJ TJ SJ q O -H 62 SJ SJ to b si ft Vh
O TJ TJ 01 01 0 b -rt ,0
a; rt -rt CO CQ n JJ OJ so 'hi
Os a a id to
H fd
SJ
TJ
J> -h q
3 -rt
Vh fi U rH -rt q b
01 O O b 01 3 0 0
o SJ
b
-rt
TJ
SJ
b
9
0
01 TJ
JJ >
JJ
SJ
CO
TJ
q
0
JJ H
X SI In
0 q 0
Eh 0 SJ
q Vh to
o, OJ JH 01 -rt 0 0 JJ 0 0 fi 0
i fi SJ fi -H V, SJ Vh H SJ 3 -rt 3 Jh0, Q.TJ ft fd 01 Id O o TJ SJ sj b \
q M JJ 3 TJ b SJ Oh rt fi b 0<u Q 01 a 0) SJ o O Cj 3 -rt rt 0 Si
1 _^
JJ
SJ fi
JJ
SJ
fi vih
H O
rH
H
rt
TJ Vh Vh
0- TJ JJ 0
0 si TJ
t-H
Q
w
Eh
O
fi
o
SJ
CJ
01
01
N
O
4J
CJ
rt
01
01
N
fi
O
SJ
>
q
id o
rt
0
01
TJ
X
0
fi
ft
0
ft
TJ
O
SI
u
rt
0
fi
3
ft
fi ft
Q. jj L7
SJ
0 -rt Vh
q s 3 rt TJ rt b 0] SJ oi 43 0 0 TJ jj 3 0
01 in o fi rH 01 *rt 3 0 b X. JJ JJ SJ 0 4J SJ
X Eh OJ SJ 0! fi id V, TJ 3 o TJ SJ b fi ft -^ b
o OJ O, to rt ft -rt OJ 01 OJ SJ rt U 0 Vh 0 0 0 S ri 0 0 ft 0 0 3 to x: -rt
q SJ SI q q q JJ 01 > sj q SJ q q q s to TJ q q q q 41 X H SJ TJ
o rt 01 rt o o o sj 0 O to 0 CO o o o JJ SJ 0 o o 0 o o 0 O rt TJ 0
S! CJ q JJ q c q TJ TJ Vh 0 ij 01 q q q Jh 0 Vh q_ JJ q fl O rt rt rtfe; OJ
$
cj
H
q
o
Eh H
CO to
-rl
3
41
fl
o, TJ
q
O
Q
01
q
O
JJ
CJ
a
tn C5
q
o
ft Eh
oi oi
O
o
H ft. 3 Q,
q
0
01 rt CO q q -H -rt to q -rt 01 q q JJ H
* SJ SJ to o o SJ co o o u SJ SJ 01 o 0 SJ SJ
o ft s 01 01 rt rt ft q 0 01 rt *H On ft q 0 oi 'ri rt 0 ftEh -rt -rt C Si SJ u 0 H q SJ JJ I rt 0 q SJ SJ -H rt
3 fi Oh fi Vh ft 0 Vt HH Vh Vh ft Vh HH Vh Vh ft 2 V,
oi 01 oi b ^ 3 01 or SJ 01 O H 3 0 r-i CJ -rt 3 0 0 sj 0 b
2 to bi Tj SJ to CJ O 1 to bi TJ SJ CO O fd 5 0] bi tj
SJ 01 b 0 E 01
OJ Vh O 01 01 X -ri 01 Vh 0 CO X 3 JP 0 V, CJ 0 01 X Oi a 0fe;
xl
Sh Q J S a; U ai TJ
0)
.. Vh
H Q 4J Si a; <S ftl jj
Jh
-rH
^ Q tj SJ a; "i 04
41
fi
Q
X X X X X X X X X X \ - XXX XXX X X X X X XXX X X X X X X X X XXX XXX
X X X 0 X X X X X X X X X X Ph XXX X X X X X X X X > XXX X X X X X X X X -rl XXX XXX
ft
I
s
g
X
0
JJ
TJ
'2
v, 0
b q
si 0
b fi
*rt rH
tj a0 S;
fi
a, tj
fi
-. id
TJ
H TJ
01- ftl
_ Vh
fi O
ft si
rn Vh
0 ft
0 b
3 0
si Vh
Vh si
V N> JJ
o
0 q
fi 0
3 Vh
a, jq
cn
to
o,
01- rH 0 rH 0
.
x bi x bi
&
q'
JJ CO to
CN 0
fi B
viS
- O U
0 JJ sj
rt si q
bi -rt
o >
j 0
o> OJ
0
a;
x
co
o to
X JJ
cn X
CO ;r|
O tSH
CN X
to
0
*4l SI
rt 0
TJ
rt ft
01 JJ
rt SI
> fi
CO TJ
X O
CN XJ
CO SJ
CO 0
IN B
q
1*1 0
rt -X
o
Jh
m
TJ ft
n '0
jj
jj N
"H
JJ
0 10
in
0 'n Cj
Q OJ HI
<N 4J Cl n ^
in n (n
tn jj Tl
n
ft H ci <N
m e q
^ rd
X TJ <N *H
vo X 01 X
O TJ vo Jh vo
\ q 0 Ul Cj
cn m X X
TJ tj TJ JJ TJ ft
O (0
JJ CO JJ TJ JJ O
CO ft JJ
fd ti
** 45
H Vh
fi O H
_
"
=. TJ
0 TJ
OJ <
> JJ
0 0
OJ Q
rH TJ
H ft
> JJ
0 0
a; Q
rH ft
O
H ft
0- TJ
0 TJ
OJ C
q
O TJ
rt 0
01 >
-rt O
> B
0 0
oj aj
o 0.
-rt
01 TJ
H 0
i TJ
0 TJ
OJ U
q fi
0 JJ
S> TJ
0 TJ
OJ -4J
r*l ft
H to
X
vo TJ
ft
3
vo -X
q
_O TJ
rt 0
CO 01
2.2
0 0
oj a;
too TJ
** ft
X In
CN 0
o Oh
IN cq
CN CQ
- 0
o\ vvh X Vh
VO js,
o TJ
bi
q
CO Co
X Cj
IN OJ
q SJ rt CU
H* 0 rr, rH N
-X TJ -rt SJ
H 0 H ft H -rt
SJ 3 sh 01
q q q q Cl
O TJ O Vh b TJ 0 H
. 0
CQ Ol
rt q
> 0
0 jj
aj 0
s- TJ
0 TJ
oj OJ
01 >
_ 0 0
ft, t O C| OJ
X X X X X X
X X X X X X
OJ OJ
II
OJ X
o o
EH Eh
CJ CJ
H H
a q
XX
a e
TJ -rt
fl OH
XXXXXXXXXXXXXXXXXXXXXX
xxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxx
N0
0
in
id
Pi
TJ
0
fi
Pi
g
A!
TJ
JJ
s
3
TJ
q
0
JJ
TJ
0
fi
ft
rt fi
0 O
0 q
Q "-
s so o
q q
0 to
rt q
ss fi
-rt 3
TJ si
O 0
SJ a;
0 0]
s so o
-rt -rt
SJ SJ
fi ft
0 0
0 b
oi X
4J ftl
o
Eh
CJ
o
TJ
a
3
TJ
0
In
fi
ftTJ
0
0 si
JJ
b si o
B oi
ss Vh
o o
sj
q b
, 0 -n
X TJ
O 0
Eh Vh
S a,
TJ .
ft 0S .Q I
H rH
J 4J 0
I CJ q
a fi
\v.
-
0 0
5 S4J O O O
SJ SJ 0 O O Tl
-rt 3 0 0
OlTJ
Vj O 01 01
U Si OJ ^
fi
ft
U
O
JJ
o
H
0
ID
rl
01
B TJ
Tl Tl 0
0 Vt
41 Oh
Cl SH
0 X -rl
4J X TJ
O fl
TJ
0
q
s
JJ
TJ
TJ
<
g
X
O
Eh
q
rt Vh
rt O O
JJ JJ Oh
"J ..
SI rN 0
CQ sj Cj
0 -rt 0
rt ft
SH JJ to
O -rt
"- to TJ
q 0
Vh O sj
O ft id
SI I) Cl
o 0 o
91 fi -1
> -H
CQ 0
0 0,
o o o o
g
X
o
Eh
q
o 0 q
rt JJ 5,
TJ si -t?
0
rt iq CO
Oh "rt JJ
CQ - b
q -^ o to
fi JJ rn q
3 SJ rH 0
sj TJ q .x
0 -rt 0 O
OJ 3 TJ si
rt
TJ
0
^ -^ rt -
01 01 a, QJ
q fi
o o 0
q q JJ
q
o
JJ
b
q
01 0 q
JJ In o
SJ -rt m q
Tj b 0
Vh i ~- -X
Cl fi 0
VM o q sj
CJ 0
q X 3
01 q 0 o 0
X O JJ si q
rt sj
SJ si TJ 0
b q 0 JJ
TJ 0 0 -H SJ
01 fi JJ oh
SJ rt sj -h q
td TJ CJ -rt
ti - 0
-H l) TJ 0 ft TJ
rH
rH 0 fi to
JJ si 0 3
Jh JJ
-H >H tQ to SJ to
s 0 'ri -r(
h; fi fi
Ul ill Ol TJ q o Vt
Jh fi to TJ 0 oh o
01 0 -X si
ft fi o q cj
n JJ Si O 0
CQ Tl b j-rt >
01 rd q 0 si
SJ 0 q 0 si
-V JJ fi o B q
Vh Cl JJ rn Vh 0
*r 0 q O O V,0 ish Vh
0
q
0
CD
fi
JJ
JJ lH q 3
Eh H "rt CJ
V, 01 0
TJ
TJ s SJ "
SJ II CO
11 1
W C tl
U CJ
SJ
01
X p
01 Cl
01 01 SJ C
0
Vh . 2 101 101Tl V, fi c
Tl rt c II II
< 'H 0 rHtl rHfl
si Cl
tn rrt
H,
rH
fi Cl t) 41
Cl Cl 0 (1 fi
o XI g a -rt
v,
ft
3 0
0 q
q o
q
<t; v-
Eh
3
TJ
X
Eh
q
0
TJ
ft
to 3 0
0 O fi ^
sj q a, 0
0 A! q
TJ 0 o
fit oi JJ q
Ej -rt Eh ^-
0 0 0
q q q
o o o
q q q
B
t) 01
Cl t;
SJ Cl
3 tl
tl SJ
3
JJ Cl
Cl
q JJ
0 tl
Vh q
JJ 0
fi
01 JJ
JJ
rH
m
01 3
Cl SJ
q b
TJ
0
fi
ft
TJ
q
0
q
0
X
g
q
o
a
ft
C TJ
to 3 0
0 O Vt
si q o,
JS *TJ 0
fl, to JJb -rt Eh
to q q TJ
si 0 - o O Tl
q 0 0 -rt -rt o
0 -h q sj sj >
vn U fi Q,
-H 3 0 0 rH
bl TJ SI to CJ 0
fi fi 0 CQ X 3
h, S a; q ftj si
ft
-rt
fi
10
to q
SJ 0 o
q 0 0 -rt
0 -rt q sj
E "h Vh Vh
3 -rt 3 0
bl TJ si 0
V, o 0 0]
X X rt
X X >
to o
0 tQ -rt
rt q SJ I
Oh Vh fi
rt 3 0 .
TJ sj IQ
O 0 to
SJ <tj
xxxxxxxxxxxxx
xxxxxxxxxxxxx
ft fi
rt
Vh
tl ^
to CT,
01 fi
<J "U
SJ tQ
q 0
0 -rt
B 'fi
3 -rt
biTJ
fi fi
h; s:
fi ft
0 0
oi b
4 3
Vh p
Ol Cl
s 01 bi0) Vh
"J U
X X X X X
X X X X X
UJ
o
<D
tn
ri
Pi
a
0
M
0
6-
o
JJ
a
h
oj
oj
g
X
JJ
fi
O
Wh
. := vo
q o H
0 fi
X ft OS. h=jh
O 0 H
Ert q 01 > X
JN 0 CQ
VV Vh 0 fl o
O M rt X
u 3 tl q in
to Sg 0 CO
rt X Q q
Jj TJ 0 O CN O
fi
m
3
SJ fc "oj
TJ 3 fi
H TJ o - >
ov ftq
01
>.
on
1
1
fi q rt 0
11 o .. to -n
SI rt CO Ol-rt SJ
SJ q O > -rt
J.) V), Cl J 0 q
Vh ri rt rt o> OJ H
O fi fi 01
0 JJ SJ Cl rt
H sj q CO >
rt 3 Cl 01 01
ft, t; Cj <J oj
e 0
CJ
u 0
JJ rt
rH
O
0
J3 Vh
** si
0
3
ft
Eh
2 2 a 4J
ss 0JJ fl
o o o VJ 0 q
t-rH
a
o
0 0
-X
OS a o rH
gg aid Eh> 03
u Vh SJ Jh
Eh O Vh
SJ -rt
1 1 CQ > <0
-rl -H
<H 0 TJ JJ ' &3
o fl 3 0
TJ -H rt CO tI
a hh o 0 rH X
id J)
TJ
fl
Xfi
q
TJ
0
al
0 0
o o
q q
q
fi 0
3 q
SJ O
0 q
a; '
to - o o
'rt 3 0 0 rH
biTJ
fi fi
K SJ i
b
01
01 n
fi 01
ft SJ
0 q
fi 0
oi
bi 01
q Vh
ti VJ,
rH 0
fi
si
0
id
fl
o
01 SJ
bi q
q fi 0) 0 TJ 0 0
o 3 q q q q
-1 SJ VI tl 01 b o Ol
tQ 01 q q fl q q fi
0 UJ tn o
CQ
q rd
tQ tQ
-rt CQ q q tn
SJ SJ oi o o a
ft q 01 01 -rt -rt o
'ri 0) SJ SJ
rt HH fi fi ft
oi II ri 3 0 0 rH
H biTJ SJ tQ CJ
S 0 Vh O 0q ^j Sj a; 4 3 3SJ
TJ
0
is.
fi
,
V1H
fi
Eh
q
O 0
rt q
SJ 0
O fi
H rH
^> aOJ Jq
fi
0. TJ
fi
0
TJ 3
H TJ
</> ft)
bi q
q 0
rt .X
TJ o
0 TJ
rt 0
b Vh
ft
rH
as fl
3 b
si q
fi 0
rt fi
Jo. JJ
* 1=0 *
fl <rt H.
. X
q >rt 0
0 =rt bl
X X 0
O CN Ol
Eh CO to
q co 0
o cn B
ri-9.
- o fi
0 JJ SI
rt SJ sj
rt 3 O
Ii, < CJ I
XXX
TJ rn
0 N
fi q si
Oh O ft
I bl-rt
! O t>
i .q 0
oin
CO *
CN *
X
CO 0
rt bi
X 0
CN CQ
CO 0
CO 0
CN B
O ft
g
X
fi
1
g
X
o
Eh
q
10
in hh
X
Qj JJ
Q 3
X 43
C\l -H
o Jh
Q JJ
(N -U
t^ Jh
Tj
th TJ
co TJ
0 fi
oj SJ
u
jj q
(0 -H
-*H 0
TJ TJ TJ O TJ TJ ft TJ
O CU
jj JJ JJ 0]
0]
UJ
cn \
Jj Jj o jj
o~> in fi o o
cn H >n
. jj
<* ^ JJ
rd
in
o vo cn 3 in io Q3 TJ CO
cn *H "^ 43 "VT q
o
"^
3*
CN
<n X iH Jh H H VO 00
TH fi CN) JJ
JJ
CN to
-H
TH q
-H
H
<n 00 X. fd O > Cj X
o CN *H *H rH Q
X X \ q X Jh X b X
X vo vo o vo vo q vo
0 o O -H O jj o o
X X \ jj X HH X Jh X
CN CN cn b CN CN CN
O O to o O Jh Q HH Cl
o O o Jh Q TJ O o q
CN CN
(d
TJ
cn -h
TJ
CN i
jj
to
CN Jh
q
CN 0
-H
CO
VO in ft ^ 43 rn Jh CN rH -h
3 CJ H a; >
fi fi
bi
h q
(0
*H Hh f< o
jj
rH
Jh
q q q q Jh q TJ q q
O b M O 43 o O TJ 0 M
H "H b> H H 43 *H M <0
to bi to bi (0 TJ to <0 0] bi 0] *H
H 3 *H 3 M -H H T< q H JJ
> 43 > 43 > TJ > q > ffl t- H
TJ H 43 q
a; Q -K Q ft, *t, Oh tn a; O a; h
0
VHJJ
a&
o o
ftl,
rt
Vh O
2
-
to JJ
0 3
TJ
JJ
3
a
01 fl
01 'fl SJ
01
fl
rt
01
01
rt Vh SJ
0 01 id
3 'cl fi
SJ
fi vh rH ^
o rt
> id
fi q tn
11 td o 'fl
SJ rt v
tl 01 SJ 01 fi
3 01 Cl N
fi '0 3 cV V
SJ rt fi 01 fi 01 01 01 n
01 S- SI q SJ q q fi H
01 tl 01 Cl 01 o n ci
'CJ fi 01 q 0) q VJ q
*- a, '0 CJ -ri
fi
q ft
o
rt 0
si fl
b si
rt
TJ to
0 q
fi fi
Oh 3
SJ SJ
0 0
bi aj
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
OXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
td a
CJ CO
0 Q
o Vh
0 TJ
fi TJ
En !
a
TJ TJ
3 3
H rH
o o
fl fl
fi p Oh fi
tl
01 biTJ SJ
0) Vh
te; VJ HCCJ SJ oj
X X X X X X
X X X X X X X X
si 0 .. a o
q 0 0 -rt -rt
fi ft
0 0
to b
oi X
C ftl
0
fi
Cl
01
k <j
X
X
X
X
i
tN
44
0
rl
0
tn
Pi
b
EH
5
bi
q
rt
to
1
0
b
2
jj Jj
g
jj
g
a
0
b 43jj i 01
H
JJ
g
H
3
b
0
JJ
SJ
0
j
0
n
fi
<Q
3
JJ
HH
O
CO
01
s
TJ
TJ
id 0
r-H
ro
3
JJ
Jh
0
CQ
0
fl
SJ
fi
O
Oh
SJ
rH
(0
3
jj
0
SJ
Vh
O
Oh
fi
0 0
fO
3
JJ
Jh
2
S
<SH
O
11 rt -r, Jh
"2
Cj
0,
CO
01
11
jU
"2 q3
0
0
Jh
"2 q Jpa
Q
H
0
b
Eh
9
0
b
Eh
Q
H
0
(0
O
U fi
ft b
^- jj Jh
O
Jh
O
jj
CJ
>
0
Vh
3
D,
bi
q
rt
SJ
fi
0
TJ
CO
0
a
13
0
0
Jh
3
b
.J
SJ
q
II
*
a
q
0
Jh
3
0
b
g
& CJ
CJ
3
ft
Jh
Eh
Jh
b >
jj
U Cj
SJ
01
111
u
jj
q
vi
JJ
3
0
0
Q to
H Q
Irt
jj jj fd ^ bi PH 3 b H 0 0
in
b > Jh bi 0 q bi 0 0 b CJ43
JJ
q tn 43
^ jj
Eh q fl -H q O fl JJ JJ 0 43 q fl
jj -rt SJ JJ -rH 43 SJ CJ
0
0
S JJ 0 00CJ
0
01
q --
Jh
_^
Jh
Jh
3
jj
rd
0 CO
{fl q _
b
fd
SJ
fi
0
0
q -
Jh
fd
JJ -^H -X
JJ
Jh
rd
0
01
q
q
CO
q -x
s
Eh
b jj
<^ ij jj HI SJ Vh 0 to JJ Jh fi 4) 0 0 ,q 0 Jh CQ C/l3 q q rd Eh 3 0 q q R =3 01 3 q q q q 01 ft. 3 q q q q CJ oj 3 q q q q jjSI -u o o 0 0 Q JJ JU (d 0 0 Ob Jh SJ sj 0 0 0 0 4J jj SJ 00 0 0 s jj b 0 0 00 q q q Jh q 43 q q O 0 0 q q 43 q q 0 q q 4^ q q 0 q q 43 3 q bibi a; ^~
q
Eh 43
a
fd
CJ
bi ft,
q
jj ^- bn *- * JJ
CJ
>
bi OJ >-
q
t* tn
CO
CO
bi QJ
q
Jh
CQ
jj
bi ft; =-
q
US H ^
TJ
<D
o CO Cfj 0 CO to O 0] tri 0 CQ Oj D> O - CO U] Cn
H 01 CJ -H to q q CJ rt 01 q q Jh rt 01 -. q q *H 01 q q rl
JJ JJ to b 0 rd JJ jj to - 0 0 fd sj si to - 0 0 TJ SJ JJ to - 0 b AJ jj jj oj 0 0 a
> s CO *H -H U ft q 10 "H -rH U ft q CO -H -H TJ ft S-rl S rt -rt ti ft q CO "H *HH OJ ,M q JJ JJ Eh -H a -H q jj jj Eh rt 0 -H q jj jj *-: rt SJ SJ rl -h -h q jj jj
* i HH Jh Jh ft Jh E HH Jh Jh ft fi HH J^ Jh ft fi E; 1-1 rt fi ft ^ H Jh U ft0 b 3 -h 3 Oj r-i b H 3 OJ 0 b 3 H 3 rH b 3 -rt 3 0 0 T-\ oi b i3 H 3 rH
B to biTj JJ to 0 rd e tp bi TJ jj to jj (d B 01 bi TJ jj to b rd Ei 01 biTJ si 0 b (d 6 tq bi'O jj ta 0 rd
J5 Jh .o 01 X 3 m Jh .0 co X 3 0 0 V, O Cf] X 3 ro 0 V, O 0 CQ X p 0 U 0 oj 01 y. p6, Q "U 5 ft, =C &J jj
JH
-rH
^ Q < 5; Q3 qj Gq JJ
Jh
X -rH
S q IJ S 0; Htt; ftl JJ
Jh
X -H
!55 Q *: S; 0; IJ ft) jj
Jh
-H
-J Q >3 fe! a; j; ftl
Jj
-HXXXX X X XXX X XXX X X X X X X N XXX X X X XXX XXX X XXX XXX XXX X X X X X X X
xxxx X X XXX > X XXX X X X X X X X > XXX X X X XXX X > XXX X XXX XXX > XXX X X X X X X X >
fi
*
<D
0
nJ
U
FH
ov
til
*b
4J
CN
m
^H
OO
O
u
fO
Jh
JJ
43
jj
Jh
O
HH
b
HH
Jh
jj
q
--H
-q
jj TJ TJ TJ TJ
TJ TJ TJ TJ
Jh
O
jj T3 TJ TJ
\ tn jj JJ JJ JJ 0 0 O
H
q -U 4J sj SJ & jj rojj JJ Jj
\ TJ CN cn in Jh CN (fl
CN mri in in tN rn (n in O X O <n Q o\ X
Cj > CN fi SO CN (0 cn OJ rn rn ri
O o CT, X <-v! "1 <*} .. rj) Jh " "P 0
N Jh
ft
to
^ rn ^
co
S
tN M
O
rn
vo
*H
CO SJ
CN 0
Ul Eh
JJ
0 0
*h as
CN
rn
O",
rn
Jj
0
in
*H
q
o fi
vo CO
*H <n X
-. SJ
vti 01 vo tn <n vo x u > (fl
CO -H U] <fl H *H H ft rH cn b H r-i TJ
Jj
*H 0 JJ CO * CN T 3 CO T3 cfl 0 (fl
-H fd Q * >H tn fN JJ 0 tn 00 in 3 rH O 0 -H rn Cj rd (0 Q -
I> CJ jj X * X q X Jh X 0 <N CN TJ CN 43 fi Eh 0 Jh rn Jh
- q
43 cfl S 0 0O fd X -H X X X X
X jj X X \ 43 Eh 43 rH
r-H fi a 43 O 2 0 X vo vo TJ vo vo 43 Vo 4J vn U 43 rH
Jh fd to \ bi X 0 X X 0 Q 0 q 0 0 JJ 0 E O C/]X O
A cfl rd 43
f-H 3 CN TJ CN CN Q CN X X X 0 X X -HCN S
b jj m
b 3 U Jh Q CO O TJ O H O CN CN CN CN -H CN E cn .ft. JJ q 3 JJ
2 ^ Jh ft in. Cj rji O 0 O O O tQ
CO 0 O rd 0 0 0 0 a q
CN CN JJ N b CN O O co q 0 3 0 Q ? s 0 0 fd e -H rd JJ -H
tn TJ
Jh
- fp
TJ _i
"2 Jh > B fd q CN cn JJ
(0
CN 0
-rt
CN Jj
Jh
CN H CN H o>l JJ 41
0
43
JJ . i
JJ
U
Jh 3 Jh
(HO Ch
Jh
(0
u
tn bi
. tH 0
CN
H Jh H &
O
H
CO
a\
TJ
00 ft
SJ
X ft vo
-H O
in 11
HtH
CJ
^f (fl
bi
f^i (0
a
a
(3
*- O
JJ
0 . a g U O CJ
H TJ 3 m . rH - bi -
3^
- O
f\t
Jh 43 -rl H 0 fl JJ -H -rl -rH
</V &] Oi TJ b rn >H TJ <-H CO fi q "H fi ^ H ft H H bv
q 0
0 JU JJ H Tl CO HHrl
iJ C JJ CJ -1
iJ
q q
<d
43 q - q q q q
Jh
3 q tj s s. as
0
A CJ
a b
01 p
a J,
rl 44
2 5
0 JJ Jj
4J llj 0
q 3%%
0] -
Jh q
o o
Eh"
O ft
.. -. in
b
H
to
0
1
0 bi
"H
CO TJ
O
'H
01
b
Jh
0 -
H
to bi
O -H
h bi
01 bi
O TJ
rt
01 TJ
0
-rt
01
ft
TJ
0
-h b
CO (0
0 bi
H
CO TJ
O *-H
03 TJ
1 1
n a
0 0
U -H X
V
0, ft ft
JJ "H
3 JJ
to
q
31 "M
j S- * -2 43jj H> TJ 2 bq H 3 M 3> 4^ rt
0
>
rS
"2 TJ -H f-H> ft
-H
> TJ
H
> TJ ^ Slh SrH 3 rl -O 0. & 0
-Q ft 0 -A <l> * (0 TJ 0 H 0 TJ TJ TJ TJ **. **, V c B B 1 0 u Xii - H </> os * ft. a. a; *$ oj -3 q; q ft; q OJ "< a; *=< ft; 0, 03 <U ft; **: 1 1 TJ 0 X
* b Vh Jh
jj b
0] <D 0 m Vh
43
-H JU
- H 44 0 *J TJ tj tj *a tj tj 44 Eh
q ui ^ c rt 3 3 3 .3 3 3 a CJ
'H 3 o 5 7< H H H rH H r4 H TJ 0 -rl
O Q at fl "rt 0 u b b U 0 0 0 0 *rt
xxxxxxxxx xxxxxxxxxxx X X X X X X X XXXXXXXX XXX X
H 0
rt TJ
a ti
rl -H
a a
-rl -rl
C a a
-H -H -H & JJ
0 itX X xxxxxxxxx X X X X X X X X X X X X X X X X X X xxxxxxxx XXX X 44= =*= * * * # * # h* 41

a,
8
TJ si
0 -rt
sj TJ
TJ
0
Ol
fl JJ
.. SJ
*N -rt
cn S
2 e
H SJ CQ
3 0
q O fi
0 TJ
rt TJ TJ
01 0 C
-rt rt
J> -t 0
0 -rt fl
OJ ft, SJ
q
0
rt
q
rt TJ
0 q
q 0
O rt
rt TJ
SJ TJ
Vh
rSTJ
IIS
^ SJ
JJ b
q SH
JJ
to
q
0
N
0
N
rt
oi V, 0 0 to 0 0
3 q q q q
si o b 0 o o
Js- -rt
0 q
a; H
JrJ E JJ
XX O
fH
JJ 3
a
SS 2 A C fl
o o JJ JJ o a
H H -rl JJ -H
Eh Eh 5 A 01 41 JJ cO CJ rn Cl a 1) 0
P 13 0 fl 0 Tl "SJ ? HX X 14 T, Vt TJ a SJ
K K si Vh TJ a a X CJ
01 Cfl
13 Z
01 41
0 a 3 nRs CJfH 2
H H V V B ' jj
a a a a s a q
SH 0 TJ TJ Tl Tl TJ Tl w -
R 3 3 3 3 3 3 O
TJ -H rt H H rt rt rt 01 -H
fl H U CJ II IJ IJ CJ 0} H
SH 0 fl fl fl fl fl fl
.3 3-rl TJ Tl T| Tl rt Tl -rl
44= 44= =tt= 41= 41= 41= 44= 44= u a
0 ^ -^ ^ ^ ^
SJ 0 0 0 0 0
id q q q q q
0 o o o o o
it q q q q q
SI 4J 0 - Q
o, q 0 to -rt -
rt 0 "rt q SJ
fi fi
cj m; Sj a; : ftl
-rt 3 0 0
Q tj 5=3 OJ u ftl
SJ 0 0] . -^ -^
T,01 SJ 0 q 0 0 0 0
q 0 3 01 q q q q fi
o 0 rt X o o o o
Cl fi Id Cl q q q q 4J
O Jo SJ n
fl
o
~ in
o 0 to
b
-rt 0 q C
c SJ SJ 0 - o o q
o ft q 0 0 -rt -rt o
rt 0 rt ^ xi t^
SJ fi B 1h Vh Vh ft SJ
oi b 3 -rt 3 0 0
1 oi bi TJ sj IQ b rt
0 Vh fi 0 CQ XJ Vh
SJ S; Q J S3 a; t; Co. sj
bi
q
g
rt 0
si q
CJ 0
3 Vh
fi -H
" 3
to Sj
q
H TJ
fi
- 0
TJ S
H TJ
Ol. ft]
bi
q
rH OJ- X *
3 O
01 > rH 0
ft - X bi
0 JJ CN 0
b - CO 0
q q co to
0 o cn 0
rt B
to sj
o co bi
0 3 CM O
H V, -H
CJ sj =h
J,
SJ
sj -
3
- o fi
0 fl sj
rH si q
q
Q, O
-rt -rt
fi 0
CJ -rt
CQ O-
bl -rt
O >
sq 0
Or OJ
CN
C| 0
rrj -H
"
VO 0
M B
CO o
co B
CN O
Vh
ft
rH fl
b
rt q
0 -rt
OJ ft.
TJ 3 TJ
45
Jh
jj
in ju 00
cn m **
o\ b" H
JJ
-rt
fi
CN ^-
CN ft
O
oq
rH Eh
X eq
CO 0
rt -rt
X -
6
bi
rt Vh =rt o
. si
rt 01
5H
> HH
0 0
OJ JJ
X TJ
x q
to
rHj
b
H SJ
0
q vsh
> TJ
0 TJ
aj J
m q
- o
H -rt
V70 SJ
b
co q
t-i 3
X VVJ
vo
O Vh
X 3 rn
TJ
rt ft
fi
rt 0
CO fl
-H Si
> fi
0 3
OJ ft,
X tN XI
vn X X
o vo oi
X CO 0
CN \ bi
CO cn q
CO 01 CO 0
0) CO fl
SJ CN b
0
to n fi
H u, o\ o
3 q
H V,
0
q ft
o b
p. TJ
0 TJ
aj t
to bi
rt 3
> J?
01 TJ
H 0
0- TJ
0 TJ
OJ IJ
bi
s q
> JJ
0 0
OJ Q
i> fi
0 td
OJ x
2
0
&
0- TJ
0 TJ
OJ *$
tQ V,
rt O
> q
0 -rt
OJ J,
Ol 0
rn B
X 0
CN b
a -rt
CO TJ
CN 0
fi
vo
Jo TJ
0 TJ
OJ J
Cr, SJ
Hi 3 h
J)
r-H ffj
X 0
co q sj
CO 0 0
X JsJ CJ
c, Oh
CO Eh TJ
co q 0
CN O Vh
rt ft
>> TJ
0 TJ
Vo TJ
h q
Co JJ
X -rt
CN fi
H fi
TJ
q Tj
O <t
*rt
0 TJ
rt 0
J> TJ
0 TJ
OJ -4J
TJ
q
O TJ
-rt 0
to bi
rt q
0- 0
0 fl
a; Cj
Ii, ; o Q a;
XXXXXXXXX
xxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
TJ
0
O
ft
I
o
fi
ft
ft
g
AJ
fi
ft
Vt
3
O
ul
g
Cl fi fi
0 JJ JJ fl
fi o
-r, 0 01
Q fl JJ
fl 41 SJ
Cl
q to 01 n
0 q -~ -v q
Vh V, 0 0 fi 01 0
0) 3 q q 3 q VI SJ
SI si o o SJ o n
0 0 q q 01 q q
bia; v- v- oj Vh
rt
qq
0 - oi 0 C)
rt 10 - q q SSI SJ 0 o o
ft q 0 oi -rt rt Jh
rt 0 -rt q SJ SJ
fi E oh
0 b 3 -rt
fi fi ft JJ
3 01 0
6 to biTJ SJ to ci
01 y
i=. U , Jj a; t, fti rH
O
Oxxxx X x X X
xxxx X X X X J-l
fi q
ft o
sj 3 q -^ -v -^ -v
V, -rt 0 0 0 0
to si o q q q q
SJ CQ ft o o o o
0J q q q q q
CQVJ^-H-^H.
o
Eh
q 01 CQ -ri -rt
01 q SI SI
Oh fi fi ft
3 01 01
TJ SJ 0 Cl
Vh
IJ
0
a; X ftl
O 01
ft q
oi fl
g"
3 fl
SJ SJ
0 -rt
a; a
ft
-rt
fi
fi Tl
0 01
SJ Vh
q -
01 0 -rt 0 01
q q o q q 01
Cl O Q, O n t-r
q q q q
^-< V. *
CO
fl
fl
0 b
u
Cl fl si
SI SI 0 -v ^
01 VlH 0 0 01 01
ft, co q q q q
SI 0 o o o Cl
0 oi fl q q q q
0 to Eh ^- v- n
3
O
X X
X X
HJ M JJ 41 VI PS, -rl
SJ <u Jsj aj o; m -o
.XXXXXXX >H
XXXXXXXO,
sj sj to o O sj
ft q 0
rt 0 -rt
Vh E Oh
0 b 3 -rt
B to biTJa i ho
fe; u i; sj
xxxxxxxxxxo
xxxxxxxxxx>
H 1 4 1
Vh fi a
3 01 01
SJ 01 ti
01 01 *
OJ IJ uj
0 q b CJ
b
fi SJ
3 01 CJ
O jj 3
oi fi
JJ SI jJh
CJ 01 CQ 3
SJ q - q
0 Vi 0 0 -rt 0) 0
Oh 3 q q q q 43
SJ SJ o O 0 tl o
0 01 q q fl q q JJ
bi OJ
q
~- -- Eh
|Jrt
JJ
fit
0 0 rr
*rt to q q
SJ 4J IQ .. ti o
ft q 0 0 -rt -rt C)
SI si
fi B 'fi fi rt ft 1
oi Cl 3 -rt 3 01 0
1 CO biTJ
SJ 01 tl
0 v, p 0
Q < Sj oj i OH 43(J
JJ
X X X XXX X X X
X X xxxx X X X [-,
b 0] O rt to
q q -rt SJ q
rt rt SJ b "H 0
0
b
3
3
fi 1
rH fl fl fi sj J3 b
SJ SJ q SI SJ 01 jj SJ
3 rt rt b CO q 3
fi rt s to JJ q -rt -q b
P 0 rt si SJ rt jj> & SJ V, CQ rt 0 ".r1 Hq 0 fl S 0 fl ;_. 0 ft
Jj
1
0 0
Vh
ft
B
0
CJ TJ
fl
SJ
SJ
73
3
SJ
b
Jj1
Vh Vh 3 0 HH b H
to O 3 b SJ fl O jj 01 b
q HH b 0 SI fO fi
"H JJ >, u rt H CQ -H SJ
Tj'
to 0 0 SJ 0 b s CQ b q q
q q fl rt Jj o 0 b 0 0
6 o
b
b
rt
SJ rt
0
SJ
o
CQ
01
TJ
0
UJ
UJ
-rt
SJ
b
SJ 0 & 0 SJ T3 (fl b 043 b fi 3 0 (fl Oi q q .
JJ
3
3
Vh
0
ft
0
a
01
01
rt
b 41 jj
to
U] .^ q
fi b
-rt -rt
b
rt
0
JJ Vh
bi H sj B 0 o 0 b 01 to 41 b TJ si ri
q Cfl 0 fl rt V, 0 fl bi 0 rt b b SJ TJ
H i- q b SJ U TJ to 0 Jh rb c SJ fl 0 0 to Jj
q rt s b TJ 0 b (0 Tj 0 b b Vh fi 3
jj 0 b Oh 3 0 jj 3 CJ 0 c a rt B
3 1 O 3 SI b Vh 0 0 fi 0 TJ TJ O
JJ
jj1
S -rt sj 0 to -rt fi q O
to u ii SJ 0 SJ rH 01 01 fl 01 01 43 Jj U JJ fl fl b Jj
Jh q o ^ S b SJ a 0 SJ 0 0] SJ jj SJ fl b b rt
Jh "H Jj Jh 0 0 3 H 0 fi 0 0 bi 0 b 0 q q SJ
o Jh
tJ
<d b 0 to ti 0 fi 01 TJ U bi to Jh bi q fl 0 0 b C
jj O iH jj Vh co JJ 0 -^ 41 TJ q TJ Tj fi q <fl Vh 0 sj rt fi 3 O
<ti jj e rd 0 0 b 0 Vh 0 0 0 TJ fi 0 0 0 0 0 T) ? Jh jj 0 fi JJ fl 0 fi 0 ri
Jh b q q q q ft Jh ft fi q q q fl 2 3 q q q q < Eh 3 5 q q q Eh oj 0 q SJ q SJq o 3 o o o B TJ 0 b 0 O o 0 SJ b 0 0 b b SJ SJ Jj o o 0 0 SJ HJ SJ 0 0 0 CQ b CJ
& 3 q q 43 q q ft b TJ fl q fl q q 0 0 0 q q fl q q 0 0 q q q q 0 0 0 fl fl q q 0ft. Eh -3 O* CJ 0 is B --1 bi a; ^r Eh bi b, ft. ^ '** Eh "" *- Ol 01 OJ Eh Eh H Vt
4J II .3 a
ri
a
q 1 tj Ii q q q jj
o 01 CO JJ o W 01 VH b 01 CQ 0 o to CO 01 o - 0 oi b
"H to q q 10 rt 0 q q 0 -rt q q 01 *H to q q CQ rt 0 q q cj
JJ jj 0] O o c SJ SJ to 0 o 4J SJ SI oi b b 0 JJ jj 01 o o 0 SJ SJ 01 b b 0
ft q CO H -H -rH ft q 0 0 -rt rt 0 ft Q 0 CQ rt -rt V, ft q to -H "H Vh ft q 0 oi rt rt Vh
"<H "H g JU jj rt 0 rt q si SJ VH -rt 0 -rt q
SJ TJ -H H q JJ JJ TJ rt 0 rt q SJ SJ OJ
Jh Jh ft Vh c SH fi fi ft 0 fi E Oh fi fi ft TJ Jh Eq HH Jh Jh & TJ fi <sh vi fi ft SJ
0J Cj *<H 3 qj b rt 3 0 0? a oi b -rt 3 0 0 < 0 U -1 3 0 < oi b 3 -rt 3 0 oj 0
I 01 5.
"O Jj to 0 CQ biTJ SJ 0 b 0 01 TJ SJ CQ b B CO bi TJ JJ 01 b l to biTJ SJ 01 b toW o fl) tn ix 4J 0 U O 0 01 k 0 fi a 0 01 rX V 5 Jh O to X 41 0 V, b 0 0 XQ * sj a; *: &, a
(3
a
% Q tj S: oj =< nq rH
o
X 0
E; Q "J SJ oj IJ 01 01
fl
0
^ Q r-3 rSI ft; *, ftl a
fl
0
fe; q <: Sj ft; t ft) TJ
XXX \ \ X X X X X XXX X X X X X X X XXX X X X X X X X XXX X X X X X X X X X X X X X X X X
T,
O X
XXX X X X X X X X u XXX X X X X X X X x jq XXX X X X X X X X CJ XXX X X X X X X X u X X X X X X X X X > X
in
u
O
m
<D
tn
l
Pi
fi
0
fl
ft, 0 Cj n
b Vh O 0
O to 0]
to 0 to 0
to fl 0 01
X
0 0) v, 0 0 0 SJ
OJ 0 q q q q 0
SJ sj o 0 o o o HI
0 0 q fl q q q
CO to w (S,
1,
q -H
o -
Htl
JJ
rt 0 - u
SJ SI 0 .. o o sft q 0 CQ -rt -rt
rt 0 -rt q sj si
fi B oh fi fi ft IJ)
0 b 3 -rt 3 0 Of q
B 0 biTj sj to Cl H
0 0 X
i% Q >, SJ aj j ft) TJ
b
.
o
bi 0
0 to
-I W lH
ft, 0 O
o Vh
o 0
CQ 0 3
JJ -H
0 4J -^ -v 0
0 0
0"
oj co q q
SJ SJ O Q
0 0 q q .
0
q q
o b
q q
E tjlTJ
id 0 fi jo
53 Q "J =3
-rt 3 0 0
b
- X
OJ J ft]
0 rH CJ
JJ fl O 3
b SJ ft fi fi
b a SJ SJ
Jh
0
i
0 g 3T3 -H q b rt
q rt
H
,1
SH
0 0 rt
O
q 01 ft 01 fi
rfl
01
rt O
1
rt SJ
q
-H ft q o q o
o O o q o b
HH
a
rt
SJ 0
-rt
SJ 0
q b b
o 3 to 3 01
H j -H rt fi ri
jj SJ SI
o SI .. 01 q 0] q
3 CJ q b q O
Jh 0 rt rt rt rt
jj fi bi SJ SJ
to rt Vh 0 b 0 b
q to TJ 0 fl 3 fl 3
H oi
0 fi SJ SJ fiSJ SJ fiSJ
JJ
a ii a Oh 01 sh 0TJ fi rt q 'rt q
bi q TJ o 10 -rt -rt
Jh *rt 0 HH 01 0 0
fd S 0 3 0 3 0
jj fi
0
SJ
8> rt
Vh
TJ
Vt
sj
fl
HJ rt
fi
SJ
fl
SJ
SJ tn q TJ O
-q 0 fi o fJj 01 HH Vh to si
JJ TJ 0 q -rt -^ sj q 41
SJ 0 0 TJ 0 41 o, fi 0 0 0 0 q vi 0 0 0 0 0]
to q q q rt q a CJ 3 q q 0 q q b 3 q q 0 q fl c
JJ b 0 b b r-H b fl fej SJ b b 3 O o CJ SJ o o 3 o 0 o
q fl q q J? tj O to 0 q ,q .fi 5 VJ 4J to 0 q q fi q q CJCO t-H X. CJ rt o; Eh ^ ta
a
o
rt o; Eh----
w c
q si q CJ q
o 01 w 0 b 0 oi b oi oi o
H tQ q q bi *rt to q q -rt oi q q Vh
JJ SJ 01 o o Vh SJ SJ co - o b SJ SJ to - o o sj
ft q 0 w rt rt 0 ft q 0 0 -rt -rt o, ft q 0 0 -rt -rt C
H 0 -rt q SI SJ (rt rt 0 -rt q si SJ o -rt 0 ri q si si O
Jh HH Vh Vh ft SJ Vh On Vh Vh ft z fi rt rt rt D, O
CJ -rt 3 0 0 0 oi b -rt 3 0 0 to 0 b rt 3 0 0 SQ
Ul tn TJ SJ 01 b 01 B tQ b>TJ SJ tQ b rl B 0 bi tj si to Cj -H
Vh O 0 01 X 0 0 V, b 0 to X 0 0 Vh O 0 0 X
Q oj SJ a; IJ c3 TJ Sj Ci < 5g oj ^j ftj rH S3 Q rj SJ a; rj ft] rH
fl
b
q
S
rt
0
fl
fl
SJ b
rt q
fl 0
fi
q fl
o i
rt q
SJ 0
tl q
hi
O fi
fi b
ft sh
fl 0
Cl tQ
q -H
m 0
fi HH
fl SI
a
01 SJ fl
fl -rt 0
fl b
q 0
O fl
rt CJ
fi
0 sj
fl to
si q
SI 0 0
0 JJ JJ
Ol SI Eh
ft
ri
fi
0 0 0 0
q q q q
o o o o
q q q q
q q
- o o
tQ 'rt :A
q si si
fi fi ft
3 0 Of
SJ to CJ
0 to X
Cl 0
q ci
01
ft 0Cl
01 oi q
oi Vh o
01 sj rt
fl SJ
Cl 01 tl
0 fl 3
Cl SJ fi
01 SJ
II CO 01
0 q q
Vh fi rt 01 0)
h 3 q q
SJ SJ 01 n o
01 01 fl q q
bi a;
i
SJ
fi -^ -^ 01
u 01 01 fl
q q C)
01 ti Cl 0
fl q ci
Eh 0
fl
q
b q5 b
-^ fi --_
0 ft 0 0 TJ
q q q --h
O 0 b O -rt
q fl q q id
Eh ^- >
biTJ
v, o _
q Sj a; < ft)
xxxxxxxxxx
xxxxxxxxxx
0 0
H q
rt fi
CQ CQ
q q
- b
fi ft
0 0
oiE 0 bi TJ sj .
13 0 rt O 0 CQ X
% q < sj oj ij ftl
xxxxxxxxxx
xxxxxxxxxx
0 B
fl p
0 0 ft 0 0 0
co to q q q q
SJ -H o 0 o o O
0 ,0 q jj q q q
01 Oh ^- Eh ~- - ~-
O - 01 0 Vh
n cq . q q m
sj SJ to - o b 0
ft q 0 CQ -rt -rt SJ
-rt 0 -rt q sj sj o
Vh E Oh V, Vh Q, g
0 b 3-rt300 QJ
B CO blTJSICQCJ TJ3 0 Vh O 0 to X
S; Q tj S; o; *; cu. tj
xxxxx\xxxxx"o
XXXXXXX\X\X1>
0 -H B ft,
ft. = fi
S . ft -rt
SJ
rt fl fl b
SJ SI ci F
B 0 0
6
rt
0 q -. v.
fi fi 0 JJ 01 0 0
a, 3 q q q q 0
SJ si o 0 n b b
0 0 q fl q q q
bl OJ ^- Eh
i,
q -rl
01 IQ
rt CQ q q D
SJ SJ 0 b b Eft q 0 co H -rt
rt 0 'rt q SJ SJ
fi E Oh fi rt ft
0 b 3 -rt 3 01 0
B 0 biTJ SJ IQ O
to X
S. Q -J SJ QJ x ftl ^H
0
\ nxxxx X X X
xxxx X X X x cj
in
<M
O
o
tx
I
Pi
s
q
TJ
S
3 S
Jh A;
10 "<H
U 0) $)
3 q q q q
U O O 3 O O
q q u q q
q u sj a; *; fc, rn
ft 0 CN b
01 fl 1*1
SI
4, Sh II 0-b
fi rt JJ
m
,-s 01 01
X 3 hi 0
Cl fi fi fl
0 SJ 0 SJ
VII rt
01 to sh
bi q id -^ -rt
fi fi 01 0
0 3 JJ q q 0
J SJ SJ o o 3
to 01 q q fi
-rt oj Ji ^- tn
0 to
- q q
si to -. o o
q 0 -rt -rt
biTJ si
fi a 0
<rj Sj a;
CJ b
q 5 = 0To
o sj q fl
rt oi to O
SJ
b q qH 'rt c a
3 1 0 O 0
fi 0 SJ fi -rt fi
SJ 0 fl q SI SJ SI
01 SJ -rt 0 b 0
q SJ fi 3
H 01
-3
sj Vh sj
0
q
rt
3 SI 3
ft CQ ft
SJ LJ SJfl J q b ftSJ o
rt B
S 3 H 3
0 O
s. bi SJ o Jrt, 0
b g 0 VhSJ HH rt 0 JJ 0fl SI fl
q rt q SJ SJ
b 0 TJ 0
rt 0 to 0 CO O fl o
SJ 0 -rt 0 SJ SI SJ
0 01 Vh isi 0
SJ 0 ft-rt q TJ q
CQ Of TJ q o q o
0 TJ fi O 0 -rt 0 -rt
fi 0 S SI SI
ft SJ bi-= 0 b sj cj
0 q q 0 V 3 Cl 3 E
rt 0 fi tdfi 0 Ufl Vto q fi SJ 'rn, SI 0
bi 0 si q O b 01 JJ 3 Vh
q o q siq fi 01 0 rt SJ
b ft fi SJ 0 H -rt CQ
rt of jjj 0 0 0 b rt
0 0 0 SJfi n rt fl ft
H
41 0
0 B si CV ta ft fl 0 JJ 3
0 O SJ fl V? sj v, sj ft
to SJ b 0 CQ to O SJ SJ
bi q 0 01 q si q CJ TJ CQ CQ 0 3 -^ -^
q fi 0 0 TJ 0 0 0 fi -rt 0 0 rt 0 0 q SJ O 0 O 0 0
b 3 q q q q 0 3 q q q q 0 q sj q q
J U o o 0 b b Ul 0 sj TJ b o 0 o 0 -rt -rt 0 "rt 0 O O
01 0 q q fl tj q a -rt 0 q q fl ,q v; 0 ,fi rt fl Ji fl q q
0 OJ
q
b
Eh
oi 01
o
j
01
0
TJ OJ 0 Eh
01 oi
rH
CQ
rt O, Eh a Eh ^- ,-
q -
b - 0 0
-rt to q q Ol rt oi q q 0 -rt 0 - q q
SJ SJ oi b b e SJ SJ 01 o b 0 si sj CO - o o
ft q 0 oi rt ri o ft q 0 0 rt -rt 0] ft q 0 to *rt -rt
-rt 0 -rt q SJ SJ rH rt 0 rt q SJ SJ -rt rt 0 -rt q sj sj
fi SH fi rt ft fi HH fi rt ft TJ Vh g "m fi fi ft
oi b -rt 3 0 Of rH oi b rt 3 0 Of oi b 3 -rt 3 0 0
I 0 TJ
SJ to b 0 CQ TJ SJ 01 b Di to Oi TJ sj 0 b
0 in Cl 0
a ! SJ aj X ftl
3
SJ s, 0Q fi a.; SJ 0oj 3 -j C-ri fe 0 In o 0 ,Xcj .q; oj i; ft)
. X X X o
. X X X JJ
o
H
JJ
O
m
a
H
TJ
q
fl B
cj Eh
q cc
M HH
ft
X 0
CQ rH
rt ft
ft
q "U
fl CQ
Cl t-
q m
0
rt 01
fl fl
SJ
SI
Cl rt
Cl
rt si
01
01 rH
fl
q Id
0 Cl
rt
01 M
rt ft
ft
q "5
cj
a
oi
IV &
0
fl
b
fl
q b rt
rt 0 q
Vh b
0 -rt b
fl TJ
SJ 0
0 >
HH b
rt V, fl
b 0
q -h -^ -rt -. -^
Vh 0 0 0 0
3 q q 0 q q
si o o 3 o o
0 q q rt q q
vf -~ Eh ^- -~
SJ SJ CQ
Q, q 0
rt 0 "rt
fi E oh
rtj Sj oj tj W rH
CQ Oh
q rt
rt 01 01 01 oi
3 q q 01 q q
SI t) Cl 3 Cl
01 q q fi q q
oj bH ^-
CO CO
I * q q
i co b o
| CQ -H -H
i-h q jj jj
j 4h Jh Jh ft
_ -H 3
CO bl T3 JJ
in o
Cl -a; S! a. < ft) rH
fl
Cl 01
SJ
II rt
3
Vh rt 0 0 0 0 si
V, SI q q 0 q q n
SJ O O 3 o o fl
III q q q fi q q 0
rt oj ri v_ v_ SJ, v_ ._ o
q
to 0 fl
to q q C)
SJ SI 0 o o CJ
q 0 0 -rt -rt 0
0 -rt q sj sj rt
Vh E oh fi fi ft Ol
3 -rt 3 0 0 01
bl TJ SJ to CJ ri
rt O 0 CQ X
-J Q tj SJ aj tj ft) rH
ft 01 Cl rt
(1 q 3 -^ ^ -rt
HI rt rt 0 0
Eh 3 SI q q 0
ai SJ 01 O O 3
01 01 q q q rfi
rt "J
q
0
rt ~- ~- Eh
rt oi -
SI SJ 0 -
ft q 0 to
rt B 'fi fi
01 Cl
01 OlTJ sj
-J cj >: 51 a;
q a
o ci
rt
SJ H
ft m
in
tl
X
ftl rH
0 Oh
VJ, q -^ -^ -rt
m rt 0 0 0 0
fi 3 q q 0 q q
Eh SI b o 3 b b
01 0 q q vh q q 01
-rt oj *- ^- Eh
q
C
o
O
o - CQ CQ
-rt IQ - q q
SJ sj to o b tl
ft q oj oi rt 'rt 0
rt 0 -rt q SJ SJ
fi 6 Oh fi fi ft H
CJ 3 -rt 3 0 0
CO biTJ SJ CQ b
co X
'< Q ij is; a; "tj ftl rH
xxxxxxxxxxxo
XXXXXXXXXXXJJ.
xxxxxxxxxxxo
XXXXXXXXXXXJJ
0o
id
Pi
C,
o
H
o
JJ
M
(3
H
0 q p
SJ 0
0 V q
TJ CQ b 3 3 0
0 SJ VS, q
q 0 01 0
ii H - A 0 TJ
rt TJ o n i b b
SJ TJ Cl 0 q b
CJ 0 SJ SJ rt 0 0 ft
3 0
fi q bi
3
Cl
ft to
H
ft"
si o rt TJ ,0 0 TJ
to -H 0 fl 0 HH 0 0
q sj sj tl SI SJ
rt CJ q 0 - 0 0
? ^ 0 rt CJ fl "rt
1 fi b fi CJ sj cj bS si q fl O 0 o
0 to 0 CO A CJ 0
fi q fi rt CQ 1 to
= -rt fl id 0 0 0
3 0 b
0 0 0 SJ 0 3 0 0
JJ fl fl tl fl fi fi fl
SJ SJ SJ 0 SJ SJ SI SJ
XXX X X X X X
XXX X X X X X
1
- - JJ
ItJJ U
CT
0
01sj Vh m
01 TJ Vh -rl O SJ 1 -
C TJ 0 TJ SJ 0 u 0,
H 0
1 1
SJ
1 -UVJ..44,
si O
1 1
h 0
fl CJ
SJ O rt 0
1 -H 3 TJ TJ q
SJ 01 01 j; 0 0 O
to Vt 01 CJ Ol fl CJ
-h fl bi OtC 11 0
rt rt Vh rH TJ O -rl O
ITJ TJ 3
fi
e < < 4J
0
q
H SH
X
X
4H
XJ
0
H
c
0
3
. i fi
p
01
-1
II
TJ
rt
rt
5
rtco rt
HH &
0 0
q fl
u q
rt
0
sj
-rt fl sj fl q
0 SJ q O SI b
*b SI CO rt o q --i >
*<H q 0] ^1 S to o a ri
ft
b
o SI rt rt
(0 b
TJ
rt SJ rt q u 0
TJ
rt
0 s
0
ft
0 q
fl 0 &
Jh to
0
TJ
0
0
s
rd s rt JJCO "ii ob
bi UJ 0 3 o a to 3
q ri b 0 CQ b q
*h to JJ rt >, CJ 0 <o
(d 0 I o 0 JJ rH 0 43
jj
g
id
TJ
rt fl
SJ rH
fl
0 SJ
-u
I
q
0
TJ 0 -v 0J u rt Ul
b ^ 3 0 0 CQCO 3 0fi & 43 0SJ rt to
01
01
0
t3
TJ
0
q
0
IQ
0
rt 0 0 SJ 0 0 jj CJ ffl fi
to Sr,
P 8>
q g 0 0 ft o 0 ftCQ
0 0 JJJ TJ W 1 0fl a fl o 43rt fi o fl 01 TJ b Si b b JJ
rt
0
SJ
b
3
rt
SI
01
q
o
b
0
JJ
H
0 0
SI 3
rt r-H
q ftj
rt !
rSTJ
ffl
ji
0 b
ft
& o
SJ
SJ
SJ
b
SJ
B
0
O
II
"tj TJ
rt
b rn
a td
SJ >
o
jj
jj
HH
O
SJ
CO
01
Vj
TJ
0 b
JJ
HH
O
JJ
o n 0 SJ 0 II II o rt TJ V *H (J *~i
to
0 -^
si 0
0 q
0 o
3
Jh
jj
Ul
X sJ fi b Vh fi 0 to 3 < rt H 3
"^
o o g
1j
CQ rH
0 0
SJ -rt 0 0 0
-,
rt'
OJ TJ
b
SJ !tj
vjiTJ 0 rt 0 0
o
SI
0
o
SJ
0
0 0
rt rt
0 O
flX
O 0
0
0 -
rt 0 CO
b
SJ
0
"n
CO 4J -
J< O QJ
01
-x ~s
.Vj
N
H
to
q
b
0 SJ
0 -rt
fi s13
Cj h
q TJ
a ,
rt
0
&
rt 0
SJ
B
q
b
rt
0
0,
O
Vh
0
&
B tn
0 'rt
Cj --
q
0 o
q
0 o
q
o
fl
o
o
rt
0
&
b q q q
o o o
SS-SgSS
(d
jj
rd
tj
q
o - ui CO
q
o -- CQ
JU
co a
q
o - <n oi
U
0
q
o 0] 0]
II
II
u
q
o - 01 0]"H 0] S q rt 0 q q a -rt 0 q q 0 -rt to - q q o rt CQ - q q0] -. b o SJ SJ 0 - o o o SJ si 0 .. o o 0 SJ SJ 0 - o o 4J SJ SJ tQ -.3 3JJ
ti
ft q 0} "H -h n S 0 0] -rt rt O 3 8 0 0 -rt rt rt ft q 0 01 -H -H fd ft q 0 0} -H -iH<H "H q
HH Jh
-rt 0 rt q u SJ --H q sj SJ d -rt 0 'rt q *J U Jh -r| 0 -rf q jj jj
rl
oi
^ Jh ft fi B si Vh rt pi ~ fi st rt rt ft TJ rt E Oh M Jh ft rt B "4 Jh Jh ftb 3 'H 3 01 b 3 -rt 3 0 0 co 0 U ? rt 3 0 of < oi b 3 -ri 3 5? ft CJ'3 -rt 30 B OJ tJl'O JJ to b 01 I 0 bl TJ
SI CO p co CQ 5 TJ SI 0 b 1 0 biTJ
JJ to O o = to bi TJ jj cn cj
H
JJ
Jh tJ to X
sj a; t: fei Jh
TJ
x TJ
0 rt o 0 co
Q rj S; a; <
X 0
oq u
9
X X Tj
St,
0 rt fl 0 to
q Sj o; ; n 4Jn 0q fi aU sj 0]03 ^ -j i-H
o
o
0 fi fl 0 0 X
q 4; oj t; ftj
X JU X XXXX X X X X v X X XXX XXX X X XXX XXX \\ s XXX X X X X X X X X X X X X X X XXXX a X xxxx X X X X \ 4 X X XXX XXX X X < X X XXX XXX X x o XXX X X X X X X \ X 43 xxxxxxxxx
rC
ta
01
3
oj
x4
0]
&} 01
0
'a rt
TJ
jj
Cl
TJ
0
X
H g H0b q0
TH ffl
O JJ
1 CH
rt
b
OO Jh
rH TJ
Tj
b
SI ^J
00 Id SJ 0
X
TJ1
T3 TJ
q
-rt
Id
SI
SJ
X,
X B T] t) TJ TJ TJ Tl TJ V s T3 fl 01
o jj jj 0 0 0 0 0 A <u q 01
X 0 JJ JJ Jj SJ tQ SJ SJ 0 SJ 1 SJ 0 jj q
CV fl TJ SJ JJ -rt Jh
Q SJ X a, 0 0 TJ Cl TJ
Q *H <*\ X to CN X fl JO rrj Q CO 0 CM 0 o *o
<N fi
o *H o
CN CN CO VT) SJ
.. 0
CO CN 0
- fl - bi
rr, Cj
- 0
fi
_
b
rt
0 fd
fi rt O tn vn O CN v B oo co b oo -rt CN b v. SI rt q
fi
SJ 00 <*1
* to H ? X
O rt 0
- o
,U 0 i=0 0
- fi
Q rd
JJ
0
SJ
0] td
*H b *H rH tn vo X VO 0 vo CO 0 VO Eh Q fd 01 0 1h
0 H H rH rt TJ H cn b H H CN Q fl o
i* "n OD cn q 0 B B SJ
fl O Cj fi O ui c-i H rt co rt o o trj O c^ 43 0
43 CL o X X CN CN rt H SJ H rt Eh rt ,fi CO rt CN U N 01 N
q X X X X X X 0 X X X Hh X Oh X rd -rt q -v H -v -^
CO fO Vh o o VO vo vo vo bi vo vo fl vo vo tn O CQ rt 0 0 CO
10 Jh 0 X X Ct o CO CO CO CO SJ co to CO 0 o 0 3 q q q q
<~H q </> c\i CN X X X X TJ X N "d X q X to X u SJ si o b b o^ c rt o O CN tN CN cn q cn cn a CN O CN 0 CN fl td 0 0 q q -q q qa S; 0 > o Q O O O CO 0 CO o CO -rt CO rH O Jh TJ OJ >- J^ C C
a U CN] V CN O * Q co tn CO Cj II co q CO SJ co b o q Hti Eh
t T3 q 43 V CN + CN 01 CN 0 CN V CN II N H CN 0 CN CN 0 4J
Jh o Jh Jh q M rt fi 0 fi SJ -rt 0 43 CJ q
- ffl b to rH O Q b o rt o 0 b 0 q 0] a ri o - CO Cf]
T3 a CO fH JJ M N AJ oo -rt X JO SJ to SJ ui 0 Crj rH CN 0 *H rt A 0 CO .H rt CQ q q
H TJ
x
OJ (fl ffl 0] TJ 0 0 .fi CJ rt t> Jj jj ti XI SJ SJ to o o
<> &jj Jh fi Jh fi *H Jh rH -rt rt -rt rn rt H rt H Eh rt 0 rH 0 *H 0 a, , o -H 3 0, q 01 t0 "H "H
Tj ^ rt 0 0 TJ ft fi 1 1 g 0 43 ft rt 0 -rt q -u jjTJ q ft q q ft q 0 q fd q ft q ft q 13 q S r q M 01 CJ O fi E >rt U U ft
01 Hi b tf o 0 C? O rt o > 0 fl b b O 0 O TJ O TJ b rt O] to 0 0 g oi b 3 -rt 3Jh q "r| "rH H H rt rt rt rt b -rt 0 -rt 0 -H 0 ii rl 0 B co biTJ JJ 01 (Jo 5 to 'b to tn CO Tj CO rt 0 TJ CQ TJ 0 TJ CQ 0 0 bi 0 bi to -rt 4J 0 -*. 01 3 0 fi fl oi Xjj rt 01 b. -H -H 3 -H *H O -rt 0 rt 0 -rt 0 rt M -rt q -rt q 'r* SJ S 9 n rt 01 fe; q t &3 ^ &]
3 sj q o > T3 > 4; t-> T3 > q t- TJ r> TJ > TJ fc- ft j!. 0 > ffl <^> rt 9,9I 0 IH43 ft 0 vq TJ 1 73 rt 0 TJ 0 TJ 0 TJ 0 0 0 fl 0 fl q V SI Jh XXX XXX XXXU -H rt -rt <o- a; <; Q, Q a; S ft. jj aj tj OJ "J aj -rj OJ OJ OJ CJ aj o ft; H 1 1 TJ XXX XXX XXX
O Jh rt CQ o 0 eg TJ
43 jj CJ -rt HH 0 TJ TJ TJ <
rH JJ q CQ > S a a 3 3 o
H 3 o 0 0 TJ -rl rH rt H 01 -rl
ftl C O a a; fl "H
HH 0
CJ
fl
CJ
fl
O
ti
CO
fd 3X X X X X X X X X X X X X X X X X X XXX X X X X X X XXX xxxx X X -rt TJ -rl Tl -rl i-H1 X X X X X X X X X X X X X X X X X X XXX X X X X X X XXX XXX xxxx X X 4S= 44= 4t= 44= 4t U a
OCl
9
Pi
s
o
SJ
0
0
0
T,
Tl CQ
0 01
0
0 fi
fl TJ
'Cl
0
rt
Cl 01
fl
0 SJ
fl 0
4J -^ SJ -^ -v
0 ta 0 0 01
0] q
.
q q q
rt SI O 0 O O O
0 0 q fl q n q
J* tn *- Eh -- v-
rt
TJ
TJ
0
0
0 3
fi sj TJ
SJ CJ 0
01 0
r-l
SJ fl
3 O
ft
IJ IJ) ffl
to
3 M OJ
O ffl fi 41
0
TJ1
CQ S
JJ TJ
si *i SI
3
O 0 ft fl
0
SI 3
X 0 .,
0 JJ 0
fl 4J fl o
2
O 0 V to CJ 01 E
0 0 0 0fl V
0 SJ rt fi 'r-l fi 0
TJ A TJ fi3 o
SJ HH SI
0 o
4J fi
0 0 0 SJ0 CQ 0
3 ft fl 0 fl 3
0 SJ tf si rt si q,
fl 0 SJ SJ
SJ ^ SI TJ to IQ IQ 3 ^
0 0 0) Oi 0 q SJ O 0 o 0
oi q q q q 0 q sj q
si o 0 tl Cl o
0 q fl q q q - .fi rt fl rt fl q
tU ^- Eh rt a, Eh & Eh
jiTJ -
- fi fl 0 to X
q i; Sj a; ; ftq
ft q 0
-rt 0 -rt q
fi "rt fi
CJ 3 -rt 3
CQ biTJ SJ
-
rt fl
-
rt *rt rH
SJ SJ 0
if ft fe
IQ UJ HH VJ HI 1 r.
; q -i; sj a; -j; ft] tj
xxxxxxxxxo
x\xxxxxxx>
.. o
01 'rt
q si
vi fi
SJ OJ rtj
to
tj
ffl rH
TJ O
6 JJ
w
01
-
SH
0
TJ
rt
B
rt
TJ
TJ
0
fi
01 TJ
0 TJ
0 0
rt
TJ TJ
TJ 0
0 si
q
0 a
rt rt
rt b
3 q
0 CJ -rt
q
0 0 0
SiH-EH-
I tQ - o O
| 0 0 -rt -rt
i -rt q si si
| 0h rt fi ft1
-rt 3 0 0
bi To
rt o 0
< S a;
to b
to X
TJ
TJ1
TJ
0
TJ1
0
fl
0 TJ
rt TJ
0
tj-^TjU-.
sj 0 0 B 0 0
cj q q q q
q o o 0 o o
3 q q fl q q
ft, ^- ^- Eh "- ~-
q -
o - cq 0
rt 0 - q q
SJ SJ co - o o
ft q 0 CQ -rt -rt
-rt 0 -rt q si si
fi 'fi fi fi &
CJ 3 -rt 3 0 0
10 biTJ SJ 0 CJ
0 rt o - 0 X
q -t Si oj < ft) 6;
\ x
X X
rt
ft
01
Vh bi q
0 q rt
a o
0 ^ SI
rt
ft
0
rt
0
SJ
^ ^ 0 ^ -^
ffl 0 TJ 0 0
q q a a
o o 0 o o
q q fl q q
^- Eh
TJ
q
rt CQ
SI SJ 0
0, q 0
-rt 0 -rt
fi B "4
b 3 -rt
CJlTJ
0 fi ~
q q
o o
I -rt -rt
J SJ sj
I fi ft
I OJ 0
I to b
0 0 X
q tj 55 oj tj ft)
fl
q
TJ
U -H
gg
^ T3
h q
bi -h
X
43
TJ jj
rtWH
o
q
0 fl
TJ
TJ
ffl
rt
TJ
TJ
rt
TJ
TJ
co
TJ
rt
O
Hh
X
0
TJ TJ
rt -^ q -^ -.
S 0 -rt 0 0
q
sj 0 o 0
0 fl q fl
a; Eh -- Eh
q q
o o
q q
c
0, q
rt 0
rt
-
to o
0 CQ -rt
rt q sj
rt rt fi
X X
b 3 -rt 3
to
bi~
ffl rt
Sj a; ; cq
to 3 q q 3 q q
t. sj o o si o o
o - 0 0
rt 0 q q
SI SI 0 -. o o
ft q 0 to -rt -rt
-rt 0 -rt q si sj
rt E Oh rt rt ft
CJ 3 -rt 3 0 0
to biTJ sj oi b
0 rt n 0 iq X
q ( 53 aj rj ftj
HH
0
171
m
Pi
nl
jj
J
Q
O
fi
u
0
V
u
id
u
I!
rt
ft
of
rt
fi fl
S P-
2
ell
H
rt O
c *
bi
fi q
q
0
fl
i q
i 0
* a
fl p ft rtWh 3/ 1^1
0 to
SI 0
s b q HJV rHq ,0 o
0 "h g J=. l-l
A 0 fi B ^ CO
cj q 0 b fl X
0 0 si b
U rt q 0 CO
0 M rt 0 SJ X
0 a 0 IN
|d SJ N CQ q co
fi SJ 0 0 CO
Eh TJ ftTJ fl CN
rt ire 0
tj a 0 O Ml
H TJ
H, ft,
0
co- oj b >H
-fi q
01 Eh O
rt q rt
o o - cq b
SI rt bl-rt 3
3 SJ q O > fl
fl ft Cl q in 0
fi rt rt H o> oj q
- o fi rt 01
0 fl SJ CJ rt
H SJ q CO s-
rt 3 0 0 01
vv, C CJ q OJ
(TJ ..,
> q
0 rt
a; SJ
rt rt
rt O
X si
vo b
H SI
fi
<T2
i= TJ
0 TJ
rt
q
o -h
> -h
0 q
a; n
a a
<{rJ
EH Eh
< <
a a id
XX
4J
id
o u Q
< < 0
tl CJ fl
H ftl CJ
CJ CJ 0
XX
O
0
Eh Eh CJ
1 1 0
rt
SH 0 Eh
O fl 0
TJ -rt CO Tl
B " CO rH
OH 0 saTl TJ
44= 44= u a
b 0)
0 fl
CQ TJ SJ
0 0
fl t> 01
rt
u, bi
0 q
rt b
rt
bi id
q
b 0
3 TJ b fi SJ 0 ..
SJ O rt 0 to o
rt 0h rH > B 0
rt O H 'ri rt n
:=. ffl 0 fi ft
q 0 rt ft 0 41
0 o TJ 3 rt to
-rt X ft UJ fl
0 SJ to 0 0
0 b Oh 0 0 SJ CJ
TJ 3 -v O SJ bi q -. -- 0
rt rt 0 fi 0 0 0 id q rt 0 0 TJ 0 0 r~
io tj SJ q q q Q o 3 q q q q
O0O 0 O o O 0 J SJ o o 0 b o b>
fi 0 q 0
S 5 -5 fl CQ 0 q q fl q_ q aa! TJ = q
*
CJ
ffl 0- ^_ v_ Eh 0
j
CQ
q 0 q rd
O oi to b o - to to
rt to q q id -rt CQ - q q tn
SJ SJ 0] o 0 Vh SJ SJ 0 o b s
o, q 0 01 -rt -rt E-. O, q 0 01 rt rt 0
rt 0 -rt q sj si 1 rt 0 -rt q SJ SJ rH
fi i rt fi fi Q, rt B "rt rt rt ft
O 3 rt 3 0 0 rH oi b 3 -rt 3 0 0
0 bi TJ SJ 0 CJ id B 0 biTJ SJ 01 b rd
0 fi b 0 to X 3 a 0 rt fl 0 to X 3
q ss oj -JJ ft] sJ S; q c. sj QJ U ft) SJ
TJ
fl
0
J> TJ
0 TJ
aj *J
Jo -rt
0 q
a; H
01
0 CQ a II
3 rH Eh ?
rt rd 1 0.
SJ VH CO
rt ._.
~
Vl 2 A vj ft] . HJ OO OJ 0 X
to 01 2 fl 0 m j i u u 4J
ft, ft. 41 g rt ea q j
0 tn rt bi cq
fl 1 Eh o rt
rt fl
ftl ftl 2 Eh 3 -H
a a H 1 o
CJ CJ 2 Eh CJ Ol J JTJ EH tJl
Eh Eh 3 o V rt cn q | fl
1 1 Eh 2 m h rt w to u a
0 nj n H OJ < SJ o
T| -rt | (B In 0
0 c fl fl 3 01 J ||H n ft, PTJ -H Tl -rl rH j cn to i
fl "H OH OH CJ S3 fiO o
3 ft, ea cj a rl
Tl
SH 0 0 0 fl SJ fl
Tl TJ TJ TJ fl fl fl 0
41= 44= 4S= 4S= 44= 0 0 -rt 44=
u
ffl
tn
131
o
4
CJ
Ei
fi a a
000
sj rt fi
q si sj
rt to IQ
o
ft SJ 0
3 M
0 3 cv.
rt o sj x
si 0 vs,
01 0 J< OH
rt Cl O
sj -rt 3
3 <rt fl rt
Oh . O
Sf bl SI
3 o -rt q
o .j aj o
fi q
0 0
fi
rt fi
0^3
bi 0 o 0 0 0
bi q q q q
o O 0 O 0 o
h q q q q
~- ~- Eh
..
01 IQ
0 .. q q IS4
SJ to - o o C vh
q 0 to -rt -rt o o
0 -rt q sj sj ggB "rt fi rt ft
3 0 0 3 3
bl TJ sj 0 CJ
fi fl 0 0 X
rt 55 a; : fci
SJ SJ
TJ TJ
XXX xxxx
XXX xxxx => >
X
4J
0
!>
Tl
Vh
a
- SI Si
si 3 3
3 O 0 -
O OH VH *SH
1 I I'M
SJ SJ rH O
1) II 3 IJ
JJ si fi o
I I I I
Vh si sj rH
X Tl
V
SH
0
CJ
EH
rt
o
rt
q
o q
o
TJ rt -rt
0 0 SJ
01 rt -rt
0 ffl to
fl b O
to ft
SJ 0
3 ~l >,
ft q, 8
B
3 rt 0
0 0 fl
SJ
fi B
0 o q
bi rt -rt
bi rt
o rt
bi 0
q bi
0
fl rt o
-^ sj Ct si rn
fi q co
0 to rt
sj 0 rt q fl
0
rt q
aa
tjj rH
o a
U Tj
fi
.. 0
TJ S
H TJ
<o= ft)
JJ co q
CN O
fi -rt
0 CQ
tj=rt -rt
bi >
O H 0
J fi
P qEh O -h
0
to -rt
, -rt si
Jo. -rt
ffl q
rt q
o o
Sl -rt 0
3 sj q
- JJ Q, O .
rt *rt -rt -rt '
O fi fi 0
0 fl sj cj -rt
rH sj q to Js.
rt 3 O 0 0
ft, ; o q oj
xxxxxxxxxx
xxxxxxxxxx
XX JJ
XX Sn a
8 8 0M rt
HH 4Jm 0bi
an SH 01V 0
1 1 sJ
0 CJ
u to Tl Eh
0 fl 3 CJ
TJ -H rH 01 Tl
fl 4 CJ 01 H
OH 0 fl 2$H TJ -rl
44= =B= =14= ti ft
SJ ffl q ft 0 -^ -* -^ Ol
-rt VI O SJ 0 0 0 1
q SJ rt ffl q q q SJ
-rt SI 0 0 O O 0 tl
ci q ft fl rt q q q SJ
H
q
3 Eh CJ
*
Vh
Cl 01 oi 1
rt 0 q q fl
SJ SI 0 o o 11
H, q 0 0 -rt "rt
q sj sj
rt F 0_t fi fi ft rt
01 Cl 3 -rt 3 0 0 0)
l= 01 torn sj 0 b hi
,ffl 0 fi P 0 CQ X 01
rt >,
rt 01 0 -^ -^
SJ 01 0 fi 0 0 01
oi tQ q sj q q q
01 tl o to o 0 tl
n q 0 q q q
^- cj ^_ Q v_ x_
rt S: a. rt 0J
Q, q 0 0 *rt rt
0) vi SI SI
rt
H.
rt fi rt VI,
tl -rt 3 01 III
to bi tj SJ 0 II
0 rt Cl 01 X
q -< s: oj rt ftl
- o o ~
o
J
CJ
rt - fl
O 0
SJ SJ
E ffl rt
0 SJ fl
0 to
rt ffl
SJ SJ
to q rt
0 b
sj rt
3 rt B
ft 3 ffl
sj b 0
3 rt
O 0 SJ
fl
bi sj
b SJ
rn q 3
o ft
fl bi 3
si q b
rt
01 TJ bi
q q O -v -v
fi 0 01 oi rH 0 0
3 ft q q q q
n Cl 0OO
0 TJ q q fl q q
aj v- Eh ^- -2
q
o 01 oi
-rt oi q q
SJ SJ CQ O O
ft q 0) 0 -rt -rt
rt 01 -rt q sj sj
rt h rt fi fi ft
b 3 0 0
oi tvn
0 rt Cl
q rt *; a; rt ftl
TJ
0
g
rt n
rt o
ti
q 01
rt fl
:t SJ
SJ
X
q 11
o rt
q SJ
fi q
3 Cl
SI U
ft
-rt
rt
01 11
M 01
Cll
H U
X X X X
X X X X
JO -rt
q vn
fl -rt
rt
rt
oi 01 O-l
rt 0 Tl CN
fl q HJV X
01 vo
sj rt Cl > o
3 -h 0 x X
ft 3 rt fl CNjj s; rt CO
3 01 01 0 co q
O TJ SI rt rH CN O
rt q 01 fl "rt
.. m H 0 0
TJ S SJ r-H -rt
H TJ 3 3 - >HJV ft) B ftrH 0
u rt
3 q
to O O rH
rt q rt 0
tl Cl - 0 -rt
SI -rt 01 bl-rt SJ
3 SJ q O JO -rt
fl ft Cl J 0 q
rt rt -rt hjv a; H
o rt fi to
0 fl SJ Cl rl
q 01 i>
o 01 0!
ft. rt CJ o OJ
& SJ 0
rt rt 0
in sj fl
& CQ Eh
0 0 0
q q q
O O O
q q q 8
&
cn
& SJ 0
-rt rt 0
rt SJ fl
S 01 Eh
b o o o sj
q q q q tn
^- ^- v- o,
SrJ
WW& (H
o o
Pi Pi
Eh Eh
l.
0 fl
TJ tI
a <u
M 0
tI TJ
44= 44=
fi ft
-00
_1 TJ SJ tQ b
fi fl 0 to X
S; oj rt o;
o 00
rt to q q Tl
SI sj in -. o o H
VI, q 0 0 -rt -rt O
0 -rt q sj SI !>
rt B oh fi fi ft
ti 3 -rt 3 0 0 rH
biTJ sj 0 0 id
01 rt O 0 to X -1
q i; 5; oj rt oj sj
f
X Tl
X TJ
fl
00
tn
i
Pi
a
a
-H
u
Pi
&
M
fi
8
0
fl
_sj bi
q
O -rt
SJ SJ
fi
ft
In Cl
H q o
> q oo
-rt rH
fl rt
01 CD
0 0 Tl O
*i q X
JJ 0 01 <>> X
0 fi Cl Q
sj M 0 :> x
q a rt v CN
rt J5J rt 43 O
fi 01 - o q
a, TJ SJ <N O
fi q H -H
- 0 H 43 CO
TJ si (fl *H -H
H TJ s. JJ . >tn ft) q *h
H Jh
Jh q
to Oi Oh
fi q h m
o u - CO -H
so rt
0 O
E^
O B
SH 0
q 0
O fi
0 fl SJ
rt sj 1J
'r| 3 O
ft, rt o
-rt tQ
sj q
ft o
bl 'rt
o >
J 0 q
cn- aj H
"l", Aa
sh w
aa 01
ZP. rt41 rHfl
H H a 01
(-. p. 0 SJ
Oi Oi
II
V c
-rt
0 rt
H 0 TJ (J,
S o 3
TJ -H rH to
fl 4 CJ 1/1
h a fl id
H TJ
44= 44=
-rl
44=
rH
U
0 O 0 01 0) 01 n
si q q q q
-rt 0 o ti Cl t)
>j fl q q q q SJ& Eh ^~ C
ri
rt
q II,
o CO to
-rt 0 - q q Tl
SJ SJ 0 C) C) rt
Q, q 0 oi rt 'rt n
q SJ SJ >
rt B "rt fi rt u,
0 3 -rt 3 ill 01 rH
to biTJ SJ to tl id
0 rt fl 0 W rx 3
q rt S: a; rt oo
fl
<M
0
0
tn
id
Pi
a
O
H
JJ
Oi
0
o
X
W
0
O
td
u
I
O
o
Eh
q
0 TJ
JJ-rt
i -rt
o
rt
fl
JJ
q
ft
b
ftl
0
b
0 0
,H
s
Eh 0
ft fi
tf -H
is 438s1
J TJ
fi
0
TJ S
H TJ
cn ft)
X co
0 fi
fi vfi
Eh ft
3
B -X
O O
rt O
SH ^
TJ ii
0 Vh
> O
H SJ
fi 0
0 rt
TJ 0
q
0 0
to a
0 0
rH O
CJ 0
rtEn
fi-tro fi
0 JJ SJ
-h sj q
rt 3 O
ft. rt <-i i
rt
TJ 0
0 fl
sj CJ
sj
X 0
<n " fl
- SJ
Jj. X
> fi rt
fl 0
x fl
q rH SI
O 0
rt o\ rt
SJ CO
ft X SJiff rx q
b co 0
r* X
00 CN 3
0 a bi
o o rt
0 tN
rt
Eh bi
ft cn q
3 - -rt
X -, fi
-H SJ
CQ ft
1 bi *rt 0
: o > cj
l sq 0 b
i tn ofi <qj
X q X
Vo 0 vo
CO -rt O
X SJ X
N QCN
CO
CO q cj co q
CN ti X CN O
rt ftl -rt
CQ 0 10
-rt b =rt -rt
:=. 0 - i>
rH 01 rt h-h 0
fi Eh U
q j? "
Cl >rt 0 Q M
rt 0 a -h 0
0 -rt 01 'rt
SI
> 'rt rt > 'rt
HI q 1 0 q
OJ i-h 1 OS H
0
OJ
-H bi
JJ si q 0
Oi b 'rt Ol
ffl fi td
u f> si m
X fl to to
w 0 S!
0 B
J_, q bi
rj O 0 a
fO rt to
(J SJ CQ bi
ft 0 CJ
CJ 0 B -rl
rd b rt
lH X 0 sj
fH
"in
0 fl
u
to
u o 0 si
H SJ fl O a
rH b SJ SI fl
X X 43 jj
3
fi 0 rt
0
CJ
1 1 Q, SJ 0 0-^
55 2 0 01 SJ SJ 0 0 0 0
o o 0 q 0 q q q q q a
H H -H b 0 -rt o o o b o
Eh Eh *J c b rt o q q 5 q -ri q
A Pi a O O 0< -- SJ o
W W rt ft rt
U CJ 0 SJ 0
X X X a q U ft
w w h 0 b - to to X 0
w w CO o -rt CQ q q 01 0
tj u 43 X sj sj to b b 0 .x
a u ftl ft q
0 to rt -rt b ftl
<d 0 -rt 0 -rt q SJ SJ id 0
P IH CJ ci rt g oh fi rt ? Vh b
04 0, to id oi CJ 3 -rt 3 0 0 Eh 0
ss otd rt(rt &TJ0 rt fl
SI
0
01
to
b
X 3
o o rl O, rj q rt SJ o; Ai D.
ss EH 3 XXX XXX X X X X oo
3
*
1 I o XXX XXX X X X X J 0
o b
<H O fl J
H*
a c 3 CJ <rl
fl -H rH W -H \ T
a *rl 0 01 H X fl
H a td fl q
oi q SJ
CO 0 q
X fl 0
X
CO
i i
X 0
CN 01
O 0
CO fi 0
CN fl
SJ
b
0
ci
q
rt
SJ
rt o
-rt ffl
> SJ
ft o
fl iff
b
SJ
q X "a
0 ftl 0 -v-
-rt 0 TJ tn to
SJ JJ Tj rt 0
ft tj ffl > TJ 0 TJ O TJiff 0 - 0 fl ffl q 0
b CJ 0 fl si b SJ ffl SJ
X 0 fl rt
ftl b q SI ,lu
TJ 0 b o X id x <rt Ol
0 rt SJ rt i* fl CN 0 "HJI
TJ
TJ
Eh
0
SJ
ft x
SJ - fi
to vo
rt B H iff "J rt su q ci
SJ 0 fl b - 0 - o
p fi 0 X x fl CO -rt vo
1 rt q3 oj -rtTJ SJ0 H SIb rt
o TJ 0 tj\ rt H 3 X
-rt 0 ! 01 TJ CO CN fi H
SI q := -rt TJ X SJ X SI X
b ffl -rt ^ X q VO CQ vo
3 rt rt q SJ CO ffl co q o
rt H 0 o p ^ X H XSJ 3 TJ rt 13 CN CNto SJ SI bi co B CO
q 0 b O co rt co o co q
H TJ to 3 rt CN 0 CN fi N O
rt 0 rt SJ Oh -rt
!? H SJ b b> 0
TJ & b 0 3 1 q CN SJ H -rt
H TJ q rt -rt oi >
tn ftl
0
rt ri SJ rn
0]
q q
H O
rt
SJ
to
h q
o
q b
0
r-H 0
rt
q
O -H
rt q -rt SJ rt TJ -rt 0
o 5 - to ft CQ 0 to -rt
SJ ri oi bl-rt 0 V "rt rt SJ
3 U q O Jo b > rH > -rt
fl ft o J ffl b 0 "rt ffl q
vi rt rt rt cn a; rt OJ aj H
0 rt rt to
oi fl SJ b rt
rt si q CQ >
rt 3 o 0 0
*H rt O q oj
22z z
o o
H H
f f
0, Pi
w a
v a
x a
fi fi
ii
Eh Eh
S S
O O
H H
Eh Eh
11t
01 OI
Z 2
H H
I I
SH 0
m fl
TJ -rl
fl <u
M 0
Tl TJ
at 44=
JJ
ft
. o,
fl 01
0 u
T, X
4J
a T.
o = 01
O fl n
x n
14 fl rt
a o si
fl -rt O
CJ 4>
id u 5
9 U
u
H
bi
sj q
b 'rt
0 rt
ri SI
fl 0
O
ft 0
X ffl
0 fl
0 q
CjJH SJ
rt o o
on, O
Tj
0
TJ
TJ
0
TJ
TJ
fl 01
O fl
CJ H
0 0 0 0
q q q q
o o o o
q q q q
rl CQ
SJ SI
ft q
0 bi
0 fi
q rt
0 0
rt q
rt rt
fl 0 to X
Sj o; rt ftl
SJ 01 Cl
11 fl 3
3 SJ rt
rt
SJ 01 01
01 q q
q rt 0) 0) rl 01 III
H 3 q q q q
SJ SJ ti ti 01 ti ti
01 01 q q fl q q
bi uj
q
O
bH
oi 01
rt 01 q q
SJ SJ CQ n u
ft q 0 01 rt rt
-rt 0) q si SI
rt rt rt rt Hi
01 Cl rt 3 01 til
ti Ol n SJ Ol ti
m 0 fi o 01 X
S3 q rt sj o; rt Cq
TJ
0
TJ
TJ
rt
a
TJ TJ
3 3
H rH
CJ CJ
a fl
-rl tI
44= 44=
XXXXXXXXXXX
XXXXXXXXXXXi
o o,
0
si
0
t-
-rt
rt
0.
q
rt -rt rd rn
c 5H O
rt
bi 'rt
0 >
J ffl
tn OJ
Jo
H ffl
fi
q
o -i
rt 0
0 -rt
rt SJ
t> "rt
0 q
OJ H
- fl ft O iJ CJ
rt *rt -rt -rt aj rt
o fi rt 0
ffl fl SI CJ 'rt
rn sj q 0 Ji.
rt 3 O ffl 0
ft, rt O q a;
xxxxxx.xxxxxxxx
U
is a 3
e Hi
2 2 JJ
O O
H H fl
Eh Eh 0 C
Oh Pi Tl t)
ftl H si .rt
O CJ a SJ
X X 0 ft
$.i s 0b
o o w X
a III
Eh E, a C
Pi Pi u tl
HH rdCl risJ
H H a VJ.
a od T,WW rt -Hr-i
HIHI B cd>
a q
M A TJ JH
0 fl 3
TJ -H HH Cfl
fl <H CJ Cfl
bi rn
si q m
O -rt to
0 fi 01
"f-l si 0
fl 0 h
b
0 Ol
q bi
o Id rn
rt to fl
SI CQ -H
ft 0 Vhiff B jj
b m
X 0
01 fl si
rt 0
0
SJ
0
fl o
fl
O
Cl SJ SJ Cl
3
rt to rt
SJ 0 0-^ rl
SJ SI ffl 0) 01 01 o
q 0 q q q q q rt q
Cl 01 -rt o ci o 0 SJ
ti rt 0 q q q q IJ, -rt
Cj a, - 0
O
X
ft
0
q ui b
o - 01 01 fl X
rt 0 " q q C) ftl
SI SJ 0 ti Cl -H q
ft q 0 oi rt rt SJ
q SI SI l>, rt
fi E oh fi rt VI, ci SI
01 b 3 -rt 3 01 01 Tl VI,
f 0 biTJ SJ to b ri Cl
ii 01 X rH 'tl
U q rt S! a; rt ftl id
SJ
rt
X X XXX X X X X ffl
XXXXXXXXXXI
n
0ffl
ta
td
Pi
a
0
H
)
a
o
0
r,
0
fi
o
0
CJ
ffl
u
0
rl
bi
q
0
bi
0
rt
CN ft *
H q fi
o TJ 0 TJ
:= -rt -. 0 fl ffl
si q SJ tl SJ
jj ft o
01 -rt SJ
q b oi X 0 OO
0 ii oi t jj CNrt tn - SI
SJ SJ X CO
u, B X >. rn fi H
ffl O 0 01
b ,fi fl X fl IT,
X rt Vh SJ CO
vq 0 q 0
ffl TJ JJ O Cr, fi vo
fl ffl 0 SJ -rt CO IN
Cl q > rt SJ X SJ X
0 0 rt 3 ftX q ^i
Cl fi rt In 0 CO 01 O
0 rt 0 O X X
- 2 TJ rt X CN CN
0 JJJ b ftl CO fn CO
fi tQ Vs, 0 CO fi co q
h, Tl to fl CN 0 HN o
fi 0 TJ CJ rt
.. fd rH 0 0 hi 0
n S b 0 Cj cn q
H TJ 3 ffl !=
tn fej
0
rt ^~ b M
0
fi q
Eh O
fi
SJ
01
rt ffl
fi
CJ-H
fi q -rt SJ -rt 0
Cl o CQ 0, 0 -rt
SI 01 01 rt SJ
3 SJ q O > Cl > -rt
fl ft o sJ| 01 Cl ffl ,q
fi ri rt tn ft. rt oj H
- o rt fi 01
0 fl SJ Cj rt
rt si q to >
rt 3 o 0 ffl
->. rt O q OJ
bi
sj q
b -rt
0 rt
X HJ
fl CQ
o
0
q bi
rt
xxxxxxxxxxxxxx
xxxxxxxxxxxxxx
XX 3
ft
z z
o o
H H
E, Eh c
P. Pi o
a a -rl
o o SJ
X X ft
H W A 0
XX
fl
O
u
X
CJ Cl t| A 01
SI fl sj aa fl 0fl
nn 0 -H oo rt id
a X sia u01
*.*! V V urO
Vha a
44 0 TJ TJ trt
C 3 3 O
TJ Tl H rH 01 -rl
fl <<H b CJ 10 r-l
*H fl fl AiH TJ Tl Tl
44= 44= 44= 44= U ft
ft 0 Ol o 4J
0 B c rt 01
b H VI, CJ
X 0 rt ft o
01 fl SJ 0
SJ
0 0 ,
fl o 4J fl r
SI SJ a
fl 0
0 to fl
b U :*
SJ SJ oi 0 0 01 rt 0 01 0 0 0
q q q q SJ 3 fl q q q q *
Cl o 0 0 fl ffl
rt 0 q q q q 0 JJ q q q q q rt
CJ VJ, -rl
SJ
o,
S: oj a
fl
CJ
q 0 U
oi u si
q q X -rt 01 q q a
SJ SJ - 3 o 01 01 Cl ii fl
ft q 01 0 -rt -rt 0 ft q 0 oi -rt -rt Cl
rt 0 q SJ SJ fl -rt "rt q Cl
fi B rt Vh fi ft u rt rt rt ft
3 0 0 ffl 0 -rt
co bi TJ SI tQ o CJ
0
tQ bi TJ 4J 01 b ffl
0 CO X
OJ rt Cq
HI rt tl 0) to X -1
q rt SJ u s q rt 41 oj rt ft) SJ
b
0 X
b, 01
fl
bi b
fl r"
-rl CJ
rt 0
SJ b
0
h0
4J
Eh
HH
a X
1>
Tl
X fl
q
Vh
u, ri *
Appendix B
Kernel Benchmark Source Files
O0
Oi
0
Pi
HE HJO *
id to oi
-6 fl v ~
X co TJ t| rt -~
O O TJ -H rO
fl fl -
-rl - CJ fl
bo six
3 -
ii a
fi - jj
p, Vh si
ft ffl 0
cd. si S
0 J8
H rH C
JJJ P *1 P
fl O (3 fl
-H fl -rl 0
-rH
MH
JJ
-Sv,
Vh O
Q, J
M
4J
o
o
TJ rt
0 0
fl SJ
ii E 40 3
rt
ft
a
,Q Cfl
fl
rt
o
rt
B
rt >
X
0 X
rt
ft SJ
ft VVh
ffl 01
rt
q
0 01
JJ
oi l-i
0 -
sj sj TJ
b 3 b
0 ftfl SJ
to B sj HH
01
fl O SB rt
O TJ O
fi ft) CO
Sh
,
H
ftl oj .. OJ
iSftsso
l^rllrt O sj
as
a[jS a,
M O
X A fl
* fl A
' fl fl
I O -rl
I tI rH fl
I TJ TJ 41
i sj si g
i to
I V V V
I
I 41 41 0
I TJ TJ TJ
13 3 3
I H H rt
I CJ CJ CJ
I fl fl fl
I -H -rl -rl
I 44= 4S= 44=
X 4J C
o fl o
u Tl rl
'*
Pi .
SJ
ffl
2, fd* Xo rt0
to rt SJ
z a rH
o t-i ft
i id 4J
w 0 fl
2 TJ 0
rH
-H
sl SJfl 1 o
Eh bi TJ Vh
-rt
Vh
ft
0.
O CN ffl
OJ 0 X *
tn rt
3
., 0 ._ 0
rH rt
*\ 5 c i C 1
ZJ 0 0 O O
X O rH TJ rH TJ
i * H JJ ri rl
X i i IH 4H in in
I -k 1 CQ 1 O X CU P. rH a rH
1 S ' 01 .H 01 X 0 X
i q i VO 1 O l tn 1 1
1 O 1 j -^ o o o l -ri 1 H 1 CQ 1 CD 0 0 0 X X
1 -rt 1 <D . . . . 1 JJ 1 (fl 1 0 1 H rH rH rH rt X *
1 SJ 1
1 O 1
HOHHiN ! 2 ! ^ ! S! S-3 HH 3 0 arH (11 1
1 0 1 1 tQ 1 TJ 1 JJ 1 0 O 0 O o rt i (U 1i tn i H IN 1 -H 1 O l O 1 TJ TJ TJ TJ TJ l -H
1
i rt i ggEs'tW
1 CJ 1
1 CU 1
fl
SJ
1 U 1
1 O I
0
TJ m i
1 O 1 01 UJ W H H 1 Q 1 0 1 ' 4J si fl a H 1
1 to 1 0. IZ Z 1 1 S i a, l CJ fl 0 M I
1 CQ 1 W J X H H 1 CD 1 sJ l l a sd t 41 rrj li 0 i 1 U i O 1 C 1 a O HH TJ S i
i b i CO fP 03 CU fP 1 3 1 O 1 O 1 H a 0
1 O 1 fl fl C fl C 1 JJ 1 OJ 1 M I fl a fl CD a rH 1
i rt i -hH -rl -rH -H -rl 1 CJ 1 I 4J 1 H rH CO I
! &! <M <M 44 <M <HCt) CD CO ID 0
1 3 1
1 U J i 1 O 1' E3 1 TJH TJ-rt TJ-H s i -q tO 1
* U i o -a -a -d -d * U i fl * 3 i O 0 0 0 0 * ~H 1
x a< i **.###. X CO 1 0 X &< 1 > > > TJ a x O 1
rt
ft
tN
HH
0
d X
* X X
0 *
tx 01 cu
0 q 3 _^
Pi 3
JJ
S:
bi
q
rt
O
rt
SJ
1
rt
m
jj
SJ
bi
q
g
rH
rt
to
a
cu
0
+
JJ
O
i
X
q
jj
*n
o
I?
-rt
JJ
'2
rt
rt
0
1
ro
X
3
O
ft
0
3
X
OJ
a
-rt
TJ
q
rt
sh
!
TJ
b
c
O
rt
2
q
i
^H
rt
fi
,
CU
q
rt
OJ
tQ
3
'rt
JJ
q
rt
CQ
q
o
rt
tn
C
O
-rl
SJ
0
H
-H
0]
ft
01
A
o
H
J-J
O
1
*
+
CN X
+ +
a
SJ
SH
>JH
O)
+
3
rt
5
jj
O
a
o
JJ
q
SO -H
JJ CQ
1
CO
SJ
0
rt
0
SJ
rt
SH
O
rt
0
SJ
-H
*
41
a
Tl IH
0
fl
SJ
ill
SJ
3
& 5B o
LO OI
X
o o
OJ
fl
JJ
cu
JJ
3
1
g !
-rt l
jj l
2 :
rt 1
U i
OJ 1
T3 1
3
o
D, +
q
Q 0
<0 Qi
3 cu Jj rt .
4H 5 -n
CJ SJ
a Pi 3
tj J-j I
* X
JJ
SJ
0 X '-h
O
O
0 i Xo CQ^ X JJ CJo q * * rtJj o 2 : o +CJ B O 0 u B fi *H rt CO O SI 3 O CN U jj i-i -31q
3
rt
X
In
fi q
ftTJ
ft
ft
ft
*H rt
X
n i-i q
3 x
in ' CN
"*H O Q, 3 (0 0 , - 0
ox
rt 0 i- i s, OJrt fO rt q S rt * SH fl Jh in fl '
1 JO ;rtrt t- <*H fl VihS O * a II O SJ O O'-H jj i Ulm CO
jj <u cu fl i
o
4-1
JJ .
01 'rt
3 O -^
-o ro OJ
3 q
tn i
O --. 1
CN
q
to q fi oi fl
- JJ
fl
rt JJ
0 SJ X X
rt O
fO "rt
fl 1
jj . I
X -
X
rt q SJ TJ O 1 3 t= -H fl > JJ rt J5 i
9 o 0 u O 3 4J CJ 3 JJ I 31 <U
1 tJJJtl
cu q
X
rt
SI
B
rH .a
U ffl CQ 0
fl 0 B
3 3
o o
oj q
q 3
CQ CO 1
<u e '
O 3
P< OO 3 J Eh rn b 0 X rH SJ Vt ^r Pi p. JJ 4h t, -- I ~. P<1 ^ Si1*3 'rt rt rt CQ X II fl1 - i,U CQ & 0 fl o X w ffl * * 0] i 1 X1 <U O <U T! 9- ft SJ ." r-t II fl fl JJ o X 1 4h XJ O 1 yoi q O ^ X <U id -rt SH i
0
ti JJ X II o rt X Eh ft ko m 1 T3 X ti Q. 1 0 rt Cft
X
X X
-rt
JJ .
0
rt
l-n rH 1 rt
i!
oi <m
TJ CD
ri
0
o
o
Sh 6 1 e G
i a OJ P o p 1 TJ 3fl JvJ rl Pi JJ JJ TJ *j 44
O O fl O fO -rH 0 0 0
<o t a -rl u * * rl jV1 rl 1 < OH rt<H 1 TJ
&j 0
3
CO 1
CO
p g Cfl fl S sj g <o ! 0rt ] .. | ^ & icn 1 rt
U
0
a*, H o J TJ ft] s Mg J !
TJ
H
t
* gij
\ ^ n.
CD
X g -HO> -
1 JS C5
%t 1
1 g CJ
x I %
4-1
O
0
IH
X C X
* 0
rH
-rl
SJ
q
H
cu CQ ffl OJ
q 3 a b q 3 1
o rt 0 0 O rt
-h P 1 CQ c/l -rt nj fljj > fl A JJ > o
*o t o ffl CO fi CN
E= CU t -H fl Q) -H fl c
-H q 1 *J SJ -rt Si X X
X jj ' fO X ^ CQ Pi
0 1 u bi o fl OJ
Jh tn 1 cu i q Jh tji O 4-1 SJ0. q 1 JJ rt a q -rt A
Q< -rt 1 -H * r^ JJ
t?
q
1 *
IH
3 CO "O
q
CO
u
~
cu -H Jj (U -rt cu
-q Ij < a -_ X .4^ <M JJ ~-
r-H jj < -H CQ JJ -rt CN
TJ q xt rt q C
> q "rt fO q ^ X
1h "rt ' X 4-1 rt rt JJJ rt
<u q Cfl 1 o b q cq a ^ fl
JJ Q> O q ( u HH q I) O q -H 4H X
fl CQ "rH 0 ' Pi o Q CQ -rt O
<H 3 JJ
to
"r|
JJ 1 <o II
0
3
q
o
-rt
Jj
3 JJ -rt
fO JJ X
1
CQ
CU o 5 fO i * -H rt CO o e jo o J3 CN
,q JJ -H 1h .D P SJ e JJ -rt u Vj rt fl
4J
q o
CU
JJ
l o
1 rH
:> id
B ^ X <uq 0 jj *w X
u O U "rH ! i o
SJ rt 'rt O lH "rt fO
o rH Q, u b X O * &.. + o
*lH HIJ.'H i O o o b U rt Q,^ *
eq ro o I -0 rt fi Q. CQ (0 O 0 II
(U o. AJ V q ft ft ft fi
3 cj jj >h si O 0 ft ro . 4J <H i JJM o OJ X 1 jJ Oi rt SJ ffl o cu X fl oi
0 m o fl o ' C -ri SJ ffl rt 'M OrQ o 0 3 C
t o u * 1 &
-H
U
X
CN b
q
6
rt
H
0
ro
jj
O r(E rt TJ O X
U
X CU rt ' u 3 X SJ rt cu rt q &
3 fO cc rt Q -rt q 3 rfl id CM 4H
jj "H q OJ *H CD
If
OJ ., . rt q rt rt q <U Oh X Ol
a
--H
in OJ cu
fl fl
t-H
5
rt
1-
TJ C
* X
II
H rH
X
II
H- JJ
ft
ffl
q
-rt
SJ
a
13 tr "JH Eh
q
o cu cu
rt
o
fl
0
rH 1
JJ
X
II i
<N <N ft sj
<U S CQ XJ o X ^ u rH c ffl -rt <u tH tH CQ fl O 0 X fl fl C
.q q u - rH X X X <H 3 *N CQ q d rt X X Ol 0 3
e o fQ JJ -H X 0 0] o 0 1 -ri C sj o
q H 6 *JH CQ JJ . o 0 QJ CU S ^ "H B i - CO CN - II X X b
o x JJ iD Pi HH <JH sj SJ TJ fl O X *- fi a S rHJJ M O <TJ rH 01 rt OJ H- II q 3 o Eh Eh rt O co x at X + P. II II CN II
.q h in In CQ X rH + 0 11 I 0 ftfl -rt Jh Jh to + 6 cbi CQ Q CU X) 4> 0 _J CQ b B 4j co Q, Qj fl ' 0 0 II JJ 0 rH OH X to
"r|
rH
jj
H **H
rt t-\
if rHX Jjc
II C M
P -H
rH O
0 X ll
fl
o
-H
0 o 0
Cj Sj
rH
X 3 Q, D, JJOJ CO -rt id irt I H rt3 3
t-H fl jj
JJ rH 3 X
C fl o
3 x u
X II
fl
o
-rl
o o 3 X U X JJ O O X SJ
tj tj
rH
O
tj
O
rt
rt B TJ TJ 0t-i ou oVh rdrt fi
JU i *J n ft 0a sj 34J JjJ i JJ u 0,ft 01SJ 3
o 0 ti o 0 -H a ti O ti o id -H 0
<D Tj -rl Hi * rt oj J TJ rt 4H * Vt
<0 a U
& 3 .
-srl
oj H
a S g oi i
0
a
O 3 TJ
+
X
H o J i
3i
TJ
-H
O
>
0tx
0
Pi
0 TJ
41 0
U 44
o a
rl fl
Tl Tl
'1
- U 0
O JJ
rt StB
to h rt
SI 01 <h a
st si
0 fl fl Vh
O 0 rH
CJ fl 3
o +
3*
0 0 Ri
*
rt rt
ITJ id -* *>-
ffl id Jl * ffl
si 0 rJ 2
rd rt
TJ 1
*
% U U tl
0 U U H
II sj C II CU CU <
fd 0 II TJ TJ &*
rt TJ 0, jj JJ |
si 0 CU 10 to EH
O, II SJ rt rt
o rt ~ *,
o-i rt II 4H 4-1 4-t Cl]
II st si | JJ JJ
S| 0 uflfi-JJ rH P -H rt JJ
a O 0, -ri P| rl rl -rt* X SJ fl a a x
tl 0 1 -rl 4H 4H 0
n si * SJ
VI fl 3
4J fl 0 si a
fl JJ rH fl a <H
-H CJ OH T| -rt -rl
01 01
4J 4J
fl fl
-H -rt
O O -
TJ TJ
_
s s
TJ TJ *?
0 td TJ
0 01 0
fi, 44 fflI I rt,
id nl I
SI IJ 4
td id si
TJ TJ ffl
I
3
&
SJ a 3
3 - ft fl
ft e JsJ 01 -rt
fl II W SJ
-rl - O -H fl
Vh O
ii fl CJ
U
si
ii
44
01 Cl
01
st 0
IrH
SJ -ri
3 oh
&"'
C si
-rl 3
ft
- C
CJ "rt
4= . .
- u
sj tn
U 0
0 4= U
fi fl Pi
14 j-
o n *
Cl CO
fl 3
c H rt * -
fl fl fl -
Tl -- > "
0 * 4 = ftl
01 OJ
rt - - - o
1 rt rt rt .J
rd rt rt rt h
SJ ffl ffl 0 rt
fl TJ TJ TJ ft,
Tl SI SJ SJ |
w to m EH
II H
rt sh ISH ft]
SJ si sj si
C c c c
3 rt -rt -H SJ
fl rt rt Vh -rt
(1 a a a x
SI VIH vu 0
3
~s1
IrH
-~ ~ SI -rt
3 VM
~ ~ 3 <C sj
0
rH
o
ft
-rH - C
to .. b -H
l~ J 0
si rd 3
1 - 0. fl tj HH
U, fl a 01 -rt si C
fl -- a in sj 0 td
-rt * rt C 01 CJ
rt O C 01
3 HHII fl CJ
O 11
SJ 4H
01 CJ -rl w
0 0
O O -rl 0
C rt
3 -rl
O fl
u S
>
H
0
a
ftl aj ftl
c-i 01 u3 ic to a
Q Eh t. cj
P a i-1 ir!\ fe rf (IS1
Eh
s
,1
Eh
JJ
a,
X A fl
* a a
i jj jj
I O Tl -
I Tl rt fl
I TJ TJ 41
SI 41 Hd
I 0 01 g
I 0 I TJ TJ TJ
I TJ I 3 3 3
I 3 I rt rt rt
I -H t O CJ CJ
I CJ I fl fl fl
* q I -H -H tI
X H I 41= 44= 4s=
I b
I 0
I 01
I CQ I
I 0 I
I CJ I
I O I
I fi I
I ft I
I ffl I
Hi fi I
x a, i
q i a m
O 1 ' -rl Bl JJ
rt 1
SJ 1 Oft OH ffl
0 1 &, tj 0 q
rt i 2 fl -- O O
ffl 1 H 0 B o ft
M 1 1 3 X
b I Eh SI fl SI 01
0 I O fl fl
VJ I a on o u
I tn rt fl rt fl
1 1 04 -rl OH -rl
rt i m
3 1
SI 1 si
b i CJ
3 1
rt i s
SI 1 Jj
CO 1 0 X ft,
id .
ffl
TJ '
rrj 3
2 td
rH TJ
-."
0
i O JJ
I tu (0
i T3
I I-H *
'eh'o
CJ ft.
a z
CO IH
H J
a <m
0
hhH
O O 0
? TJ TJ
n
rt
ft
tI fi
v a
rt
JP O
rt
.. p.
0
01
*
a *
D *
TJ fl fl
r-- r*
0
M
rd rt rt
SJ rt rt
ffl
TJ TJ TJ
SJ SI
O CQ 0]
til g _ -~-
rH H St HH
-H 1 SI SJ
St ^t c c
1 CJ II rt -rt
sj la rt rt
3 tn ft ft
ft M St ISH
c 01
-rl rt
* V m
CJ
3 2 -~
H SI VH
VH fl
rt .<
-
O
00
3 C 3
C H rt
rr,
fi STJ ^ i>
I ffl 0
I TJ TJ
I SJ SJ
a
a
rt3
rt h
ffl tt
TJ ft,
si
OH OH HH H
SJ SJ SJ
fl fl (J
3 -rt -H
0 rt rt
u p, a
VH -rl
a, x
OH 0
a ft
r* Tl
C
SH 01
tN
-ri
JP id
0) ..
* rt
SH rd B
Cl SJ fl
t| -rl SH CO fl
rt fl - m -h
o e
l* tn rt 3 - jj.
0 fl so ffl ffl si
4J -rt 3 ffl J> 0
fl O 6 rt, Jh, g
ti a io i a
TJ ffl SI ffl rt
C C C SJ td JJ 01
01 > - (. TJ H TJ H
rH -rl TJ -H Jl X JJ B,
H a ro o o
MJ 0 rt
I a rt o c a sj
si jj i fl o a ci
I Eh rd E, -h ? 01
U A si a sj ri m a
CJ ^r ffl r^ CJ -^ -rt ^*
rt r TJ = C fl s=
01 SSI U |=J OH
SJ sJ sJ U SJ
tl (J c c c c
rrt -H -rt -rt -ri -rt
rt Vi Vh rt rt
St ft 0,0,0, ft
q
3
Oh
B 0
fi 5
I oi
U SJ
q q
fi b '
ft a,
fl
-rt HH
01
SJ 0
TJ
p qft, 0
!=J
H 0
I 41Eh'
q
Cj 0
ftl -h
co cj
H 0
m ish
rt -rt -v
0 0 SI fl
fl o b
sj b q o
3 -rt
o ffl *sh TJ
sj fl
ffl q
0
oi
q o 0 q -h
o si 5, b
ft q -h si
c/j
J
3
0 O 01
O X SH
b 0) ISH in
A
1
A 0
rH O
HH
SH
id ffl b 01
SJ SJ II A tl
0 ffl II 1
TJ TJ rd
. SJ
A
rH US ffl
B -rt TJ SJ
A n
TJ Tl
X 01 .
< SJ
rt X c x B
0
IS, C HH <H
= 0 rH
SJ
O rH
ft
rH
+ C X X stf *?
e 0 =
q
0 =
A
iu ftHH ffl VM OH
SJ X SJ SJ SJ SJ
C 0 c ffl C C
ri /\ rl TJ -rl -rl
rt i rt rt Vh
U rd 0, ft VJ,
bi
q
SI o -~ ~-
01
fl
rt TJ 01
ft o SJ
ftfl q
-rt
& Cl
q S ft
ro
q rt
to o
01 -rt
SJ SJ SI
b 3 CJ
01 ft ffl 0
01 B to SJ
-rt O -rt
fl CJ a, o
VH
Cl
O
O
tn
Pi
rs
fl
fl
SJ
<U rt
X o
OH
fl
3 0Tl
g
si
1
91
3 rt
a
rt
fl
TJ Vh
rt 0
0 fl
41 0
a
Eh
1
bi
o
jj
fl
i,
In
o --
U OJ
P, Bl
m
* CJ
slfi
C 3
-rt 41
rt 0
ft fi
X
HH
-rt SH qsh ffl Cl
TJ
'CJ sj
rt
rt
O 3
3
.2 X .S
TJ
q
TJ n
y ft a
0 fl
fl t?
fl
rt 01
rt 0 fl
OJ ft SJ X
i VI, o
0 rt
rt SJ U." 3 o
-H
H 0
01 s- o
J> rt 0
rt 0 q
!
fl -
Cn JJ
-H 4H
)H 0
c
-rt
o -
p. -
fl
X
II fl
X
4H
*
-ri -
4H Ol -^
II dP
+
O -H
e
II CO
II
+
e
CO
fH r-H rH
rt rt rt rt
X
rt
S< TJ
O rt
rt Cl
ft 9
01 u,
ffl
01 fi
fl h
X S
to fl
0 SI
SJ
3 bi
ft a q
td B "rt
rt o to
SJ CJ 3
ftl
to
- o
fa a,
Px fe; a,
q
TJ -rt cj rH
q 0 0 0
oi rt rt
bi sj bi
SJ 01 fl ffl
si si bl sj
to q -rt q
J -rt OJ -rt
r, Hh
q sh
SI -,
CJ Id
ffl rt
to bi
ffl
X m
^- 3
st rt
i 0 _
o, si fi
J/i q
JJ -rt -H
H HH ffl
0 TJ
TJ -rt
O
SJ
q tj
-rt m
rt *rt
O 0
TJ
_, ffl r, -H
* SJ 0 3 0 0
cm q q fi N
rt -H ffl 0 -rt bl ffl
H rH SJ ffl ft
"
3 q si 0
fi o q fi
O "rt Eh
01
. O ffl 01
q si sj fl
O -rt SJ
co sj q
bl IU t, Q, O -rt TJ
q fl ffl B C "rt q
rt SJ ft -r, fflffl
B AT CD rt TJ
B rt fi o 0
0 O Eh rt 0 -H
fi vv, o rt fl 3
bi 0 HH 0 SI rt
O 0 fl fl
rt 3 sj to si rt 0
O, rt rt 0 o *
fd TJ 0 fl vh q
B > q 5 o
q 0 fi ffl ffl
o ffl 0 tj 0 ft
-rt si ffl si q 3 B
SI 0 rt q 0 rt -rt
0 B 3 -rt nj Cfl
O "r| fi fl - >
rl K 3 ffl fl
-t O CQ ffl rt ffl SJ
ft rt - 3 SI O
ft ft q 'rt rt ffl fl
< 3 o o g
0 01 rt --H J*,
b ft rt 0 X fl
rt 0 B 0 TJ O
sh fl -rt fl -H rt TJ
rt SJ tij o D, 0
SJ 3 N ft SJ
q ffl bi q ffl 0 3
ffl TJ q a ft
rt q -rt 0 0 0 B
CJ ;rt fl fi fl O
CO ft, 3 Eh tl Eh O
cq nj .. ca
jojis
* H s 3 a
x Sj rt o Sj
g
a
g
S
a,
I 0 I TJ TJ TJ TJ
I TJ I 3 3 3 3
rt rt rt rt
O b O b
fl fl fl R
I -rt -rt rt -rt
I -1
I tj
q
X H I 44= 44= 44= 44=
fi
ft
Of
rt
x a.
o, ftl
ftl I
I srt
X ft, I
ii
O 0
TJ TJ
01 01
si si
fl fl
-rt -rl
O O
Q, 0,
TJ TJ
a s
&
-rt rt
0 0
SJ SJ
fl fl
bi tn
-H -rt
rt rt
0
rH rt
ii
O 0
TJ TJ
si SJ
SI IM -
0 0 -,
rH rH
X
a a
rH m a
^5
o o 3
Tl TJ O
TJ
an
if oj
H Vh
01 si CO
rH
TJ TJ fl
-rl -rt 3
0 0 0
> > TJ
2 -i
.1
41 o ...
-. rt u 0
01 O 0 (0 j3 to
rH <u fl rt E r-i fl
ffl ** (ti p
> c > fl >
rt O fl rl u
0 T, ^ II 0 0 0 II
sj 41 a JJ fl JJ
C - g~~ fl fl ti nrt SJ si -ri --H
1 rH -H * 1 rl |
SJ 3 X >! n u CO 0 JJ U
CQ O as to l8 JJ Ol ffl
- 01 fi fl SJ fl 0 n
to rt a n u fl
. flrH | a ii si
fl E0 JJ a cu 3 J P
> ~ 01 -. .* # - tf
rt - rt
ffl SJ 0 rt
SJ rH fl id 4H OH 4H
G 3 sj fl a JJ OH SI JJ 4H
-rl 0 O CJ rH C C fl fl fl
1 01 fl SI -H
rt oi fl
rt ffl 'rt -rt
to rt lH u rt Vh .c.
_
1 Cn * Ul oi ft U ro v
a 0 st
0, rH si 0
ffl 3
C rt
a o rt fl
3 TJ ft S
^ -^ <u
3 p
0 10
0 0
u u c
Ul XJ 44
-!. -H *
w w o
rt rt 3
0 fO
jS
0 0 si
W JJ rt
3
0J
a, a,
ftj u 01
rrt'fH1
c
X X o
a a n
rH rH
OJ OJ 1
Oh a (3
ft] ft] --*
1 1 fl
Eh Eh
ft, ft.
ft] 61
J J
4H
JJ
a a fl
g 0 rt
-rl VH H
01 JJ a
o0
tn
Pi

w0
0
a
Pi
TJ
u
x
H
u
1
rt
0
a
rt
JC
3
O
SJ
0
rt
rt
0
fl
JJ
"
C
0
rH
0
0
rt
0
fl
Hr"
a
q
rt
rt
ft
-rt
SJ
rt
3
B
4h
O
o
rt
0
fl
SJ
r-i
O
O
rt
fi
O
u
g
fl
SJ
rt
H
a
0
rt
0
rt
rl
fl
SJ
TJ
0
fl
. O
SJ
X -
3
o
rt
to
SJ
0 ~
fl
1
SJ
~ - ~ -
CQ
01
-rt
Cl
rt
0
&
01 X
rt
- o
SI - "r
*i = O -SJ * *J JU ~
rt tn
H i. B q J ~ c J fl Id SJ * ~ .rt X C G J->O rl -- 3 J ^ B H^ * rt rt tiu
rt
0 X
*
0 fl
HH -"
01
rt _ fll ti -** o
q 0
CQ sj
- X - G
S3 -"
^- ^- ^
IH HH
* -- * --* * a ffl ffl **-* to 0 O HH
a * 0 II c * II fl SJ O C fl * 0 0 0 00 * q II -** * II .*- * TJ -rt U - -*- * rt H M 03
o
0
0 JJ
rt * O &*
_
&* 0
fl rH rH X vh
0 3 TJ *
O 0
b
rt
rt rt N
O OH
u H 0 m tj rt 0 TJ O TJ SJ O O "r, 0 rt rt TJ rt * * 0
T-t 0 q ffl 41 0 41 0 CJ cj rt si 0 Cj HI 0
-h e ft *j
SJ t-l r-i *
"rt ^s fl O SJ O si 0 H CN SJ ffl O O rtQJ g SJ s 0 fl 0 fl fl Ii 0 TJ O rt 0 B u u oU M 44 fl rt X rl fi c iH Vh fl SJ b q -ri - JU fl rt CN O
3 3
-
u
0
3
0 0
fl *J
JJ ftl
OJ
rt
He
'
1
"""
"1 rto 3 3
0
SJ
CQ 0
U rt rt
St. i e
fl 0
0
0
rt
CO T3 S1 H oi rH <H 0 fN <H 0 rt O O fi bi fl O B 3
C jj q ft Eh SJ rH O Eh CN o &< Vh rt Jrt 0 fl 4) Eh SJ rt rt O
> tti <0 0 3
_
td
iH
> co H CN rt to fl
1301rt * flJJ 0 a oi q-rt >tn AH > SB ll 0 0 ~ " 41 S 0flUS bi 41 Vh ffl E H (0 rt rt Sh (0 rt :i rt fl B TJ - O rtj? C OS
ffl tj a o
If i? Vh
SJ
* CN 0 (0 ffl tn rt rt 0 h a 0 h a O SI o u -
X rH CO 12 rt 0 0 0 b * c ffl 0 o o oU -rH =J CQ rt SJ fl rt s fl Vh
t? r>P
SH fl SJ rt rt o
fl <N Vj tQ 0 0, fl CJ Pi C 0 Ph TJ O sj TJ CQ O 0, 0 .H rt rt
fl 0 JJ 5 3 g TJ 0 3 0 3 q
dP <*
3 0 11ao rt a 0 0 * a q ft tn V -It P. a a * ffl 0 SJ o to TJ TJ# s* fl * fi-rt a; 0 Jh hi SJ ffl O .je * o # hh e s q 3 rt b
41 * jg si C 4H c 0 Hi 44 fl o 59 1 1 a o u * * *
.
O * e *- rr- 0 0 ^" z ^" z 4 IS r-l j^ jj? * Jn JU -P *
01 rH ro rH fl bi II rH II t S= c rH o rt CN o O rt si rH rt G G JJ
rt rt *a jj 1 SJ rd 1 rt 0 0 u CJ o q fl 1 rt -ri -ri ti
id rH X q p 11 01 rH CN rt rt rt 1 O -rt ffl
' rt
0 -H rt fti o St SH G ft 01 0 4H 44 iSt G 0 4H OH OH e 0 -rt -H & rt Urt ISH HH SH s b41 rt Sh o SJ SJ 3 0 JJ SJ SJ i-H JJ si si fl HH M4 0 ft rH si si si si rt 1! II
fl -H jj u M -u CJ C fl 3 B -H fl c c P -rH fl fl C p SI II II JJ _ o C C fl fl 3 q II
-rl 4H IQ cj q Ol -H -rl 41 q 4H -H ri -ri <U 4H -H -rl -rl HP sj q CJ -rl -H -rH -H sJ oi <-H (N
* fl 0 -rt U rt rt 0 ffl 0 Jh rt rt O .M rt rt 0 SJ 44 44 5 rH 0 r-l rt rt rt rt 0 1 X X n* 0 fl H 0 a a rt ftfl ft a a n ft a a u 0 fl c o o rt fl a a a a Vh -rH rt 0fl W U o, o bi 0 ea u CJ H SJ TJ rl k 3
tI J jJ *J V CJ CQ CO JJ JJ CQ
l\ Mbi fl-ri flri \ HHri ,-, X HHrt --, HHti ,-,
*
X
(0 w
44 44
fl
0
fl
0
He
X
VH
rt -.
*
X ias
ffl >,
rt -i
o its
rt CJ
q -H
0 B
& fi rt
0 bl-rt
o S
sj rt
S t
o
rt
ft
Eh TJ SJ si
0 to ffl q
ffl fl rt 6 OJ
fl -rt fl
IQ O "SH SJ SJ
O
ffl q TJ
q
rt 1% 0 si to 3
fi 01 rt O q
-rt rt Cl SJ Cl
q Cl SJ rt tl SI SJ
01 -rt 0 SJ q tl
r rt K rt CQ 3
SJ rt n 01 01 'U
bi ffl o Cl q rt tl o
K a tl o 0 rt fi
b SJ u rt ft
rt rt
O fl
0
01 JJ 0 ffl
fl ijh -rt rt
si fl -rt
si sj .
SJ 3 E '
b 01 ft 0
3 fl SJ fl
TJ Eh 3 SJ
O O
rt "rt
ft rt O
0 rt
ffl ffl
fl rt & Cl 0 O
3 B
6 TJ ffl
0 O TJ fl
fi fi q sj
bi ft o ,
o b HH
rt 01 0 H
ftfl CQ
0 ffl
TJ JJ TJ fl 01
0 En q SJ Si
fi 0,0
o in q
u - TJ O -rt
tQ TJ 0 B 0
uj rn 0 -H tO Vl SJ
0 SJ -H a ffl 0
- fti fl ffl ft o u q
tn J O -rt rt -rt
CQ b rt O u rt B
rtsjrtrtrt Olrt fi
J Q -rt rt 3 fl -rt fflCjSjSflB-uSsi
ffl rt
S -rt
TJ
tn q
q ffl
rt
q ffl
H M
ffl b
SJ -rt
q fi
o sj
b ffl
B
1 si *
i q i
rt a A 1 0 -rt 1
X A fl 10*1
n * fl ! ^sj-i0 1 i ao si i q 1 Q -rl
6" i o q i
1 -rt 1 TJ TJ 1 SI -rt i
1 SJ 1 SJ SI
1 Cl i a a 1 jV '
OJ EJ i ffl 1 V V i a,
^- i
EJ rt 1 co i
rt Q i i a 0 i q rt i
Q i 0 1 TJ TJ
Eh 1 TJ i 3 3 I -rt 6
&s 1 31 rt 1 rH rH1 o u i b TJ i
a. Eh t b 1 fi fl i q -rt i
te; i X * q * 3 O 1
HO* \ H 1 44= 44= X ft. > 1
0 q
ffl
TJ CO
q 5
O O
b rt
01
CQ 0
fl
0 SJ
fl
SJ rt
O
o Vh
SJ
CQ
rt fi
0 0
si bl
0 q 0
rt si TJ
b o q ffl
rt 0, -rt -rt
rt rt
SJ - TJ ft
0 X q -rt
ti rt 0 SI
fi
.
-<
O SJ X 3
S
SJ B fi
rt si 0 A
O ?! B
fi o
SJ -rt rt SI
CJ rt 0
3 q
TJ 01 -rt 0
b fl vvi -rt
rt sj o
ft 0 -rt
O fl rt
0 SJ SI SI
JJ 0
SJ rt q B
0 fi
01 SJ 3 o
SJ qua
0 -, ffl si
ffl o fi
rt ft 0
XV*
:3
k cjj
S!-g:J
H H o ai 0
IN
HH
0
tN
tn
0
Pi
-~ -> v
TJ
0
Vh
ft
!
rt
a
o
v,
a.
O
X
ri
u
% E
-rl 3
Vh sj
ft 0
SH -^ -rt
- - 1
v e -^
TJ
0
0
rt
TJ
q
5-j fl r~
r- -rt
F c +
+ + <
ri 0
X rt Sj
0 H= a
rt ^
X
-rt fl
0 fl O Sh!
n 0 O JJ
0 rt
b
a
a A g
-rt -rt K
fi CJ s * u
SI -rt o
-rt 0 rt Jh rH
Sh B 4J rt fcs
jj
ffl t fa Tl it
JJ V in u
SJ <#
fl ri s :<
SJ Eh o
X 3 (J ' Sh
O rr o 4H rt
Sh JJ h
SJ II c
r
q
iu ri Sj HH
rt si ft rt
u ft C
rl
rt * rt 0
B X a HJ
c
-h
rt
a
Appendix C
Benchmark Input Sets
O CN
\o en
o r- cn \o
o o
CD < i o o
o o O <> o o
>,fi T-i >irt rH >trt rH
o o o o o o o
OCN niNCAO CO
o ** -st cn r- oo oi
o r- r~i <# in ^f vo
cn o cn vo ** r-i in
o o o o o o o
o o o o o o o
OOOOOOOfTi
Ofoiooioiincoo
o tn rt -^f in
O VO <J\ CN 00
o m rx cn rt
o o o o o
o o o o o
o o o o o o
o o o oo o cn
>,r~oooortrHrtrt >iinorHCNnin-^ fl
Appendix D
Example Simulator Output File
0>
fl
-ri
0 0
TJ O
rt 0
01 Vh
A
Vh
Vh
si
C
cn m
0
0
0 Ul
rt O Jh
rt XJ 0
XJ
* 01
O 0
fl XJ
0
0 tfc
0
TJ
u
ri IH
-Q 0
H fl0
0 TJ
> 0 rt
JJ
0 "lev, m C 44=-H
C
-~ -rt
rt-
0, FH
~s
41
Vh
3 01
si Vh
CJ 3
2tJ
CO C
JJ
ft 0]
3
^ ft
O 3
O ^
rt O
O
r-i ,H
0
> fl
0 0
rt >
0
XJ rt
0
rl JJ
ri Ui
HJ vh
rt
HH HH
O
HH
rti O
JJ
TJ 0
-ri N
3 rt
CO
fl 0 0 rt > 0 Sh 0 ,. XJ
<D ^ -0 3 Ul 0 0 (0 3
& /V
A
Gi
01 a 0 tj
U fli rt >*.
3 OH 3 0
- -H
O
TJ
JJ
to
0 0 >i
Pi 1 rt 0w flfl o CCI 0 rt rt ShTJ -H 0 0-H ffj > -rt 4Jrt 03 TJ 0 ja" 1r-i XJ
Vh
rt 01
JJ 01
$z a
A 0 fl -~ rH >> ta r-i sa rt (0 0 fl
O CO
V
1
u
V A
M .Q H lt> a
01 itj TJ Ct] -H
rt HH
HH -
c
SH
U 0 rt
0 > O
Vh ^r- Dt rt rt *+ 01 ' .u tn cn 1 rH A
si
TJ
rt
3
01 13
s
sj J3
n Vh
O O
0 si
CJ O
-rt -H
0 13
0) 41
Vh Vh
a a
0 0
s s
Vj Vh
0 0
r-i rt
a a
ri -H
JJ XJ
rH ri
11
0 TJ fl) Ol-rlJ]
01 rt CJ -H Vh xj D - - Cn 0 .. X! 0 rt fl JJ ^
sj tn
(H
- HH
C
>, 10
CJ >
0 rH j g
-ri 0 3 g
Vh 3
CJ -Q
XJ CJ
0 O
V
JJ
fl
O 0 0 .>,
>, Si rH CO
X
0
rH SJ 0 0
u
US
a ft w XJ JJ
0
rd 41
fl w
U CO
- rrl
*
TJ
u 0
JJ H fi Vh
TJ
fl
J3
A
rt V rt tn
b
h e c a
4J BtI-H
rt 4J O O
rt
si jq
X 'H
0 0
W t
rt JJ
m 0 0
rt JJ
IH 0
0 C 0
3 111 n
0 O 3 Oi
O
jj
CJ
-rt
S
01 r-H
1
#
1
#
0 u
XJ 0
0 Ol
r-i QJ
XJ
w fl
0 rt
g<U
CO
e 0
0
xj 3
"3 fiTJ
-**. rt
JJ 0
0 XJ
C O
rt XJ
mu p p UJ sj
si rrj
sit
0 O
C 0
rt 1
0 TJ
Oi Vh
0 0
X
0 CJ
0
xj xi
0
XJ fl
01 -rt
0 0
rt XJ
rt 0
<JH Vh
0 0
rl ft
ft 0
0
1
u
0}
0
jC
CJ
0
CJ
0
0
0
Vh
XJ
0 U
1 'XI
0 .
U V>
3 m
- CN
O
- 0
0 N
XJ rt
0 CO
0 XJ
0 0
3 MH
rt rH
U JJ
O CO
01 HH
I
0 0
- m
vo 3
m
tji
O
rH
41
A
u
id
0
01
CJ
rd
Vh
si
m
si
rd
Vh
41
C
ai
01
0
3
0
fi
rA
0
HH
CO
0
TJ
0
JJ
JJ
0
HH
a
an
an
c
a
a
0
0
0 c
rt 0 c
Vt. O ir
0 .-
O CN
# O
cc
r-
+
C
-rt
1
CS.
" 0
Vh
-rt ~
TJ
0 0
Vh
ft Vh
0
r-l JJ
0 0
> "H
0 Oi
rt 0
1 Vh
CN
JJ
rl HH
O -ri
HH JH,
01
Ol
0 HH
rt O
1 ^_
X w
0 rt -
0 Vj
Cn 0
>
Vh 0
0 rH
^
_
JJ TJ
0 c
CN
Vh
O Vj
O
~ HH
to
Sh co
0 CO
u cy
fl Vh
3 TJ
O TJ
CJ 0
HH TJ
O fl
0
H*
-&
0
0 s
+
; 5
44
JH CO
" ^ 41= H= * Hfc 4*= n =* * *
(NO X1
.. .. p 4fc 4S =H=
*
44- * 4fc * # CU
A
TJ
XJ XJ
ft
XJ 0 r-i
0 0 TJ O O Vj
U JJ
Vj
fl X > 0
O 0 XJ
rt 0
0 JJ
r
< CN
vo vo O VO xt OO VO & A 0 TJ
0 Ot 5
n a t: A Oi cn
0
rt ^f 41 rt CN eo -a"
Vh
0
fl
0
O
0
.fl 3 0 -
XJ rH -rt
Sh Sh j-
XJ JJ ^3 -rt - rt 0]XJ 3 "rl > todl -rt CN II
I
cn cn n rt rt rt 01 0 ri -rt rH : CN cn rt cn CN V 0 Oi 0 HH Ol dpjS w a. 0 JJ OlrH Si O A O Ifrt rt O W G <U rH p, O rH 3 rt 0 Sh fl 0 > -ri . r< O
>< O
Vh - Ul 0,-i Tf 3 0
fl HH
fl
: 3 g s H US UH jj + 0 0 Ul O 0 oSj 3 S Vh Vj TJ Vh - s - s
1 c<i fl 4 En 44 1 * 000 tn &, pa m D &4 Ol rt C O 3 e S sV " 0 TJfi Vh V 4fc 0 si Oi ft - jj rt ~ HH XJ (N X < <TJ Oi XJ fl 01 XJ X
fd fl 0
000 0 0 HH S HH CN S CN S
fl XI
0 - I a C& c - a 0 c. O O fl C -rl fl -CN VO 0 fi 01 0 TJ - Vh hh 0 jj 0 0 O -ri Si -rt 0 to
fi rH Vh Vh 0 TJ -rt fi fl Jh in V Vh Vh CJ 0 1 Vj S S 3 SXJ JJ
-rt TJ
- 3 XI rd U 0 n 30 XJ XJ JJ XJ JJ .. (fl UOO
ti - O 0 0 CJ 0 - & O ft ft ft ft ft VH 01 0 HH 0 fl JJ
O 0 .fl 41 A Xi Vj 0 Si XJ Vh 1 1 1 1 ( O fl -rt O ri ^. CJ rH t-H S S
JJ 0 01 JJ XJ JJ Vh JJ fl 0 rH xJ O Vh Vh rt rt
O TJ N C Vj XJ O 0 rt cj rt jj xi JJ 1 TJ
O CO rt -H TJ id 0 HH 10 fi XJ 0 ri U fl XJ fl 0 0
w fl A 3, 0, rt n jj O -rl 0 .rt 3 cfl TJ 0 0 TJ 0 0 VhXJ CO O sj 1 1 O CO fl r-i & Vh fl to 0 Vh rt ^ ftVh jj 0 -rt OJ Tl jj jj 01 0 .fl 01 V Ui fl < Vh -rt -rt 0 Vh 3 = 3
U
XI JJ O 3 rH JJ ff 0 XJ u H 0 0 rH fi 00 t\)
O 0 TJ O O 0 HH r-i ft o> 0
JJ fl XI 3 rt Qirt 3
a e g
JJ 0 Vh ft id 3 0,0, A 0 O rd 4fc G -rl JJ TJ ft ri r-l tn Oi tn Oi3 JJ Tj rt r-i u rt 0 ft 0 1 O Vh rd rti U N CO Vh 0 JJ - TJ 0 0 1 Si HH ft *: < *: <5 0 -rt JJ JJ 0 0 e 0 ft a XJ fi -fl XJ 0 SJ A 0, a ft ft bl v xi H to SJ CSi 3 OJ QJ c si w cj a rZ, s :*. x e CJ) O Cu Airt 3 rt TJ rt -ri h g vu y m 0 O 0 ft 01 0
O 3 rfl
.. 4 9-9-9-9 -rlfj
Ui XJ 0 0 01
a
rt
WJ Xi U
JJ 0
0 X
Oi Oi O xJ 3
fl a 0
00000
X fl 0
0 0
Sh
id
tN ii Xi rQ Xi 0 01 01 0 Ui X> ft Ol > si O- " JJ XJ XJ JJ
w
rt rt rt 0 0 0 0 0 0 1 3 rt CJ CJ O 0 1 rd u u CJ O 0 ci a a a H Oh PQ 0 Vh Vh 10 jj Xi m
m & n JJ JJ JJ rl in u u u rt .0 fl jj JJ u Vh SJ 4J JJ XJ -rt u a a J3 Xt
H
<
XJ 1 1 1 1 1 1 1 1 1 1 rt HX 1 O 1 l n 4S, V 1 1 l 1 Vj 1 1 I
rH 0 O ^ ~ C
V a Oi O CN A JJ 0 0 0
0 C 0 rH fl C rt
0 c TJ N 3 0 O 0
0) Sh 0 O -ri 0 fl fl >
I > V ri fi Ul HH -H
<n
H SJ -rt 1 ^ 0 CN
rH gHSJ A 3 .Q JJ O TJ rH
o
>i
rH
a
01
VU
O
nj
U
Sh
Vh
CO 0
CJ
OJ
X
XJ
CJ
Ul
xi
0
JJ
to <-.
0
xi
r-, (U
0 c
TJ
rt ~
TJ 0
A XJ
fl 0 cn OJ JJ TJ OJ 0 V
a 1 jj c 0 rH CO Oi oi toO 0 X, SJ Vh jJ HH 0 0 fl TJ 0 -H 0 fl
3 XJ u C 0 0 CO O Vh A n ft G rt HH rt -ri
0 CO to 01 A -H 4J sj 0 0 3 Q A A CJ fl u
ffl CN m Ot e 01 1 -rt CO JJ ft M XJ rt C A Oi Ol >% 0 >, JJ
3 rt -H fl -H iS HH 3 Ui 01 -rt ~ 0 ^ O Ol -ri n CJ U U -riri SJ Oi O JJ > C CO A Vh ri ri t-| ~ HH V fl
r-l "J H d)r- >, c c O C TJ 0 -H 0 CN 0 fl JJ ~ HH CO fl CO fl fl C 1
0 0 > u VH rH S4 Li 01 rt JJ C >t xj a; r-i NO -rl 0J -~ 3 0 fl fJJ 0 0 O rt -rt CN
-rt JJ 3 TJ rt 0 O 01 V SI E w -H O id 0 V rt fl rt 01 CJ r-i O rt O rt CJ - cn
u HH O Vh jj Vh 44 SJ _ JJ 3 -rt c rt jj 0 0 U rt 0 CJ O CJ V U V
c u HH O 0 XJ id e rH 3 O JJ OJ C 0 01 A 1 Sh -xi >, O 41 X >i V >,-" >i~ :>, 0 > O
c TJ 0 r-i 1 rt O -rl 5 rt ft 01 -rt xJ u c ~ 0 0 O A 0 O > 3 0 CJ 0 -* 0 CJ O U JJ
o 0 fi E-< O HH 3 - 0 rrj Vt V1H JJ X 0 0 0 0 A N rt HH ^TJ ^ U 111 \ N - c -H fl
(N > E fa HH O U Vh r-i 01 SH 3 >t 01 Vj C rH 01 x 0 -rt XI xj ft tn ^ cn Oi ui -rt - fl c 0 0 CO
Sh O Ph 1 0 0 -rt 0 o i O O JJ O HH OJ c 0 N CO O rt 3 sj tn -h C JJ IO -rt 0 rt 0 x> - XJ 01 0
0 U \ cn JJ ft JJ HH r-l 01 g a sj -rt O HH V N fl H jj ri rH XJ ~ > cn si O CO aj m . - 0 Ol 0 rt C0
Vh 01 1 fl 3 01 0 ri ai -h O <3 si 0 -rt O JJ jj 01 rt I -ri Ul a 01 u Vh fl N -ri -rt r-l ri r-i rH 01d 0 fl 0 O rt 0 HH tn rl SJ ja - CO -rt CJ 0 V 0 0 xj Vh hc 3 H B H -rt >, >1 HH 0 004 o O ri TJ 3 01 ss 3 Vh -h in JJ i fl 0 JJ N 0 O V-H Tj O - CJ - JJ fl JJ U VHfl cj u TJ fl E fi 0 n Vh sj 3 a Oi Vh TJ 0 0 O t-i 0 -rt rt JJ n cc - C Oi C Ol-H O -rt TJ
0 0 ft 0 0 rt O 0 O rd U SI O p, si 0 3 ;d Xi 01 fi (A CJ CJ s - 3 S . Ol 0 rt 0 rt Xi u .a e tj
> JJ f ) rH 0 rt 0 Vh O O) XJ fl 01 3 Vh in ft -H 0 TJ HH 0 0 -rt V O rt ^ S 1 O ^H O rt XJ HH JJ HH 0 0
O si . . 0
0 0 0
HH XJ 0 Oi rd -H X 0 P, Oi C a 3 0 O a JJ HH
~ x ta tj ra ^ c tj m JJ Ul HH 0 fl 0 fl 0 0 0 JJ
a tn e JJ Oi 3
ai n
0) C rt rt - V fl O CO 0 m -n rt J C r-l O rt O si X3 M JJ
-H 0 JJ JJ U fl fl 0 0 Xi Vh a -h M 0 ft TJ jj 0 Oi 0 0 Vh 41 W JJ fl O U U CJ U U >, Ul
HH P* TJ 0 0 0 fl O O Ol fl 0 0 C 01 01 O 01 rt SH 0 O .fl t c CJ rt xJ V ft d 01 J3 fl TJ 3 O XJ JJ 0 0 0 0C
o 0 0 TJ >1 0 ri -rt 0 O TJ 01 SJ O SI SJ 3 O 0 O CO 0 Sh Ol HH 0} 0 3 4J O fi 0 -rl Q) -rt 0 CJ U U rt
rt CJ D] E JJ XJ CO rt 0 Ol id rd rd fj to Vh JJ -rH 1 O -H Vj S A ? 0 cn -rt -H fi 0 3 0 si si x: x: fl
o rt 0 (J) &>, 0
0 Vh *m
0 0 CO jj fi 0 0 H rH rt 41 Vh JJ XJ 0 fi JJ JJ HH O 0 01 ta > 41 tn 3 XJ O jj 0 .fl 0 0 c C fl O XJ
<
VH
HH in Vh Vj 0 0 JJ n c u 3 2 -fl 01 0 0 HH fl U fl JJ U CO XJ -rt O -H CJ CJ 0 3 O 0 0& 0 J3 CJ
000 O O n
cn cj cn 3 3 fi Vh Oi-H OJ rd e e 0 C ft Xi 0 ri O CJ 0 0 XJ OJ 3 TJ x; a rt -rt -rt M fl
o > O Vh Oi o> 0 3 rt O -H -h tn rt -rt s y Vh TJ CJ -rt Vh Vh 01 0 c a e *j fl ft CJ 0 CJ XJ JJ JJ 0 1
fl HH TJ 0 fi 0
0 0ft
ri -rt ft QlrQQ e oi ih in cn ft 0 a HH 0 TJ O^ JH 0 O -H jj 0 3 0 0 0 0 XJ 0 U U X! "*
0
rt TJ
0 4-1 HH r-i O 0 3 n 61 n C HH -ri 0 Vh Vh 0 XJ TJ 5 3 -H -H rt 10 -rt Vh 0 U JJ U Ol 3 3 3 U vo
Vh Si njri rj r
0 0
fl fl 0) TJ fl a -rl SJ si 0 O 0 JJ Vj HH ft O Vh CJ 0 3 U SJ SJ OJ c jj Vh O XJ 0 C vh
Ui JJ 0 c
0
rH O O -fl 0 -ri rH 41 u CJ sj JJ u XI O JJ ft -rl fl 0 CJ CJ Q -rt CJ 0 JJ 0 0 T3 0 rt xj XJ JJ U JJ
Sh 01 0 CN JJ rt O U Ui 0 E id In 0) 01 id Vh 0 3 xi CJ TJ fl V ft 3 3* 3 jj CO TJ XJ IJ Ol 00 Vh0 3 fl
< 0
u
. -rt
jj fl 0 W u
O rt XJ O rl O Vh Vh rH 0 Vh Sh nj TJ CJ ri r-l 0 Vh to <U Vh 01 ^ 0 CN 0 iH C C C X! 0
> 01 > -rt tj a fl -Q Xi Vh Tj SJ si -H jj 3 -rt ft 0 XJ Sh 0 c TJ 0 H 3 XJ XJ 3 JJ -ri TJ rH TJ rH TJ rt rt -rt rt to >
0 | 0
0 rt Vh 01
0 fi ri Vh 0 0 C "rl cn tj a B X 1 A CO JJ 0 0 0 > Oi jj Cn * to (0 fl
fl fl 3
to to Oi 0 rt 3 fl
u 0 3 u 0 fl XJ rd C 01 V 41 -H a 3 0 fl X ft Vh Vh 0 0 -H w fl 0 O rH H*r CM Jtrl CN CN rt OQ) & r-i Oi > rt 1 O fl r^ TJ ft > 0 W U H M Vi Vh cn C Ot rl 0 0 Xi ft rt Ot VH HH A ri -rt Vh rt -rt Vh rrt * rH rH rH HH1J O
If) O ft O jj O C fl rH fi r-i
*d w OH S E 3 0 -h *fc 4t= *:#.%*- 41= 4*= 4S= st 44= 4S= H* tt=
- *t= * # *t= rt (N -rt =tt= O rt tt -n. = 41= Hjfc *= - r-t -tfc " * " * : #
r-l
0
o
TJ -H
O
tn Vh
0
A 0
u
C
0
a
cu
5
rt rt jj
3 0 0 0 0 0 H 01 A A A O O 0 A co m rt TJ TJ *
fl a 3
h a> fl VO VO 0 0 VO CN
^5
VO ^P rt
rt
VO - rH CN VO 0 0
Vh 0 fi Vh 0 0 0 0 cn rH rH rH rt OJ 0 O fl m v1 &
rt rH 01 3 rt rt in -3< CN rt 01 01
&H O -ri CJ rt rt rt rt rH rH rH rH rH r-i Vj 6 0 rt Vh in CN CN VO m TJ rt rH
JJ XJ (fl ft 0 0 0 0 US 3 2 3 2 o< -rt O m 0 .U ro 0 0
0
u
O 0 JJ O
rt -rt 01
IU HH IH HH HH C C
V V
C
V
fl
V
Ph X3 00 CJ HH ql
CO CN CN
HH HH
I-H O O] 1 TJ 3 3 rt 0 #
^J1 H* CN O O
0H O 0 fi 0 E fl C CN *p ri rH rH
O rt ri JJ -rt Vh h -h
^j>
Sh (N ft co Sh MO rrt ^f r-i CN CN 0 rH CN ri
0
rt
' 6
<a -rt
0 (fl 0 0 O rt XJ rt r-i
JJ 01 01 - ft CN rH rt in 0
TJ
TJ 3 ri
0 cn cn 0 10 -ri 0 U -rt
O CX c rC U H Q ft3
-fl to
CO rt "JH -rt C Eh O 0
N
u 10
0 o *-< O
-rt
VH ftrH
- Pi ft rH o> Ol
1
O
Vh
.fl 0
0
ft si JJ JJ 4-1
0
xJ Vh
I o co TJfl iJ Vh ^0 -rt e O -ri JJ TJ TJ 0 JJ Xi TJ Oi JJ 0 0 0 0 Jh ft0 0 Vh W HH rl Vh fO 0 0 9 3 ft TJ XJ Vh C TJ r-l rt r-i rt oi E,-H O 0 HH fl m 0, O1 r-i 0 fi 0 fi 0 a ra -rt TJ O 0 -rt r-H rt CN CN rH rH CN CN 3 O
to JJ w
.fl u 1 Vh rt fl O Oi 0
jj 0 w ft ft rt r-i 0 0 *j 3 rt fl H 3 0 0 rt rt rH rt rt rH rH rH rH U
g O0O -rt 0 sJ Vh Vh
H
d
(0 TJ U
fl 3 0
rt hh Vh
H fi to
*s "
Xi cn CJ Vh fl TJ CJ - 3 -H
-TJTJTJ Vh ftTJ 0 0
3 - N N TJ TJ TJ TJ -ri -rt rt -rt HH -rt
CJ
Di 0
H >
u
> M
ft -H
o si
0
rj
-rt
Cf]
jJ U -H >,
3 W JJ CJ
*W ft
fl fi M S Xi 43 Xi TJ TJ - 0 -rt to 0 0 0 0 0 0 0 0 0 0 0
0 rl 3 fl O 3 TJ 0 01 01 XJ jj CJ 0 0 0 0 0 0 A 0 0 0 ft 01 0 3 3 3 S -j3.flx..fl.fljflx:x.jc.x:
1 0 CJ 0
ldrd>'C-Hl!)D' CJ vh Vh u X 01 ft XJ XJ JJ Vh U Vh Vj Vh Vh Vj Vh X] 1 U CQ M w fi 3 O" (J U CJ U O CJ O U U U
e B
-ri
a
-rt
fi ft 0 XJ
H 3 X 0
1 1 1 110 1 1 1 1 -rt 0 0 1 0 0 0 &-r ft ft O ft ft ft 1 fl 0 0 01 0 O 3 CO 0 0 0 0 0 0 0 0 0 0
0 c rt *XJ HH HH XH 0 jq>jq,q>:,q.Q.Q 0 -o -h -h ri U Sh rt 0 u CJ UOU U U V O
CO u e in 0 0 W 0 rt * *fc
*- -4t- Hfc 4t 44= 44= P>, 4S= t 1 *f A 1 1 1 Vh 1 0 1 1 V 1 1 1 * fl 1 1 1 ( 1 1 lilt 1 1 1 1 1 1 1
tj
01
cn
3
a HH 3 ^
0 o W
01 CO jj
si Tl a fl ri
id 01 41 0 xi
Vh A a -rt
tn P, JJ VI
n 3 O CJ
ss.cu VJ, 0, ri
u TJ n 0
u cn tn 0 JJ - 0
1 in cn Vh -rt - ui ta
M 41 41 ft x; 00 0
Tj
Tl
VH
Tl 41 co cn 0 01 0-rt u jj n
id TJ
id
TJ
0 SS -~ U rt rt0 fl E
: # *fc 4fc ^t =tt H*
^OO^WOO^iflflOO
rltDMJlOHhrlntji
'j^ooiNo^f'vfninio
cN^'CNr-'Ooiooocnt^
ci pi r- rt in -
CD^^OOOOOCftCNOVO
ir vo rt i^ rt
rnoi>inooc^ornoocDcNOo<Nrtajovoinr^ro(no\oi
novoi^oifji^fnifl^^Ma.^HfntjM^ofNoofflsfl
trrgcaivouivooinovoo^a)invovowi^o<NvocNincnrt
rtr>ovoor^om^cNi>c300f*i vOMsofNMnM'oiN
. JO * * --vooo - .^ . . . -co , tn cn oo ovot> oo vo cn o oo ravoHON coco^ocDnH^m^
r-i r-i TJ fi r-i r-i
0 0 0 0 0 0
jj jj Vh xj jj xj
O O ft O O O
JJ U 4J XJ XJ
* *= == W
O O rt
vo m *
cn vo oo
4t= 5* I
C/l
# * 4*
in
CN O Cl rt
vo cn in cn m
r- rt * vo c-- a\
vo rt cn vo in
co vo a\ o rH co
^ n rt O OO rt
^ m co
r- rt rt
0 0 U
fl M TJ H fl
0 U *XJ 0 O 0
XJ fl 0 O xj Vh
0 rt Vh rH 01 fl 3
H I I i i i mI rt rt rt rH rH 0 |
JJ00000rt U
Bl XI X XJ JJ XJ UOU 01
flooooo^cKAX
W JJ JJ XI JJ XI U M CJ 0
ri -ri -ri -ri -ri -ri -ri -ri -rl -rt r-i
wnoitnoicfioioioioio
tn
ta a I
t.3
01 3 O U xJ xJ rt
ft fl
3 0 0 r-i
U xJ XJ rt
-
3
e ol o> J J J
3 - .
HH U HH O VHrHHH UHH OVfrtHH
^'B'
rl X X
Ol 4J J3 -H
O, 3 si I A tn 41 rt
H ^ id Vh I si tn A
~i O 13 TJ Vh -h cn I
01 O Q, TJ -rt A -H VH . .
CJ334l4JrHP,Jrt3rd,C3l g -r-> -n -r-> CU -n XI
300SISJrt-rHg . - -VH -iJ~ a o ta m -jn-H'O'O'd'ci'O'Oij'ci'cJ tjtj
g a
SJ 4) SJ
I ,1
cn Vh
id tj
Vh TJ
I Id
C I
O TJ
a 41
.' a
- c
01 o
WOIOJOIOITJOJCUOJOJCIOIO)
I ij I j j j j J llHUVHVHidVHVHUHrfVjVHennillVHi-!
.!333OIOID,D'DlD'gt3i0,ap,fj.fi ft O Oti O tt a u (J
2-s-sptnuiininmin.H>AAAAinAAAA i .Q .Q si ~
JJ 0 1 A Ul
0 JJ a
Vh 0 O 3 o
1 Vh 3 2 3
0-, Oh Oh
-si u 0 0 0
TJ -n
T,
I C 0
TJ 0 XJ
0
JJ
Vh -rt 0
1 fl Vh U
0 0 0 0 CO (0 TJ 1 1 0
Vh Vh Vh 0 XJ XJ 0 0 0 0
ft ft ft 0 QJ 0] 0 0 W
fl fl fl cn Vh
- ai
Sh 3 H Vh 0 in
TJ TJ TJ ^ TJ ci
0 to 0 0-^0 0
U 0 Vh rt Vh 01 H Vj M H Si li - -
ft xj ft 01 ft XJ ft ft U
M-S-M
41
cn US US 1.3 -i*if -rt-rtc n K i --i
c c
_r
rd C CJ Tj
Vh O Id 41
I -rl t) SI
SI Vh
Vh O = O
H rt 0,
U TJ 3
O cn = cn
fc, c
_
H H Tj 41
Cs, C Vi
TJ
B
TJ
B
- 01 sj
3 a 01
< -H
CNJ3
Vh
- O id
3 U U
^ , rn
"ti -HSH
o C
o O
41
Vh Vh 01
id O a
A 4J u
Dl u rd
Ol -rH Cl
TJ
41 0)
Vh C
Ph H
ft: rt 0 o c O
i
0 0
> fl
fl
-rt
rH -rt
O
iH
en
TJ 0 JJ ~ CN CN ft CN SJ
0 rrt rt CN rt rt rH C
fl Oi o rt TJ 3 H 3 3!
-rt fO fl u TJ rH e i toHH 0 r-i rt CN CN -rt CN JJ
0 X!
fl S
Oi w tu XJ r-i r-i rH 0 -H
TJ U rt Vi fl 3 rn 0 -rt TJ TJ m to fl
0 U 0 rt fl >? X cn
Ol U 0 0 JJ CN CN JJ >, -rt TJ 0 0 si 0 rj fl c 41
fl fl U 0 cn ro fl fl to 0 fl fl V fl O -rt -rt A -H
ri 0 U Vh ri U C xJ O U Vh U SI Vh
0 fl 0 0 JJ VO VO O Vh 0 fl 0 0 0 0 XI O TJ sj
fl JJ V fl ta
jj
cn
o
a.
o
ft 0
0
0 rl O U
O I I
Vh
0
u
1 41
0)
N
CD
N
O
tn
0
N
-H
3
G
01
0 fl 0 4J v* <* > -H x> ft rt CJ -rl -rt tn -ri TJ
fl -H fl HH fl fl fl w rt rt fl rt c rd in 0 rd Ul C sj
U XJ O 0 rt oo O Ul Vh U * A
0 ta
S
rH CN TJ 0 2 ri r-i r-l 0 ri JJ X 0 O 41 41 0 Xl O.
CJ XJ HH TJ rt 0 fl fl 0 41 fl 0 A M x:
0 O xJ U -rt U CN ^f CN U CN N ish TJ U 0 Cl rt u V, X! SH
0 0 -H 0 rH ii HH 0 rH VO m 0 cn -rt O 01 a C 0 0 id tn 0 O 0 JJ O
X! 0 > rt rt r-l rt CJ CO H - - U 0 N rl 1 u | o u SJ N fl TJ
JJ HH N -H ft TJ XJ C JJ CO vo vo Vh H u 01 -H JJ -rt Vh
O -ri JJ 0 TJ 3 0 fl cn tn TJ in 0 41 in 01 <u .. 41 0 ri N CO TJ 3 01
HH 0 0 Vh 0 JJ 0 0 rt CN 0 CN U 1 U Vh U Vh U Vh CJ TJ ri ri
O Vh -rt fl fl 0 0 fl " -rt 0 X Id O 0 0 id O 0 X! 01 in JJ 3 jj
0 -V u ,* u rH fl TJ V fi r-l HH rH rH Sh 01 Vh SJ Sh jJ Vh SI Vh XJ V, 1 0 1 0 0
OJ D U o u 0 JJ Oi 10 r-i r-i ri r-i r-i xj G TJ sj rd XJ 0 sj rd JJ TJ a SJ ft XJ ft N C
3 3 rt
ta o u TJ fl Ol Vj U -H TJ gTJ 3 G Vh Vh Vh -rt rd 0 -ri
ta i-h 1 1 0 fl 0 fl, Hfc gi 41= -H 4t= 01 H* QJ 4S= 41 =tt 3 44 j # j 4t UlC fl fl 0 fl U XJ CN rt rt 1 1 rt c C 1fl rt rt rt >irt rt VO m CC 41 VO 0 rH 0) CO ro ^ O rj>
1 1 1 i i O] XJ o ri TJ rt -rt TJ rt O in O O o <N rt CN
ri 0 -H TJ " " rt 0 0 01 41 CN 0 41 CN U Vh O Vh Vh o
0 0 JJ 0 0 0 3 0 0 u U u CJ U O VO 0 O rt O O rH
A A A 0 > >. 0 rt fl fl HH fl fl 0 0 rd rd 0 id OO XJ JJ jj jj
A 01 0 U A r-i 0 fl Vh HH U O U u Vh Vh H Vh Vh Vh CN u U U U
0 XI N O rH ft rt U 3 ri 0 0 0 0 0 & Eh Eh 6- Eh -rt -rt ri ri
E 0 rt
0 0 0
ra a 1 Vh Oi fl U u U u TJ TJ Tj TJ TJ TJ TJ d TJ TJta 0 0 0 rt 3 I I - 1 1 0 0 01 01 0 41 0 0 0 0
C C fl 0 Vj X fl r! HH Vh u U O O U O Vj Vh Vh Vh
V V V V V Clj U 0
0 -rt
V Xi
c
o
U
< O fl
0
<
C
0
<
C
rd
>
TJ
<
C
rd
Tj
<
fl
0
TJ
<
c
id
TJ
a,
Oi
S.
s
Oi
2
Oi
<
EL,
2
Oi
Oi
* # = -tl= *= *fc
cn "* r-i o cn en
m OX rt O VO CF.
m cn r^ o in m
rH CN O O -^<
rJH -rt -rt rt rt -rt -rt -rt
0 W Cfl tfl CO CO 10 (0
o
H
fe
a h
0 0
jj 0 0
0 0 fl
urn 0 xj
TJ O rt JJ CU
0 rt g 0 Oh O
XJ rt rl H u
0 0 0
U rt 01 0 xl TJ
0
Vh
0
XI
3
o
u
Ul
c
o
-rl
O ta fl ta fl fl
rt 0 0 0] -rt xl 0
rt oi xi 0 fi oi
0 0 IQ O
ft 0 ta 0 xj oi
CO Ol 0 rt 0
0 >, 0 O fl xi 3
Ol VH ft U 0 fl
0 0 0 Xl CU 0
TJ
01
Vh
01
si
o
a 6 rH 01 XJ
X
me
da
H
EH
E
TJ
rl
r-i
0
V XI rt -rl rt ? 01 o u XJ TJ >fl 0 10 0 0 U TJ
fiNSHO>>HVH>,fl U 5 Vh<4H s ug
0
u3rtrt 00OU0 0 Vh U 0 TJ oflBIH flrl fl " TJ 0 JJ rH 0 tfl
U IH fl a 0 0 ft N 0 r-i
rtrtrtrtXJ0Ofl u TJ Jh fl fl fl 0 rt 0 XJ 00 0 0 0 tfl fl CJ JJ O 0 fl u u -H Vh 0 ri fl 0 >
xjx>xjxjVhEExj 0 fr fl JJ fl JJ JJ XJ u ri -rt TJ 0 o
OOOO-rt330 JH O TJ 0 0 TJ 0 0 0 ra 0 fl JJ 0 ft rt
XI X) XI XI 4H fl fl vm fi XI 0 (XI Vh 0 0 to 0 0 Vh jj 3 Vh 3 rt
41 II O 0 XJ fl XJ 0 u xj Oi TJ 0
#-*Hl-*#*fl. CJ U fH O 0 jj 0 0 0 TJ Tl Ti fl JJ Vt ui >
rd (H fi 0 TJ -rl 0 fl fl fl 0 0 xj Vh 0 0 01 0 fl TJ x> o c 0
fnr^'oo.HMnin ft o 0 o XJ 0 U Vh JJ Jj Xl TJ *d fl XJ U U Vh TJ fl rt 0 0 -rt XJ O r-i
cnoioioowrtin tn 0- TJ 0 H tfl JJ o TJ TJ 3 X 0 X 0 -rl fl XI U XJ U rt
m vo co o in in oo 0 fl ft fl o 01 0 jj tfl fl to fl CO fl 0 0 0 TJ ffl Vh 0 Vh TJ 0 0) xi TJ H 0 -rt XI
rt o m o in cm O fl U 0 ri i 01 JJ rt JJ rt XJ rt XI -- 1 U -rt E xJ fi xj fl Cfl3 -h a 0 0 0 0 0 TJ U Ulm - o co u, fl O fl OlMH
XJ 0 0 O
0 0 fl -rt fl -H fl rt fl 0 01 1 rt E N ft Vh rt 0 -rt fl
VO O CM VO o H o -rt TJ jj Vh 0 Vh x JJ X! xi fl JJ 3 0 oi 0
& O 0 > 01
oi lra I fi rt E
TJ w TJ oi 3 | &
rt U rt Vh TJ o
rn r- rt
S^
XJ TJ 0 TJ Vh 4J 0 ft xi s-i w to 0 -rt
-^S
-rt r-i 0 Ul -rt ft 0 rt
rt rl 0 cih 0 fl fl 0 TJ jj fl xi xi xi
3 'rl 0 rt -rt
fl 3 3 3 -rt 0 -rt Tj fl TJ fl TJ -r-i Ol 0 rt fl 0 0] HH JJ Vh XI
Ol Ol 0 fl fl 0 Ol 0 0 O (JH U Sh fl Vh rl MH fl
3 xj 0 o 0
0 fl 0 fl > W
0 0 XI 0
XJ U U 0 <*H " ft " u
Oi 3 G XJ U to tj TJ U 0 fl -rt u o O O Ol M fl fl 0 fi cn fi ta ri
1 XJ
01 3 0 0 U JJ O O o -rt
rt O rt 01 xj 0 xj 0 Vh xi U u TJ1 U 0 U XJ JJ 1 *J | xi 1 U | 0 -~ CJ Vh 0 cfl rt O XJ o
fl G si 0 fl 0 XJ 0 fl XJ o Sh 1 Vh ta - rt .. -rt - -rt .. aj .. vh - g - fl - tJI
3 - 3 - Vh - 0
xi H fl U U * " rr 041 Vh 0 MH U 4-1 O ft 0 0 tn 41 0 U 0 10 0 .. A " fl - fl .. 3 .. oj ..
Vh & Vh fl Vh
"0 | XJ -rt rt 0 JJ 0 TJ Vh
o Id u 1 fl l E _] o hh to sj O fl Vh 0 Vh (fl Vh U Vh Vh Vh O Vh O Vh rt Vi Vh Vh u 3 0 rt 0 fl u Vh 0 ft
o 4J SJ 0 0 0 TJ O TV H |0 g oi fi O U O xj O 0 O O TJ O 3 O rt O E O U O U O TJ O 0 O 0 0 3 Vh ft JJ G 0 Sh Vh 01
Jj o tn Sh 0 Vh 0 Vh 0 0 u 0 g oi 3 xj u xj -rt xj Sh u XJ rt xi
0 fi 0
Vh jj fl x> 3 xi
0 3 0 fl 0
JJ xi fl xt > xi Vh fl 0 TJ X 0 3 Vh O ftHG siJGXtsJftsJftO Vh s fl 0 fl 0 0 0 fl 0 JJ 0 rt E 0 C 0 -n 0 0 0 JJ 1 fl 1 0 TJ fl Vh U ra
0 0 Oi U O O 10 Vh 0 Vh Vh Vh Sh VI Vh Vh Vh Vh Vh Vh Vh Vj ft O -rt
01 XJ O 44= G 4* fl * E 4t E == oi * !
4*= rl -- 0 * 0 # 0 41= 0 * 0 tt= 0 * OJ* O* 4) 4t= 0 4t= 0 41= 0 4t= 0 41= "4*= - 4= 3 # o * fi 4t=
0 0 0 O 0 O O 0 1 fl fl fl fl fl C fl fl c fl fl fl fl JJ XJ 1 1
CO co Sh Vh rH U a Vh ri U o\ U oo 0 o oo - o 0 cn 0 in 0 r- 0 in 0 O 0 o 0 rt 0 in 0 KO Q) r-i V rl Q) *& (D O -H UJ -ri in fl - T rH
XI 0 to | 0 XJ CM 3 fl vo ft co p, in Vh
|i> | cn * co
CN O n u ** CJ i> a 3" CU O C3 a, O en O ^ rj ^ rj io CJ) * O o fl r- fl rt in p* - o
fl 0 0 0 JJ CO Hi CT. 0 0 O 0 rH 0 cn 0 ri 0 0 0 O 0 00 0 00 0 rt 0 en 0 'tf 0 rH 3 VO P in Sh m Vh r- Vh CN
3 fi co u to 0 m - .. *# .. O " CT\ ' cj in u U r- u in u 00 u in u u U -* U cn U rt U (N O CT, U cn U r-l O r-i CN O in o o o C--
O0rtU-rtO10rH " ro .. r- - m - -* rd O". 0 0 rt 0 ri 0 l> 0 rH 0 0 0 in 0 in 0 0 ^ 0 0 0 r-l in r-i CN JJ (30 JJ rt JJ <H
"i^l^JiJ 41 0 m 0 *d" 0 r- 0 Vh rt Vh Vh r Vh ^ Vh in Vh ** Vh Vh Vh Vh Vh Vh Vh H ^r Vj -ri if -rl U fl U rt uA fl fl fl . fl Eh Eh E- E- E- E- h Eh ^ E* Eh Eh rt Eh frj CN &HTJ TJ TJ H -rt rt4I4JXIX1X1 l>,CJO O O U UOU TJ TJ TJ TJ TJ o TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ
OibiidtdidOcjsJid id 0 0 0 0 01 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
idtdsisisisJ l oi o CJ o a o cj O U U U U u U U U U U U U U UOU Vh Vh Vh
q, o, o, a a i jh vw oi 01 0 0 0 0 G fl fl fl fl fl fl C fl fl fl fl fl fl
0 0 0
fl fl fl Oh Oh- Oh
o U U U u rd 0 0 0 0 0 0 0 0 0 0 Oi Oi Oi
rd 0 0 0 0 > > > > > > > > > > > > > >, < $ $
Vh u u u u TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ TJ 0* Oj Oh
egBBScnintnEH Eh H -> Eh Eh < < < < < < < < < < < <: << < <C < < S r, a
3 N to 0
fl rl
0 Ui fl Oi
TJ
CO
-rt
to
-rt
fl
fl to CO (JH
0
0
fl 0
Vh
-rt
01
CO TJ
TJ
01 O
0 Vh
(0 0 TJ 0 Vh 0
0 tfl 0 TJ N
to 0 - XJ TJ l
. * , . . , . - 01 fl XJ to 0 fl
SH HH JH *JH XI (XI (*H VIH (JH MH 0 tfl -rl 0 O
u-u 0 ~ 0 <D ^ 0 0 0 0 0 Vh 0 0 XJ fl fl rac
Vh hh is Vh MH Vh Vh (xi Vh Vh MH Vh Vh mh Vh tJ Ul JJ fl -rt Oi o ra
^ 41 \ ^w 0 \ ^. 0 -^ 0 *. 0 ^ TJ 'SM', rl a. oj -
tn tn Vh cn 0 co Sh to 0 0 Vh 0 01 0 Vh 01 ta ra Vh ra 0 "^rt
fl Vj ta
cn g rH -- >
sJ o vh 0, cn G
cn fl r-( ^ > m fl rt -*. > CO fl ~rt \ > 01 13 ~^ ^ rl TJ W
SJ O hH ft (Jl a SJ O (jh ft tn fl JJ O HH ft tn & t! 0 *H ft 01 fl 01 xi fl 0 tJ 0 TJ 0
Ci CO -H 41 M H
111 Jr" JJ Vj V, Q
G Cfl ri <U 4) M -ri G (fl -rt 0 0 M -ri C to -rt 0 0 J* -rt fl (0 rt 0 0 X -ri 3 fl -h ra fl 0 <U -rl ta a
41 X XJ Vh Vh fl 01 M JJ Vj Vh fl 0 X XJ U U fl 0 X u Sh S-i fl Dl 0 0 to N XJ 1
E E E .
,
:
E E
O 0 ^- rl - M
m tj to - S 0
u
0
0 \ Vj - tn
0 tn - 3 -0
u
0 tJ ra -
Sh
3
-to fi U 0 \ U - O
0 TJ 01 - 3 fl
fi 0 0
Ol N JJ -
0
fl
rl -ri 0) ti
ra fl ra 0
Cfl U -O ri ta 0 0 CO Cl XI rt 0 0 0 CO u fl -ri 0 - 0 0] ra u fl -H 0 - 0 <D <-! as ta -rt 0 -rt
0 0 0 rt Ul OJ - Ui 0 id 0 rt ta 0 - w 0 0 0 ri tn 0 '01 0 0 0 rt 01 0 - -0 ra in tJ jj XJ ^! fl TJ
ta -< j-j rd to rt 0 oi 0 rH XJ 0 01 - - -rt 0 Ul tfl r-i JJ 0 0 rt 0 ra ra rH JJ 0 01 rt > 0 fl U fl
ta ft
-ri 0
ri > -rt -rt UJ v O XI
fl E O rt
ffl
rt
ft
01
-rt
Sh
> -rl -ri 0 U XI
fl fi . U rt
Ul ft
rt 0 Sh
> -rt -rt
c fi
0 U XJ Cfl ft
U rt -ri 0
-rt > -rt rt 0 -rt
DCG- xj
. TJ TJ
OJ 01 0 - I
0
0 JJ XJ 0
xi fl fl
fi rl rl rt 0 0 fl
-0 Xl
e Vh 3 rt -rt 0 0 fl
- 0 XJ
e u 3 -rt
- 0
ri 0 0 fl fi Vh
xi
5 -H -rt 0 fTj
~ 0 XI rt
TJ TJ N -
O O rt
ra rt 0 0
O fi rt
H-t 4H MH (XI Xl 0 *IH (M JH si IH (JH XI 0 MH *XI HH VH HH (JH XJ dJ IU (4-1 UH <XJ *w *w xi 0 3 U O rt TJ to rt ft a fl
O 0 O O 0 0 0 Vh O O
* Vh xj
o O O O 0 0 0 Vh 0 O
Vh jj
0 0 o O 0 0
Vh
0
U
Vh O O O O O O 0 0 0 Vh U
H XJ 0
* 0 0
-rt ^ X
0 O 0
ri >, Vj jj
xi Vh rt 3Vh Sh Vh Vh -rt 0 fl Vj Vh Vj Vh Vh Vh -h 0 fl Vh Vh Vh Vh Sh H -rt 0 fl Vh Vh Vh Vh Vh Vh -rt 0 fl ft JJ JJ XJ XJ u
0 0 0 0 ~ jj Vh O 0 0 0 41 0 0 ~ jj Vh O 0 0 0 0 0 0 XJ
fl c
Sh O 0 0 0 0
-rt fl fl fl fl
oj oj - jj k o in
fl fl fl -ri i
X X -rl rt
0 0 C C
0
JJ
-rt xi > U
fl fl fl 0
"E 0 0 Jv4 xi *E *E E 0 0 X xi "G *E | 0 0 .* xj fi fi E fi E E 0 0 x xi c i j i j -rt -rt ra rt 0 0 X
C C fl
3 xj fi O 0 3 3
fl 0 0 0 TJ fl fl
Vh U fl -H
C G fl
3 xj fi U 0 3 3
fl 0 0 0 TJ fl C
Vh U fl -H
fl fl fl C 0
Vh U
O 0 3 3 3 3
0 TJ fl fl fl fl
fl -H
3 3 xj fi u 0 O
fl fl 0 0 0 TJ C
Vh U fl -H i i 1 id 0 0 JJ
rH r-l 0 0 r-i r-l r-l r-i rH rt rt 0 0 rt r-i rt rt rt rH ri 0 0 rt rt rt rt rt r-i r-l 0 0 ri ri Vj Vj Vj Vh Vh Vh Vi Vh 0
0 0
JJ xJ
0 0 0] rt XJ 0 0 0 0 td 0 0 0 rt JJ 0 0 0 0 0 0 0 0 rt JJ 0 0 0 0 0 0 0 0] rt JJ 0 0 0) Ol Oi Oi o> 0i Oi Oi Oi
J JJtflft-rt>JJjJ JJ SJ JJ JJ 01 ft -rt > XJ XJ JJ JJ JJ XJ ra ft -rt > .u jj xj jj XJ XJ 0 ft -rt > XJ 0 O O O o O 0 O Vh
O O
XJ JJ
o O -H 0 rl fl 0 O O O o O -rt 0 Vt fl 0 O o o o 0 rt 0 Vt fl O O O 0 O O -H 0 Vj fl O Vi Vh Vh Vh Vh Vh Vh Vh 0
XJ xj fi Vi 3 -h xi xi JJ SJ JJ -u fi Vh 3 rt jj xi JJ JJ JJ XJ fi H 3 -rt JJ Xl XJ XJ u jj fi Vj 3 rt xj ft ft ft ft ft ft ft ft JJ
4*=44=4t41=4s=4fe4t44=4l= -tfc *= 4fc h* 4t= 4t= *= 41= * 4t * 44= 4fc #.::*: 4fc # # * 4t=
tx- # # 4fc 41= 4*= 4fc 4fc 41= 4fc * 4t= h* 4fc ft - -ft. * * # # 4* * * *- *
UjOOOOfOOOrtrt
vo oi ov o o vo o
VO O O O O O rt
r> o o o o c vo
rH CN CN
o o o o i> r-
GO OO o n vo vo o rt o r-i O O o cn o o o in in O O o O O O O O VO O VO O o o o o o o o o o o o O ^P o o o
rH O O O vo O VO ro O O O vo ** CN O O O O O VO rt o o o o o vo o o O ffl ^ o
o o o o av r> CN VO O O O CN CN o o O o to m o o o o o in o m o n rt o
o o o o cn oo rt O O O O O O
. . . . o o
o o O O q' ^jH
- CN CN
o o o o O NO Ol
O 00 o
u
<JH
VO O 00
rH O MH
o o o o o o o o a\ a,
rl r-i
o o O O 00 CO o o o o ^fl o
o o
(JH
4H
^l "XI
O (<H
O rl r- o r-
X X X X X
o o o o o
tfl
fl
0
ri
U 0 0
aj xi xi 0 0
rj 0 0 0 xi 0
H Vj Vh -i-> 0 w
Ul 01
tfl
fl tfl
01
fl 0
G
0
-rt
TJcn
cn a 0
JJ
C
I'
0 O r
OJ 0
0 rt
Jl ft -
rt Q)
in
si
fl
O fl tfl
o
ri
4J
G
O Vj
tfl -rt TJ
fl
0 0
SI O
Ul
o
0 '
Q -
0 f
u
rl
M
G 0 rt 3. X XJ 0 0 0 X JJ 0 0 TJ ra 1
.
41 M
B u
U 0 0 0
0 JJ Xl 0 0
u
0
0 JJ JJ
TJ 0 0 0
0 0 fi
JJ 0 0
U 0 JJ JJ 0 0
0 TJ 0 0 0 XI | 0 0 0 0
0
tfl
0 > 0 Oi
n Vi fl -rt8 0 TJ 0 0 0 XJ Cfl 0 u fl rt Vh Vh JJ 0 0] Ul U fl -rt Vj Vj xi 0 TJ 0 N 01 N 0 ri XJ | fl
(fl CJ XI rt Vh Vh xi 0 U 0 0 0 rt | | 0 U Ul 0 0 0 rt | | 0 Vh -rt 0 -rl Oi -rl M fl ra fl fl |
h j | 0 Vh oi 0 rd 0 rt I I 0 Vj 0 0 0 rt XJ ni ta r-i Vh | 0 0] 01 rt U 0 tfl rt Vj | rt fl W fl 0] 0 1 1 0 0 xj
Tj Ul r-i U 10 0
> Ui ft 1 > 0 XJ
5 rt 0 fl fl U -H
Cfl rt u 0 to rt Vh ! U xj 01 ft ri > tn ft J > U jj oi ft H > 01 ft | > 0 1 1 1 1 JJ X X I Vt 0
CO ft rt > m ft J > O rt rt 0 Vh fl -H 0 fl fl O -rt -rt 0 Vh fl -rt 0 fl fl > JJ JJ 0 0 >i u O Ol -H Ol
ri 41 Vj fl -rt 0 fl fl 0 fl fi rl 3 H E rl 3 rt 0 fl fi Sh 3 -h E Jh 3 -h fl X X xj xi .ft 0 0 0 > Vj
3 rl J - H fi rl 1* rt 0 fl B Vh 3
-
. . - - - fl fl fl fl fl fl fl fl fl fl fl fl fl fl fl fl fl fl fl fl J
r-i r-l r-l r-t r-l ri fi
Xl XI XI XI XI JJ -rl
Vh 0 0 0 0
0 jj jj tj tj C
xJ
0] 5
JJ Vh fl 0
ra ft 0 xj
TJ TJ TJ Tj
C
0
rtrtrtrtrtrtrtrtrtr
rHrHrHrHrHrHrHrHrHr
rt -rt -H -H -H -H -H Tj Tj 1
HHHdHHHHlNWMMMtNfNtSfVCNHrlHrl
IS^ririr-lr-lrlrlr-lr-lr-lr-lr-lr-ir-lrirlHaiJ XlXJ
H
U
rt rt rt
XJ xi xJ
-i
XJ
rt rt t rt rt
JJ XI Xl XJ XJ TJ TJ TJ TJ
rl u
0
-rt
1-1
CJTJTJtJtJtJTJTJ 3 3 3 3 3 3 3 3 3 3 -r* n -n -ri H ri -rl -ri rt H TJ tJ tj TJ Tj TJ TJ TJ *0 TJ 01 Ol rt r-l r-i rt 0 rt XJ rt rt rt rt C
HH
0
o
Ol
0
Pi
H
4J
MH
HH
I
Ol
O
id
a
a
3
TJ
01
H
a
a Vh
m M JJ
V, 01
14 G Tl
o 01
Tl G SJ
41 id t)
SJ Vh Fi
II XJ C)
fi Vh
n TJ ft
Vh 01
11, si
O
- fi VJ
-rt rt
XJ fl xi
U - O fltl"
-rt rt 3 O CN
O 0 jJ o
0 jj O U Vh
M 0 -H | 0 XJ
Oi Vh TJ 0 fl O
ra I 0 jj e *
-rt TJ Jh 0 3 Vh
fi 0 ft TJ fl U
U ft O
ft4t= 3, ==
fl
O .
-rt CN
(N-H -rt U
si fl Tl cn
-H 01 cl
01 Tl Vh Cl
U 01 ft rl
Vh VI tn SJ
rt - en
" cr\ -in
Ij in Vt n
O m O in
JJ VO XJ OO
U CO U en
rt -H
TJ o TJ
~ 1
vo
CN
01 Tl Vh id
Vh 0) ft Vj
H VJ cn
11 U -H TJ
Cl cn fi 01
41=
-H
6
Vh
44= ft
' U TJ w
1 rt 0 fl
| TJ Vj O
I 0 ft -H '
Vh in jj
ftrt u
fi -H
JJ ITJ
U 0 0
0 ra vh .
Vh -rt ft -rt TJ xj Vh jj
VnOOftrtUrtO
TI|U,SJ,JTJ l
ra u TJ a tj 0 TJ
Vh
O TJ rt ~
U 0 fi 0
JJ TJ xi Vh JJ
U 0 fl n fl
H Sj 3 jj 3
TJ -H O 0 O
0 jj U Vh U
I
Vh
O .
U fl
fi, W 0 Q H Q
0 -rt Vh rt 0* r-l
jJ Tj Sh <0 (0 ft)
O 0 O JJ rt JJ
O fi -rt fi Vh U O
U O fi O ft | -U
a*
2
Ol
co
Vh oo Vj en U
rH O rt O tn O
xi r- xJ oo xj
O oo U m O
rt -rl
TJ o tJ
I
in
fl 4t= ft 4fc ft 41= ft :
t cn U <r Vh en Vj i
i O r- O cr\ O
i JJ CN XJ CN XJ
Sh ro
O CN
x rt
TJ
S
Oh
2
Vh
Oh
3 fn tn1 <
Uh Uh
a 2
Vh rl U co
O oo O co
JJ CO Xl CN
U <J\ U rt u
Oh
Oi
<
Vh ci Vh
O cn O
jj rt xi
U m U
4t O 4fr
XI
r- - \o
f*l " o.
oo Vh rt
m O cm
co xj en .
cn U
SSH
u
O, Vh Tj tn Tj
I oj a ui
rt to Vh O Vh
ffl ft H |-H
si O sj Vh si
O I Oi -h 41
sj XI H TJ Vh
H c
in m * o
cn -in - rt
rH jj cn XJ CN
CO -rt in -ri o>
m fl oo fl -rjl
oo t> ro >
- fl fl
o U U
Vh
O
