针对移动终端上GPU的高功耗问题,提出一种基于Android系统的GPU动态调频方案。方案根据各种应用对GPU的性能需求,引入了GPU的频率一性能模型,包括选择工作频率和测量相对性能的方法。动态调频算法通过历史负载计算出预测负载,将其代入频率一性能模型后预测出下一周期GPU的频率。实验结果表明,方案在典型场景下可以快速跟踪GPU负载的变化,预测GPU频率的准确率达到95% 以上。

系统级芯片(SoC)是智能移动终端的核心,决定了一款机器的性能水平。目前的中高端嵌入式SoC中普遍集成了嵌入式图形处理器GPU(Graphic Processing Unit),主要用于处理CPU并不擅长的三维图形任务。但高性能GPU所带来的高功耗对于移动终端是一个严峻的挑战。

动态电压频率调整DVFS(Dynamic Vohage and Fre—quency Scaling)是降低动态功耗的常用方法,其核心思想是根据当前所运行的任务对计算能力的不同需求来动态调节处理器的工作频率和电压,从而达到节能的目的。DVFS的理论依据是如下动态功耗的计算公式?:

其中

, 代表动态功耗,C为负载电容, 为供电电

压,.厂为工作频率。从式(1)中可以看出,在负载电容一定的情况下,动态功耗与供电电压的平方成正比,与工作频率成正比。同时,电压与频率也存在一定的对应关系,频率越高,所需要的电压也越高。

嵌入式GPU(下文均简称GPU)的发展时间短,技术更新快,在设计目标、软硬件架构、图形标准、运行系统等方面与PC显卡都有所差异t21,有关降低功耗的研究尚不多见。针对这种现状,本文基于目前最流行的嵌入式操作系统Android, 在GPU的内核驱动层提出了一种GPU 动态调频方案,使GPU可以根据性能需求自适应地调节运行频率和电压,从而降低GPU的动态功耗。

1 Android应用对GPU的性能需求

