This application claims priority of Chinese Patent Application No. 202111381852.6 filed on Nov. 19, 2021, which is incorporated herein in its entirety by reference.
The present disclosure relates to a field of an artificial intelligence technology, in particular to fields of distributed data processing and deep learning technologies, and specifically to a federated learning method, an electronic device, and a storage medium.
Federated learning (FL) is a distributed machine learning technology. Federated learning may perform collaborative training of models using multiple devices and their respective local data without exposing the local data of each device.
The present disclosure provides a federated learning method, an electronic device, and a storage medium.
According to an aspect of the present disclosure, a federated learning method is provided, including: determining, for each task in at least one task in a current learning period, a set of target devices corresponding to the task according to respective scheduling information of a plurality of candidate devices corresponding to the task based on a scheduling policy, wherein the scheduling policy enables a time cost information and a device fairness evaluation information of completing the task in the current learning period to meet a predetermined condition; transmitting a global model corresponding to each task to the set of target devices corresponding to the task, so as to train the global model corresponding to each task by using the corresponding set of target devices; and updating the corresponding global model based on trained models in response to receiving the trained models from the corresponding set of target devices, so as to complete the current learning period.
According to another aspect of the present disclosure, an electronic device is provided, including: at least one processor; and a memory communicatively connected to the at least one processor, wherein the memory stores instructions executable by the at least one processor, and the instructions, when executed by the at least one processor, cause the at least one processor to implement the method described above.
According to another aspect of the present disclosure, a non-transitory computer-readable storage medium having computer instructions therein is provided, and the computer instructions are configured to cause a computer to implement the method described above.
It should be understood that content described in this section is not intended to identify key or important features in embodiments of the present disclosure, nor is it intended to limit the scope of the present disclosure. Other features of the present disclosure will be easily understood through the following description.
The accompanying drawings are used for better understanding of the solution and do not constitute a limitation to the present disclosure, in which:
Exemplary embodiments of the present disclosure will be described below with reference to accompanying drawings, which include various details of embodiments of the present disclosure to facilitate understanding and should be considered as merely exemplary. Therefore, those ordinary skilled in the art should realize that various changes and modifications may be made to embodiments described herein without departing from the scope and spirit of the present disclosure. Likewise, for clarity and conciseness, descriptions of well-known functions and structures are omitted in the following description.
Researches of federated learning have attracted more and more attention. Improvements of convergence efficiency and convergence accuracy of federated learning are important aspects of researches of federated learning. However, most of researches focus on a performance of reaching a convergence of model in a case of a single task, and few researches were conducted for a performance of federated learning for multiple tasks. If training needs to be performed for multiple tasks, a main problem of researches is how to assign a set of target devices for each task, so that global models for all tasks converge faster and the convergence efficiency and the convergence accuracy meet requirements.
Therefore, embodiments of the present disclosure propose a federated learning solution. In a current learning period, for each task in at least one task, a set of target devices corresponding to the task is determined according to respective scheduling information of a plurality of candidate devices corresponding to the task based on a scheduling policy. The scheduling policy enables a time cost information and a device fairness evaluation information of completing the task in the current learning period to meet a predetermined condition. A global model corresponding to each task is transmitted to the set of target devices corresponding to the task, so as to train the global model corresponding to the task by using the corresponding set of target devices. The corresponding global model is updated based on trained models in response to receiving the trained models from the corresponding set of target devices, so as to complete the current learning period.
Each candidate device may store training data corresponding to each task. Therefore, data is associated with devices, and a data fairness may be represented by a device fairness. The time cost information may reflect a processing capacity of device. The scheduling policy is a policy that enables the time cost information and the device fairness evaluation information of completing the task of the current learning period to meet the predetermined condition, in which not only the processing capacity of device but also the data fairness are considered. Therefore, it is possible to properly determine a plurality of sets of target devices for a plurality of tasks respectively based on the scheduling policy. On this basis, the federated learning of a task is performed using the set of target devices corresponding to the task, so that the convergence accuracy and the convergence efficiency of global models for multiple tasks may be effectively ensured.
It should be noted that
As shown in
The devices 101, 102 and 103 may be used by a user to interact with the server 105 through the network 104 to receive or send messages or the like. The devices 101, 102 and 103 may be installed with various communication client applications, such as knowledge reading applications, web browser applications, search applications, instant messaging tools, email clients and/or social platform software, etc. (for example only).
The devices 101, 102 and 103 may be various electronic devices having display screens and supporting web browsing, including but not limited to smart phones, tablet computers, laptop computers, desktop computers, or the like. In addition, the devices 101, 102 and 103 may be edge devices.
The server 105 may be various types of servers providing various services. For example, the server 105 may be a cloud server, also known as a cloud computing server or a cloud host, which is a host product in a cloud computing service system to solve shortcomings of difficult management and weak service scalability existing in an existing physical host and VPS (Virtual Private Server) service. The server 105 may also be a server of a distributed system or a server combined with a block-chain.
It should be noted that the federated learning method provided by embodiments of the present disclosure may generally be performed by the server 105. Accordingly, the federated learning apparatus provided by embodiments of the present disclosure may be generally provided in the server 105. The federated learning method provided by embodiments of the present disclosure may also be performed by a server or server cluster different from the server 105 and capable of communicating with the devices 101, 102, 103 and/or the server 105. Accordingly, the federated learning apparatus provided by embodiments of the present disclosure may also be provided in a server or server cluster different from the server 105 and capable of communicating with the devices 101, 102, 103 and/or the server 105.
It should be understood that the number of devices, network and server shown in
As shown in
In operation S210, for each task in at least one task in a current learning period, a set of target devices corresponding to the task is determined according to respective scheduling information of a plurality of candidate devices corresponding to the task based on a scheduling policy. The scheduling policy enables a time cost information and a device fairness evaluation information of completing the task in the current learning period to meet a predetermined condition.
In operation S220, a global model corresponding to each task is transmitted to the set of target devices corresponding to the task, so as to train the global model corresponding to each task by using the corresponding set of target devices.
In operation S230, the corresponding global model is updated based on trained models in response to receiving the trained models from the corresponding set of target devices, so as to complete the current learning period.
According to embodiments of the present disclosure, each learning period may refer to a model training round. A plurality of learning periods may exist. The task may refer to a task to be performed. The at least one task may include at least one selected from an image processing task, an audio processing task, or a text processing task. For example, the image processing task may include at least one selected from an image classification, an object detection, a semantic segmentation, or the like. The audio processing task may include a semantic recognition or the like. The text processing task may include at least one selected from a text translation, a text generation, or the like.
According to embodiments of the present disclosure, the plurality of tasks may refer to a plurality of independent tasks. Different tasks have different global models. Each task may correspond to a plurality of learning periods, that is, for each task, a global model that meets an expected performance may be obtained through training of a plurality of learning periods. The expected performance may include at least one selected from: a prediction accuracy being less than or equal to a predetermined accuracy threshold, an output value of a loss function converging, or a number of training rounds reaching a maximum number of training rounds.
According to embodiments of the present disclosure, a plurality of candidate devices may participate in federated learning. Each candidate device may be provided with training data (i.e. local data) corresponding to each task. A scheduling information of the candidate device may be determined according to a resource information of the candidate device and a scheduling-related statistical information. The resource information may include at least one selected from a device hardware resource and a storage data resource. The scheduling-related statistical information may include a statistical value of a number of scheduling times. The statistical value may include an average value or a standard deviation.
According to embodiments of the present disclosure, for each task in the at least one task, the scheduling policy may refer to a policy that enables the time cost information and the device fairness evaluation information for completing the task in the current learning period to meet the predetermined condition. The time cost information may indicate a time cost of training. The time cost information may be represented by a time length information of performing the task. The device fairness may refer to that different candidate devices may fairly participate in the model training of federated learning. The device fairness evaluation value may be represented by a statistical information related to the scheduling of candidate devices. For example, the statistical information related to the candidate devices may include a statistical value determined according to a number of times the candidate devices are scheduled. Each candidate device may store training data corresponding to each task. Therefore, the data is associated with devices, and a data fairness may be represented by a device fairness. The data fairness may refer to that a plurality of training data may fairly participate in the model training of federated learning.
According to embodiments of the present disclosure, the time cost information and the device fairness evaluation information corresponding to the current learning period may be determined according to the scheduling information of the candidate devices participating in the model training in the current learning period. A performance evaluation information corresponding to the current learning period may be determined according to the time cost information and the device fairness evaluation information corresponding to the current learning period. The performance evaluation information may indicate a training performance of the global model. The training performance may include the convergence efficiency and the convergence accuracy.
According to embodiments of the present disclosure, the plurality of candidate devices may form a plurality of combinations. Accordingly, a plurality of scheduling schemes may be obtained for the current learning period, and each scheduling scheme includes a set of candidate devices corresponding to each task in the at least one task. The predetermined condition may refer to that the performance evaluation information is optimal. The performance evaluation information may be determined according to the device time cost information and the device fairness evaluation information, and the device time cost information and the device fairness evaluation information may be determined according to the scheduling information of the candidate devices participating in the model training in the current learning period. Therefore, the predetermined condition is used as a condition for determining a target scheduling scheme from a plurality of scheduling schemes. The set of candidate devices corresponding to the target scheduling scheme may be referred to as a set of target devices.
According to embodiments of the present disclosure, in the current learning period, for each task in the at least one task, the set of target devices corresponding to the task may be determined according to the respective scheduling information of the plurality of candidate devices corresponding to the task based on the scheduling policy. Then, the sets of target devices for the at least one task may be obtained. Operations of determining the sets of target devices for each task in the at least one task may be performed in parallel.
According to embodiments of the present disclosure, for each task in the at least one task, a global model corresponding to the task may be transmitted to the set of target devices corresponding to the task. Each target device included in the set of target devices may train the global model corresponding to the task by using the training data of the target device, so as to obtain a trained model corresponding to the task. Each target device corresponding to the task may transmit the trained model to the server, and the server aggregates all the trained models corresponding to the task to obtain a new global model corresponding to the task in the current learning period. Then, new global models respectively for all tasks in the current learning period may be obtained. The above-mentioned operations S210 to S230 may be performed repeatedly until a joint training end condition is met.
According to embodiments of the present disclosure, processes of training the global models for the plurality of tasks may be performed asynchronously and in parallel.
According to embodiments of the present disclosure, each candidate device may store training data corresponding to each task. Therefore, data is associated with devices, and a data fairness may be represented by a device fairness. The time cost information may reflect a processing capacity of device. The scheduling policy is a policy that enables the time cost information and the device fairness evaluation information of completing the task of the current learning period to meet the predetermined condition, in which not only the processing capacity of device but also the data fairness are considered. Therefore, it is possible to properly determine a plurality of sets of target devices for a plurality of tasks respectively based on the scheduling policy. On this basis, federated learning of tasks is performed using the sets of target devices corresponding to the tasks, so that the convergence accuracy and the convergence efficiency of global models for multiple tasks may be effectively ensured.
The federated learning method described in embodiments of the present disclosure will be further described with reference to
As shown in
The set of candidate devices corresponding to the first task is a set of candidate devices 302, and the set of candidate devices corresponding to the Pth task is a set of candidate devices 303. The set of candidate devices 302 includes candidate device 302-1 to candidate device 302-G. The set of candidate devices 303 includes candidate device 303-1 to candidate device 303-Q. P and Q are integers greater than or equal to 2.
For example, in the current learning period, for the first task, the server 301 may determine a set of target devices corresponding to the first task according to the respective scheduling information of the set of candidate devices 302 corresponding to the first task based on the scheduling policy. The set of target devices corresponding to the first task includes the candidate device 302-1 and the candidate device 302-G.
The server 301 may transmit the global model 301-1 corresponding to the first task to the set of target devices corresponding to the first task. Since the set of target devices corresponding to the first task includes the candidate device 302-1 and the candidate device 302-G, the global model 301-1 is trained using the candidate device 302-1 and the candidate device 302-G respectively, so as to obtain a trained model 301-10 and a trained model 301-11.
The candidate device 302-1 may transmit the trained model 301-10 to the server 301, and the candidate device 302-G may transmit the trained model 301-11 to the server 301. The server 301 may update the global model 301-1 based on the trained model 301-10 and the trained model 301-11.
For the Pth task, the server 301 may determine a set of target devices corresponding to the Pth task according to respective scheduling information of the set of candidate devices 303 corresponding to the Pth task based on the scheduling policy. The set of target devices corresponding to the Pth task includes the candidate device 303-1 and the candidate device 303-Q.
The server 301 may transmit the global model 301-P corresponding to the Pth task to the set of target devices corresponding to the Pth task. Since the set of target devices corresponding to the Pth task includes the candidate device 303-1 and the candidate device 303-Q, the global model 301-P is trained by using the candidate device 303-1 and the candidate device 303-Q respectively, so as to obtain a trained model 301-P0 and a trained model 301-P1.
The candidate device 303-1 may transmit the trained model 301-P0 to the server 301, and the candidate device 303-Q may transmit the trained model 301-P1 to the server 301. The server 301 may update the global model 301-P based on the trained model 301-P0 and the trained model 301-P1.
As shown in
According to embodiments of the present disclosure, the above-mentioned federated learning method may further include the following operations.
For each candidate device in the plurality of candidate devices corresponding to the task, a time length information of the candidate device performing the task is determined according to a resource information of the candidate device. A number of times the candidate device performed the task in a learning period before the current learning period is determined as a number of scheduling times. The scheduling information of the candidate device is obtained according to the time length information and the number of scheduling times.
According to embodiments of the present disclosure, the resource information may include at least one selected from: a number of CPU (Central Processing Unit), a frequency of CPU, a capacity of memory, a number of GPU (Graphics Processing Unit), an occupation information of computing resources, a data amount of local data, a communication mode, a bandwidth occupation information, or the like. The time length information may include at least one selected from a training time length information or a communication time length information.
According to embodiments of the present disclosure, the learning period before the current learning period may refer to all or some of the learning periods before the current learning period. The number of times that the candidate device performed the task in the learning period before the current learning period may refer to a total number of times that the candidate device was scheduled in the learning period before the current learning period.
According to embodiments of the present disclosure, determining the time length information of the candidate device performing the task according to the resource information of the candidate device may include the following operations.
A computing index of the candidate device is determined according to the resource information of the candidate device. The computing index may indicate a computing capacity of the candidate device. The time length information of the candidate device performing the task is determined by using a predetermined displacement exponential distribution function according to the computing index and the data amount of training data corresponding to the task stored in the candidate device.
According to embodiments of the present disclosure, the computing index may include a maximum value of the computing capacity, a maximum value of the communication capacity, a fluctuation value of the computing capacity, and a fluctuation value of the communication capacity.
According to embodiments of the present disclosure, a computing index ak and a computing index μk may be determined according to Equation (1) and Equation (2):
According to embodiments of the present disclosure, k represents an index of device, k∈{1, 2, . . . , K−1, K}, K represents a set of all devices, and |K| represents a number of devices included in the set of all devices. The set of all devices may be a set formed by all devices. |K| is an integer greater than or equal to 2. MAC represents a parameter related to a weight of the global model. MAC is proportional to a number of weights. f represents a frequency of CPU. ak represents a computing index corresponding to the candidate device k, and ak is in unit of ms/sample. μk represents another computing index corresponding to the candidate device k.
According to embodiments of the present disclosure, the time length information of the candidate device performing the task may be determined according to Equation (3):
According to embodiments of the present disclosure, P[tmk<t] represents a predetermined displacement exponential distribution function, Dkm represents a data amount of training data corresponding to task m stored by the candidate device k, τkm represents a number of times that the global model corresponding to the task m is trained by the candidate device k, tmk represents a time length information of the candidate device k performing the task m, and t represents a predetermined time length.
According to embodiments of the present disclosure, the time cost information corresponding to the task is determined according to the time length information of the set of candidate devices corresponding to the task and the time length information of the set(s) of target devices corresponding to all or some of other tasks. The other tasks refers to any task other than the task in the at least one task.
According to embodiments of the present disclosure, the device fairness evaluation information corresponding to the task is determined according to a scheduling balance variance of the set of candidate devices corresponding to the task and a scheduling balance variance of the set(s) of target devices corresponding to all or some of other tasks. The scheduling balance variance is determined according to the number of scheduling times of the devices included in the set of devices, and the set of devices includes the set of candidate devices or the set of target devices.
According to embodiments of the present disclosure, the set of target devices corresponding to the task refers to a set of candidate devices with which the time cost information and the device fairness evaluation information of the task meet the predetermined condition.
According to embodiments of the present disclosure, for each task in the at least one task, the process of determining the set of target devices corresponding to the task may be performed based on a fact that a set of target devices has been determined for any other task respectively.
According to embodiments of the present disclosure, in the process of determining the set of target devices corresponding to the task, the set of candidate devices with which the time cost information and the device fairness evaluation information of the task meet the predetermined condition may be determined as the set of target devices corresponding to the task.
According to embodiments of the present disclosure, for the current learning period, the time cost information corresponding to the task may be determined according to the time length information corresponding to the task and the time length information corresponding to all or some of other tasks. The time length information corresponding to the task may be determined according to the time length information of the set of candidate devices corresponding to the task. For example, a plurality of candidate devices included in the set of candidate devices may have respective time length information, and the time length information corresponding to the task may be a largest time length information among the plurality of time length information.
According to embodiments of the present disclosure, the time length information corresponding to the set of candidate devices corresponding to the task may be determined according to Equation (4):
T
m
r(Vmr)=max{tmk} (4)
According to embodiments of the present disclosure, r represents a learning period, Vmr represents a set of candidate devices corresponding to task m in the rth learning period, Tmr(Vmr) represents a time length information corresponding to the set of candidate devices Vmr, M represents a set of all task, m represents an index of task, m∈{1, 2, . . . , M−1, M}, |M| represents a number of tasks, and |M| is an integer greater than or equal to 2.
According to embodiments of the present disclosure, the scheduling balance variance may be determined according to the number of scheduling times of the devices included in the set of devices. If the set of devices is a set of target devices, the scheduling balance variance is determined according to the number of scheduling times of the target devices included in the set of target devices. If the set of devices is a set of candidate devices, the scheduling balance variance is determined according to the number of scheduling times of the candidate devices included in the set of candidate devices.
According to embodiments of the present disclosure, the scheduling balance variance corresponding to the set of devices may be determined according to Equation (5):
According to embodiments of the present disclosure, Fmr(Vmr) represents a scheduling balance variance corresponding to the set of candidate devices Vmr, sk, mr represents a total number of times the candidate device k performed the task m in (r−1) learning periods before the rth learning period. The candidate device k is a target device k when the predetermined condition is met.
According to embodiments of the present disclosure, a scheduling result of each task may have a potential impact on the scheduling of other tasks. Therefore, the impact of other tasks on the scheduled device for the current task is considered in the time cost information and the device fairness evaluation information. With fully considering the impact of the current scheduling scheme on other tasks, it is possible to more properly schedule device resources for each task, so as to improve the convergence efficiency.
According to embodiments of the present disclosure, operation S210 may further include the following operations.
A scheduling constraint function is determined based on the scheduling policy. A parameter item of the scheduling constraint function includes a time cost item corresponding to the time cost information of each task and a device fairness evaluation item corresponding to the device fairness evaluation information of each task for the current learning period. The set of target devices corresponding to the task is determined using a scheduling algorithm according to the respective scheduling information of the plurality of candidate devices corresponding to the task. The scheduling information of the set of target devices enables a first output value of the scheduling constraint function to meet the predetermined condition.
According to embodiments of the present disclosure, the scheduling constraint function may be determined according to the scheduling policy. The parameter item of the scheduling constraint function may include the time cost item corresponding to the time cost information of each task and the device fairness evaluation item corresponding to the device fairness evaluation information of each task for the current learning period. The time cost evaluation information and the device fairness evaluation information may be determined according to the scheduling information of the set of devices.
According to embodiments of the present disclosure, for each task in the at least one task, the first output value of the scheduling constraint function is determined according to a set of scheduling information of the set of target devices corresponding to each task. One or more scheduling algorithms may be used.
According to embodiments of the present disclosure, the respective scheduling information of the plurality of candidate devices corresponding to the task may be processed using the scheduling algorithm, so that the first output value of the scheduling constraint function meets the predetermined condition. The set of candidate devices corresponding to the task determined when the first output value of the scheduling constraint function meets the predetermined condition is determined as the set of target devices corresponding to the task.
According to embodiments of the present disclosure, the scheduling constraint function may be determined according to Equation (6) to Equation (8):
According to embodiments of the present disclosure, Vmr∈{K\Vor}, Vor represents a set of devices that have been scheduled in the rth learning period,
represents a plurality of candidate devices corresponding to the task m in the rth learning period, Vjr represent a set of target devices corresponding to a task j in the rth learning period, j∈{1, 2, . . . , M−1, M}, j≠m. A calculation process of Equation (7) and Equation (8) may refer to Equation (1) to Equation (6) described above.
According to embodiments of the present disclosure, the set of target devices may be determined according to Equation (9):
According to embodiments of the present disclosure, V′mr represents a set of target devices corresponding to the task m in the rth learning period.
According to embodiments of the present disclosure, the scheduling algorithm includes at least one first scheduling algorithm, at least one second scheduling algorithm, and a third scheduling algorithm.
According to embodiments of the present disclosure, determining the set of target devices corresponding to the task by using a scheduling algorithm based on the respective scheduling information of the plurality of candidate devices corresponding to the task may include the following operations.
The scheduling information of the plurality of candidate devices is processed using each first scheduling algorithm in the at least one first scheduling algorithm, so as to obtain a first set of candidate devices corresponding to the task. The scheduling information of the first set of candidate devices enables a second output value of the scheduling constraint function to meet the predetermined condition and to be greater than the first output value. The scheduling information of the plurality of candidate devices is processed using each second scheduling algorithm in the at least one second scheduling algorithm, so as to obtain a second set of candidate devices corresponding to each task in the at least one task. The scheduling information of at least one first set of candidate devices and the scheduling information of at least one second set of candidate devices are processed using the third scheduling algorithm, so as to obtain the set of target devices corresponding to the task.
According to embodiments of the present disclosure, the scheduling algorithm may include a first type of scheduling algorithm, a second type of scheduling algorithm, and the third scheduling algorithm. The first type of scheduling algorithm may be used to determine the first set of candidate devices according to the respective scheduling information of the plurality of candidate devices so that the second input value of the scheduling constraint function meets the predetermined condition. The second type of scheduling algorithm may be used to determine the second set of candidate devices directly according to the respective scheduling information of the plurality of candidate devices.
According to embodiments of the present disclosure, the first type of scheduling algorithm may include one or more first scheduling algorithms. The plurality of first scheduling algorithms may include at least one selected from: Bayesian Optimization (BO) algorithm, Reinforcement Learning (RL) algorithm, Genetic Algorithm (GA), or Greedy Algorithm (GA).
According to embodiments of the present disclosure, the second type of scheduling algorithm may include one or more second scheduling algorithms. The plurality of second scheduling algorithms may include at least one selected from Federated Average (FedAvg) algorithm or federated learning-based heuristic device selection algorithm. The Federated Average algorithm may include a random algorithm. The federated learning-based heuristic device selection algorithm may include FedCS (Client Selection for Federated Leading with Heterogeneous Resources in Mobile Edge) algorithm.
According to embodiments of the present disclosure, for each task in the at least one task, the respective scheduling information of the plurality of candidate devices corresponding to the task may be processed using each first scheduling algorithm in the at least one first scheduling algorithm, so as to obtain a first set of candidate devices with which the second output value of the scheduling constraint function meets the predetermined condition. That is, the respective scheduling information of the plurality of candidate devices corresponding to the task is processed using the first scheduling algorithm to determine the first set of candidate devices from the plurality of candidate devices, so that the second output value of the scheduling constraint function meets the predetermined condition. Therefore, a first set of candidate devices may be obtained in the above manner for each first scheduling algorithm, and thus at least one first set of candidate devices may be obtained.
According to embodiments of the present disclosure, for each second scheduling algorithm in the at least one second scheduling algorithm, the respective scheduling information of the plurality of candidate devices corresponding to the task is processed using the second scheduling algorithm, so as to obtain a second set of candidate devices corresponding to the second scheduling algorithm, and thus obtain at least one second set of candidate devices.
According to embodiments of the present disclosure, after at least one first set of candidate devices and at least one second set of candidate devices are obtained, a set of scheduling information of the at least one first set of candidate devices and a set of scheduling information of the at least one second set of candidate devices may be processed using the third scheduling algorithm, so as to obtain a set of target devices with which the first output value of the scheduling constraint function meets the predetermined condition and the first output value is less than the second output value.
For example, in the rth learning period, for the task m, it is possible to solve Equation (6) by using the BO algorithm, the RL algorithm, the genetic algorithm and the greedy algorithm respectively, so as to obtain a first set of candidate devices VBOm, r corresponding to the Bayesian optimization algorithm, a first set of candidate devices VRLm, r corresponding to the reinforcement learning algorithm, a first set of candidate devices VGeneticm, r corresponding to the genetic algorithm, and a first set of candidate devices VGreedym, r corresponding to the greedy algorithm.
The respective scheduling information of the plurality of sets of candidate devices corresponding to the task m is processed using the FedCS algorithm and the Random algorithm respectively, so as to obtain a second set of candidate devices VFedCSm, r corresponding to the FedCS algorithm and a second set of candidate devices VRandomm, r corresponding to the Random algorithm.
A set of target devices corresponding to the task m that meets Equation (6) may be selected from Θmr by using the third scheduling algorithm,
Θmr={VBOm,r,VRLm,r,VGeneticm,r,VGreerdym,r,VFedCSm,r,VRandomm,r}.
According to embodiments of the present disclosure, operation 210 may include the following operations.
Operations are performed in parallel to obtain the sets of target devices corresponding to each task. The operations include: obtaining a set of target devices corresponding to each task according to the respective scheduling information of a plurality of candidate devices corresponding to each task based on the scheduling policy.
According to embodiments of the present disclosure, the operations of determining the sets of target devices respectively for the plurality of tasks may be performed in parallel without waiting for each other, so that the convergence efficiency may be improved.
According to embodiments of the present disclosure, a number of learning periods may be determined according to Equation (10):
According to embodiments of the present disclosure, βm0, βm1 and βm2 are hyper-parameters corresponding to the task m. The hyper-parameters relate to a convergence curve of the task m. lm represents an output value of a predetermined loss function. Rm represents a number of learning periods required to achieve the output value of the predetermined loss function.
The above are merely exemplary embodiments, but the present disclosure is not limited thereto. Other federated learning methods known in the art may also be included, as long as the convergence efficiency and the convergence accuracy may be improved.
It should be noted that in the technical solution of the present disclosure, an acquisition, a storage, a use, a processing, a transmission, a provision, a disclosure and an application of user personal information involved comply with provisions of relevant laws and regulations, take essential confidentiality measures, and do not violate public order and good custom. In the technical solution of the present disclosure, authorization or consent is obtained from the user before the user's personal information is obtained or collected.
As shown in
The first determination module 510 may be used to determine, for each task in at least one task in a current learning period, a set of target devices corresponding to the task according to respective scheduling information of a plurality of candidate devices corresponding to the task based on a scheduling policy. The scheduling policy enables a time cost information and a device fairness evaluation information of completing the task in the current learning period to meet a predetermined condition.
The transmission module 520 may be used to transmit a global model corresponding to each task to the set of target devices corresponding to the task, so as to train the global model corresponding to each task by using the corresponding set of target devices.
The training module 530 may be used to update the corresponding global model based on trained models in response to receiving the trained models from the corresponding set of target devices, so as to complete the current learning period.
According to embodiments of the present disclosure, the federated learning apparatus 500 may further include a second determination module, a third determination module, and an obtaining module.
The second determination module may be used to determine, for each candidate device in the plurality of candidate devices corresponding to the task, a time length information of the candidate device performing the task, according to a resource information of the candidate device.
The third determination module may be used to determine a number of times the candidate device performed the task in a learning period before the current learning period as a number of scheduling times.
The obtaining module may be used to obtain the scheduling information of the candidate device according to the time length information and the number of scheduling times.
According to embodiments of the present disclosure, the second determination module may include a first determination sub-module and a second determination sub-module.
The first determination sub-module may be used to determine a computing index of the candidate device according to the resource information of the candidate device. The computing index indicates a computing capacity of the candidate device.
The second determination sub-module may be used to determine, by using a predetermined displacement exponential distribution function, the time length information of the candidate device performing the task, according to the computing index and a data amount of training data corresponding to the task stored in the candidate device.
According to embodiments of the present disclosure, the time cost information corresponding to the task is determined according to the time length information of the set of candidate devices corresponding to the task and the time length information of a set of target devices corresponding to all or some of other tasks, and the other tasks refer to any task other than the task in the at least one task.
According to embodiments of the present disclosure, the device fairness evaluation information corresponding to the task is determined according to a scheduling balance variance of the set of candidate devices corresponding to the task and a scheduling balance variance of the set of target devices corresponding to all or some of the other tasks, the scheduling balance variance is determined according to the number of scheduling times of devices in a set of devices, and the set of devices includes the set of candidate devices or the set of target devices.
According to embodiments of the present disclosure, the set of target devices corresponding to the task is a set of candidate devices with which the time cost information and the device fairness evaluation information of the task meet the predetermined condition.
According to embodiments of the present disclosure, the first determination module 510 may include a third determination sub-module and a fourth determination sub-module.
The third determination sub-module may be used to determine a scheduling constraint function based on the scheduling policy. A parameter item of the scheduling constraint function includes a time cost item corresponding to the time cost information of each task and a device fairness evaluation item corresponding to the device fairness evaluation information of each task for the current learning period.
The fourth determination sub-module may be used to determine, by using a scheduling algorithm, the set of target devices corresponding to the task, according to the respective scheduling information of the plurality of candidate devices corresponding to the task. The scheduling information of the set of target devices enables a first output value of the scheduling constraint function to meet the predetermined condition.
According to embodiments of the present disclosure, the scheduling algorithm includes at least one first scheduling algorithm, at least one second scheduling algorithm, and a third scheduling algorithm.
According to embodiments of the present disclosure, the fourth determination sub-module may include a first obtaining unit, a second obtaining unit, and a third obtaining unit.
The first obtaining unit may be used to process the scheduling information of the plurality of candidate devices by using each first scheduling algorithm in the at least one first scheduling algorithm, so as to obtain a first set of candidate devices corresponding to the task. The scheduling information of the first set of candidate devices enables a second output value of the scheduling constraint function to meet the predetermined condition and to be greater than the first output value.
The second obtaining unit may be used to process the scheduling information of the plurality of candidate devices by using each second scheduling algorithm in the at least one second scheduling algorithm, so as to obtain a second set of candidate devices corresponding to each task in the at least one task.
The third obtaining unit may be used to process the scheduling information of at least one first set of candidate devices and at least one second set of candidate devices by using the third scheduling algorithm, so as to obtain the set of target devices corresponding to the task.
According to embodiments of the present disclosure, the at least one first scheduling algorithm includes at least one selected from: a Bayesian optimization algorithm, a reinforcement learning algorithm, a genetic algorithm, or a greedy algorithm.
According to embodiments of the present disclosure, the at least one second scheduling algorithm includes at least one selected from: a federated average algorithm, or a federated learning-based heuristic device selection algorithm.
According to embodiments of the present disclosure, the first determination module 510 may include a parallel performing sub-module.
The parallel performing sub-module may be used to perform operations in parallel to obtain the set of target devices corresponding to each task. The operations include: obtaining the set of target devices corresponding to each task according to the respective scheduling information of the plurality of candidate devices corresponding to the task based on the scheduling policy.
According to embodiments of the present disclosure, the present disclosure further provides an electronic device, a readable storage medium, and a computer program product.
According to embodiments of the present disclosure, an electronic device is provided, including: at least one processor; and a memory communicatively connected to the at least one processor. The memory stores instructions executable by the at least one processor, and the instructions, when executed by the at least one processor, cause the at least one processor to implement the method described above.
According to embodiments of the present disclosure, a non-transitory computer-readable storage medium having computer instructions therein is provided, and the computer instructions are configured to cause a computer to implement the method described above.
According to embodiments of the present disclosure, a computer program product containing a computer program is provided, and the computer program, when executed by a processor, causes the processor to implement the method described above.
As shown in
A plurality of components in the electronic device 600 are connected to the I/O interface 605, including: an input unit 606, such as a keyboard, or a mouse; an output unit 607, such as displays or speakers of various types; a storage unit 608, such as a disk, or an optical disc; and a communication unit 609, such as a network card, a modem, or a wireless communication transceiver. The communication unit 609 allows the electronic device 600 to exchange information/data with other devices through a computer network such as Internet and/or various telecommunication networks.
The computing unit 601 may be various general-purpose and/or dedicated processing assemblies having processing and computing capabilities. Some examples of the computing units 601 include, but are not limited to, a central processing unit (CPU), a graphics processing unit (GPU), various dedicated artificial intelligence (AI) computing chips, various computing units that run machine learning model algorithms, a digital signal processing processor (DSP), and any suitable processor, controller, microcontroller, etc. The computing unit 601 executes various methods and steps described above, such as the federated learning method. For example, in some embodiments, the federated learning method may be implemented as a computer software program which is tangibly embodied in a machine-readable medium, such as the storage unit 608. In some embodiments, the computer program may be partially or entirely loaded and/or installed in the electronic device 600 via the ROM 602 and/or the communication unit 609. The computer program, when loaded in the RAM 603 and executed by the computing unit 601, may execute one or more steps in the federated learning method described above. Alternatively, in other embodiments, the computing unit 601 may be configured to perform the federated learning method by any other suitable means (e.g., by means of firmware).
Various embodiments of the systems and technologies described herein may be implemented in a digital electronic circuit system, an integrated circuit system, a field programmable gate array (FPGA), an application specific integrated circuit (ASIC), an application specific standard product (ASSP), a system on chip (SOC), a complex programmable logic device (CPLD), a computer hardware, firmware, software, and/or combinations thereof. These various embodiments may be implemented by one or more computer programs executable and/or interpretable on a programmable system including at least one programmable processor. The programmable processor may be a dedicated or general-purpose programmable processor, which may receive data and instructions from a storage system, at least one input device and at least one output device, and may transmit the data and instructions to the storage system, the at least one input device, and the at least one output device.
Program codes for implementing the methods of the present disclosure may be written in one programming language or any combination of more programming languages. These program codes may be provided to a processor or controller of a general-purpose computer, a dedicated computer or other programmable data processing apparatus, such that the program codes, when executed by the processor or controller, cause the functions/operations specified in the flowcharts and/or block diagrams to be implemented. The program codes may be executed entirely on a machine, partially on a machine, partially on a machine and partially on a remote machine as a stand-alone software package or entirely on a remote machine or server.
In the context of the present disclosure, a machine-readable medium may be a tangible medium that may contain or store a program for use by or in connection with an instruction execution system, an apparatus or a device. The machine-readable medium may be a machine-readable signal medium or a machine-readable storage medium. The machine-readable medium may include, but is not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus or device, or any suitable combination of the above. More specific examples of the machine-readable storage medium may include an electrical connection based on one or more wires, a portable computer disk, a hard disk, a random access memory (RAM), a read only memory (ROM), an erasable programmable read only memory (EPROM or a flash memory), an optical fiber, a compact disk read only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the above.
In order to provide interaction with the user, the systems and technologies described here may be implemented on a computer including a display device (for example, a CRT (cathode ray tube) or LCD (liquid crystal display) monitor) for displaying information to the user, and a keyboard and a pointing device (for example, a mouse or a trackball) through which the user may provide the input to the computer. Other types of devices may also be used to provide interaction with the user. For example, a feedback provided to the user may be any form of sensory feedback (for example, visual feedback, auditory feedback, or tactile feedback), and the input from the user may be received in any form (including acoustic input, voice input or tactile input).
The systems and technologies described herein may be implemented in a computing system including back-end components (for example, a data server), or a computing system including middleware components (for example, an application server), or a computing system including front-end components (for example, a user computer having a graphical user interface or web browser through which the user may interact with the implementation of the system and technology described herein), or a computing system including any combination of such back-end components, middleware components or front-end components. The components of the system may be connected to each other by digital data communication (for example, a communication network) in any form or through any medium. Examples of the communication network include a local area network (LAN), a wide area network (WAN), and the Internet.
A computer system may include a client and a server. The client and the server are generally far away from each other and usually interact through a communication network. The relationship between the client and the server is generated through computer programs running on the corresponding computers and having a client-server relationship with each other. The server may be a cloud server, a server of a distributed system, or a server combined with a block-chain.
It should be understood that steps of the processes illustrated above may be reordered, added or deleted in various manners. For example, the steps described in the present disclosure may be performed in parallel, sequentially, or in a different order, as long as a desired result of the technical solution of the present disclosure may be achieved. This is not limited in the present disclosure.
The above-mentioned specific embodiments do not constitute a limitation on the scope of protection of the present disclosure. Those skilled in the art should understand that various modifications, combinations, sub-combinations and substitutions may be made according to design requirements and other factors. Any modifications, equivalent replacements and improvements made within the spirit and principles of the present disclosure shall be contained in the scope of protection of the present disclosure.
Number | Date | Country | Kind |
---|---|---|---|
202111381852.6 | Nov 2021 | CN | national |