Respuesta :
Answer:
Explanation:
From the given information;
The first objective is to derive an expression for the execution time in cycles
For an execution time T for the non-pipelined processor;
[tex]T = \dfrac{N \times S}{R}[/tex]
where
N = instruction count
S = average number of clock cycles to fetch & execute an instruction
R = clock rate
From the average number of clock
[tex]S = 1 + \delta _{branch\_penality }[/tex]
where;
[tex]\delta _{branch\_penality }= {Dynamic \ count \times Delay \ Slots}[/tex]
Similarly, we are given that the dynamic count is 20%
∴
The execution time required for all the delayed slots that is filled with NOP instructions can be estimated as:
[tex]\delta _{branch\_penality }=0.20 \times 1.00[/tex]
[tex]\delta _{branch\_penality }=0.20[/tex]
Therefore;
S = 1 + 0.20
S = 1.2
Recall that:
For an execution time T for the non-pipelined processor;
[tex]T = \dfrac{N \times S}{R}[/tex]
[tex]T = \dfrac{N \times 1.2}{R}[/tex]
[tex]T = \dfrac{ 1.2 \ N}{R}[/tex]
To derive another expression that reflects the execution time of 70% delay; we have:
[tex]\delta_{branch\_penality} = 0.20 \times ( 1-0.7)[/tex]
[tex]\delta_{branch\_penality} = 0.20 \times ( 0.3)[/tex]
[tex]\delta_{branch\_penality} = 0.06[/tex]
S = 1 + 0.06
S = 1.06
For an execution time T for the non-pipelined processor;
[tex]T = \dfrac{N \times S}{R}[/tex]
[tex]T = \dfrac{N \times 1.06}{R}[/tex]
[tex]T = \dfrac{ 1.06 \ N}{R}[/tex]
Finally, the compiler's contribution to the increase in speed up percentage for the above two cases is:
[tex]=\begin {pmatrix}\dfrac{T_{all \ delay \ slots }}{T_{70\% \ delay \ slots } } -1 \end {pmatrix} \times 100[/tex]
[tex]= \begin {pmatrix}\dfrac{1.2 }{1.06 } -1 \end {pmatrix} \times 100[/tex]
= (1.1320 - 1) × 100
= 0.1320 × 100
= 13.20%
Therefore, the compiler's contribution to increasing performance as expressed as speed up percentage is 13.20%