转:https://blog.csdn.net/leonwei/article/details/7998412

从后缓存到显示器

最近在看D3D的架构,在这过程中对帧率这个一直认为很简单的东西有了更多的理解。在过去看来,帧率就是显卡渲染一帧所用时间的倒数,现在看来远远不是这个样子。

要真正理解这个问题要从绘制数据从显存中到屏幕的这一个过程来说起,下图就是这个过程

显存中存在前后缓存,前缓存就是屏幕上最终看到的像素,而后缓存是绘制使用,后缓存绘制好一帧,通常就交换一次,写给前缓存,而显示器则从前缓存不断的读取数据。

交换帧率与刷新帧率

通常我们很在意渲染的效率,其实就是绘制的效率,这就是图中的f1,也成为交换帧率,f1决定了显卡一秒能绘制多少次,以前一直以为这就是用户的帧率了,其实不是,因为还有其他因素。

我们看到显示器读取前缓存也存在一个频率,即f2,f2也被称为显卡的刷新频率,即显卡按照多少的频率去讲前缓存的数据给显示器绘制一次,它不管前缓存的数据是否是新的还是旧的。由此可见我们最终用户看到的帧率是f1 和 f2的共同结果。实际的帧率f应该表述为显示器所能表现的缓存交换帧率,即在1秒内有多少个后缓存的传递到了显示器。这样看f=min(f1,f2),即受这两个帧率的制约了。比如说你渲染很快,一秒绘制60次,但是显卡一秒只想显示器刷30次,那帧率最高也只有30,再比如你渲染很慢,因为模型特别大,一秒画10次,显示器一秒刷60次,那用户看到的实际帧率也只有10。到这里似乎帧率是被这两者决定的,但是其实还不是这样。

垂直同步与帧率

从图中可以看到一点就是前缓存处于被后缓存写而被显示器读的状态,那么这过程就极有可能发生读写冲突,而显示器的绘制是从上到下一行行刷新的,一种典型的情况就是显示器在读这一帧时前缓存被写入新的下一帧数据,那么显示器的上部分和下部分将显示不同帧的画面,这就是常出现的“画面撕裂”现象,他就是因为缓存交换太快不等显示器读完而造成的。

为了解决这个现象,引入了“垂直同步”的相关技术,垂直同步就是指显示器从上到下绘制一个完整帧的画面的一个过程,在这个过程中,显卡保证不去改变前缓存,如果这过程绘制好一帧,那么后缓存发现前缓存在被读取就不进行交换操作,这样的结果会保证显示器绘制不被撕裂,但是也带来了另一个问题,就是卡帧率,因为正常的交换帧率被显示器的垂直同步各种打断掉,交换帧率大大降低,降低最终帧率。

看来垂直同步与不垂直同步是两个极端,他们分别代表着最高的画面完整度与最高的帧率。所以在实践中就产生了很多种折中的办法,就是允许显卡最多在n帧刷新中只打断一次缓存交换,n越大越接近完全不用垂直同步,帧率越高,n越小越接近垂直同步,撕裂现象概率越小。垂直同步、不垂直同步和几种折中其实就对应了D3D9的交换参数的D3DPRESENT_DONOTWAIT、D3DPRESENT_INTERVAL_IMMEDIATE和D3DPRESENT_INTERVAL_ONE(~FOUR)。那么最终的帧率f应该接近与min{f1-min{f1,f2}/(1+n),f2},通常f2都是足够大的。

所以帧率不仅与交换帧率、刷新帧率有关,还与垂直同步策略有关,所以我们可以看到一些玩家的游戏中关闭垂直同步会卡机,也有一些玩家打开垂直同步会降低帧率,就是这个原因。

显存

当然我们看到垂直同步会制约帧率的时候,是因为我们这个图中的的前缓存存只有一处,处于读写冲突状态,那么会想只要让显存不存在这种状态不就行了吗,那需要显存非常大,后缓存是生产者,显卡是消费者,前缓存如果足够的大(可以分成n多块),那么生产者就有可能不用顾忌的往缓存上堆新东西,事实上完全的不存在冲突是不太可能的,因为显存的大小永远存在一个限制,只要缓存大小有限制,就必然可能出现生产者和消费者的冲突,存在冲突,要么选择生产者等消费者(生产降低,即帧率降低),要么消费者拿到的东西会紊乱(即撕裂),但是显存越大,这种潜在的冲突的可能性就越小,问题就越容易避免。

所以我么看到显卡显存较大的客户端及时完全关闭垂直同步(即理论最大帧率)也不太容易撕裂,或者完全打开垂直同步帧率还是非常高,显存不仅有利于绘制也有利于解决前缓存冲突提高帧率。

基于这些思考,所以在选择渲染策略时,一定要充分考虑垂直同步的策略,根据潜在用户的硬件、游戏的绘制效率、刷新效率一起考虑,知道帧率是由绘制效率,显卡刷新效率和垂直同步策略三者共同决定的。在D3D9中微软推荐使用的垂直同步策略时D3DPRESENT_INTERVAL_ONE,即最接近完全垂直同步的折中策略,即最多在一次显卡刷新中打断一次缓存交换,实际帧率应该是接近于f1/2,如果最终用户看到的要在30帧的话,z在f2是60的情况下,那么f1要在60帧以上。

