一种低功耗分布式调用方法、设备及装置与流程

文档序号:27484089发布日期:2021-11-20 02:09阅读:128来源:国知局
一种低功耗分布式调用方法、设备及装置与流程

1.本技术涉及物联网领域,尤其涉及一种智能设备之间分布式协同互联低功耗调用方法、设备及其装置。


背景技术:

2.随着智能设备不断的进入普通消费者的生活中,智能设备之间的交互也变得越来越多。当某个智能设备需要使用到其它智能设备的某些功能或者某些数据时,智能设备之间将会出现频繁的相互调用。例如,手机通过远程调用的方式调用智能温度计获取某位置的温度信息,又或者手机调用家庭摄像头拍摄一张照片等。对于不同设备之间跨设备的调用、业务执行等,在业界认为是一种“分布式调用”,其涉及到的智能终端也可称为“分布式终端设备”,对应的应用场景也可称为“分布式终端业务场景”。对于存在分布式调用关系的分布式终端设备所在的网络,可称为“分布式终端设备网络”。例如图1所示出的一种分布式终端业务场景,设备a和设备b均可称为分布式终端设备,其中,设备a作为调用者向设备b发起调用业务执行请求,该请求可称为分布式调用请求。设备b作为被调用者在执行完相应操作后,向设备a返回结果或者数据。对于设备a和设备b所处的网络环境,即分布式终端设备网络。
3.当然相较于图1所示出的分布式终端业务场景中仅有设备a和设备b,随着智能设备越来越多,多个设备之间的互动也变得越来越频繁。分布式终端业务场景逐渐由两个分布式终端设备之间的调用,演变为多个分布式终端设备之间的调用。例如图2示出的,可以包括多个不同的分布式终端设备。对于其中的某一个分布式终端设备而言,将有很大概率处理更多的来自不同分布式终端设备的分布式调用请求。显然图2中示出的每个分布式终端设备可以是调用者,也可以是被调用者。
4.可见,对于任意一个分布式终端设备而言,将面临多个调用者发起的分布式调用请求例如图3示出的。随着调用者的不断增加,如图4所示该设备需要处理的分布式调用请求的数量也成倍增长,增长趋势呈现某种线性关系。
5.目前,分布式调用的方案大致分为两种类型,一种是按需发起型分布式调用,例如图5a所示,调用者主动发起分布式调用,将相对应的请通过分布式终端设备网络发送至被调用者,被调用者按照请求执行相应逻辑,然后根据需求返回结果或者数据;而另一种则是定期发起型分布式调用,例如图5b所示,调用者本身可能并不需要发起分布式调用,而是被调用者定期执行某个业务逻辑,然后将相关的结果或者数据返回至调用者,以便调用者使用。


技术实现要素:

