【系统架构设计师】计算机组成与体系结构 ⑮ ( 流水线技术 | 流水线吞吐率计算 | 流水线加速比计算 )

文章目录

在软考中 , 涉及到 流水线技术 的相关题型 :

  • 流水线执行时间计算
  • 流水线吞吐率计算
  • 流水线加速比计算

一、流水线吞吐率计算


1、流水线吞吐率概念

流水线吞吐率 ( TP , Though Putrate ) 是指 单位时间 内流水线所完成的 指令或任务数 , 是衡量流水线性能的重要指标之一 ;

流水线吞吐率 计算公式 为 :

吞吐率 T P = 指令条数 流水线执行时间 \rm 吞吐率 TP = \cfrac{指令条数}{流水线执行时间} 吞吐率TP=流水线执行时间指令条数

流水线 最大 吞吐率 计算公式 为 :

T P m a x = lim ⁡ n → ∞ n ( k + n − 1 ) t = 1 t TP_{max} = \lim_{n \to \infty}\cfrac{n}{(k + n - 1)t} = \cfrac{1}{t} TPmax=n→∞lim(k+n−1)tn=t1

  • t t t 是 流水线周期 ;
  • n n n 是 执行的指令条数 ;
  • k k k 是 一条指令 所需的步骤数 ;
  • ( k + n − 1 ) t (k + n - 1)t (k+n−1)t 是 流水线指令执行的 总时间 , 如果 n 无穷大 , 则 k − 1 k - 1 k−1 可以忽略 ;

2、流水线吞吐率示例

一条指令执行需要经过 取指 / 分析 / 执行 三个步骤 , 流水线周期 是 上述三个步骤中最长的一段时间 , 如 : 取指 1 ms , 分析 2 ms , 执行 3 ms , 则 流水线周期是 3 ms ;

指令完整的执行时间是 1 + 2 + 3 = 6 1 + 2 + 3 = 6 1+2+3=6 ms ;

如果要串行执行 10 条指令 , 则需要花费 10 × 6 = 60 10 \times 6 = 60 10×6=60 ms ;

如果按照流水线方式执行 , 则执行 10 条指令所需的时间为 :

( 1 + 2 + 3 ) + ( 10 − 1 ) × 3 = 6 + 27 = 33 (1 + 2 + 3) + (10 - 1) \times 3 = 6 + 27 = 33 (1+2+3)+(10−1)×3=6+27=33 ms

流水线吞吐率 计算公式 为 :

吞吐率 T P = 指令条数 流水线执行时间 \rm 吞吐率 TP = \cfrac{指令条数}{流水线执行时间} 吞吐率TP=流水线执行时间指令条数

指令条数为 10 条 , 流水线执行时间为 33 ms , 则吞吐率为 T P = 10 33 m s \rm TP = \cfrac{10}{33 ms} TP=33ms10

流水线 最大 吞吐率 计算公式 为 :

T P m a x = lim ⁡ n → ∞ n ( k + n − 1 ) t = 1 t TP_{max} = \lim_{n \to \infty}\cfrac{n}{(k + n - 1)t} = \cfrac{1}{t} TPmax=n→∞lim(k+n−1)tn=t1

上述指令的 流水线周期是 3ms , 则该流水线的 最大吞吐率为 : T P m a x = 1 3 m s \rm TP_{max} = \cfrac{1}{3ms} TPmax=3ms1

二、流水线加速比计算


1、流水线加速比概念

流水线加速比 是指 完成同样一批任务时 , " 不使用流水线执行指令的时间 " 与 " 使用流水线执行指令的时间 " 之比 ;

流水线加速比 计算公式为 :

流水线加速比 = 不使用流水线执行指令的时间 使用流水线执行指令的时间 流水线加速比 = \cfrac{不使用流水线执行指令的时间}{使用流水线执行指令的时间} 流水线加速比=使用流水线执行指令的时间不使用流水线执行指令的时间

2、流水线加速比示例

一条指令执行需要经过 取指 / 分析 / 执行 三个步骤 , 流水线周期 是 上述三个步骤中最长的一段时间 , 如 : 取指 1 ms , 分析 2 ms , 执行 3 ms , 则 流水线周期是 3 ms ;

指令完整的执行时间是 1 + 2 + 3 = 6 1 + 2 + 3 = 6 1+2+3=6 ms ;

如果要串行执行 10 条指令 , 则需要花费 10 × 6 = 60 10 \times 6 = 60 10×6=60 ms ;

如果按照流水线方式执行 , 则执行 10 条指令所需的时间为 :

( 1 + 2 + 3 ) + ( 10 − 1 ) × 3 = 6 + 27 = 33 (1 + 2 + 3) + (10 - 1) \times 3 = 6 + 27 = 33 (1+2+3)+(10−1)×3=6+27=33 ms

执行 10 条指令 ,

  • 不使用流水线 , 需要消耗 60ms 时间 ;
  • 使用流水线 , 需要消耗 33 ms 时间 ;

流水线加速比 计算公式为 :

流水线加速比 = 不使用流水线执行指令的时间 使用流水线执行指令的时间 流水线加速比 = \cfrac{不使用流水线执行指令的时间}{使用流水线执行指令的时间} 流水线加速比=使用流水线执行指令的时间不使用流水线执行指令的时间

将上面的数值代入到上述公式 :

流水线加速比 = 不使用流水线执行指令的时间 使用流水线执行指令的时间 = 60 33 流水线加速比= \cfrac{不使用流水线执行指令的时间}{使用流水线执行指令的时间} = \cfrac{60}{33} 流水线加速比=使用流水线执行指令的时间不使用流水线执行指令的时间=3360

相关推荐
龙亘川15 小时前
智慧城市SaaS平台之智慧城管十大核心功能(七):后台支撑系统
服务器·人工智能·系统架构·智慧城市·运维开发·智慧城市saas平台
币须赢1 天前
机器人智能系统架构:大脑
系统架构·机器人
qqxhb1 天前
系统架构设计师备考第17天——企业资源规划(ERP)& 典型信息系统架构模型
系统架构·erp·b2c·b2b·g2g·g2b·g2c
谱写秋天1 天前
软考-系统架构设计师 *密钥管理技术详细讲解
系统架构·软考架构师
qqxhb1 天前
系统架构设计师备考第19天——信息安全系统的组成框架
系统架构·管理·技术·组织
武子康2 天前
Java-122 深入浅出 MySQL CAP理论详解与分布式事务实践:从2PC到3PC与XA模式
java·大数据·数据库·分布式·mysql·性能优化·系统架构
全栈技术负责人2 天前
前端全链路质量监控体系建设与实践分享
前端·系统架构·前端框架
文火冰糖的硅基工坊2 天前
[硬件电路-180]:集成运放,在同向放大和反向放大电路中,失调电压与信号一起被等比例放大;但在跨阻运放中,失调电压不会与电流信号等比例放大。
嵌入式硬件·系统架构·电路·跨学科融合
武子康2 天前
AI-调查研究-75-具身智能 从LLM到LBM:大模型驱动下的机器人分层控制架构
人工智能·ai·职场和发展·架构·系统架构·机器人·具身智能
qqxhb2 天前
系统架构设计师备考第22天——信息安全的抗攻击技术
系统架构·dos·arp·密钥选择·ip欺骗·dns欺骗