垂直同步、绘制效率、显示器刷新频率与帧率相关推荐

  1. (转) 垂直同步、绘制效率、显示器刷新频率与帧率

    (转) 垂直同步.绘制效率.显示器刷新频率与帧率 从后缓存到显示器       最近在看D3D的架构,在这过程中对帧率这个一直认为很简单的东西有了更多的理解.在过去看来,帧率就是显卡渲染一帧所用时间的 ...

  2. 垂直同步、绘制效率、显示器刷新频率与帧率(转)

    从后缓存到显示器       最近在看D3D的架构,在这过程中对帧率这个一直认为很简单的东西有了更多的理解.在过去看来,帧率就是显卡渲染一帧所用时间的倒数,现在看来远远不是这个样子. 要真正理解这个问 ...

  3. 显示器刷新频率与帧率、垂直同步以及绘制效率

    从后缓存到显示器       最近在看D3D的架构,在这过程中对帧率这个一直认为很简单的东西有了更多的理解.在过去看来,帧率就是显卡渲染一帧所用时间的倒数,现在看来远远不是这个样子. 要真正理解这个问 ...

  4. 游戏开发中——垂直同步、绘制效率、显示器刷新频率与帧率

    [转]: here 从后缓存到显示器       最近在看D3D的架构,在这过程中对帧率这个一直认为很简单的东西有了更多的理解.在过去看来,帧率就是显卡渲染一帧所用时间的倒数,现在看来远远不是这个样子 ...

  5. 关于笔记本电脑修改显示器刷新频率后,重新开机时会自动修改为上一次的频率问题

    下面是我使用win11笔记本遇到的一些问题,也是找了好久 才找到解决的办法(亲测有效) 下面就给大家介绍一下笔记本修改显示器刷新频率后,重新开机时会自动修改为上一次的频率解决办法. 第一步:点击  & ...

  6. 解决: Mac外接4K显示器刷新频率只有30Hz,例如(P2415Q,30赫兹->60赫兹)

    如果你的Mac Pro 外接了个 4K显示器(P2415Q),如果刷新频率没有 60Hz,可以按照下面这操作,或许能帮到你! 一步到位: APP Store 下载: easyres 运行:

  7. DELL显示器刷新频率调到75进桌面黑屏,解决办法:启动VGA模式

    最近买了一二手的DELL的显示器运气不好,屏幕有斜纹,这样就罢了,调了1440*900/75HZ用得还好好的,但关机重启后到滚动条还有画面,进桌面就没有了.原来也是1440*900,不过是60HZ的, ...

  8. 刷新计算机无法显示,显示器无法调整刷新频率的解决办法

    显示器无法调整刷新频率的解决办法 在"显示属性"中显示器刷新频率无法调整,其实无法调整显示器刷新频率大多是因为人们没有选择正确的显示器类型或者显卡的驱动程序安装不正确所造成的.显示 ...

  9. 帧率、显示器刷新率与垂直同步

    提到显卡的帧率(FPS).显示器刷新率和垂直同步的关系,第一印象是这些概念之间似乎没有直接的关系,实则不然. 首先来解释帧率(FPS,即Frame Per Second,帧/秒).通俗来说,帧率是用来 ...

最新文章

  1. 2021语言与智能技术竞赛上线!百度飞桨提供平台算力支持
  2. R语言可视化韦恩图实战:VENN DIAGRAM
  3. Spring Security 实战干货:自定义配置类入口 WebSecurityConfigurerAdapter
  4. 数据库常考面试知识点
  5. day21-python模块
  6. 漫画:什么是囚徒困境?
  7. 《HTML5和JavaScript Web应用开发》——第 2 章 移动Web 2.1移动优先
  8. 【自然语言处理】--视觉问答(Visual Question Answering,VQA)从初始到应用
  9. 简单高效搞定---迁移学习
  10. Base64编码工具类
  11. MySQL Workbench 6.3CE 汉化及使用教程(转载)
  12. 大数据平台需求调研大纲模板
  13. 百度云OCR图片文字识别实现
  14. Passenger 和 Nginx
  15. 微信小程序uni-app
  16. git常用操作--分支同步master 本地库提交到远程分支
  17. java中jsp的题
  18. php-fpm status,使用php-fpm状态页观察当前的php-fpm状态
  19. GPIO 配置之ODR, BSRR, BRR 详解
  20. python就业前景不好_担心学习Python就业情况不好?来看看Python发展前景

热门文章

  1. oauth2.0--基础--01--理论
  2. 用windows运行命令打开
  3. 击鼓传花---c语言实现
  4. CSS fr单元简介
  5. uView——分段器、选项卡
  6. Cesium修改鼠标左键、中键旋转和平移事件
  7. java.lang.module_如何修复“java.lang.module.FindException:module java.se.ee not found”错误
  8. 《一步一步使用ABP框架搭建正式项目系列教程》
  9. Fire! UVA - 11624
  10. 第十七周-day72-Python编程基础day04