6.本技术实施例提供了一种低功耗分布式调用方法,通过确定分布式调用请求对应的精准度阈值,并根据精准度阈值确定最佳被调用设备。并根据自身设备的唤醒机制,在最优时刻发送分布式调用请求至被调用设备,并在最佳时刻读取被调用设备反馈的调用结
果。可以降低网络环境中的调用者和被调用者由于频繁唤醒所造成的功耗问题。
7.第一方面,提供了一种低功耗分布式调用设备,设备为分布式网络中的第一设备,分布式网络还包括至少一个第二设备,其中,第一设备为分布式网络中的一个设备,第二设备为分布式网络中除第一设备以外的其它设备,设备包括:设备主体和低功耗桥接模块;其中,低功耗桥接模块确定分布式调用请求的第一精准度阈值,其中,第一精准度阈值用于约束分布式调用请求;根据第一精准度阈值,确定第一被调用设备,其中,第一被调用设备为至少一个第二设备中的一个设备;在第一时刻通过通信模块发送分布式调用请求至第一被调用设备;在第二时刻通过通信模块接收第一被调用设备发送的调用结果并临时存储至缓存中;设备主体在第三时刻通过向低功耗桥接模块发送分布式调用请求,并获取缓存中存储的调用结果;其中,设备主体和低功耗桥接模块各自具有独立的休眠机制,低功耗桥接模块根据第一被调用设备确定第一时刻和第二时刻;设备主体根据自身的休眠机制,确定第三时刻。
8.在一个可能的实施方式中,低功耗桥接模块还用于,通过通信模块发送配置信息到至少一个第二设备,以便至少一个第二设备根据配置信息确定第二精准度阈值;通过通信模块接收至少一个第二设备发送的第二精准度阈值;根据至少一个第二精准度阈值,确定第一精准度阈值,其中,第一精准度阈值的范围与任意一个第二精准度阈值的范围存在交集。
9.在一个可能的实施方式中,低功耗桥接模块还用于,根据第一精准度阈值,确定分布式调用请求的初始被调用设备,初始被调用设备为至少一个第二设备中的一个设备;通过通信模块发送初始选择信息至初始被调用设备,初始选择信息用于指示初始被调用设备作为第一被调用设备;通过通信模块接收初始被调用设备发送的反馈信息;根据反馈信息,确定分布式调用请求的第一被调用设备。
10.在一个可能的实施方式中,若第三时刻位于第一时刻之前,低功耗桥接模块确定缓存中是否存在调用结果;当缓存中存在调用结果,则设备主体在第一时刻直接调用调用结果;当缓存中不存在调用结果,则低功耗桥接模块确定分布式调用请求的第一精准度阈值。
11.在一个可能的实施方式中,低功耗桥接模块还用于确定调用结果是否满足第一精准度阈值;当调用结果满足第一精准度阈值,则设备主体在第一时刻直接调用所述调用结果;当调用结果不满足第一精准度阈值,则低功耗桥接模块确定分布式调用请求的第一精准度阈值。
12.在一个可能的实施方式中,低功耗桥接模块还用于,根据调用结果,确定分布式调用请求的第三精准度阈值以及第二被调用设备。
13.在一个可能的实施方式中,设备还包括:显示模块,用于当用户准备执行分布式调用请求时,显示提示消息,提示消息用于指示是否选择低功耗模式执行分布式调用请求;低功耗桥接模块还用于,若用户选择低功耗模式执行分布式调用请求,则确定分布式调用请求的第一精准度阈值。
14.在一个可能的实施方式中,第一精准度阈值或第二精准度阈值包括:分布式调用请求的参数阈值信息、分布式调用请求的时效阈值信息和/或分布式调用请求的结果阈值信息。
15.第二方面,提供了一种低功耗分布式调用设备,其特征在于,设备为分布式网络中的第二设备,分布式网络包括第一设备和至少一个第二设备,其中,第一设备为分布式网络中的一个设备,第二设备为分布式网络中除第一设备以外的其它设备,设备包括:设备主体和低功耗桥接模块;其中,低功耗桥接模块,用于通过通信模块接收第一设备发送的分布式调用请求并临时存储至缓存中;在第一时刻向设备主体发送分布式调用请求;设备主体,用于根据分布式调用请求的第一精准度阈值确定调用结果;低功耗桥接模块还用于,通过通信模块将调用结果发送至第一设备;其中,设备主体和低功耗桥接模块各自具有独立的休眠机制,低功耗桥接模块根据设备主体的休眠机制,确定第一时刻。
16.在一个可能的实施方式中,低功耗桥接模块还用于,通过通信模块接收第一设备发送的配置信息,其中,配置信息包括分布式调用请求和第一精准度阈值的阈值范围;根据分布式调用请求,确定第二设备允许被第一设备调用;根据第一精准度阈值的阈值范围,确定第二精准度阈值;通过通信模块将第二精准度阈值发送至第一设备,以便第一设备根据第二精准度阈值确定第一精准度阈值,其中,第一精准度阈值的范围与任意一个第二精准度阈值的范围存在交集。
17.在一个可能的实施方式中,低功耗桥接模块还用于,通过通信模块接收第一设备发送的初始选择信息,初始选择信息用于指示第二设备作为第一被调用设备;根据自身设备的特征信息,确定反馈信息,反馈信息用于表示第二设备是否同意作为第一被调用设备;通过通信模块发送反馈信息至第一设备。
18.在一个可能的实施方式中,分布式网络还包括第三设备,其中,第三设备为分布式网络中的一个设备,第三设备为分布式网络中除第一设备、第二设备以外的一个设备;在第一时刻之前,低功耗桥接模块通过通信模块接收第三设备发送的分布式调用请求;若第三设备发送的分布式调用请求与第一设备发送的分布式调用请求的类型相同,则将第三设备发送的分布式调用请求与第一设备发送的分布式调用请求进行合并。
19.在一个可能的实施方式中,第一精准度阈值或第二精准度阈值包括:分布式调用请求的参数阈值信息、分布式调用请求的时效阈值信息和/或分布式调用请求的结果阈值信息。
20.第三方面,提供了一种低功耗分布式调用方法,方法应用于分布式网络中的第一设备,分布式网络还包括至少一个第二设备,其中,第一设备为分布式网络中的一个设备,第二设备为分布式网络中除第一设备以外的其它设备,方法包括:确定分布式调用请求的第一精准度阈值,其中,第一精准度阈值用于约束分布式调用请求;根据第一精准度阈值,确定第一被调用设备,其中,第一被调用设备为至少一个第二设备中的一个设备;在第一时刻发送分布式调用请求至第一被调用设备;在第二时刻接收第一被调用设备发送的调用结果并临时存储至缓存中;在第三时刻获取缓存中存储的调用结果;其中,第一设备具有独立的休眠机制,第一设备根据第一被调用设备确定第一时刻和第二时刻,以及根据自身设备的休眠机制确定第三时刻。
21.在一个可能的实施方式中,确定分布式调用请求的第一精准度阈值包括:发送配置信息到至少一个第二设备,以便至少一个第二设备根据配置信息确定第二精准度阈值;接收至少一个第二设备发送的第二精准度阈值;根据至少一个第二精准度阈值,确定第一精准度阈值,其中,第一精准度阈值的范围与任意一个第二精准度阈值的范围存在交集。
22.在一个可能的实施方式中,确定第一被调用设备包括:根据第一精准度阈值,确定分布式调用请求的初始被调用设备,初始被调用设备为至少一个第二设备中的一个设备;发送初始选择信息至初始被调用设备,初始选择信息用于指示初始被调用设备作为第一被调用设备;接收初始被调用设备发送的反馈信息;根据反馈信息,确定分布式调用请求的第一被调用设备。
23.在一个可能的实施方式中,方法还包括:若第三时刻位于第一时刻之前,确定缓存中是否存在调用结果;当缓存中存在调用结果,则在第一时刻直接调用调用结果;当缓存中不存在调用结果,则确定分布式调用请求的第一精准度阈值。
24.在一个可能的实施方式中,当缓存中存在调用结果,则在第一时刻直接调用调用结果,还包括:确定调用结果是否满足第一精准度阈值;当调用结果满足第一精准度阈值,则在第一时刻直接调用调用结果;当调用结果不满足第一精准度阈值,则确定分布式调用请求的第一精准度阈值。
25.在一个可能的实施方式中,方法还包括:根据调用结果,确定分布式调用请求的第三精准度阈值以及第二被调用设备。
26.在一个可能的实施方式中,在确定分布式调用请求的第一精准度阈值之前,方法还包括:当用户准备执行分布式调用请求时,显示提示消息,提示消息用于指示是否选择低功耗模式执行分布式调用请求;若用户选择低功耗模式执行分布式调用请求,则确定分布式调用请求的第一精准度阈值。
27.在一个可能的实施方式中,第一精准度阈值或第二精准度阈值包括:分布式调用请求的参数阈值信息、分布式调用请求的时效阈值信息和/或分布式调用请求的结果阈值信息。
28.第四方面,提供了一种低功耗分布式调用方法,方法应用于分布式网络中的第二设备,分布式网络包括第一设备和至少一个第二设备,其中,第一设备为分布式网络中的一个设备,第二设备为分布式网络中除第一设备以外的其它设备,方法包括:接收第一设备发送的分布式调用请求并临时存储至缓存中;在第一时刻根据分布式调用请求的第一精准度阈值确定调用结果;将调用结果发送至第一设备;其中,第二设备具有独立的休眠机制,第二设备根据自身设备的休眠机制,确定第一时刻。
29.在一个可能的实施方式中,方法还包括:接收第一设备发送的配置信息,其中,配置信息包括分布式调用请求和第一精准度阈值的阈值范围;根据分布式调用请求,确定第二设备允许被第一设备调用;根据第一精准度阈值的阈值范围,第二精准度阈值;将第二精准度阈值发送至第一设备,以便第一设备根据第二精准度阈值确定第一精准度阈值,其中,第一精准度阈值的范围与任意一个第二精准度阈值的范围存在交集。
30.在一个可能的实施方式中,方法还包括:接收第一设备发送的初始选择信息,初始选择信息用于指示第二设备作为第一被调用设备;根据自身设备的特征信息,确定反馈信息,反馈信息用于表示第二设备是否同意作为第一被调用设备;发送反馈信息至第一设备。
31.在一个可能的实施方式中,分布式网络还包括第三设备,其中,第三设备为分布式网络中的一个设备,第三设备为分布式网络中除第一设备、第二设备以外的一个设备;方法还包括:在第一时刻之前,接收第三设备发送的分布式调用请求;若第三设备发送的分布式调用请求与第一设备发送的分布式调用请求的类型相同,则将第三设备发送的分布式调用
请求与第一设备发送的分布式调用请求进行合并。
32.在一个可能的实施方式中,第一精准度阈值和第二精准度阈值包括:分布式调用请求的参数阈值信息、分布式调用请求的时效阈值信息和/或分布式调用请求的结果阈值信息。
33.第五方面,提供了一种低功耗分布式调用装置,装置包括:处理器,用于与存储器耦合,以及读取并执行存储器中的指令;当处理器运行时执行指令,使得处理器还用于执行第三方面或第四方面任意方法。
34.第六方面,提供了一种计算机可读存储介质,计算机可读存储介质中存储有指令,当指令在终端上运行时,使得终端执行第三方面或第四方面任意一项的方法。
35.第七方面,提供了一种包含指令的计算机程序设备,当其在终端上运行时,使得终端执行第三方面或第四方面中的任一项的方法。
36.本技术公开了一种低功耗分布式调用方法及装置,通过确定分布式调用请求对应的精准度阈值,并根据精准度阈值确定最佳被调用设备。结合自身设备的唤醒机制,在最优时刻发送分布式调用请求至被调用设备。被调用设备可以根据自身设备的唤醒机制,在最佳时刻执行分布式调用,并发送调用结果至调用设备。调用设备可以将调用结果进行缓存,以便在在最佳时刻读取反馈的调用结果。通过上述方式可以降低网络环境中的调用者和被调用者由于频繁唤醒所造成的功耗问题,同时还可以避免多次重复的分布式调用,进一步降低网络的功耗开销。
附图说明
37.图1为一种分布式终端业务场景示意图;
38.图2为另一种分布式终端业务场景示意图;
39.图3为一种智能设备分布式调用示意图;
40.图4为一种分布式调用增长趋势示意图;
41.图5a为一种分布式调用示意图;
42.图5b为另一种分布式调用示意图;
43.图6a为本技术实施例提供的一种按需发起型分布式调用示意图;
44.图6b为本技术实施例提供的另一种按需发起型分布式调用示意图;
45.图6c为本技术实施例提供的又一种按需发起型分布式调用示意图;
46.图7为本技术实施例提供的一种按需发起型分布式调用被调用设备状态示意图;
47.图8为本技术实施例提供的一种分布式调用数量、功耗开销与分布式终端设备关系示意图;
48.图9为本技术实施例提供的再一种按需发起型分布式调用示意图;
49.图10为本技术实施例提供的一种低功耗分布式调用方法流程图;
50.图11为本技术实施例提供的一种低功耗分布式调用架构示意图;
51.图12为本技术实施例提供的另一种低功耗分布式调用架构示意图;
52.图13a为本技术实施例提供的一种分布式终端示意图;
53.图13b为本技术实施例提供的另一种分布式终端示意图;
54.图14为本技术实施例提供的一种精准度阈值协商示意图;
55.图15为本技术实施例提供的一种被调用设备协商示意图;
56.图16a为本技术实施例提供的一种定期发起型分布式调用示意图;
57.图16b为本技术实施例提供的另一种定期发起型分布式调用示意图;
58.图17为本技术实施例提供的一种低功耗分布式调用时序示意图;
59.图18为本技术实施例提供的另一种低功耗分布式调用时序示意图;
60.图19为本技术实施例提供的又一种低功耗分布式调用时序示意图;
61.图20为本技术实施例提供的一种低功耗分布式调用的功耗开销示意图;
62.图21为本技术实施例提供的一种低功耗分布式调用设备示意图;
63.图22为本技术实施例提供的另一种低功耗分布式调用设备示意图;
64.图23为本技术实施例提供的一种低功耗分布式调用装置示意图;
65.图24为本技术实施例提供的另一种低功耗分布式调用装置示意图。
具体实施方式
66.下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行描述。
67.本技术主要应用在分布式终端业务场景。在该场景下,具有至少两个分布式终端设备,其中至少一个分布式终端设备作为调用设备,用于发起分布式调用请求,调用设备也可称为“调用者”;以及至少一个分布式终端设备作为被调用设备,用于执行调用者发布的分布式调用请求,并将调用结果反馈至调用者,被调用设备也可称为“被调用者”。可以理解的是,对于某个分布式终端设备而言,调用者以及被调用者的身份可以随时进行转换,例如当设备a调用设备b时,设备a为调用者、设备b为被调用者;当设备b反过来调用设备a时,此时设备b为调用者、设备a为被调用者。本技术中涉及到的“调用者”和“调用设备”为同一含义,可以相互使用;以及“被调用者”和“被调用设备”为同一含义,可以相互使用。
68.在本技术涉及的分布式终端业务场景中,分布式调用并不改变分布式终端设备上长期的程序逻辑。例如,可以是调用者通过分布式调用请求获取分布式数据,如获取温度数据、光线数据等传感器数据。在该场景下,由于并没有更改被调用者的数据以及程序逻辑,显然对后续的分布式调用请求也不会产生任何影响。
69.本技术涉及的另一个分布式终端业务场景中,还可以不影响分布式终端设备后续功能的执行,或是形成影响但是分布式终端设备可以容忍。例如调用者通过分布式调用请求完成分布式临时单点功能,如被调用者为摄像头,分布式调用请求为拍摄一张当前摄像头覆盖范围内的照片。显然,若拍一张照片并不会影响后续摄像头的使用,同时拍摄的照片虽然占用了摄像头的存储容量,但是由于被占用的空间不会对摄像头造成影响,则是被允许的(或是可容忍的)。
70.在本技术涉及的又一个分布式终端业务场景中,还可以在分布式调用请求所返回的调用结果在满足预设的阈值范围内,可以允许调用者接受该调用结果。例如,通过分布式调用请求同步各个分布式终端设备的设备状态,若分布式调用请求要求t1时刻的设备状态,但实际调用者接收到的是被调用者t2时刻的状态,若t1和t2满足预先设置的阈值范围,则调用者可以认为反馈的结果满足要求。又或是,调用者在t1时刻发布分布式请求并获得调用结果,在t2时刻再次发布相同的分布式请求,此时若调用结果再t2时刻仍然处于有效期时,调用者可以认为t1时刻反馈的结果满足要求。
71.在一些方案中,采用了按需发起型分布式调用技术。例如远程过程调用(remote procedure call,rpc)的方案,其主要是通过调用者在需要调用远程终端设备的能力时,向被调用者发起一个调用请求。该请求例如可以是如图6a示出的通过函数调用的形式进行发送。假设设备a为调用者,设备b为被调用者。当设备a中的程序a需要调用设备b中程序b的能力时,程序a采用分布式函数调用,通过分布式函数调用框架或桩等形式对分布式调用请求进行封装。然后通过某种网络协议发送至设备b。当设备b接收到分布式调用请求后,采用与设备a相同的分布式函数调用框架或桩等形式将调用请求进行解封装。并通过程序b执行某个具体的分布式函数。当该分布式调用具有返回值时,则采用相同的分布式函数调用框架或桩等形式对返回值进行封装,并通过上述网络协议进行传输。对于设备a则仍然采用相同的分布式函数调用框架或桩等形式对返回值进行解封装。
72.当然还可以采用某种分布式协议代替图6a中的分布式调用函数。例如图6b示出的,假设设备a为调用者,设备b为被调用者。当设备a中的程序a需要调用设备b中程序b的能力时,程序a采用某种分布式协议对分布式调用请求进行封装。然后通过某种网络协议发送至设备b。当设备b接收到分布式调用请求后,采用与设备a相同的分布式协议将调用请求进行解析。并通过程序b执行某个具体的功能操作。当该分布式调用具有返回值时,则采用相同的分布式协议对返回值进行封装,并通过上述网络协议进行传输。对于设备a则仍然采用相同的分布式协议对返回值进行解封装。
73.可以看出,按需发起型分布式调用的技术方案是根据调用者按照程序的需求发起分布式调用请求。例如图6c示出的,当调用者准备发起分布式调用请求时,可以通过某种函数框架或者协议对该分布式调用请求进行封装,并传输至被调用者进行调用。此时调用者可以等待或者处理其它任务。对于被调用者则进行资源和任务调度并执行该分布式调用请求。最后选择返回结果或者不返回结果。显然,分布式调用请求的触发方式是通过调用者主动发起,而被调用者则需要“被动”执行。并且相关操作步骤都需要调用者和被调用者“在线”执行,即当被调用者处于休眠状态则需要立即唤醒该设备。
74.但是,上述方案的调用者在发起分布式调用请求时,并不清楚被调用者的设备状态。例如图7示出的上半部分示意出了被调用设备随着时间所处的各个状态。可以看出被调用设备大部分时间处于深度休眠状态,当该设备根据自身设备的需求需要调度时,则在相应的时刻从深度休眠的状态唤醒为应用运行状态,此时系统也进行运行。当调度完成后,设备处于一段时间的空闲状态,然后再次进行入深度休眠状态,以保证较低的功耗。但是如图7下半部分示出的,当被调用设备在深度休眠状态下被调用时,如圆圈所圈出的在深度休眠状态下被调用设备被调用,则被调用设备需要立即唤醒并执行相应的分布式调用请求。
75.可以看出调用者会立即发起分布式调用请求至被调用者,对于被调用者若处于低功耗待机或深度休眠等类似状态时,需要立即唤醒并处理该分布式调用请求。显然对于被调用者来讲,实时性是不可预知的,被动唤醒导致功耗线性增加。同时,系统运行以及空闲状态的功耗开销也被放大,深度休眠等机制被严重干扰,导致对功耗开销有很大影响。例如图8左半部分示出的,当分布式终端设备增多时,分布式调用请求也会增加。导致相互的分布式调用将会频繁的拉起被调用设备,如图8右半部分示出的,会使得被调用设备整体运行的功耗呈现线性增加。
76.同时由于该方式的调用者与被调用者之间并没有进行协商确认,因此对于不同的
调用者发起重复的分布式调用时,重复的分布式调用请求均会被传输至被调用者,并被重复执行。例如图9示出的,例如设备a和设备b可以均为调用者,设备c为被调用者。当设备a和设备b同时向设备c发起相同的分布式调用请求时,设备c会根据接收到的分布式调用请求执行两次,并将相同的结果返回给设备a和设备b。显然上述方式将导致重复的资源开销和功耗开销。
77.上述方案对于设备低功耗业务的功耗开销有着明显的影响。对于电池消耗的消费产品则是非常严重的问题。
78.本技术通过调用设备确定分布式调用请求对应的精准度阈值,并根据精准度阈值确定最佳被调用设备。结合自身设备的唤醒机制,在最优时刻发送分布式调用请求至被调用设备。被调用设备可以根据自身设备的唤醒机制,在最佳时刻执行分布式调用,并发送调用结果至调用设备。通过上述方式可以降低网络环境中的被调用者由于频繁唤醒所造成的功耗问题,同时还可以避免多次重复的分布式调用,进一步降低网络的功耗开销。
79.下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行详细描述。
80.图10为本技术实施例提供的一种低功耗分布式调用方法流程图。
81.如图10所示,本技术提供了一种低功耗分布式调用方法,该方法应用于分布式网络,该分布式网络中包括多个分布式终端设备,例如第一设备和至少一个第二设备。其中,第一设备可以是调用设备(也称“调用者”),第二设备可以是被调用设备(也称“被调用者”),该方法可以包括以下步骤:
82.s1001,调用设备确定分布式调用请求的第一精准度阈值。
83.在一个实施例中,针对分布式网络中的分布式终端设备,对于调用者而言在设备原有的基础上,增加低功耗桥接模块。使得原本调用者直接发送至被调用者的分布式调用请求,不再直发送至被调用者,而是先发送至调用者内的低功耗桥接模块。对于被调用者而言,也需要增加一个低功耗桥接模块,以便接收分布式调用请求。
84.调用者通过自身设备的低功耗桥接模块确定分布式调用请求所携带的精准度阈值。可以理解的是,调用者可以预先确定所有准备发起的分布式调用请求的精准度阈值,以便在发送分布式调用请求至被调用者的低功耗桥接模块时,可以携带有该分布式调用请求的精准度阈值。
85.例如图11示出的一种低功耗分布式调用架构示意图,由图11中可以看出,调用者包括通用处理单元和低功耗处理单元;被调用者同样也包括通用处理单元和低功耗处理单元。通用处理单元上运行设备本体,而低功耗处理单元上运行低功耗桥接模块。调用者的低功耗处理单元与被调用者的低功耗处理单元之间通过物理网络设备进行连接通信。其中,通用处理单元主要用于运行普通的程序,若是调用者的通用处理单元,则运行的程序可以是用于发起分布式调用请求的主体;若是被调用者的通用处理单元,则运行的程序可以是用于执行分布式调用请求的目标程序或者功能模块。在一个例子中,通用处理单元一般由通用中央处理器(central processing unit,cpu)构成。当然在其它例子中,通用处理单元还可以是应用处理器(application processor,ap),调制解调处理器,图形处理器(graphics processing unit,gpu),图像信号处理器(image signal processor,isp),控制器,视频编解码器,数字信号处理器(digital signal processor,dsp),基带处理器和/
或神经网络处理器(neural-networkprocessing unit,npu)等任意等效的处理器。低功耗处理单元主要用于运行上述提到的低功耗桥接模块,在一个例子中,可以是由微控制单元(microcontroller unit,mcu)构成。当然在其它例子中,低功耗处理单元也可以采用上述其它任意等效的处理器。对于一些特定的分布式终端设备而言,其通用处理单元与低功耗处理单元可以集成在一起,或是属于同一个物理器件。例如通用处理单元与低功耗处理单元可以由通用cpu构成或mcu构成。在调用者的低功耗处理单元与被调用者的低功耗处理单元之间建立连接的物理网络设备为分布式网络所使用的网络设备,主要用于负责连接各个分布式终端设备,以保障各个分布式终端设备之间可以相互进行通信并发起分布式调用请求。
86.应当注意的是,本技术中处理单元上运行设备本体或程序,以及低功耗处理单元上运行低功耗桥接模块具有独立的休眠机制。并且低功耗桥接模块在休眠时,若接收到分布式调用请求或者调用结果,则会立即唤醒。
87.对于调用者、被调用者新增的低功耗桥接模块,该模块独立运行在低功耗处理单元上,并具有独立的休眠等低功耗运行机制。低功耗桥接模块在启动以及运行过程中,主要负责分布式网络中各个分布式终端设备所需要的分布式协商,例如精准度阈值的协商以及确定被调用者的协商等。同时还可以负责发起分布式调用请求以及接收分布式调用请求。例如图12所示出的,可以看出,调用者通过低功耗处理单元上运行的低功耗桥接模块发起分布式调用请求,并且经过网络设备发送至被调用者。被调用者通过低功耗处理单元上运行的低功耗桥接模块接收分布式调用请求,然后经通用处理单元上运行的程序执行后,通过低功耗桥接模块将结果进行反馈。
88.调用者可以通过自身的低功耗桥接模块,针对可能发起的分布式调用请求进行分析,并针对每个分布式调用请求通过调用者与被调用者之间进行协商,从而确定分布式调用请求的精准度阈值,例如第一精准度阈值。在一个例子中,分布式终端设备可以在加入分布式网络或者在运行过程中,新增低功耗分布式协商模块。可以理解的是,该低功耗分布式协商模块运行在低功耗处理单元上。例如图13a示出的,通用处理单元上运行着常规程序,低功耗处理单元上运行着低功耗桥接模块和低功耗分布式协商模块。当然在另一个例子中,低功耗分布式协商模块可以和低功耗桥接模块合并为同一个模块进行部署,合并后的模块可以仍然称为低功耗桥接模块。例如图13b示出的,通用处理单元上运行着常规程序,低功耗处理单元上运行着低功耗桥接模块。
89.在一个例子中,精准度阈值可以包括分布式调用请求的参数阈值信息、分布式调用请求的时效阈值信息、分布式调用请求的结果阈值信息。当然在其它例子中,还可以包括任何可能需要的阈值信息,本技术在此不作限定。
90.例如图14示出的一种精准度阈值协商示意图。首先调用者针对自身设备可能发起的分布式调用请求,确定该分布式调用请求的配置信息。配置信息可以是包括该分布式调用请求,以及该分布式调用请求相关的第一精准度阈值的精准度阈值范围需求。如图14中的a,调用者将配置信息经过网络设备发送至所有可能的被调用者,如图中调用者针对每个可能的被调用者均执行a步骤。每个可能的被调用者在接收到配置信息后,可以执行b步骤,即根据被调用者自身设备的情况,确定是否可以作为被调用者执行分布式调用请求。此时将会出现两种情况,即被调用者确定自身设备无法作为被调用者执行分布式调用请求,以
及被调用者确定自身设备可以作为被调用者执行分布式调用请求。情况一,若该可能的被调用者确定自身设备无法作为被调用者执行分布式调用请求,则执行c步骤,发送第一反馈信息,第一反馈信息用于告知该可能的被调用者无法执行分布式调用请求的信息。在一个例子中,第一反馈信息也可以是包括用于告知该可能的被调用者无法成为被调用者的信息。情况二,若该可能的被调用者确定自身设备可以作为被调用者执行分布式调用请求,则执行c步骤,发送第二精准度阈值至调用者。其中,第二精准度阈值为可能的被调用者根据第一精准度阈值的精准度阈值范围需求确定的精准度阈值初始值。调用者接收到多个可能的被调用者反馈的第二配置信息后,可以执行d步骤,即结合自身设备的实际情况,确定该分布式调用请求最终的精准度阈值,即第一精准度阈值。可以理解的是,由于第一精准度阈值的确定参考了多个第二精准度阈值,因此第一精准度阈值的范围与任意一个第二精准度阈值的范围均会存在交集。
91.在另一个例子中,当调用者确定第一精准度阈值后,可以将第一精准度阈值发送给所有可能的被调用者,即图14中的e步骤。当可能的被调用者接收到第一精准度阈值后,可以执行f步骤,即被调用者将接收到的第一精准度阈值进行保存。以便之后被调用者再次接收到该分布式调用请求时,根据第一精准度阈值进行相应计算并得到调用结果。
92.在另一个实施例中,在执行s1001之前,当用户准备执行分布式调用请求时,可以在调用设备上显示提示信息,该提示信息用于指示是否选择低功耗模式执行该分布式调用请求。调用设备接收指示信息,该指示信息为用户通过调用设备选择是否采用低功耗模式执行该分布式调用请求。当用户选择低功耗模式执行该分布式调用请求时,则执行s1001。
93.s1002,根据第一精准度阈值,确定被调用设备。
94.调用者根据第一精准度阈值,从所有可能的被调用者中选择其中一个作为第一被调用设备,即被调用者。
95.调用者可以根据第一精准度阈值,从所有可能的被调用者中选择其中一个作为该分布式调用请求的初始被调用设备。可以理解的是,初始被调用设备为调用者根据各个被调用者反馈的信息以及整个网络的低功耗业务特性进行综合分析,从所有可能的被调用者中选择其中一个最合适的被调用者。然后,调用者将初始选择信息发送至初始被调用设备上,其中初始选择信息用于指示该初始被调用设备被作为被调用设备。当初始被调用设备接收到初始选择信息后,根据自身设备上运行业务的业务特征等信息,确定自身是否适合作为被调用者,并发送第二反馈信息至调用者。可以理解的是,若初始被调用设备确定自身设备可以作为被调用者,则第二反馈信息用于告知调用者该初始被调用设备允许作为被调用者。若初始被调用设备确定自身设备并不适合作为被调用者,则第二反馈信息用于告知调用者该初始被调用设备不适合作为被调用者。在另一个例子中,若该初始被调用设备上存储有其它设备的设备信息,还可以根据其它设备的设备信息,给出被调用者的选择建议,并将选择建议添加至第二反馈信息中,然后将包含选择建议的第二反馈信息发送至调用者。调用者接收到初始被调用设备发送的第二反馈信息后,根据第二反馈信息,确定第一被调用设备。该第一被调用设备为调用者确定的最终的最合适的被调用者。可以理解的是,当第二反馈信息告知调用者该初始被调用设备允许作为被调用者,则将初始被调用设备作为第一被调用设备;当第二反馈信息告知调用者该初始被调用设备不适合作为被调用者,则调用者可以根据第二反馈信息以及第一精准度阈值,从其余的可能的被调用者中再次选择
一个最适合的被调用者,并重复上述过程。直至选择出该分布式调用请求的第一被调用设备为止。
96.在一个例子中,可以例如图15示出的一种被调用设备协商示意图。由图15可以看出,首先调用者会根据第一精准度阈值,从多个可能的被调用者中选择一个作为初始被调用设备。然后执行g步骤,发送初始选择信息至初始被调用设备。初始被调用设备在接收到初始选择信息后,可以执行h步骤,根据自身设备的业务特征决定是否允许自身设备作为第一被调用设备。然后执行i步骤,将第二反馈信息发送至调用者。可以理解的是,若初始被调用设备确定自身设备可以作为被调用者,则第二反馈信息可以包括于告知调用者该初始被调用设备允许作为被调用者的信息;若初始被调用设备确定自身设备并不适合作为被调用者,则第二反馈信息可以包括于告知调用者该初始被调用设备不适合作为被调用者的信息。当然在其它例子中,当初始被调用设备上存储有其它设备的设备信息,则第二反馈信息还可以包括选择建议信息,例如建议调用者选择某个更为合适的被调用者。调用者接收到第二反馈信息后,可以执行j步骤,若初始被调用设备确定自身设备可以作为被调用者,则调用者可以根据第二反馈信息选择该初始被调用设备作为该分布式调用请求的最佳的执行实体。可选的,j步骤之后还可以执行k步骤,用于同步将初始被调用设备作为第一被调用设备的信息。当初始被调用设备接收到该信息后,可以执行m步骤,用于记录该信息。在另一个例子中,若j步骤中,初始被调用设备确定自身设备并不适合作为被调用者,则调用者可以重复上述g步骤至i步骤,直至选择出该分布式调用请求的第一被调用设备为止。
97.通过上述协商过程,调用者根据各个被调用者的设备能力以及整个网络低功耗的业务特征,确定一个分布式调用请求的执行实体,从而保证了该分布式调用请求执行时可以满足整个网络的低功耗需求。
98.s1003,在最佳时刻发送分布式调用请求至被调用设备。
99.调用者在第一时刻将分布式调用请求发送至第一被调用设备上。可以理解的是,第一时刻为调用者根据该第一被调用设备确定的发送分布式调用请求的一个最佳时刻。其中该第一时刻为调用者认为被调用者适合执行分布式调用请求的最佳时刻。
100.s1004,被调用设备接收调用设备发送的分布式调用请求并临时存储至缓存中。
101.被调用者接收到调用者发送的分布式调用请求,并将该分布式调用请求临时存储至缓存中。
102.可以理解的是,由于第一时刻是调用者认为的最佳时刻,而实际上在被调用者接收到分布式调用请求时,并不一定处于运行状态,当处于休眠等低功耗状态时,可以先将分布式调用请求临时存储至缓存中,以便在合适的时刻再执行该分布式调用请求。
103.s1005,被调用设备根据自身设备的唤醒机制,在最佳时刻执行分布式调用请求。
104.被调用者根据自身设备的唤醒机制,在最佳时刻被唤醒并执行s1004中缓存的分布式调用请求。
105.在一个例子中,若在执行分布式调用请求之前,缓存有多个同类的分布式调用请求。则被调用者可以根据自身设备的情况,将多个同类的分布式调用请求进行合并执行,以减少重复执行所带来的资源消耗。
106.s1006,根据分布式调用请求所携带的第一精准度阈值确定调用结果。
107.被调用者根据分布式调用请求中携带的第一精准度阈值,确定此次分布式调用请
求的调用结果。
108.s1007,将调用结果发送至调用设备,调用设备接收并进行缓存。
109.被调用者将调用结果在合适的时刻发送至调用者。可以理解的是,被调用者可以在得到调用结果后立即发送至调用者,也可以根据自身的唤醒机制、调用者设备的设备状态以及可能存在的其它业务的执行情况,选择最佳时刻发送调用结果至调用者。
110.在一个例子中,若该调用结果为多个同类的分布式调用请求合并执行后的调用结果,则被调用者需要将该调用结果分别发送至多个同类的分布式调用请求的调用者设备上。
111.在一个例子中,调用者在第二时刻接收被调用者发送的调用结果,并将该调用结果临时存储至缓存中。可以理解的是,调用者在接收到调用结果时,调用者的设备主体并不一定立即调用该调用结果,因此,调用者可以将调用结果临时存储至缓存中,以便在调用者的设备主体有需要时进行调用。
112.s1008,调用设备根据自身设备的唤醒机制,在最佳时刻从缓存中调用调用结果。
113.在一些方案中,通过采用定期发起型分布式调用技术。例如图16a示出的,例如设备a为调用者,设备b为被调用者。其主要通过设备a发起分布式调用请求,该请求中可以包括执行的业务功能、执行周期、返回内容等等信息。当该请求被传输至设备b时,设备b则可以按照请求中的执行周期,定期的执行相应内容,并将结果或数据反馈至设备a。当然还可以例如图16b示出的,例如设备a为调用者,设备b为被调用者。设备a无需发送分布式调用请求,设备b可以按照自身设备的机制调用执行某个功能,并将结果或数据返回给调用者。当然设备b也可以不返回结果或数据。该方案一定程度的减少了分布式调用对休眠等低功耗等措施带来的干扰和影响。
114.但是在此类方案中,被调用者反馈的结果对于调用者来讲也存在影响,由于被调用者并不清楚调用者某个时刻的设备状态和任务执行情况。因此被调用者定期返回结果或者数据给调用者时,有很大可能会影响到调用者的休眠机制或其它低功耗措施,使得影响调用者的功耗开销。
115.因此本技术的调用设备可以根据自身设备的唤醒机制,在第三时刻从缓存中调用接收到的调用结果。可以理解的是,第三时刻为调用者根据自身设备的唤醒机制,选择调用该调用结果的一个最佳时刻。从而保障了被调用者的返回信息符合调用者的运行周期,并减少返回结果对调用者的干扰和影响。
116.在一个例子中,在s1003中,若调用设备在准备发送分布式调用请求的第一时刻确定设备的缓存中缓存有调用结果,则调用设备可以在第一时刻直接从缓存中调用该调用结果。若在第一时刻确定设备的缓存中不存在调用结果,则执行s1003。当然在另一个例子中,若在第一时刻确定设备的缓存中缓存有调用结果后,还可以确定该调用结果是否仍在精准度阈值范围内。若该调用结果满足精准度阈值的范围,则调用设备可以直接从缓存中调用该调用结果,从而无需再发送分布式调用请求至被调用者,进一步减少了对被调用者的干扰。当然,若该调用结果不满足精准度阈值的范围,则执行s1003。
117.在又一个例子中,当调用者接收并调用完调用结果后,调用者还可以根据调用结果重新确定下一次执行该分布式调用请求的精准度阈值,即第三精准度阈值。同时还可以重新确定最合适的被调用者,即第二被调用设备。可以理解的是,若精准度阈值进行了更
新,以及确定的被调用者也进行了更新,则调用者可以将更新后的信息发送至新的被调用者,以便新的被调用者将上述信息进行同步更新。
118.本技术通过确定分布式调用请求对应的精准度阈值,在这个精准度阀值范围内,可以认为调用结果符合调用设备需求。调用设备根据精准度阈值确定最佳的被调用设备。调用设备根据自身设备的唤醒机制,在最优时刻发送分布式调用请求至被调用设备。被调用设备可以根据自身的唤醒机制,在最佳时刻执行分布式调用,并发送调用结果至调用设备。调用设备可以将调用结果进行缓存,以便在在最佳时刻读取反馈的调用结果。若调用设备发起分布式调用请求时,已经缓存有调用结果,则可以读取调用结果。通过上述方式,分布式终端设备之间在处理分布式调用的低功耗业务时,可以按照自身设备的业务特征进行唤醒并执行,然后将相关结果发送至调用设备上,以便被调用设备可以进行下电等处理。可以降低网络环境中的调用者和被调用者由于频繁唤醒所造成的功耗问题,同时,由于可以将处理结果反馈给多个调用设备,从而避免了多次重复的分布式调用,进一步降低整个网络的功耗开销。
119.如图17所示,为本技术实施例提供的一种低功耗分布式调用时序示意图。
120.图17示出了图10至图15的分布式调用过程。其中,图中黑色粗体线条为各个处理单元运行时间片。可以看出,调用者的通用处理单元上运行的程序以及被调用者的通用处理单元上运行的程序具有周期性,即有固定的运行时间片以及固定的休眠时间片。同时,还可以看出,调用者的运行时间片与被调用者的运行时间片显然是相互独立,可能存在重叠,也可能不存在重叠。因此通过本技术提供的低功耗分布式调用方式,可以解决由于时间片不同步,导致功耗过多开销的问题。
121.首先,调用者的低功耗处理单元上运行的低功耗桥接模块执行s1701,即判断调用者的通用处理单元上运行的程序可能即将发起的分布式调用请求,以及各个分布式调用请求的发起时机。然后低功耗桥接模块确定各个分布式调用请求的精准度阈值,并执行s1702,将该分布式调用请求以及该请求的精准度阈值发送至被调用者的低功耗桥接模块。其中精准度阈值包括分布式调用请求的参数阈值信息、分布式调用请求的时效阈值信息、分布式调用请求的结果阈值信息等任意可能需要的信息。此时调用者的低功耗桥接模块可以进行休眠。被调用者的低功耗桥接模块在接收到上述信息后执行s1703,即判断何时的执行时刻。若无法立即执行该分布式调用请求,则进行休眠。当被调用者的低功耗桥接模块判断可以执行该分布式调用请求时,则进行s1704向被调用者的程序发起该分布式调用请求。被调用者的程序接收到该分布式调用请求后执行s1705,立即执行该分布式调用请求。被调用者的程序执行完该分布式调用请求后执行s1706,将调用结果通过低功耗桥接模块发送至调用者的低功耗桥接模块。当调用者的低功耗桥接模块接收到返回的调用结果后,由于调用者的程序可能正处于休眠状态,则调用者的低功耗桥接模块可以临时存储该调用结果,即s1707。当调用者的程序处于运行状态时,即s1708调用者的程序此时需要用到该分布式调用请求的结果时。调用者的低功耗桥接模块可以将缓存的调用结果发送至调用者的程序,以便后续操作,即s1709。
122.如图18所示,为本技术实施例提供的另一种低功耗分布式调用时序示意图。
123.图18示出了图17的另一种可能的情况,当调用者再次发起相同的分布式调用请求时,可以参照图18示出的。其中,s1701至s1709与图17中的步骤相同,为方便描述,在此不再
赘述。
124.在s1709之后,若调用者的程序再次发起相同的分布式调用请求至调用者的低功耗桥接模块,即s1801。调用者的低功耗桥接模块可以执行s1802,即判断缓存的调用结果是否仍在精准度阈值的范围内。若判断为缓存的调用结果仍在精准度阈值的范围内,则可以执行s1803,直接返回调用结果至调用者的程序。当然在其它例子中,若判断为缓存的调用结果不在精准度阈值的范围内,则可以执行s1701至s1709,为方便描述,在此不再赘述。
125.如图19所示,为本技术实施例提供的又一种低功耗分布式调用时序示意图。
126.图19示出了图17的又一种可能的情况,当存在多个调用者针对同一个被调用者发起相同类型的分布式调用请求时,可以参照图19示出的。其中,s1701至s1704、s1705至s1706与图17中的步骤相同,为方便描述,在此不再赘述。
127.显然,若存在另一个调用者,即调用者2也发起与调用者1相同的分布式调用设备,且被调用者相同,则调用者2的低功耗桥接模块可以执行s1901和s1902。其中,s1901和s1902与图17示出的s1701和s1702的步骤相同,为方便描述,在此不再赘述。当被调用者的低功耗桥接模块接收到调用者1和调用者2分别发送的相同类型的分布式调用请求后,可以执行s1903,将相同类型的两个分布式调用请求进行合并,并作为一个分布式调用请求发起调用并执行。当被调用者的低功耗桥接模块接收到返回结果后,根据不同的调用者,分别将调用结果返回给不同的调用者。调用者1的低功耗桥接模块与调用者2的低功耗桥接模块分别执行s1904和s1905,即将返回结果进行缓存。
128.本技术通过将相同类型的分布式调用请求进行合并处理,减少了重复的调用所导致的额外功耗。
129.通过图10至图19所示的低功耗分布式调用方法,调用者的程序在处理分布式调用请求的结果,以及被调用者的程序在执行分布式调用请求的功能时,可以按照各自预定的执行周期、运行时间或者休眠机制片进行调度和运行,从而最大可能的减少由于分布式调用所带来的运行唤醒干扰,并降低系统运行功耗。同时将符合精准度阀值同类型分布式调用可以合并,减少被调用者的执行次数,并且只要符合精准度阈值的返回结果可以重复使用,进一步的降低调用者和被调用者以及整个分布式网络的功耗开销。
130.如图20所示,图20为本技术实施例提供的一种低功耗分布式调用的功耗开销示意图。
131.通过图20可以看出,当分布式终端设备不断增加时,或者说分布式调用请求的业务总和增加时,功耗开销不再是线性增加,而是缓慢增加。意味着将大幅度降低调用者、被调用者在分布式网络中因为分布式调用被频繁唤醒等问题而影响功耗开销。通过合并相同类型的分布式调用请求,也可以降低总体的分布式调用请求数量,并从源头降低整个分布式网络的功耗开销。将分布式网络中的分布式调用请求对分布式终端设备功耗影响的线性增加幅度减缓为缓慢增加。
132.图21为本技术实施例提供的一种低功耗分布式调用设备示意图。
133.如图21所示,本技术提供了一种低功耗分布式调用设备2100,设备2100为分布式网络中的第一设备,分布式网络还包括至少一个第二设备,其中,第一设备为分布式网络中的一个设备,第二设备为分布式网络中除第一设备以外的其它设备,设备2100包括:设备主体2101和低功耗桥接模块2102;其中,低功耗桥接模块2102确定分布式调用请求的第一精
准度阈值,其中,第一精准度阈值用于约束分布式调用请求;根据第一精准度阈值,确定第一被调用设备,其中,第一被调用设备为至少一个第二设备中的一个设备;在第一时刻通过通信模块2103发送分布式调用请求至第一被调用设备;在第二时刻通过通信模块2103接收第一被调用设备发送的调用结果并临时存储至缓存中;设备主体2101在第三时刻通过向低功耗桥接模块2102发送分布式调用请求,并获取缓存中存储的调用结果;其中,设备主体2101和低功耗桥接模块2102各自具有独立的休眠机制,低功耗桥接模块2102根据第一被调用设备确定第一时刻和第二时刻;设备主体2101根据自身的休眠机制,确定第三时刻。
134.在一个可能的实施方式中,低功耗桥接模块2102还用于,通过通信模块2103发送配置信息到至少一个第二设备,以便至少一个第二设备根据配置信息确定第二精准度阈值;通过通信模块2103接收至少一个第二设备发送的第二精准度阈值;根据至少一个第二精准度阈值,确定第一精准度阈值,其中,第一精准度阈值的范围与任意一个第二精准度阈值的范围存在交集。
135.在一个可能的实施方式中,低功耗桥接模块2102还用于,根据第一精准度阈值,确定分布式调用请求的初始被调用设备,初始被调用设备为至少一个第二设备中的一个设备;通过通信模块2103发送初始选择信息至初始被调用设备,初始选择信息用于指示初始被调用设备作为第一被调用设备;通过通信模块2103接收初始被调用设备发送的反馈信息;根据反馈信息,确定分布式调用请求的第一被调用设备。
136.在一个可能的实施方式中,若第三时刻位于第一时刻之前,低功耗桥接模块2102确定缓存中是否存在调用结果;当缓存中存在调用结果,则设备主体2101在第一时刻直接调用调用结果;当缓存中不存在调用结果,则低功耗桥接模块2102确定分布式调用请求的第一精准度阈值。
137.在一个可能的实施方式中,低功耗桥接模块2102还用于确定调用结果是否满足第一精准度阈值;当调用结果满足第一精准度阈值,则设备主体2101在第一时刻直接调用所述调用结果;当调用结果不满足第一精准度阈值,则低功耗桥接模块2102确定分布式调用请求的第一精准度阈值。
138.在一个可能的实施方式中,低功耗桥接模块2102还用于,根据调用结果,确定分布式调用请求的第三精准度阈值以及第二被调用设备。
139.在一个可能的实施方式中,设备2100还包括:显示模块2104,用于当用户准备执行分布式调用请求时,显示提示消息,提示消息用于指示是否选择低功耗模式执行分布式调用请求;低功耗桥接模块2102还用于,若用户选择低功耗模式执行分布式调用请求,则确定分布式调用请求的第一精准度阈值。
140.在一个可能的实施方式中,第一精准度阈值或第二精准度阈值包括:分布式调用请求的参数阈值信息、分布式调用请求的时效阈值信息和/或分布式调用请求的结果阈值信息。
141.图22为本技术实施例提供的一种低功耗分布式调用设备示意图。
142.如图22所示,本技术提供了另一种低功耗分布式调用设备2200,设备2200为分布式网络中的第二设备,分布式网络包括第一设备和至少一个第二设备,其中,第一设备为分布式网络中的一个设备,第二设备为分布式网络中除第一设备以外的其它设备,设备2200包括:设备主体2201和低功耗桥接模块2202;其中,低功耗桥接模块2202通过通信模块2203
disk drive,hdd)或固态硬盘(solid state drive,ssd);存储器2302还可以包括上述种类的存储器的组合。
152.第一处理器2301和第二处理器2306与存储器2302耦合,以及读取并执行存储器2302中的指令;当第一处理器2301和第二处理器2306运行时执行指令,使得第二处理器2306确定分布式调用请求的第一精准度阈值,其中,第一精准度阈值用于约束分布式调用请求;根据第一精准度阈值,确定第一被调用设备,其中,第一被调用设备为至少一个第二设备中的一个设备。
153.发送器2303在第一时刻发送分布式调用请求至第一被调用设备。
154.接收器2304在第二时刻接收第一被调用设备发送的调用结果并临时存储至缓存中。
155.第一处理器2301在第三时刻获取缓存中存储的调用结果。
156.其中,第一处理器2301和第二处理器2306各自具有独立的休眠机制,第二处理器2306根据第一被调用设备确定第一时刻和第二时刻;第一处理器2301根据自身的休眠机制,确定第三时刻。
157.在一个可能的实施方式中,发送器2303发送配置信息到至少一个第二设备,以便至少一个第二设备根据第一配置信息确定第二配置信息;接收器2304接收至少一个第二设备发送的第二精准度阈值;第二处理器2306根据至少一个第二精准度阈值,确定第一精准度阈值,其中,第一精准度阈值的范围与任意一个第二精准度阈值的范围存在交集。
158.在一个可能的实施方式中,第二处理器2306根据第一精准度阈值,确定分布式调用请求的初始被调用设备,初始被调用设备为至少一个第二设备中的一个设备;发送器2303发送初始选择信息至初始被调用设备,初始选择信息用于指示初始被调用设备作为第一被调用设备;接收器2304还用于,接收初始被调用设备发送的反馈信息;第二处理器2306根据反馈信息,确定分布式调用请求的第一被调用设备。
159.在一个可能的实施方式中,若第三时刻位于第一时刻之前,第二处理器2306确定缓存中是否存在调用结果;当缓存中存在调用结果,则第一处理器2301在第一时刻直接调用调用结果;当缓存中不存在调用结果,则第二处理器2306确定分布式调用请求的第一精准度阈值。
160.在一个可能的实施方式中,第二处理器2306确定调用结果是否满足第一精准度阈值;当调用结果满足第一精准度阈值,则第一处理器2301在第一时刻直接调用所述调用结果;当调用结果不满足第一精准度阈值,则第二处理器2306确定分布式调用请求的第一精准度阈值。
161.在一个可能的实施方式中,第二处理器2306根据调用结果,确定分布式调用请求的第三精准度阈值以及第二被调用设备。
162.在一个可能的实施方式中,显示器2305,可以是液晶显示器(liquid crystal display,lcd)。当然在一些例子中,显示器2305还可以与触摸屏集成为一体。显示器2305用于当用户准备执行分布式调用请求时,显示提示消息,提示消息可以指示是否选择低功耗模式执行分布式调用请求;第二处理器2306若用户选择低功耗模式执行分布式调用请求,则确定分布式调用请求的第一精准度阈值。
163.在一个可能的实施方式中,第一精准度阈值或第二精准度阈值包括:分布式调用
请求的参数阈值信息、分布式调用请求的时效阈值信息和/或分布式调用请求的结果阈值信息。
164.图24为本技术实施例提供的另一种低功耗分布式调用装置示意图。
165.如图24所示,提供了另一种低功耗分布式调用装置2400,该装置2400可以是分布式网络中的第二设备,分布式网络包括第一设备和至少一个第二设备,其中,第一设备为分布式网络中的一个设备,第二设备为分布式网络中除第一设备以外的其它设备,装置2400可以包括第一处理器2401、存储器2402、发送器2403、接收器2404、第二处理器2405以及总线2406。装置2400中的第一处理器2401、存储器2402、发送器2403、接收器2404和第二处理器2405可以通过总线2406建立通信连接。发送器2403用于发送信息;接收器2404用于接收外部信息。
166.第一处理器2401可以为cpu、ap、调制解调处理器、gpu、isp、控制器、视频编解码器、dsp、npu等任意等效的处理器。第二处理器2405可以是mcu或cpu、ap、调制解调处理器、gpu、isp、控制器、视频编解码器、dsp、npu等任意等效的处理器。
167.在一个例子中第一处理器2301与第二处理器2306可以集成在一起,或是为同一个处理器。
168.存储器2402可以包括易失性存储器(volatile memory),例如随机存取存储器(random-access memory,ram);存储器2402也可以包括非易失性存储器(英文:non-volatile memory),例如只读存储器(read-only memory,rom),快闪存储器,硬盘(hard disk drive,hdd)或固态硬盘(solid state drive,ssd);存储器2402还可以包括上述种类的存储器的组合。
169.接收器2404接收第一设备发送的分布式调用请求并临时存储至缓存中。
170.第一处理器2401和第二处理器2405与存储器2402耦合,以及读取并执行存储器2402中的指令;当处理器2401和第二处理器2405运行时执行指令,使得第二处理器2405在第一时刻向第一处理器2401发送分布式调用请求;第一处理器2401用于根据分布式调用请的第一精准度阈值确定调用结果。
171.发送器2403将调用结果发送至第一设备。
172.其中,第一处理器2401和第二处理器2405各自具有独立的休眠机制,第二处理器2405根据第一处理器2401的休眠机制,确定第一时刻。
173.在一个可能的实施方式中,接收器2404接收第一设备发送的配置信息,其中,配置信息包括分布式调用请求和第一精准度阈值的阈值范围;第二处理器2405根据分布式调用请求,确定第二设备允许被第一设备调用;根据第一精准度阈值的阈值范围,确定第二精准度阈值;发送器2403将第二精准度阈值发送至第一设备,以便第一设备根据第二精准度阈值确定第一精准度阈值,其中,第一精准度阈值的范围与任意一个第二精准度阈值的范围存在交集。
174.在一个可能的实施方式中,接收器2404接收第一设备发送的初始选择信息,初始选择信息用于指示第二设备作为第一被调用设备;第二处理器2405根据自身设备的特征信息,确定反馈信息,反馈信息用于表示第二设备是否同意作为第一被调用设备;发送器2403发送反馈信息至第一设备。
175.在一个可能的实施方式中,分布式网络还包括第三设备,其中,第三设备为分布式
网络中的一个设备,第三设备为分布式网络中除第一设备、第二设备以外的一个设备;在第一时刻之前,接收器2404接收第三设备发送的分布式调用请求;若第三设备发送的分布式调用请求与第一设备发送的分布式调用请求的类型相同,则第二处理器2405将第三设备发送的分布式调用请求与第一设备发送的分布式调用请求进行合并。
176.在一个可能的实施方式中,第一精准度阈值或第二精准度阈值包括:分布式调用请求的参数阈值信息、分布式调用请求的时效阈值信息和/或分布式调用请求的结果阈值信息。
177.本技术为调用者和被调用者增加低功耗桥接模块,用于负责接管发起的分布式调用请求和负责接收分布式调用请求。低功耗桥接模块还用于协商分布式调用请求的精准度阀值以及执行该分布式调用请求的实施主体等。在整个分布式网络运行过程中,调用者的低功耗桥接模块会根据协商出来的精准度阀值和执行主体,在恰当的时间点发起分布式调用请求。当被调用者的低功耗模块接收到分布式调用请求后,也会根据被调用者当前的状态,在合适的时机通过唤醒被调用者通用处理单元上的相关程序执行具体的功能,并将结果返回给被调用者的低功耗桥接模块。被调用者的低功耗桥接模块在恰当的时机返回给调用者的低功耗桥接模块。调用者将返回值临时保存下来。当调用者真正需要该分布式调用请求的值时,如果在低功耗桥接模块已经有相应的调用结果后者满足精准度阀值的调用结果,则直接返回给调用者通用处理单元的程序。
178.本技术通过在适当的时候发起分布式调用请求,可以支撑调用者完全按照自己的休眠等低功耗机制发起分布式调用请求,同时也可支撑被调用者完全按照自己的休眠等低功耗机制对分布式调用请求进行调度优化。解决分布式调用请求对调用者以及被调用者的休眠等低功耗机制的影响。同时将同类的分布式调用请求进行合并处理,从而减少重复的分布式调用,最终降低调用者或者被调用者的功耗开销。当调用结果仍在精准度阈值范围内时,可以直接返回调用结果,从而减少分布式调用次数,进一步降低功耗开销。
179.本领域普通技术人员应该还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本技术的范围。
180.本领域普通技术人员可以理解实现上述实施例方法中的全部或部分步骤是可以通过程序来指令处理器完成,所述的程序可以存储于计算机可读存储介质中,所述存储介质是非短暂性(英文:non-transitory)介质,例如随机存取存储器,只读存储器,快闪存储器,硬盘,固态硬盘,磁带(英文:magnetic tape),软盘(英文:floppy disk),光盘(英文:optical disc)及其任意组合。
181.以上所述,仅为本技术较佳的具体实施方式,但本技术的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本技术揭露的技术范围内,可轻易想到的变化或替换,都应涵盖在本技术的保护范围之内。因此,本技术的保护范围应该以权利要求的保护范围为准。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1