调频方法、调频装置、存储介质与电子设备转让专利

申请号 : CN201910939771.X

文献号 : CN110647401B

文献日 :

基本信息:

PDF:

法律信息:

相似专利:

发明人 : 黄志根

申请人 : OPPO(重庆)智能科技有限公司

摘要 :

本公开提供了一种调频方法、调频装置、存储介质与电子设备,涉及计算机技术领域。该方法包括:响应于待运行任务组中的目标任务开始运行,检测延迟调频模式的状态;当所述延迟调频模式为关闭状态时,调用原生的调度器进行调频;当所述延迟调频模式为开启状态时,在预设延迟时间后检测所述目标任务的状态;如果在所述预设延迟时间后所述目标任务处于运行状态,则调用预设的实时调频线程进行调频。本公开可以在任务运行中快速判断出是否需要调频,并通过实时调频线程立即调频,解决了相关技术中调频与任务运行不匹配的问题,提高调频的针对性和时效性,改善对于任务运行的实际加速效果。

权利要求 :

1.一种调频方法,其特征在于,包括:

响应于待运行任务组中的目标任务开始运行,检测延迟调频模式的状态;

当所述延迟调频模式为关闭状态时,调用原生的调度器根据所述待运行任务组的负载参数更新全局负载参数,并根据所述全局负载参数进行调频;

当所述延迟调频模式为开启状态时,在预设延迟时间后检测所述目标任务的状态;所述预设延迟时间大于或等于所述目标任务正常运行所需的时间;

如果在所述预设延迟时间后所述目标任务处于运行状态,则调用预设的实时调频线程进行调频。

2.根据权利要求1所述的方法,其特征在于,所述目标任务为所述待运行任务组中的第一个任务;

所述待运行任务组中的目标任务开始运行,包括:所述待运行任务组中的第一个任务进入运行队列。

3.根据权利要求2所述的方法,其特征在于,在调用预设的实时调频线程进行调频后,所述方法还包括:当所述待运行任务组中的最后一个任务运行结束时,关闭所述实时调频线程。

4.根据权利要求1所述的方法,其特征在于,所述目标任务包括周期性运行的线程;所述预设延迟时间为所述线程在每个周期的运行时间。

5.根据权利要求4所述的方法,其特征在于,所述线程包括连续帧的渲染线程,所述预设延迟时间为每一帧的时间。

6.根据权利要求1所述的方法,其特征在于,所述方法还包括:当生成所述待运行任务组时,获取所述待运行任务组中的任务所属的程序;

如果所述待运行任务组中的任务所属的程序包括预设程序,则开启所述延迟调频模式。

7.根据权利要求1所述的方法,其特征在于,所述方法还包括:当生成所述待运行任务组时,获取所述待运行任务组的负载参数;

根据所述负载参数确定是否需要调频,当确定需要调频时,执行所述响应于待运行任务组中的目标任务开始运行,检测延迟调频模式的状态。

8.一种调频装置,其特征在于,包括:

模式检测模块,用于响应于待运行任务组中的目标任务开始运行,检测延迟调频模式的状态;

原生调频模块,用于当所述延迟调频模式为关闭状态时,调用原生的调度器根据所述待运行任务组的负载参数更新全局负载参数,并根据所述全局负载参数进行调频;

延迟检测模块,用于当所述延迟调频模式为开启状态时,在预设延迟时间后检测所述目标任务的状态;所述预设延迟时间大于或等于所述目标任务正常运行所需的时间;

实时调频模块,用于如果在所述预设延迟时间后所述目标任务处于运行状态,则调用预设的实时调频线程进行调频。

9.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现权利要求1至7任一项所述的方法。

10.一种电子设备,其特征在于,包括:

处理器;以及

存储器,用于存储所述处理器的可执行指令;

其中,所述处理器配置为经由执行所述可执行指令来执行权利要求1至7任一项所述的方法。

说明书 :

调频方法、调频装置、存储介质与电子设备

技术领域

[0001] 本公开涉及计算机技术领域,尤其涉及一种调频方法、调频装置、计算机可读存储介质与电子设备。

背景技术

