Answer:
Step-by-step 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;
data:image/s3,"s3://crabby-images/cf181/cf181d91f5e265917eac1dfd5c5ec5d6b15f03c4" alt="T = (N * S)/(R)"
where
N = instruction count
S = average number of clock cycles to fetch & execute an instruction
R = clock rate
From the average number of clock
data:image/s3,"s3://crabby-images/95529/95529da829ed422540dc90ac6354bb2447f395cd" alt="S = 1 + \delta _(branch\_penality )"
where;
data:image/s3,"s3://crabby-images/367a1/367a13e4bf52d6c09f7e67edf92d2f92e6604340" alt="\delta _(branch\_penality )= {Dynamic \ count * Delay \ Slots}"
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:
data:image/s3,"s3://crabby-images/014a9/014a9057711696af8bf392667055eb55e260b765" alt="\delta _(branch\_penality )=0.20 * 1.00"
data:image/s3,"s3://crabby-images/b35f0/b35f07e6c16be9e461d06dc511c66346db061ef1" alt="\delta _(branch\_penality )=0.20"
Therefore;
S = 1 + 0.20
S = 1.2
Recall that:
For an execution time T for the non-pipelined processor;
data:image/s3,"s3://crabby-images/cf181/cf181d91f5e265917eac1dfd5c5ec5d6b15f03c4" alt="T = (N * S)/(R)"
data:image/s3,"s3://crabby-images/fba70/fba704dc0841544f1aa25e5be3085d4106d98711" alt="T = (N * 1.2)/(R)"
data:image/s3,"s3://crabby-images/f9a61/f9a61a6b9d07249672e7c1106bf486f42fa097ae" alt="T = ( 1.2 \ N)/(R)"
To derive another expression that reflects the execution time of 70% delay; we have:
data:image/s3,"s3://crabby-images/d9392/d93923b7808ea997631b3c2d314bd32b9f1d639e" alt="\delta_(branch\_penality) = 0.20 * ( 1-0.7)"
data:image/s3,"s3://crabby-images/d97cd/d97cd526c275a107cf891dfb7aaf0a3d5691164e" alt="\delta_(branch\_penality) = 0.20 * ( 0.3)"
data:image/s3,"s3://crabby-images/5825a/5825a71436e080d28c26c41c47b93cfc67749409" alt="\delta_(branch\_penality) = 0.06"
S = 1 + 0.06
S = 1.06
For an execution time T for the non-pipelined processor;
data:image/s3,"s3://crabby-images/cf181/cf181d91f5e265917eac1dfd5c5ec5d6b15f03c4" alt="T = (N * S)/(R)"
data:image/s3,"s3://crabby-images/e7d7d/e7d7d0775a389977a84f86f138430b32e74fb248" alt="T = (N * 1.06)/(R)"
data:image/s3,"s3://crabby-images/fa034/fa034a3dd5d3b9bcb9a7c537b478705fc8beb01e" alt="T = ( 1.06 \ N)/(R)"
Finally, the compiler's contribution to the increase in speed up percentage for the above two cases is:
data:image/s3,"s3://crabby-images/e2654/e2654385af220d86f6aea4d26f49e61f056c68da" alt="=\begin {pmatrix}(T_(all \ delay \ slots ))/(T_(70\% \ delay \ slots ) ) -1 \end {pmatrix} * 100"
data:image/s3,"s3://crabby-images/e92ea/e92ea33592c1ebf7958715ead518c96e089e72db" alt="= \begin {pmatrix}(1.2 )/(1.06 ) -1 \end {pmatrix} * 100"
= (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%