GPA简介
GPA(Graphics Performance Analyzers)是Intel公司提供的一款免费的跨平台性能分析工具。
填写e-mail、name和country并提交后,就会收到一封有专属下载链接的邮件,点开之后,有3大os平台的GPA版本可供下载
我本机是win7 64bit,于是下载gpa_17.2_release_312434_x64_standalone.msi 最新GPA版本简介
GPA 2017 R2版本支持的平台及图形API:
宿主机(GPA所在机器) | 目标机(游戏所在机器) | 图形API |
Windows* 7 SP1/8/8.1/10 | Windows* 7 SP1/8/8.1/10 | DirectX* 9/9Ex, 10.0/10.1, 11.0/11.1/11.2/11.3 |
Windows* 10 | Windows* 10 | DirectX* 12, 12.1 |
Windows* 7 SP1/8/8.1/10 或者 macOS* 10.11, 10.12 或者 Ubuntu* 16.04 |
Android* 4.1, 4.2, 4.3, 4.4, 5.x, 6.0 |
OpenGL* ES 1.0, 1.1, 2.0, 3.0, 3.1, 3.2 |
Ubuntu* 16.04 | Ubuntu* 16.04 | OpenGL* 3.2, 3.3, 4.0, 4.1 Core Profile |
GPA的工具集关系如下:
Graphics Monitor -- GPA最核心组件,其主要作用有:
①Hook目标进程,来实现游戏内hud绘制和快捷键、截帧、捕获trace、抓取cpu、gpu、图形api数据、执行实验选项等功能
②客户端必须启动Graphics Monitor并Hook目标进程,服务端的System Analyzer才能与客户端机器建立连接并获取进程各项数据指标
③必须启动Graphics Monitor,Graphics Frame Analyzer才能打开帧文件进行分析
④托盘快捷菜单可以快速拉起System Analyzer、Graphics Frame Analyzer、Platform Analyzer和Trace Analyzer工具
⑤通过Profiles和Preferences界面来进行GPA的各项设置
Graphics Frame Analyzer -- 打开形如:MeshFromOBJ_2017_09_25__15_23_01_609.gpa_frame的帧文件进行gpu上各种消耗的细致分析
①使用API log显示出图形api的调用过程,并查看是否存在一些error或warning
②查看某个draw call在gpu消耗,颜色、深度、模板buffer,像素的alpha值及format
③执行一些实验选项来精确查看gpu消耗的减少情况
Platform Analyzer -- 打开形如:MeshFromOBJ_2017_09_25__14_29_27_931.gpa_trace\MeshFromOBJ_2017_09_25__14_29_27_931.gpa_trace.amplxe的trace文件来分析cpu与gpu协作工作及消耗的细节
①标识出cpu与gpu的帧边界
②依据时间线来review执行流程上的各段时间消耗
③查看gpu的任务队列、检查cpu利用率
④捕获时,目标进程在机器上cpu与gpu的消耗情况
System Analyzer -- 支持本机与远程连接目标进程
①用良好的图形化界面显示建立连接的目标进程的cpu、gpu、图形api各项数据指标的曲线图
②在其图形化界面执行实验选项来快速确定是cpu还是gpu造成了性能瓶颈
③在其图形化界面上进行截帧和捕获trace
Trace Analyzer -- 与Platform Analyzer一样,利用Trace Viewer For Google Chrome方式来可视化trace中cpu与gpu分析cpu与gpu协作工作及消耗的细节
打开形如:MeshFromOBJ_2017_09_25__14_39_01_887.sea的trace文件夹
注1:启动Graphics Monitor后,等待弹出如下气泡时,再去操作Graphics Monitor,否则会引发卡死
注2:点击Profiles面板Tracing标签页的Collection Settings按钮,来设置捕获那种类型的trace文件
Graphics Monitor
双击托盘中的Graphics Monitor图标会弹出Analyze Application对话框
点击Analyze Application对话框中Manage按钮会弹出Profiles面板(或单击托盘中的Graphics Monitor图标,选择Profiles...)
windows下,GPA有2种Hook D3D的方法:
方法① 从Analyze Application中拉起一个D3D程序
方法② 单击托盘中的Graphics Monitor图标,选择Preferences...,弹出如下对话框,勾选“Auto-detect launched applications”,
此时会看到Graphics Monitor图标从蓝色变成绿色
则后续启动的D3D程序都会成为被Hook目标(注:开了这个之后,会引发2010及以上版本的vs崩溃)
若Profiles的HUD Options标签页的Display Mode没有选择Disable的话,就会在程序的窗口上看到GPA的HUD
下图为gpasample.exe被Hook时的情况:
注:877为当前帧的fps(1s / 当前帧的时间),为过去1s内min fps(1s / 最耗时一帧的时间),为过去1s内max fps(1s / 最快一帧的时间)
看到了GPA的HUD表明程序已经被GPA成功Hook了,可以按Ctrl + Shift + C进行截帧,按Ctrl + Shift + T进行截取一段时间内(时长在Profiles的Tracing标签页中设置)的Trace
截取的帧和Trace放置在“文档\GPA”目录中
若截取的帧的图像在Graphics Frame Analyzer中无法预览(状态栏右下角的进度条卡死无法完成),可能是显卡不兼容导致的,若有多个显卡(如:1个nVidia独显+1个Intel集显),可以切到另外一个显卡上重新截帧
GPA简介的更多相关文章
- ASP.NET Core 1.1 简介
ASP.NET Core 1.1 于2016年11月16日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强.这个版本包含了多个新的中间件组件.针对Windows的WebListener服 ...
- MVVM模式和在WPF中的实现(一)MVVM模式简介
MVVM模式解析和在WPF中的实现(一) MVVM模式简介 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在 ...
- Cassandra简介
在前面的一篇文章<图形数据库Neo4J简介>中,我们介绍了一种非常流行的图形数据库Neo4J的使用方法.而在本文中,我们将对另外一种类型的NoSQL数据库——Cassandra进行简单地介 ...
- REST简介
一说到REST,我想大家的第一反应就是“啊,就是那种前后台通信方式.”但是在要求详细讲述它所提出的各个约束,以及如何开始搭建REST服务时,却很少有人能够清晰地说出它到底是什么,需要遵守什么样的准则. ...
- Microservice架构模式简介
在2014年,Sam Newman,Martin Fowler在ThoughtWorks的一位同事,出版了一本新书<Building Microservices>.该书描述了如何按照Mic ...
- const,static,extern 简介
const,static,extern 简介 一.const与宏的区别: const简介:之前常用的字符串常量,一般是抽成宏,但是苹果不推荐我们抽成宏,推荐我们使用const常量. 执行时刻:宏是预编 ...
- HTTPS简介
一.简单总结 1.HTTPS概念总结 HTTPS 就是对HTTP进行了TLS或SSL加密. 应用层的HTTP协议通过传输层的TCP协议来传输,HTTPS 在 HTTP和 TCP中间加了一层TLS/SS ...
- 【Machine Learning】机器学习及其基础概念简介
机器学习及其基础概念简介 作者:白宁超 2016年12月23日21:24:51 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结 ...
- Cesium简介以及离线部署运行
Cesium简介 cesium是国外一个基于JavaScript编写的使用WebGL的地图引擎,一款开源3DGIS的js库.cesium支持3D,2D,2.5D形式的地图展示,可以自行绘制图形,高亮区 ...
随机推荐
- 比较 Spring AOP 与 AspectJ
本文翻译自博客Comparing Spring AOP and AspectJ(转载:https://juejin.im/post/5a695b3cf265da3e47449471) 介绍 如今有多个 ...
- C++版 - LeetCode 144. Binary Tree Preorder Traversal (二叉树先根序遍历,非递归)
144. Binary Tree Preorder Traversal Difficulty: Medium Given a binary tree, return the preorder trav ...
- ZOJ Problem Set - 3706
#include <cstdio> #include <cstdlib> #include <cstring> #include <set> #incl ...
- iOS逆向开发(5):微信强制升级的突破 | 多开 | 微信5.0
接下来的几篇文章,小程以微信为例,实战地演示一下:如何注入iOS的APP.其中使用到的知识,基本在前面的文章中都有介绍到. 小白:小程,我想用回旧版本的微信! 小程:为什么要用旧版本微信呢? 小白:你 ...
- LeetCode-63. 不同路径 II
最近英文版的访问特别慢,转战中文吧 和上一题一样,递归会超时 //63 不同路径2,递归解法 int uniquePaths2(vector<vector<int>>& ...
- iOS 快速排序
一.快速排序概念及其思想 快速排序(QuickSort),又称为交换排序,是分治算法的一种,快速排序采用分治的策略. 1.分治法的基本思想: 将原问题分解为若干个规模更小但结构和原问题相似的子问题.递 ...
- WPF 获取DataGrid 控件选中的单元格信息
获取 DataGrid 选中的单元格的信息DataGridCellInfo cell_Info = this.studentTable.SelectedCells[0]; studentTableIt ...
- C#爬虫----Fiddler 插件开发 自动生成代码
哈喽^_^ 一般我们在编写网页爬虫的时候经常会使用到Fiddler这个工具来分析http包,而且通常并不是分析一个包就够了的,所以为了把更多的时间放在分析http包上,自动化生成封包代码就尤为重要了( ...
- SSM 设置静态资源处理
使用weblogic的虚拟路径virtual-directory-mapping 在页面上展示文件服务器上的图片 <weblogic-web-app> ......省略其他部分 <c ...
- 【转】hibernate 延迟加载
Hibernae 的延迟加载是一个非常常用的技术,实体的集合属性默认会被延迟加载,实体所关联的实体默认也会被延迟加载.hibernate 通过这种延迟加载来降低系统的内存开销,从而保证 Hiberna ...