[0002] 调频是指调节电子设备上处理器的运行频率,包括对CPU(Central Processing Unit,中央处理器)、GPU(Graphics Processing Unit,图形处理器)等的调频,以提高性能或降低功耗。
[0003] 相关技术中,调频方法主要包括两种:第一种是从系统层级进行统一调频,CPU上运行的任务都得到加速(提频时)或减速(降频时),显然这种方法的针对性较差,使得一部分无需调频的任务也得到调频,造成资源浪费;第二种是从任务层级进行调频,仅针对需要调频的任务进行调频,但是相关技术存在调频时间和任务运行之间的不匹配问题,导致任务无法得到有效的调频优化。
[0004] 因此,有必要提出一种新的调频方法,以解决上述技术问题。
[0005] 需要说明的是,在上述背景技术部分公开的信息仅用于加强对本公开的背景的理解,因此可以包括不构成对本领域普通技术人员已知的现有技术的信息。

发明内容

[0006] 本公开提供一种调频方法、调频装置、计算机可读存储介质与电子设备,进而至少在一定程度上提高调频的针对性和时效性。
[0007] 本公开的其他特性和优点将通过下面的详细描述变得显然,或部分地通过本公开的实践而习得。
[0008] 根据本公开的第一方面,提供一种调频方法,包括:响应于待运行任务组中的目标任务开始运行,检测延迟调频模式的状态;当所述延迟调频模式为关闭状态时,调用原生的调度器进行调频;当所述延迟调频模式为开启状态时,在预设延迟时间后检测所述目标任务的状态;如果在所述预设延迟时间后所述目标任务处于运行状态,则调用预设的实时调频线程进行调频。
[0009] 根据本公开的第二方面,提供一种调频装置,包括:模式检测模块,用于响应于待运行任务组中的目标任务开始运行,检测延迟调频模式的状态;原生调频模块,用于当所述延迟调频模式为关闭状态时,调用原生的调度器进行调频;延迟检测模块,用于当所述延迟调频模式为开启状态时,在预设延迟时间后检测所述目标任务的状态;实时调频模块,用于如果在所述预设延迟时间后所述目标任务处于运行状态,则调用预设的实时调频线程进行调频。
[0010] 根据本公开的第三方面,提供一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现上述调频方法。
[0011] 根据本公开的第四方面,提供一种电子设备,包括:处理器;以及存储器,用于存储所述处理器的可执行指令;其中,所述处理器配置为经由执行所述可执行指令来执行上述调频方法。
[0012] 本公开的技术方案具有以下有益效果:
[0013] 根据上述调频方法、调频装置、计算机可读存储介质与电子设备,响应于待运行任务组中的目标任务开始运行,当延迟调频模式为关闭状态时,调用原生的调度器进行调频,当延迟调频模式为开启状态时,在预设延迟时间后检测目标任务的状态,若处于运行状态,则调用预设的实时调频线程进行调频。一方面,通过设置延迟调频模式以及实时调频线程,在运行性能需求较高的任务时,可以在延迟调频模式下,调用实时调频线程,根据运行队列中的任务情况进行快速实时调频,使调频的时间区间和任务运行的时间区间基本重合,从而解决相关技术中调频与任务运行不匹配的问题,提高调频的针对性和时效性,改善调频后对于任务运行的实际加速效果。另一方面,设置预设延迟时间,在目标任务开始运行的预设延迟时间后检测其是否运行结束,从而快速判断出是否发生卡顿等异常情况,以确定是否需要调频,相比于相关技术中通过调度器计算负载进行判断的方式,本公开的技术方案更为高效。再一方面,通过控制延迟调频模式的开关状态,可以在实时调频线程和原生的调度器之间切换调频机制,实时调频线程可以实现任务级的快速调频,调度器可以从负载的角度实现基于调频的资源调配,从而可以根据实际需求选择合适的调频模式,具有较高的灵活性。
[0014] 应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。

附图说明