Android系统主界面的混合与叠加采用GPU硬件加速[31,除此之外,图库、动态壁纸、3D桌面、3D游戏等多种应用也需要GPU的支持。各种应用对于GPU性能的需求大不相同,例如,动态壁纸的帧率一般被限定在15~20 f/s左右,对GPU的性能需求较低;不同的3D游戏对于GPU性能的需求也大不相同, 即使在同一个游戏中,对GPU性能的需求也是随着场景的变化而不断变化的。GPU性能测试软件需要反映GPU 的最高性能,对GPU处理能力的要求远超其他应用程序。根据以上分析,如果GPU始终以固定的频率运行,则会出现两种情况:对于低复杂度的任务,若GPU运行在高频,则性能过剩,造成功耗的浪费[41;对于高复杂度的任务,若GPU没有运行在足够高的频率,则无法满足性能需求。因此最理想的情况是GPU 能够根据需求快速地调整频率,以提供期望的性能。

2 GPU频率一性能模型

2.1选择GPU 工作频率

Android系统的时钟模块可以为GPU提供多种频率,GPU动态调频的工作频率从这些频率中选出。在备选频率中,选择能满足最低性能需求的最低频率作为最低工作频率,选择GPU能正常工作的最高频率作为最高工作频率。在最低和最高工作频率之间尽可能等间隔地选择工作频率,并且相邻频率的间隔不能太小,否则GPU容易在相邻的两个频率上反复切换。以1 200 MHz的输入时钟为例,通过分频可以得到75 MHz、100 MHz、120 MHz、150 MHz、20o MHz、240 MHz、300 MHz、400 MHz、600 MHz等频率。根据上述方法首先确定最低工作频率为100 MHz,最高工作频率为400 MHz。考虑到相邻工作频率之间的间隔,在1O0 MHz~400 MHz之间的频率中选择200 MHz和300 MHz作为工作频率。

2.2测量GPU相对性能

GPU的性能可以通过运行Nenamark2、GLBenchmark、Basemark等专业的GPU性能测试软件测量得到的帧率反映出来。图1是测量得到的某GPU的频率一帧率对应关系图。不同的测试软件下发给GPU 的任务量不同,因此测得的帧率有所差异,但是帧率与频率之间都呈现近似分段线性的关系,且频率越高帧率的增长速度越缓慢。这是因为随着频率的增加,GPU内部某个模块会最先达到性能瓶颈,从而影响整体性能的提升。

设GPU共有Ⅳ 个工作频率,分别为fi, 1,2,? ,Ⅳ,fi 对应的帧率为 ,相对性能Ri=Pi/PI。表1是运行性能测试软件得到的3组相对性能值。从表中可看出,通过不同的性能测试软件测得的 值是基本一致的。综合R 值就可以建立该GPU 的频率一性能模型,如图2所示。

3 GPU动态调频算法

在Android系统的主界面切换、动态壁纸、游戏等3D应用场景中,GPU的负载在几帧到几十帧的短时间内具有相关性, 因此可以根据过去一段时问内的GPU负载预测将来的GPU性能需求。为了兼顾精确度和复杂度的需求,本文采用一种基于历史值加权平均的动态调频算法,算法可分为4步:

(1)每隔周期T 计算GPU的负载。由于只有部分GPU驱动提供了统计负载的专用接口 Sl,所以本文介绍一种近似估计GPU负载的通用方法。GPU都具有工作状态与空闲状态这两种基本的电源状态,可能还具有其他一些临时状态。在GPU驱动中根据电源状态的转换统计出一个周期内GPU的工作时间Tworking和空闲时间 Tklle,估算出GPU负载率 L:

如果忽略掉GPU处于临时状态所的一些时间,则可以推导出下式:

可以认为GPU 的相对负载 等于GPU 负载率与GPU处于当前频率点. 时的相对性能 的乘积,这样可以得出下式:

假设LCD的显示帧率为60 f/s,则T值可在16 ms~50 ms范围取值,即LCD显示1~3帧的时间。这样计算出的GPU负载值包含了1~3帧的统计信息,且算法的跟踪速度较快。

(2)预测下一周期GPU负载。预测GPU负载 W【n+1】由历史值加权计算得出

其中,W[n—k】,k=0,l,? ,K一1为前K 个周期的GPU负载,K为大于0的常数。hD]为预测系数,离当前时刻越

近的GPU负载值的权重越大,即满足0≤h[K-1】

4实验结果

本文在Android4.1系统上,选择了界面切换、动态壁纸(bubbles)、捕鱼达人游戏和Nenamark2 4种典型的应用场景测试动态调频的效果。作为测试对象的某GPU有4种工作频率:100 MHz、200 MHz、300 MHz和400 MHz。实验参数选择如下:GPU负载的统计周期T=30 ms,式(5)中K=4,预测系数h[0】=0.4,h[1]=0.3,h[2]=0.2,h【3]=0.1,性能门限/3=0.9。在每个应用场景下随机抽取10 S的统计数据,如表2所示。

表2中,预测负载误差是指预测负载值与实际负载值的平均误差。由于GPU只有4个离散的工作频率,因此预测频率的错误率比预测负载误差小很多。预测频率的准确率不仅与预测负载误差的大小有关,还与应用对GPU性能的需求范围有关。如果应用对GPU性能的需求变化大,GPU可能的工作频率多,频率的调整比较频繁,则预测频率的准确率就会降低。实验结果表明,4种典型场景下预测GPU工作频率的准确性都达到了95%以上。

GPU负载统计周期为30 I/1S时,在最差情况下,即GPU的初始频率为100 MHz、需求工作频率为400 MHz时,动态调频算法只需要8个周期,即240 ms就可以完成调频的过程。因此对于各种3D应用,动态调频算法都能快速跟踪GPU 负载的变化,及时调整频率以满足需求。

本文介绍了一种基于Android系统的GPU 动态调频方案,可以有效降低GPU的动态功耗,延长移动终端的工作时间。通过调整动态调频算法的系数,方案适用于多种GPU,且易于移植到不同版本的Android系统上。针对特定的GPU,还可以通过GPU驱动中提供的其他一些有用信息以及GPU厂商提供的开发工具对方案进行优化。本方案已申请国家发明专利,并在多款平板电脑产品上应用实施。

扫一扫电子创新网微信号,收看深度资讯!

android 系统gpu 调试_基于Android系统的GPU动态调频方案 | Imagination中文技术社区相关推荐

  1. android个人理财通项目_基于Android个人理财系统设计与实现.doc

    基于Android个人理财系统设计与实现 基于Android个人理财系统设计与实现 摘要:随着Android移动应用的飞速发展人们的日常生活越来越离不开移动应用设备.该系统是基于Android移动应用 ...

  2. android个人理财通项目_基于Android平台的个人理财系统

    [实例简介] 该项目基于Eclispe开发,使用了Sqlite数据库进行收入支出的存储,并且实现了用户登录注册功能,界面功能很完善 [实例截图] [核心代码] FinancialSys └── Fin ...

  3. mysql异地多活方案_基于MGR高可用异地多活方案-阿里云开发者社区

    一.概述 主要目的实现MySQL高可用解决方案,实现异地多活. 二.实现构思 基于MGR实现高可用异地多活 首先要基于位置信息进行分片,例如华北 华中,华南,程序层要进行ip过滤和判断, 针对不同的i ...

  4. Android开发英语听力软件,基于Android平台的大学英语听力学习系统的设计与实现...

    摘要: 随着信息技术的飞速发展,移动设备给学习提供了一种全新的学习模式,使学者能够在任何时间.任何地点获得自己想要的知识,实现自主学习.本文对基于Android平台的大学英语听力学习系统展开研究,旨在 ...

  5. Java毕业设计_基于Android的校园二手商品交易平台

    基于Android的校园二手商品交易平台 基于Android的校园二手商品交易平台mysql数据库创建语句 基于Android的校园二手商品交易平台oracle数据库创建语句 基于Android的校园 ...

  6. Java毕业设计_基于Android 的日用百货销售App

    基于Android 的日用百货销售App 基于Android 的日用百货销售Appmysql数据库创建语句 基于Android 的日用百货销售Apporacle数据库创建语句 基于Android 的日 ...

  7. android新闻客户端实验报告,基于Android平台的新闻客户端设计与实现

    摘 要 在Android开发平台上,并在JavaWeb开发的PC端新闻网站的基础上结合现在的需求开发了移动版的新闻客户端App,这个系统设计主要分为用户登录验证模块.新闻列表的显示功能模块以及新闻内容 ...

  8. 基于Android的网络菜谱app,基于Android平台的菜谱实现

    <基于Android平台的菜谱实现>由会员分享,可在线阅读,更多相关<基于Android平台的菜谱实现(14页珍藏版)>请在人人文库网上搜索. 1.基于Android平台的菜谱 ...

  9. android 系统gpu 调试_[RK3288][Android6.0] 调试笔记 --- 读取当前DDR和GPU频率方法

    Platform: Rockchip OS: Android 6.0 Kernel: 3.10.92 ddr和gpu的clock都受dvfs模块管控, 所以只要执行: root@rk3288:/ # ...

最新文章

  1. docker 简单入门(一)
  2. python不换行_Python print 输出时不换行
  3. Python实现快速傅里叶变换(FFT)
  4. 简略图解:输入 url 到出现页面,浏览器做了什么?
  5. html5储存类型特点,避免踩雷!你不得不知的 HTML5 “新”特性
  6. 使用flot.js 发现x轴y轴无法显示轴名称
  7. log4j的使用 20220228
  8. STL常用函数总结-stack
  9. hihocoder1241 Best Route in a Grid
  10. php static 关键字
  11. 索引法则--尽量使用覆盖索引
  12. linux opencl安装方法,如何在Ubuntu上安装libOpenCL.so
  13. imsi、 ICCID、ki、IMEI
  14. 2 Features Engineering for Machine Learning中文翻译系列(二)
  15. R| 混合效应模型,lme4
  16. java bridge_JavaBridge
  17. 【博客5】缤果LabView串口调试助手V2.0 (高级篇)
  18. phpstudy 403 forbidden
  19. evus是什么意思_美国签证和EVUS之间的区别是什么
  20. height和line-height的区别(简单易懂)

热门文章

  1. stl文件怎么用Java读取_vtk对stl文件进行下采样
  2. 多可文档管理的数据备份
  3. ubuntu16.04通过网络访问windows共享文件夹(samba)
  4. 计算机网络实验一、验证性实验
  5. linux下使用VSCode的C++添加json问题。
  6. android wine教程_如何在 Android 上借助 Wine 来运行 Windows Apps
  7. android 获取cpu温度
  8. QQ邮箱测试域用户密码过期邮件提示
  9. Netbackup5230备份一体机重删率异常故障分析日志收集
  10. java tea bag_设计模式系列教程—Template Method Pattern(模板方法模式)