[0015] 此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施方式,并与说明书一起用于解释本公开的原理。显而易见地,下面描述中的附图仅仅是本公开的一些实施方式,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
[0016] 图1示出相关技术中实际调频结果的示意图;
[0017] 图2示出本示例性实施方式中一种调频方法的流程图;
[0018] 图3示出本示例性实施方式中一种调频方法的子流程图;
[0019] 图4示出本示例性实施方式中一种调频流程的示意图;
[0020] 图5示出本示例性实施方式中一种调频装置的结构框图;
[0021] 图6示出本示例性实施方式中一种用于实现上述方法的计算机可读存储介质;
[0022] 图7示出本示例性实施方式中一种用于实现上述方法的电子设备。

具体实施方式

[0023] 现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的范例;相反,提供这些实施方式使得本公开将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施方式中。在下面的描述中,提供许多具体细节从而给出对本公开的实施方式的充分理解。然而,本领域技术人员将意识到,可以实践本公开的技术方案而省略所述特定细节中的一个或更多,或者可以采用其它的方法、组元、装置、步骤等。在其它情况下,不详细示出或描述公知技术方案以避免喧宾夺主而使得本公开的各方面变得模糊。
[0024] 此外,附图仅为本公开的示意性图解,并非一定是按比例绘制。图中相同的附图标记表示相同或类似的部分,因而将省略对它们的重复描述。附图中所示的一些方框图是功能实体,不一定必须与物理或逻辑上独立的实体相对应。可以采用软件形式来实现这些功能实体,或在一个或多个硬件模块或集成电路中实现这些功能实体,或在不同网络和/或处理器装置和/或微控制器装置中实现这些功能实体。
[0025] 相关技术中,以EAS(Energy Aware Scheduling,能源调度策略)中的Schedtune(进程调度)原生机制为例,如图1所示,当运行游戏时,需要通过渲染线程(Render)渲染游戏画面,为了加速渲染过程,减少画面的卡顿,需要进行调频(主要是提频,以提高CPU/GPU性能)。然而,Schetune原生机制中,通过系统负载情况判断是否调频,当渲染线程运行了一段时间后,如果系统性能无法满足线程的需求,会反映到各项系统负载参数上,进而再进行调频。该过程的响应时间较长,通常存在着较为明显的滞后问题,图1中实际提频区间总是晚于渲染线程运行的区间,从而影响渲染线程的实际加速效果。
[0026] 鉴于上述一个或多个问题,本公开的示例性实施方式首先提供一种调频方法,该方法可以应用于计算机、智能手机、平板电脑等各种电子设备。图2示出了该方法的一种流程,可以包括以下步骤S210至S240:
[0027] 步骤S210,响应于目标任务开始运行,检测延迟调频模式的状态。
[0028] 其中,待运行任务组是由多个待运行任务形成的任务组,例如在Android系统中,待运行任务组可以是Boost Group;目标任务可以是待运行任务组中的任一任务(但通常不是任务组中的最后一个任务)。延迟调频模式是本示例性实施方式中增加的一种调频模式,区别于原生的调频模式,可以实现快速实时调频。系统内可以设置延迟调频模式的开关,用于开启或关闭延迟调频模式,或者设置延迟调频模式的状态变量,例如设置Defered Boost变量,当Defered Boost值为On时,表示延迟调频模式已开启,当Defered Boost值为Off时,表示延迟调频模式已关闭。
[0029] 关于如何控制延迟调频模式的状态,下面提供几种具体实施方式,但下述内容不应对本公开的保护范围造成限定:
[0030] (1)可以人为控制延迟调频模式的状态,例如在系统设置中增加关于延迟调频模式的选项,使用户可以自定义开启或关闭延迟调频模式。
[0031] (2)也可以将延迟调频模式的状态和特定的程序关联起来,例如系统在运行大型游戏或图形处理软件等对于处理性能要求较高的程序时,可以自动开启延迟调频模式,当上述程序关闭时,可以自动关闭延迟调频模式。基于此,在一种实施方式中,参考图3所示,可以通过以下步骤S310和S320开启延迟调频模式:
[0032] 步骤S310,当生成待运行任务组时,获取待运行任务组中的任务所属的程序;
[0033] 步骤S320,如果待运行任务组中的任务所属的程序包括预设程序,则开启延迟调频模式。
[0034] 其中,预设程序是事先确定的需要延迟调频模式的程序,例如上述大型游戏或图形处理软件等。由此,在生成每个待运行任务组时,如果其中的任务包括预设程序下的任务,说明当前有预设程序在运行或即将运行,可以开启延迟调频模式。进一步的,如果待运行任务组中的任务所属的程序包括预设程序,可以将该待运行任务组标记为快速调频任务组,当系统中所有的快速调频任务组运行结束时,即系统当前运行的任务组中不包括快速调频任务组时,可以关闭延迟调频模式。通过任务组对延迟调频模式的开关进行控制,可以提高针对性。
[0035] 进一步的,也可以将延迟调频模式的状态和特定的事件关联起来,例如发生活动(Activity)切换,触屏点击等事件时,可以自动开启延迟调频模式。
[0036] (3)还可以根据系统的负载情况控制延迟调频模式的状态,例如在系统负载较高,或者运行的进程或线程数量较多的情况下,开启延迟调频模式,或者在设备温度较高的情况下,关闭延迟调频模式。
[0037] 需要说明的是,可以采用上述任意多种方式的组合,以控制延迟调频模式的开启或关闭。
[0038] 步骤S220,当延迟调频模式为关闭状态时,调用原生的调度器进行调频。
[0039] 其中,原生的调度器可以通过原生机制进行调频。具体而言,调度器可以获取待运行任务组的负载参数,根据该负载参数对系统资源进行统一的调度,并确定调频的参数,进行调频。
[0040] 在一种可选的实施方式中,步骤S220可以具体包括:调用原生的调度器根据待运行任务组的负载参数更新全局负载参数,并根据全局负载参数进行调频。例如,调度器可以获取待运行任务组的Boost参数,并综合其他任务情况,更新全局负载参数Utility,再根据Utility计算所需的CPU/GPU频率,从而进行调频。可见,该过程需要一定的处理及响应时间,无法立即实现调频。
[0041] 步骤S230,当延迟调频模式为开启状态时,在预设延迟时间后检测目标任务的状态。
[0042] 其中,预设延迟时间是为了检测目标任务的运行是否异常而设置的时间参数,通常可以是目标任务正常运行所需的时间(可以留出一定的余量)。举例说明,以目标任务开始运行的时间为T0,预设延迟时间为Tw,在T0+Tw时刻检测目标任务的状态,主要检测目标任务是否运行结束,正常情况下目标任务此时应当运行结束,若其仍处于运行状态,则说明运行速度慢于预期水平,可能存在卡顿的情况。
[0043] 在一种可选的实施方式中,可以设置定时器Timer,将Timer的时间设置为预设延迟时间,当目标任务开始运行时,触发Timer开始计时,当计时到预设延迟时间时,检测目标任务的状态。
[0044] 步骤S240,如果在预设延迟时间后目标任务处于运行状态,则调用预设的实时调频线程进行调频。
[0045] 由上可知,在预设延迟时间后目标任务仍处于运行状态。说明目标任务运行期间可能出现了卡顿等异常情况,需要立即进行调频已改善运行,可以调用实时调频线程。本示例性实施方式中,实时调频线程是基于延迟调频模式设置的一个用于快速调频的线程,其原理是读取运行队列中的任务情况,根据任务情况确定需要调频的程度、时间等参数,立即实施调频。当延迟调频模式开启时,调用实时调频线程进行调频。具体而言,由于此时运行队列中运行目标任务,实时调频线程可以读取该任务的信息,进行调频,如果运行队列还包括其他需要调频的任务,则实时调频线程也可以读取这些任务的信息,进行调频。以目标任务为待运行任务组中的任务A为例,实时调频线程读取任务A的信息,确定任务A分配至CPU#1运行,则可以对应的提高CPU#1的频率。
[0046] 基于上述内容,本示例性实施方式中,响应于待运行任务组中的目标任务开始运行,当延迟调频模式为关闭状态时,调用原生的调度器进行调频,当延迟调频模式为开启状态时,在预设延迟时间后检测目标任务的状态,若处于运行状态,则调用预设的实时调频线程进行调频。一方面,通过设置延迟调频模式以及实时调频线程,在运行性能需求较高的任务时,可以在延迟调频模式下,调用实时调频线程,根据运行队列中的任务情况进行快速实时调频,使调频的时间区间和任务运行的时间区间基本重合,从而解决相关技术中调频与任务运行不匹配的问题,提高调频的针对性和时效性,改善调频后对于任务运行的实际加速效果。另一方面,设置预设延迟时间,在目标任务开始运行的预设延迟时间后检测其是否运行结束,从而快速判断出是否发生卡顿等异常情况,以确定是否需要调频,相比于相关技术中通过调度器计算负载进行判断的方式,本示例性实施方式更为高效。再一方面,通过控制延迟调频模式的开关状态,可以在实时调频线程和原生的调度器之间切换调频机制,实时调频线程可以实现任务级的快速调频,调度器可以从负载的角度实现基于调频的资源调配,从而可以根据实际需求选择合适的调频模式,具有较高的灵活性。
[0047] 由上可知,本示例性实施方式实际是以任务组为单位进行调频的控制。考虑到有些任务组对处理性能要求较高,需要调频,而有些任务组对处理性能要求较低,无需调频。在一种可选的实施方式中,在步骤S210之前,可以先执行以下步骤:
[0048] 当生成待运行任务组时,获取待运行任务组的负载参数;
[0049] 根据上述负载参数确定是否需要调频;
[0050] 当确定需要调频时,执行步骤S210。
[0051] 其中,负载参数是反映待运行任务组占用系统资源多少,或对于性能要求高低的一个或多个指标参数,例如对CPU的占用率、单位时间内运行的数据量等。在生成待运行任务组时,由于还未实际运行其中的任务,负载参数可以通过历史运行数据进行估计,或者通过线程数量等已分配、已确定的参数进行计算得到。根据待运行任务组的负载参数,可以确定当待运行任务组运行时,是否需要调频,具体而言,负载参数高时需要调频,或者当前系统剩余资源不足以支持待运行任务组的负载时,需要调频,等等。当确定需要调频时,可以监控待运行任务组的状态,当其中的目标任务开始运行时,则可以采用图2所示的方法步骤进行调频;当确定不需要调频时,可以在当前处理器频率下正常运行其中的任务。
[0052] 进一步的,根据负载参数确定是否需要调频,可以具体通过以下方式实现:
[0053] 根据负载参数计算待运行任务组的最大加速值;
[0054] 当最大加速值高于预设值时,确定需要调频。
[0055] 其中,最大加速值是对待运行任务组运行期间所需的最大加速程度的度量,例如可以是Android系统中的Boost Max值,可以通过负载参数计算平均加速值,在此基础上通过对待运行任务组峰值情况的估计,以平均加速值加上幅度值计算最大加速值。最大加速值具有估计预测的性质,为了任务能够顺利运行,在计算最大加速值时还可以留出一定的余量,例如基于待运行任务组的峰值,加上一定的余量得到幅度值,并以此计算最大加速值,以保证能够满足任务的性能需求。预设值是对系统正常运行能力的度量,可以根据系统硬件条件、历史运行数据、经验值等设定,可视为用于衡量是否需要加速的阈值,当最大加速值高于预设值时,说明系统正常频率下无法满足任务需求,因而需要调频。通过计算最大加速值,并和预设值进行比较的方式,可以较为准确地估计出待运行任务组的运行状况,以确定是否需要调频,从而减少在无需调频时进行调频的情况,提高系统资源的使用效率。
[0056] 在一种可选的实施方式中,目标任务可以是待运行任务组中的第一个任务;待运行任务组中的目标任务开始运行,可以包括:待运行任务组中的第一个任务进入运行队列。通过这样的方式,在待运行任务组的第一个任务运行时即确定是否存在卡顿等异常,从而在异常情况下进行实时调频,可以保证后续任务的正常运行。
[0057] 进一步的,在调用预设的实时调频线程进行调频后,当待运行任务组的最后一个任务运行结束时,可以关闭实时调频线程。其中,在关闭实时调频线程前,可以先恢复处理器的运行频率。最后一个任务运行结束,表示待运行任务组运行结束,此时无需再进行调频,关闭实时调频线程。换而言之,在正常不需要调频的情况下,实时调频线程处于关闭或休眠状态,后续如果生成了其他需要调频的任务组,并且延迟调频模式为开启状态,则可以再次启动实时调频线程。
[0058] 在一种可选的实施方式中,目标任务可以是周期性运行的线程,预设延迟时间可以是该线程在每个周期的运行时间。例如正常情况下目标任务在每个周期运行Tw时间,则第一个周期运行时,将预设延迟时间设为Tw,通过在Tw后检测目标任务的运行状态,确定其是否运行卡顿,如果卡顿,立即进行调频,后续周期可以保证目标任务的正常运行。
[0059] 进一步的,上述线程可以是连续帧的渲染线程,预设延迟时间可以是每一帧的时间。例如在运行游戏时,逐帧渲染游戏画面,假设帧率为50fps,即每一帧的时间为20ms,可以将预设延迟时间设为20ms。在每一帧开始渲染时,延迟20ms检测该帧是否渲染完成,若还在渲染中,则说明渲染线程的运行出现卡顿,此时采用调频的方式进行优化加速,可以保证后续帧的渲染速度。
[0060] 图4示出了一种调频流程的示意图。待运行任务组Boost Group中包括n个任务,分别为Task1、Task2、…、Taskn。当第一个任务Task1开始运行时,系统检测当前Defered Boost变量值,分别如下处理:
[0061] 若Task1开始运行时Defered Boost变量值为On,表示延迟调频模式为开启状态,则在预设延迟时间Tw后检测Task1是否仍在运行状态;若Task1在Tw后仍在运行状态,则说明出现卡顿,调用实时调频线程根据Boost Group的情况对相应的CPU进行调频,例如其中的Task运行在CPU2上,则实时调频线程调整CPU2的频率,通常是提高运行频率以提高性能;在Boost Group运行期间,若Defered Boost变量值不变,即一直保持为On,则实时调频线程可以持续化进行调频,并且还可以根据实时负载情况进行动态调频。
[0062] 若Task1开始运行时检测Defered Boost变量值为Off,表示延迟调频模式为关闭状态,或者,虽然Defered Boost变量值为On,但是Tw后检测Task1已经运行结束,表示无需进行实时调频,在这两种情况下都可以采用原生调频机制。具体而言,可以计算Boost Group的最大加速值Boost Max,调用调度器根据Boost Max值更新全局负载参数Utility,再对CPU进行调频。
[0063] 当最后一个任务Taskn运行结束时,同样检测当前的Defered Boost变量值,若为On,则调用实时调频线程将CPU恢复到正常频率,若为Off,则调用调度器,通过计算Utility将CPU恢复到正常频率。
[0064] 需要补充的是,在Boost Group运行期间,调用实时调频线程提高CPU频率后,如果Defered Boost变量值被修改为Off,即关闭了延迟调频模式,当Boost Group运行结束时,可以通过调度器恢复CPU频率;相反情况也成立,调用调度器提高CPU频率后,如果Defered Boost变量值被修改为On,即开启了延迟调频模式,当Boost Group运行结束时,可以通过实时调频线程恢复CPU频率;即在一次调频中,提频和降频可以通过不同的调频机制实现,本公开对此不做限定。
[0065] 本公开的示例性实施方式还提供一种调频装置,如图5所示,该调频装置500可以包括:模式检测模块510,用于响应于待运行任务组中的目标任务开始运行,检测延迟调频模式的状态;原生调频模块520,用于当延迟调频模式为关闭状态时,调用原生的调度器进行调频;延迟检测模块530,用于当延迟调频模式为开启状态时,在预设延迟时间后检测目标任务的状态;实时调频模块540,用于如果在预设延迟时间后目标任务处于运行状态,则调用预设的实时调频线程进行调频。
[0066] 在一种可选的实施方式中,目标任务可以是待运行任务组中的第一个任务;模式检测模块510,还可以用于响应于待运行任务组中的第一个任务进入运行队列,检测延迟调频模式的状态。
[0067] 进一步的,实时调频模块540,还可以用于当待运行任务组的最后一个任务运行结束时,关闭实时调频线程。
[0068] 在一种可选的实施方式中,目标任务可以是周期性运行的线程,上述预设延迟时间可以是该线程在每个周期的运行时间。
[0069] 进一步的,上述线程可以包括连续帧的渲染线程,上述预设延迟时间可以是每一帧的时间。
[0070] 在一种可选的实施方式中,调频装置500还可以包括:模式控制模块,用于当生成待运行任务组时,获取待运行任务组中的任务所属的程序,以及如果待运行任务组中的任务所属的程序包括预设程序,则开启延迟调频模式。
[0071] 在一种可选的实施方式中,原生调频模块520,还可以用于调用原生的调度器根据待运行任务组的负载参数更新全局负载参数,并根据全局负载参数进行调频。
[0072] 上述装置中各模块的具体细节在方法部分实施方式中已经详细说明,未披露的细节内容可以参见方法部分的实施方式内容,因而不再赘述。
[0073] 所属技术领域的技术人员能够理解,本公开的各个方面可以实现为系统、方法或程序产品。因此,本公开的各个方面可以具体实现为以下形式,即:完全的硬件实施方式、完全的软件实施方式(包括固件、微代码等),或硬件和软件方面结合的实施方式,这里可以统称为“电路”、“模块”或“系统”。
[0074] 本公开的示例性实施方式还提供了一种计算机可读存储介质,其上存储有能够实现本说明书上述方法的程序产品。在一些可能的实施方式中,本公开的各个方面还可以实现为一种程序产品的形式,其包括程序代码,当程序产品在电子设备上运行时,程序代码用于使电子设备执行本说明书上述“示例性方法”部分中描述的根据本公开各种示例性实施方式的步骤。
[0075] 参考图6所示,描述了根据本公开的示例性实施方式的用于实现上述方法的程序产品600,其可以采用便携式紧凑盘只读存储器(CD‑ROM)并包括程序代码,并可以在电子设备,例如个人电脑上运行。然而,本公开的程序产品不限于此,在本文件中,可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
[0076] 程序产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以为但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑盘只读存储器(CD‑ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
[0077] 计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。可读信号介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
[0078] 可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、有线、光缆、RF等等,或者上述的任意合适的组合。
[0079] 可以以一种或多种程序设计语言的任意组合来编写用于执行本公开操作的程序代码,程序设计语言包括面向对象的程序设计语言—诸如Java、C++等,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(LAN)或广域网(WAN),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
[0080] 本公开的示例性实施方式还提供了一种能够实现上述方法的电子设备。下面参照图7来描述根据本公开的这种示例性实施方式的电子设备700。图7显示的电子设备700仅仅是一个示例,不应对本公开实施方式的功能和使用范围带来任何限制。
[0081] 如图7所示,电子设备700可以以通用计算设备的形式表现。电子设备700的组件可以包括但不限于:至少一个处理单元710、至少一个存储单元720、连接不同系统组件(包括存储单元720和处理单元710)的总线730和显示单元740。
[0082] 存储单元720存储有程序代码,程序代码可以被处理单元710执行,使得处理单元710执行本说明书上述“示例性方法”部分中描述的根据本公开各种示例性实施方式的步骤。例如,处理单元710可以执行图2或图3所示的方法步骤。
[0083] 存储单元720可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(RAM)721和/或高速缓存存储单元722,还可以进一步包括只读存储单元(ROM)723。
[0084] 存储单元720还可以包括具有一组(至少一个)程序模块725的程序/实用工具724,这样的程序模块725包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
[0085] 总线730可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理单元或者使用多种总线结构中的任意总线结构的局域总线。
[0086] 电子设备700也可以与一个或多个外部设备800(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该电子设备700交互的设备通信,和/或与使得该电子设备700能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口750进行。并且,电子设备700还可以通过网络适配器760与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器760通过总线730与电子设备700的其它模块通信。应当明白,尽管图中未示出,可以结合电子设备700使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
[0087] 通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本公开实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD‑ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、终端装置、或者网络设备等)执行根据本公开示例性实施方式的方法。
[0088] 此外,上述附图仅是根据本公开示例性实施方式的方法所包括的处理的示意性说明,而不是限制目的。易于理解,上述附图所示的处理并不表明或限制这些处理的时间顺序。另外,也易于理解,这些处理可以是例如在多个模块中同步或异步执行的。
[0089] 应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本公开的示例性实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。
[0090] 本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其他实施方式。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施方式仅被视为示例性的,本公开的真正范围和精神由权利要求指出。
[0091] 应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限。