TRAINING METHOD, APPARATUS, CHIP, AND SYSTEM FOR NEURAL NETWORK MODEL

Information

  • Patent Application
  • 20190279088
  • Publication Number
    20190279088
  • Date Filed
    May 29, 2019
    5 years ago
  • Date Published
    September 12, 2019
    5 years ago
Abstract
A method for training a neural network model are disclosed. Each training period includes K iterations, and for an ith iteration of one of N worker modules within each training period, each worker module performs in parallel the following steps: calculating a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculating a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration; and pulling, by the worker module, a global gradient of an rth iteration from a server module and/or pushing, by the worker module, a local gradient of an fth iteration to the server module. In this way, time windows of a calculation process and a communication process overlap, thereby reducing time delay.
Description
TECHNICAL FIELD

Embodiments of this application relate to the field of machine learning, and in particular, to a training method, apparatus, chip, and system for a neural network model.


BACKGROUND

With rapid development and popularization of computers and information technologies, industry application data has exploded. Big data of industries and enterprises on a trillionbyte (TB) or even petabyte (PB) scale often implies in-depth knowledge and value that are not available in a small amount of data. Data analysis led by large-scale machine learning (including deep learning) is a key technology for transforming big data into useful knowledge. Google, Facebook, Microsoft, Baidu and other large domestic and foreign Internet companies have set up specialized big-data-based machine learning and artificial intelligence research and development institutions to deeply and systematically study big-data-based machine learning and intelligent computing technologies.


Currently, a parameter server computing architecture is relatively commonly used to deploy large-scale machine learning algorithms in large-scale distributed parallel computing systems, in combination with an effective stochastic gradient descent algorithm for training. FIG. 1 is an example of a schematic diagram of a distributed training system. As shown in FIG. 1, the system includes a server module set 101 and a worker module set 102. The server module set may include a plurality of server modules. The worker module set may include a plurality of worker modules. The server module is similar to a master server node. The worker module may represent a calculation performer. The distributed training system includes a plurality of distributed nodes. Each node may include one or more worker modules, or may further include one or more server modules.


Using FIG. 1 as an example, a signaling interaction process between a server module and a worker module in a distributed system is described in detail. FIG. 1 includes N worker modules and P server modules. The N worker modules and the P server modules are configured to train a model parameter in a neural network model. In this example, one model parameter is trained.


First, a distributed computing platform is started, and an application is deployed. A server module performs initialization, to obtain an initialized model parameter ω1. A global model parameter ω1 is pulled from the server module to each worker module.


Second, each worker module performs a first iteration: reading sample data, and calculating a local gradient based on the global model parameter ω1, where a worker module 1 obtains a local gradient Δω1-1 through calculation, a worker module 2 obtains a local gradient Δω2-1 through calculation, . . . , and a worker module N obtains a local gradient ΔωN-1 through calculation.


Third, each worker module performs a second iteration: pushing, by the worker modules, the local gradient Δω1-1, the local gradient Δω2-1, . . . , and the local gradient ΔωN-1 that are generated in the first iteration to the server module, and calculating, by the server module, a global gradient ω1_1 based on the local gradient Δω1-1, the local gradient Δω2-1, . . . , and the local gradient ΔωN-1; pulling the global gradient ω1_1 from the server module to each worker module; and updating, by each worker module, the local model parameter ω1 to a model parameter ω2 based on the global gradient Δω1_1.


Each worker module reads the sample data, and calculates a local gradient based on the global model parameter ω2, where the worker module 1 obtains a local gradient Δω1-2 through calculation, the worker module 2 obtains a local gradient Δω2-2 through calculation, . . . , and the worker module N obtains a local gradient ΔωN-2 through calculation.


Fourth, in subsequent iterations, the worker modules push respective local gradients to the server module, to pull a global gradient again from the server module, so that each worker module updates a local model parameter based on the global gradient pulled from the server module and calculates a gradient.


Fifth, after repeated iterations, each worker module reports a local model parameter updated for the last time to the server module, and the server module determines an average value based on the updated local model parameter reported by each worker module, to obtain a trained model parameter. This process may be referred to as a training period (which may be referred to as an epoch), and the model parameter may be trained by using a plurality of training periods.


It can be learned from the foregoing descriptions that, for each model parameter in an iteration, each worker module first pushes the local gradient to the server module, waits until the global gradient of the model parameter is pulled from the server module, then updates the local model parameter based on the global gradient, and then calculates the local gradient based on the updated local model parameter. It can be learned that a time taken by each iteration process includes a communication time of pushing the local gradient to the server module, a communication time of pulling the global gradient to the server module, a time of updating the local model parameter, and a time of calculating the local gradient. Consequently, one iteration takes a relatively long time, resulting in a large delay in a model parameter training process.


SUMMARY

Embodiments of this application provide a training method, apparatus, chip, and system for a neural network model, to reduce a model parameter training delay and improve model parameter training efficiency.


According to a first aspect, an embodiment of this application provides a training method for a neural network model. This embodiment of this application is applicable to a training system that includes a server module and N worker modules, the server module and the N worker modules are configured to train a model parameter within at least one training period, each of the at least one training period includes K iterations, and for an ith iteration of one of the N worker modules within each training period, each worker module performs in parallel the following steps: calculating a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculating a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration; and pulling, by the worker module, a global gradient of an rth iteration from the server module and/or pushing, by the worker module, a local gradient of an fth iteration to the server module.


In this embodiment of this application, a first process and a second process are executed in parallel in each iteration process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art problem in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


Optionally, the calculating, by the worker module, a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration includes: calculating, by the worker module if determining that a global gradient of a jth iteration that meets a first condition has been pulled from the server module, the model parameter of the (i+1)th iteration based on the global gradient of the jth iteration, the local gradient of the ith iteration, and the model parameter of the ith iteration, where j is a positive integer less than or equal to i, and the first condition includes: the global gradient of the jth iteration has not been used to calculate a model parameter in any iteration between a first iteration and the ith iteration. In this way, the model parameter of the (i+1)th iteration can be calculated based on the global gradient of the jth iteration that meets the first condition and that has been pulled from the server module, thereby improving accuracy of calculating the model parameter of the (i+1)th iteration. On the other hand, the global gradient of the jth iteration that meets the first condition is selected from global gradients that have been pulled from the server module, and there is no need to wait for the communication process, thereby further reducing iteration duration and improving the model parameter training efficiency.


Optionally, the calculating, by the worker module, a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration includes: calculating, by the worker module if determining that a global gradient of a jth iteration that meets a first condition has not been pulled from the server module, the model parameter of the (i+1)th iteration based on the local gradient of the ith iteration and the model parameter of the ith iteration. In this way, there is no need to wait for the communication process, thereby further reducing the iteration duration and improving the model parameter training efficiency.


Optionally, the first condition further includes: the global gradient of the jth iteration is a global gradient in an iteration with a largest iteration batch number in all global gradients that have been pulled from the server module. In this way, a model parameter can be updated based on a global gradient in an iteration nearest to a current iteration process, thereby accelerating model parameter convergence.


Optionally, the global gradient of the jth iteration is determined based on the following content: one or more local gradients of the jth iteration that are reported by M of the N worker modules, where M is an integer greater than or equal to 1 and less than or equal to N. In this way, the worker module and the server module can work more flexibly, and an amount of communication between the worker module and the server module is further reduced.


Optionally, the pulling, by the worker module, a global gradient of an rth iteration from the server module and/or pushing, by the worker module, a local gradient of an fth iteration to the server module includes: pulling the global gradient of the rth iteration from the server module; or pulling the global gradient of the rth iteration from the server module, and pushing a local gradient of an (i−1)th iteration to the server module; or pulling the global gradient of the rth iteration from the server module, and pushing the local gradient of the ith iteration to the server module; or pushing a local gradient of an (i−1)th iteration to the server module; or pushing the local gradient of the ith iteration to the server module. In this way, flexibility of the worker module can be improved, and on the other hand, a local gradient in an iteration nearest to a current iteration process can be pushed to the server module as much as possible, thereby accelerating model parameter convergence.


Optionally, if i is K, the method further includes: pushing, by the worker module, a model parameter of a (K+1)th iteration to the server module after the worker module calculates a local gradient of a Kth iteration and calculates the model parameter of the (K+1)th iteration based on the local gradient of the Kth iteration and a model parameter of the Kth iteration, where the model parameter of the (K+1)th iteration is used to enable the server module to determine a model parameter of a first iteration within a next training period based on the iteration quantity K and the model parameter of the (K+1)th iteration that is pushed by each of the N worker modules to the server module. In this way, accuracy of a model parameter of a training period is improved.


According to a second aspect, an embodiment of this application provides a training apparatus for a neural network model, where the training apparatus includes N worker modules, the training apparatus is applicable to a training system that includes a server module and the N worker modules, the server module and the N worker modules are configured to train a model parameter within at least one training period, and each of the at least one training period includes K iterations; each of the N worker modules includes a communications module and a calculation module; and for an ith iteration of one of the N worker modules within each training period, where N and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K: the communications module and the calculation module of each worker module run in parallel, where the calculation module is configured to: calculate a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculate a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration; and the communications module is configured to: pull a global gradient of an rth iteration from the server module and/or push a local gradient of an fth iteration to the server module, where r and f each are a positive integer less than or equal to i.


In this embodiment of this application, the communications module and the calculation module run in parallel in each iteration process, the communications module executes a first process, and the calculation module executes a second process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


Optionally, the calculation module is configured to: calculate, if it is determined that a global gradient of a jth iteration that meets a first condition has been pulled from the server module, the model parameter of the (i+1)th iteration based on the global gradient of the jth iteration, the local gradient of the ith iteration, and the model parameter of the ith iteration, where j is a positive integer less than or equal to i, and the first condition includes: the global gradient of the jth iteration has not been used to calculate a model parameter in any iteration between a first iteration and the ith iteration. In this way, there is no need to wait for the communication process, thereby further reducing the iteration duration and improving the model parameter training efficiency.


Optionally, the calculation module is configured to: calculate, if it is determined that a global gradient of a jth iteration that meets a first condition has not been pulled from the server module, the model parameter of the (i+1)th iteration based on the local gradient of the ith iteration and the model parameter of the ith iteration. In this way, a model parameter can be updated based on a global gradient in an iteration nearest to a current iteration process, thereby accelerating model parameter convergence.


Optionally, the first condition further includes: the global gradient of the jth iteration is a global gradient in an iteration with a largest iteration batch number in all global gradients that have been pulled from the server module. In this way, the model parameter of the (i+1)th iteration can be calculated based on the global gradient of the jth iteration that meets the first condition and that has been pulled from the server module, thereby improving accuracy of calculating the model parameter of the (i+1)th iteration. On the other hand, the global gradient of the jth iteration that meets the first condition is selected from global gradients that have been pulled from the server module, and there is no need to wait for the communication process, thereby further reducing iteration duration and improving the model parameter training efficiency.


Optionally, the global gradient of the jth iteration is determined based on the following content: one or more local gradients of the jth iteration that are reported by M of the N worker modules, where M is an integer greater than or equal to 1 and less than or equal to N. In this way, the worker module and the server module can work more flexibly, and an amount of communication between the worker module and the server module is further reduced.


Optionally, the communications module is configured to: pull the global gradient of the rth iteration from the server module; or pull the global gradient of the rth iteration from the server module, and push a local gradient of an (i−1)th iteration to the server module; or pull the global gradient of the rth iteration from the server module, and push the local gradient of the ith iteration to the server module; or push a local gradient of an (i−1)th iteration to the server module; or push the local gradient of the ith iteration to the server module. In this way, flexibility of the worker module can be improved, and on the other hand, a local gradient in an iteration nearest to a current iteration process can be pushed to the server module as much as possible, thereby accelerating model parameter convergence.


Optionally, if i is K, the communications module is further configured to: push a model parameter of a (K+1)th iteration to the server module after the calculation module is used to calculate a local gradient of a Kth iteration and calculate the model parameter of the (K+1)th iteration based on the local gradient of the Kth iteration and a model parameter of the Kth iteration, where the model parameter of the (K+1)th iteration is used to enable the server module to determine a model parameter of a first iteration within a next training period based on the iteration quantity K and the model parameter of the (K+1)th iteration that is pushed by each of the N worker modules to the server module. In this way, accuracy of a model parameter of a training period is improved.


According to a third aspect, an embodiment of this application provides a training apparatus for a neural network model, where the training apparatus includes a processor, a memory, and a transceiver, the processor includes N processor cores, the training apparatus is applicable to a training system that includes a server module and N processor cores, the server module and the N processor cores are configured to train a model parameter within at least one training period, and each of the at least one training period includes K iterations, where


the memory is configured to store an instruction; the processor is configured to: execute the instruction stored in the memory, and control the transceiver to transmit data to the server module; and when the processor executes the instruction stored in the memory, each of the N processor cores is configured to:


calculate a model parameter of an (i+1)th iteration based on a local gradient of an ith iteration and a model parameter of the ith iteration, and if i is less than K, calculate a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration;


the transceiver is configured to: pull a global gradient of an rth iteration from the server module and/or push a local gradient of an fth iteration to the server module, where r and f each are a positive integer less than or equal to i; and


the memory is configured to store the global gradient pulled from the server module and the calculated local gradient.


In this embodiment of this application, the transceiver and the processor run in parallel in each iteration process, the processor executes a first process, and the transceiver executes a second process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


Optionally, the processor is configured to: calculate, if determining that a global gradient of a jth iteration that meets a first condition has been pulled from the server module, the model parameter of the (i+1)th iteration based on the global gradient of the jth iteration, the local gradient of the ith iteration, and the model parameter of the ith iteration, where j is a positive integer less than or equal to i, and the first condition includes: the global gradient of the jth iteration has not been used to calculate a model parameter in any iteration between a first iteration and the ith iteration. In this way, there is no need to wait for the communication process, thereby further reducing the iteration duration and improving the model parameter training efficiency.


Optionally, the processor is configured to: calculate, if determining that a global gradient of a jth iteration that meets a first condition has not been pulled from the server module, the model parameter of the (i+1)th iteration based on the local gradient of the ith iteration and the model parameter of the ith iteration. In this way, a model parameter can be updated based on a global gradient in an iteration nearest to a current iteration process, thereby accelerating model parameter convergence.


Optionally, the first condition further includes: the global gradient of the jth iteration is a global gradient in an iteration with a largest iteration batch number in all global gradients that have been pulled from the server module. In this way, the model parameter of the (i+1)th iteration can be calculated based on the global gradient of the jth iteration that meets the first condition and that has been pulled from the server module, thereby improving accuracy of calculating the model parameter of the (i+1)th iteration. On the other hand, the global gradient of the jth iteration that meets the first condition is selected from global gradients that have been pulled from the server module, and there is no need to wait for the communication process, thereby further reducing iteration duration and improving the model parameter training efficiency.


Optionally, the global gradient of the jth iteration is determined based on the following content: one or more local gradients of the jth iteration that are reported by M of the N worker modules, where M is an integer greater than or equal to 1 and less than or equal to N. In this way, the worker module and the server module can work more flexibly, and an amount of communication between the worker module and the server module is further reduced.


Optionally, the transceiver is configured to: pull the global gradient of the rth iteration from the server module; or pull the global gradient of the rth iteration from the server module, and push a local gradient of an (i−1)th iteration to the server module; or pull the global gradient of the rth iteration from the server module, and push the local gradient of the ith iteration to the server module; or push a local gradient of an (i−1)th iteration to the server module; or push the local gradient of the ith iteration to the server module. In this way, flexibility of the worker module can be improved, and on the other hand, a local gradient in an iteration nearest to a current iteration process can be pushed to the server module as much as possible, thereby accelerating model parameter convergence.


Optionally, if i is K, the transceiver is further configured to: push a model parameter of a (K+1)th iteration to the server module after the processor is used to calculate a local gradient of a Kth iteration and calculate the model parameter of the (K+1)th iteration based on the local gradient of the Kth iteration and a model parameter of the Kth iteration, where the model parameter of the (K+1)th iteration is used to enable the server module to determine a model parameter of a first iteration within a next training period based on the iteration quantity K and the model parameter of the (K+1)th iteration that is pushed by each of the N worker modules to the server module. In this way, accuracy of a model parameter of a training period is improved.


According to a fourth aspect, an embodiment of this application provides a training chip for a neural network model, where the chip is applicable to a training system that includes N chips and a server, the server module and the N chips are configured to train a model parameter within at least one training period, and each of the at least one training period includes K iterations; and each of the N chips is configured to perform the method performed by the worker module in the first aspect.


According to a fifth aspect, an embodiment of this application provides a training system for a neural network model, where the system includes a server module and N worker modules, the server module and the N worker modules are configured to train a model parameter within at least one training period, and each of the at least one training period includes K iterations; for an ith iteration of one of the N worker modules within each training period, each worker module is configured to perform in parallel the following steps: calculating a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculating a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration; and pulling a global gradient of an rth iteration from the server module and/or pushing a local gradient of an fth iteration to the server module, where r and f each are a positive integer less than or equal to i, where N and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K; and the server module is configured to: calculate the global gradient of the rth iteration based on a received local gradient of the rth iteration that is pushed by the worker module, and pull the global gradient of the rth iteration to the worker module; and receive the local gradient of the fth iteration that is pushed by the worker module, and calculate a global gradient of the fth iteration based on the local gradient of the fth iteration that is pushed by the worker module.


According to a sixth aspect, a computer program product is provided, where the computer program product includes a computer program (which may also be referred to as code or an instruction), and when run, the computer program causes a computer to perform the method according to any possible implementation of the first aspect.


According to a seventh aspect, a computer readable medium is provided, where the computer readable medium stores a computer program, and when run on a computer, the computer program causes the computer to perform the method according to any possible implementation of the first aspect.


In the embodiments of this application, the first process and the second process are executed in parallel in each iteration process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.





BRIEF DESCRIPTION OF DRAWINGS


FIG. 1 is a schematic diagram of a distributed training system shown in the background;



FIG. 2 is a schematic architectural diagram of an application scenario applicable to an embodiment of this application;



FIG. 3 is a schematic diagram of an applicable training system according to an embodiment of this application;



FIG. 4 is a schematic flowchart of a training method for a neural network model according to an embodiment of this application;



FIG. 5 is a schematic flowchart of a training method for a neural network model according to an embodiment of this application;



FIG. 6 is a schematic structural diagram of a training apparatus for a neural network model according to an embodiment of this application;



FIG. 7 is a schematic structural diagram of a training apparatus for a neural network model according to an embodiment of this application; and



FIG. 8 is a schematic structural diagram of a training system for a neural network model according to an embodiment of this application.





DESCRIPTION OF EMBODIMENTS


FIG. 2 is an example of a schematic architectural diagram of an application scenario applicable to an embodiment of this application. As shown in FIG. 2, in a specific implementation, there may be various raw data, for example, telecom data 201, financial data 202, and consumer data 203 in FIG. 2. A big data platform 204 performs data collection, data storage, data calculation, or the like on the raw data. Then data processed by the big data platform 204 is obtained. A data mining platform 205 obtains, from the big data platform, the data processed by the big data platform 204, and performs data mining, for example, performs data mining by using a deep learning module such as logistic regression analysis (LR), a large-scale traditional neural network model Latent Dirichlet Allocation (LDA), a convolutional neural network (CNN), a recurrent neural network (RNN), a sparse autoencoder (SAE), to obtain a data mining result. An application platform 206 includes various fields, and can perform, based on the data mining result determined by the data mining platform 205, big data analysis in the telecommunications field, big data analysis in the financial field, big data analysis in the consumer field, big data analysis in another field, and the like.


This embodiment of this application may be used to train a distributed parallel computer cluster of massive data. Suitable algorithms include various deep learning algorithms such as a convolutional neural network (for image, speech, or video processing), a recursive neural network (for natural language processing), and a deep neural network (for speech processing), and a large-scale machine learning algorithm.


The solution provided in this embodiment of this application is applied to the data mining platform 205. The data mining platform 205 can perform mining analysis on underlying raw data through deep learning intelligent analysis, and improve, through an accelerated training process of a distributed architecture, performance and scalability of the data mining platform trained based on the deep learning, thereby supporting decision-making and operation of an upper-layer application platform, such as video analysis, image recognition, object detection, natural language processing, and other upper-layer application platform services.


In this embodiment of this application, a node may be a computer device that includes at least one graphics processing unit (GPU) chip and/or at least one central processing unit (CPU) chip. Each GPU chip includes one or more GPU cores. Each CPU chip includes one or more CPU cores. In this embodiment of this application, a worker module may include one or more GPU cores, and a server module may include one or more CPU cores.


For ease of description, a plurality of server modules may be referred to as a server module set, and a plurality of worker modules may be referred to as a worker module set. FIG. 3 is an example of a schematic diagram of an applicable system architecture according to an embodiment of this application. As shown in FIG. 3, this embodiment of this application includes a server module set 307 and a worker module set 308. The server module set 307 includes a plurality of server modules, which are separately a server module 301, a server module 302, . . . , and a server module 303. The worker module set 308 may include a plurality of worker modules, which are separately a worker module 304, a worker module 305, . . . , and a worker module 306.


A distributed system architecture includes a plurality of distributed nodes. There are three types of specific deployment forms for each node. In a first form, worker modules and server modules are deployed on a same node, and a quantity of the worker modules is the same as or different from a quantity of the server modules. In a second form, worker modules and server modules are respectively deployed on different nodes, and a quantity of the worker modules is the same as or different from a quantity of the server modules. In a third form, worker modules and server modules are deployed on different nodes in a mixed manner. To be specific, at least one of the plurality of nodes includes both worker modules and server modules, and a quantity of the worker modules is the same as or different from a quantity of the server modules. The solution provided in this embodiment of this application is applicable to any specific deployment form.


The server module and the worker module are configured to train a model parameter within at least one training period. Each training period (which may be referred to as an epoch) may include K iterations. The model parameter may be trained in one or more training periods. In this embodiment of this application, one training period is mainly described in detail in the following content. A solution of another training period is similar to the following content and is not further described.


Based on the foregoing content, FIG. 4 is an example of a schematic flowchart of a training method for a neural network model according to an embodiment of this application. The training method for a neural network model is applicable to a training system that includes a server module and N worker modules. The server module and the N worker modules are configured to train a model parameter within at least one training period. Each of the at least one training period includes K iterations. For an ith iteration of one of the N worker modules within each training period, where N and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K, as shown in FIG. 4, the method includes the following steps.


Step 401: Each worker module performs in parallel step 402 and step 403. The worker module is one of the N worker modules.


Step 402: Each worker module calculates a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculates a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration.


Step 403: Each worker module pulls a global gradient of an rth iteration from the server module and/or pushes a local gradient of an fth iteration to the server module, where r and f each are a positive integer less than or equal to i. Specifically, there are several solutions. In a first solution, the worker module pulls the global gradient of the rth iteration from the server module. In a second solution, the worker module pushes the local gradient of the fth iteration to the server module. In a third solution, the worker module pulls the global gradient of the rth iteration from the server module and pushes the local gradient of the fth iteration to the server module. Specifically, that the worker module pulls the global gradient of the rth iteration from the server module includes: The worker module receives the global gradient of the rth iteration that is sent by the server module, or the worker module proactively obtains the global gradient of the rth iteration from the server module. The pushing the local gradient of the fth iteration to the server module is specifically: sending, by the worker module, the local gradient of the fth iteration to the server module.


In this embodiment of this application, step 402 and step 403 are performed in parallel in each iteration process. Step 402 is a first process and step 403 is a second process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. On one hand, in the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


On the other hand, in this embodiment of this application, the second process is executed while the first process is executed. This avoids a prior-art problem in which a communication process needs to be executed only after a local gradient of an (i+1)th iteration is calculated, thereby further reducing duration of an iteration and improving model parameter training efficiency.


In this embodiment of this application, the N worker modules and the server module may be located on one node. The node is a computer device that includes a plurality of GPU cores and a plurality of CPU cores. One worker module includes one or more GPU cores, and one server module includes one or more CPU cores. In this case, the N worker modules and the server module may communicate with each other through inter-core communication between the GPU cores and the CPU cores. If the N worker modules and the server module are separately located in a plurality of nodes, the N worker modules and the server module may communicate with each other through some links between the nodes. In this embodiment of this application, each of the N worker modules and the server module can communicate with each other.


Optionally, in step 402, the calculating, by the worker module, a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration includes: calculating, by the worker module if determining that a global gradient of a jth iteration that meets a first condition has been pulled from the server module, the model parameter of the (i+1)th iteration based on the global gradient of the jth iteration, the local gradient of the ith iteration, and the model parameter of the ith iteration, where j is a positive integer less than or equal to i, and the first condition includes: the global gradient of the jth iteration has not been used to calculate a model parameter in any iteration between a first iteration and the ith iteration. In this way, the model parameter of the (i+1)th iteration can be calculated based on the global gradient of the jth iteration that meets the first condition and that has been pulled from the server module, thereby improving accuracy of calculating the model parameter of the (i+1)th iteration. On the other hand, the global gradient of the jth iteration that meets the first condition is selected from global gradients that have been pulled from the server module, and there is no need to wait for the communication process, thereby further reducing iteration duration and improving the model parameter training efficiency.


The calculating, by the worker module, a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration includes: calculating, by the worker module if determining that a global gradient of a jth iteration that meets a first condition has not been pulled from the server module, the model parameter of the (i+1)th iteration based on the local gradient of the ith iteration and the model parameter of the ith iteration. In this way, there is no need to wait for the communication process, thereby further reducing the iteration duration and improving the model parameter training efficiency.


Specifically, the communication process and the calculation process in the system are two processes independent of each other and can be executed in parallel. Optionally, when executing the communication process, the worker module pushes the local gradient to the server module once and pulls the global gradient from the server module once; or continuously pushes the local gradient to the server module a plurality of times, and pulls the global gradient from the server module once or continuously a plurality of times. Optionally, in step 403, if the server module has calculated the global gradient of the rth iteration, the worker module may pull the global gradient of the rth iteration from the server module in step 403. In another optional solution, in step 403, if the worker module has just completed a process of pushing the local gradient to the server module once, or the worker module turns to a process of pushing the local gradient to the server module, the worker module may choose to push the local gradient of the fth iteration to the server module. In another optional solution, the communication process between the worker module and the server module is executed relatively quickly. During calculation of the model parameter of the (i+1)th iteration and the local gradient of the (i+1)th iteration, the worker module may pull the global gradient of the rth iteration from the server module and push the local gradient of the fth iteration to the server module; or may push the local gradient of the fth iteration to the server module and pull the global gradient of the rth iteration from the server module. In this embodiment of this application, there is no sequential order between pushing the local gradient of the fth iteration to the server module and pulling the global gradient of the rth iteration from the server module. In the foregoing solution, there are a plurality of implementation solutions that the worker module may choose to push the local gradient of the fth iteration to the server module.


The following describes in detail the foregoing content by using an example. The worker module currently has been successfully pulled a global gradient of a first iteration, a global gradient of a third iteration, a global gradient of a fourth iteration, and a global gradient of a sixth iteration from the server module. The global gradient of the first iteration has been used for calculating a model parameter of a second iteration. None of the global gradient of the third iteration, the global gradient of the fourth iteration, and the global gradient of the sixth iteration is used. Currently, a process of a ninth iteration is performed, and a model parameter of the ninth iteration is updated. In other words, the (i+1)th iteration is the ninth iteration. The global gradient of the jth iteration that currently meets the first condition is any one of the global gradient of the third iteration, the global gradient of the fourth iteration, and the global gradient of the sixth iteration. Optionally, the model parameter of the ninth iteration may be calculated based on a local gradient of an eighth iteration, a model parameter of the eighth iteration, and any one of the global gradient of the third iteration, the global gradient of the fourth iteration, and the global gradient of the sixth iteration.


Optionally, the first condition further includes: the global gradient of the jth iteration is a global gradient in an iteration with a largest iteration batch number in all global gradients that have been pulled from the server module. In this way, a model parameter can be updated based on a global gradient in an iteration nearest to a current iteration process, thereby accelerating model parameter convergence. The iteration batch number is a sequence number of an iteration. For example, an iteration batch number of the third iteration is 3. A larger iteration sequence number indicates a larger iteration batch number. With reference to the example, the iteration with the largest iteration batch number in the global gradient of the third iteration, the global gradient of the fourth iteration, and the global gradient of the sixth iteration is the sixth iteration. Therefore, preferably, the jth iteration is determined as the global gradient of the sixth iteration. Optionally, the model parameter of the ninth iteration is calculated based on the global gradient of the sixth iteration, the local gradient of the eighth iteration, and the model parameter of the eighth iteration.


Optionally, in a process of updating the model parameter of the ninth iteration, the communication process may be executed in parallel. In the process of updating the model parameter of the ninth iteration by the worker module, the worker module has calculated local gradients in processes of first eight iterations, and has pushed a local gradient of the first iteration, a local gradient of the third iteration, a local gradient of the fourth iteration, and a local gradient of the sixth iteration to the server module. Local gradients that have not been pushed to the server module include: a local gradient of the second iteration, a local gradient of a fifth iteration, a local gradient of a seventh iteration, and the local gradient of the eighth iteration. Optionally, the worker module may selectively perform the following solutions:


Solution a1: In processes of updating the model parameter of the ninth iteration and calculating a local gradient of the ninth iteration, the worker module performs in parallel the following step: pulling the global gradient of the rth iteration from the server module. Assuming that the worker module has pushed the local gradient of the fifth iteration to the server module and the server module has calculated a global gradient of the fifth iteration, but the worker module has not performed pulling from the server module, the worker module may pull the global gradient of the fifth iteration from the server module. In other words, in this embodiment of this application, the worker module may perform in parallel the following step: pulling the global gradient of the rth iteration from the server module, and the global gradient of the rth iteration has been calculated by the server module.


Solution a2: In processes of updating the model parameter of the ninth iteration and calculating the local gradient of the ninth iteration, the worker module performs in parallel the following steps: pulling the global gradient of the rth iteration from the server module and pushing the local gradient of the fth iteration to the server module; or pushing the local gradient of the fth iteration to the server module. There are a plurality of cases for pushing the local gradient of the fth iteration to the server module, including a solution b1, a solution b2, a solution b3, a solution b4, and the like as follows:


Solution b 1l: The worker module determines one local gradient in local gradients that have not been pushed to the server module, and pushes the determined local gradient to the server module. For example, the worker module selects any one of the local gradient of the second iteration, the local gradient of the fifth iteration, the local gradient of the seventh iteration, and the local gradient of the eighth iteration, and pushes the selected local gradient to the server module.


Solution b2: A local gradient of an (i−1)th iteration is pushed to the server module. The worker module selects a local gradient with the second largest iteration batch number that has not been pushed to the server module, and pushes the selected local gradient to the server module. For example, the worker module selects the local gradient of the seventh iteration from the local gradient of the second iteration, the local gradient of the fifth iteration, the local gradient of the seventh iteration, and the local gradient of the eighth iteration, and pushes the selected local gradient to the server module.


Solution b3: The local gradient of the ith iteration is pushed to the server module. The worker module selects a local gradient with the largest iteration batch number that has not been pushed to the server module, and pushes the selected local gradient to the server module. For example, the worker module selects the local gradient of the eighth iteration from the local gradient of the second iteration, the local gradient of the fifth iteration, the local gradient of the seventh iteration, and the local gradient of the eighth iteration, and pushes the selected local gradient to the server module.


Solution b4: The worker module may keep waiting, and push the local gradient of the (i+1)th iteration to the server module. To be specific, the worker module waits until the local gradient of the ninth iteration is determined, and then pushes the local gradient of the ninth iteration to the server module.


It can be learned from the foregoing solution that, in this embodiment of this application, during the (i+1)th iteration, the local gradient of the fth iteration that has been calculated may be selected and pushed to the server module, or the global gradient of the rth iteration that has been calculated by the server module may be selected and pulled from the server module, without a need to report a local gradient in each iteration that is calculated by the worker module and pull a global gradient in each iteration from the server module, thereby reducing an amount of communication between the worker module and the server module.


Optionally, the global gradient of the jth iteration is determined based on the following content: one or more local gradients of the jth iteration that are reported by M of the N worker modules, where M is an integer greater than or equal to 1 and less than or equal to N. In this way, the worker module and the server module can work more flexibly, and the amount of communication between the worker module and the server module is further reduced. For example, there are 50 worker modules in total, N is 50, and M is 20. The worker module may calculate the global gradient of the jth iteration based on local gradients of the jth iteration that are reported by 20 worker modules. Optionally, the global gradient of the jth iteration may be calculated based on local gradients of the jth iteration that are reported by all of the N worker modules.


Optionally, in the foregoing solution, the server module may calculate the global gradient of the jth iteration based on all local gradients of the jth iteration that are reported by a plurality of worker modules. There are various specific algorithms for calculating a global gradient based on a local gradient, such as averaging, weighting calculation, and averaging for several local gradients with large weights. A schematic description is provided by using several examples. For example, the server module averages all the local gradients of the jth iteration that are reported by the plurality of worker modules, to obtain the global gradient of the jth iteration. For another example, the server module multiplies all the local gradients of the jth iteration that are reported by the plurality of worker modules by corresponding weights, and then calculates an average value of the local gradients that have been multiplied by the weights, to obtain the global gradient of the jth iteration.


Optionally, if i is K, the method further includes: pushing, by the worker module, a model parameter of a (K+1)th iteration to the server module after the worker module calculates a local gradient of a Kth iteration and calculates the model parameter of the (K+1)th iteration based on the local gradient of the Kth iteration and a model parameter of the Kth iteration. The model parameter of the (K+1)th iteration is used to enable the server module to determine a model parameter of a first iteration within a next training period based on the iteration quantity K and the model parameter of the (K+1)th iteration that is pushed by each of the N worker modules to the server module. In this way, accuracy of a model parameter of a training period is improved. For example, the model parameters of the (K+1)th iteration that are pushed by all of the N worker modules to the server module are averaged, or a solution of dividing a sum of the model parameters of the (K+1)th iteration that are pushed by all of the N worker modules to the server module by the iteration quantity K is used, to obtain the model parameter trained in the training period. Optionally, another training period may be started to train the model parameter. In this case, the model parameter obtained through training in this training period is determined as a model parameter of a first iteration within a next training period. Alternatively, no training period may be started any longer, and the model parameter obtained through training in this training period is determined as a trained model parameter.


To further describe the solution provided in this embodiment of this application, the method includes:


A distributed computing platform is started, and an application is deployed. The server module performs initialization, to obtain an initialized model parameter ω1_0. The model parameter ω1_0 is pulled from the server module to each worker module.


The worker module performs a first iteration.


GPUs of the worker modules separately read sample data of the first iteration, calculate local gradients based on the global model parameter ω1_0, and preprocess sample data of a second iteration at the same time. In this way, a time of a training period can be further reduced. Subsequently, a model parameter of the second iteration is calculated.


For example, in the N worker modules, a worker module 1 obtains a local gradient Δω1-1 through calculation, the worker module 2 obtains a local gradient Δω2-1 through calculation, . . . , the worker module n obtains a local gradient Δωn-1 through calculation, . . . , and the worker module N obtains a local gradient ΔωN-1 through calculation.


The worker module performs the second iteration.


Optionally, the worker module performs in parallel the following steps: calculating the model parameter of the second iteration, calculating a local gradient of the second iteration, and pushing a local gradient of the first iteration to the server module. Optionally, after the server module calculates a global gradient of the first iteration, the worker module may pull the global gradient of the first iteration from the server module.


Because the global gradient has not been pulled from the server module in this case, the model parameter of the second iteration is determined based on a model parameter of the first iteration and the local gradient of the first iteration. Specifically, there are various determining solutions. For example, the model parameter of the second iteration is made more approximate to a final value through error calculation. Optionally, a formula (1) for a worker module n to calculate the model parameter of the (i+1)th iteration is provided:






w
n_i
=w
n_i-1
+η·Δw
n_i  formula (1)


In the formula (1):


wn_i is the model parameter of the (i+1)th iteration of the worker module n;


i is the iteration quantity, a value range of i is [1, K], and a value range of n is [1, N];


wn_i-1 is the model parameter of the ith iteration;


Δwn_i is the local gradient obtained through calculation by the worker module n in i iterations; and


η is a learning rate control factor. η may be determined based on a specific applicable scenario.


In this example, the model parameter of the second iteration is calculated by using the foregoing formula (1).


The GPUs of the worker modules separately read the preprocessed sample data of the second iteration, and then perform in parallel the following content: calculating the local gradient based on the model parameter of the second iteration, and preprocessing sample data of a third iteration.


The worker module pushes the local gradient of the first iteration to the server module. For example, the server module may receive N local gradients Δω1-2, Δω2-2, . . . , Δωn-2, . . . , and ΔωN-2 of the first iteration that are respectively reported by the N worker modules, and optionally, calculate an average value of the N local gradients of the first iteration, to obtain the global gradient Δω1 of the first iteration. In this way, the local gradient of the first iteration is pushed to the server module while the local gradient of the second iteration is calculated, so that time windows of a calculation process and a communication process overlap, thereby reducing a time of a training period. Optionally, an average value of local gradients of the first iteration may be calculated based on M local gradients of the first iteration that are reported by M of the N worker modules, to obtain the global gradient of the first iteration.


The worker module performs the third iteration.


Optionally, if the worker module has not pulled the global gradient of the first iteration from the server module, the worker module performs in parallel the following steps: calculating a model parameter of the third iteration, calculating a local gradient of the third iteration, and pulling the global gradient Δω1 of the first iteration from the server module. In this way, the global gradient of the first iteration is pulled from the server module while the model parameter of the third iteration is calculated and the local gradient of the third iteration is calculated, so that time windows of a calculation process and a communication process overlap, thereby reducing a time of a training period.


Because the global gradient has not been pulled from the server module in this case, in other words, there is no global gradient of the jth iteration that meets the first condition, the model parameter of the third iteration is determined based on the model parameter of the second iteration and the local gradient of the second iteration. Optionally, the model parameter of the third iteration is determined by using the foregoing formula (1).


The GPUs of the worker modules separately read the preprocessed sample data of the third iteration, and then perform in parallel the following content: calculating the local gradient based on the model parameter of the third iteration, and preprocessing sample data of a fourth iteration.


The worker module performs the fourth iteration.


Optionally, the worker module performs in parallel the following steps: calculating a model parameter of the fourth iteration, calculating a local gradient of the fourth iteration, and pushing the local gradient of the third iteration to the server module. Alternatively, the worker module does not push the local gradient to the server module and does not pull the global gradient from the server module while calculating a model parameter of the fourth iteration and calculating a local gradient of the fourth iteration. In this way, an amount of communication between the worker module and the server module is reduced. In this embodiment of this application, a description is provided by using an example in which the local gradient is not pushed to the server module and the global gradient is not pulled from the server module.


Because the global gradient of the first iteration has been pulled from the server module and the global gradient of the first iteration has not been used for updating the model parameter in this case, the model parameter of the fourth iteration is determined based on the model parameter of the third iteration, the local gradient of the third iteration, and the global gradient of the first iteration that is pulled from the server module. Specifically, there are various determining solutions. For example, the model parameter of the fourth iteration is made more approximate to a final value through error calculation. Optionally, a formula (2) for the worker module n to calculate the model parameter of the fourth iteration is provided:






w
n_i
=w
n_i-1
+λ·Δw
n_i
+χ·Δw
j  formula (2)


In the formula (2):


wn_i is the model parameter of the (i+1)th iteration of the worker module n;


a value range of n is [1, N], i is the iteration quantity, and a value range of i is [1, K];


wn_i-1 is the model parameter of the ith iteration of the worker module n;


Δwn_i is the local gradient obtained through calculation by the worker module n in i iterations;


Δwj is the global gradient of the jth iteration; and j is a positive integer less than or equal to i; and


λ and χ each are a learning rate control factor. λ and χ may be separately determined based on a specific applicable scenario.


The GPUs of the worker modules separately read the preprocessed sample data of the fourth iteration, and then perform in parallel the following content: calculating the local gradient based on the model parameter of the fourth iteration, and preprocessing sample data of a fifth iteration. In this way, the local gradients are used for calculation in the first three iterations, and the global gradient is used for calculation in the fourth iteration, thereby ensuring that the model parameter more quickly and accurately approximates to a correct value.


The worker module performs the fifth iteration.


Optionally, the worker module performs in parallel the following steps: calculating a model parameter of the fifth iteration, calculating a local gradient of the fifth iteration, and pushing the local gradient of the fourth iteration to the server module. Alternatively, the worker module performs in parallel the following steps: calculating a model parameter of the fifth iteration, calculating a local gradient of the fifth iteration, and pushing the local gradient of the third iteration to the server module. In this embodiment of this application, the following content is described by using an example in which the local gradient of the fourth iteration is pushed to the server module.


Because only the global gradient of the first iteration is pulled from the server module in this case, but the global gradient of the first iteration has been used for calculating the model parameter of the fourth iteration, the model parameter of the fifth iteration is determined based on the model parameter of the fourth iteration and the local gradient of the fourth iteration, as shown in the formula (1).


The GPUs of the worker modules separately read the preprocessed sample data of the fifth iteration, and then perform in parallel the following content: calculating the local gradient based on the model parameter of the fifth iteration, and preprocessing sample data of a sixth iteration. In this way, the server module may receive n local gradients Δω1-4, Δω2-4, . . . , Δωn-4, . . . , and ΔωN-4 of the first iteration that are respectively reported by the n worker modules, and optionally, calculate an average value of the N local gradients of the fourth iteration, to obtain a global gradient Δω4 of the fourth iteration.


The worker module performs the sixth iteration.


Optionally, the worker module performs in parallel the following steps: calculating a model parameter of the sixth iteration, calculating a local gradient of the sixth iteration, and pulling the global gradient of the fourth iteration from the server module. In this way, the global gradient of the fourth iteration is pulled from the server module while the model parameter of the sixth iteration is calculated and the local gradient of the sixth iteration is calculated, so that time windows of a calculation process and a communication process overlap, thereby reducing a time of a training period.


Optionally, because the worker module has not successfully pulled the global gradient of the fourth iteration from the server module when calculating the model parameter of the sixth iteration, the model parameter of the sixth iteration may be determined by using the foregoing formula (1).


The GPUs of the worker modules separately read the preprocessed sample data of the sixth iteration, and then perform in parallel the following content: calculating the local gradient based on the model parameter of the sixth iteration, and preprocessing sample data of a seventh iteration. In this way, the server module may receive the N local gradients Δω1-4, Δω2-4, . . . , Δωn-4, . . . , and ΔωN-4 of the first iteration that are respectively reported by the N worker modules, and optionally, calculate the average value of the N local gradients of the fourth iteration, to obtain the global gradient Δω4 of the fourth iteration.


The worker module performs the seventh iteration.


Optionally, the worker module performs in parallel the following steps: calculating a model parameter of the seventh iteration, calculating a local gradient of the seventh iteration, and pushing the local gradient of the sixth iteration to the server module.


Because the global gradient of the fourth iteration has been pulled from the server module and the global gradient of the fourth iteration has not been used for updating the model parameter in this case, the model parameter of the seventh iteration is determined based on the model parameter of the sixth iteration, the local gradient of the sixth iteration, and the global gradient of the fourth iteration that is pulled from the server module by using the foregoing formula (2).


The GPUs of the worker modules separately read the preprocessed sample data of the seventh iteration, and then perform in parallel the following content: calculating the local gradient based on the model parameter of the seventh iteration, and preprocessing sample data of an eighth iteration. In this way, the local gradients are used for calculation in the fifth iteration and the sixth iteration, and the global gradient is used for calculation in the seventh iteration, thereby ensuring that the model parameter more quickly and accurately approximates to a correct value.


After iterations are repeated, convergence or the iteration quantity meets a requirement. In a last iteration within a current training period (which may be referred to as an epoch in English), that is, the Kth iteration, after calculating the local gradient of the Kth iteration, the worker module calculates the model parameter of the (K+1)th iteration based on the foregoing formula (1). After receiving local model parameters respectively reported by the N worker modules, the server module calculates a global model parameter of the current training period. There are various specific methods, such as calculating an average value. This embodiment of this application provides a formula (3) for a server to calculate a global model parameter:





ω2_0=(w1_K+w2_K. . . +wn_K. . . +wN_K)/K  formula (3)


In the formula (3):


w2_0 is the global model parameter, or w2_0 may also be referred to as a model parameter of a first iteration within a next training period;


wm_K is a local model parameter of the worker module n; and


a value range of n is [1, N]; and K is a total iteration quantity within the training period.


In the foregoing example, a source of sample data may be a local disk (which may be referred to as a disk in English) corresponding to the worker module, or a corresponding distributed storage node, such as a Hadoop distributed file system (Hadoop Distributed File system, HDFS for short), an S3, or a distributed file system (Google File System, GFS for short).



FIG. 5 is an example of a schematic flowchart of a training method for a neural network model. As shown in FIG. 5, the method includes one server module and two worker modules: a worker module 1 and a worker module 2. One training period includes K iterations. In a process of a second iteration, each worker module pushes a local gradient of a first iteration to the server module. In a process of a third iteration, each worker module pulls a global gradient of the first iteration from the server module. In a process of a fifth iteration, each worker module pushes a local gradient of a fourth iteration to the server module. In a process of a sixth iteration, each worker module pulls a global gradient of the fourth iteration from the server module. It can be learned that, in this embodiment of this application, on one hand, the time windows of the calculation process and the communication process overlap, thereby reducing the time of the training period and improving model parameter training efficiency; on the other hand, local gradients and global gradients in only some iterations are respectively pushed to and pulled from the server module, so that the local gradients and the global gradients in all the iterations are prevented from being respectively pushed to and pulled from the server module, thereby reducing the amount of communication between the worker module and the server module.


To further describe the solutions provided in the embodiments of this application, this embodiment of this application provides a specific example below for detailed description. An application scenario of this example is: classifying an image data set by using a deep neural network. The data set in this example is an image recognition database (for example, ImageNet), including 1000 types of 1.28 million images in total. In this example, a neural network is GoogleNet and belongs to one of large-scale neural network models. In this example, a distributed system includes four nodes (which may be referred to as a node each in English). Each node includes one server module and one worker module. The server modules and the worker modules are separately: a server module 1, a server module 2, a server module 3, a server module 4, a worker module 1, a worker module 2, a worker module 3, and a worker module 4. Each worker module corresponds to one K80 GPU card (12 G video RAM), and each server module corresponds to one Intel Xeon E5-2620 CPU. Optionally, each worker module further corresponds to a part of the CPU, for preprocessing sample data. GoogleNet is currently a relatively common image classification network with high classification accuracy. A description is provided by using a first iteration as an example.


The first iteration starts.


The server module 1 initializes a global model parameter, to obtain a model parameter of the first iteration. The model parameter of the first iteration complies with W˜N(0, 0.01) The model parameter of the first iteration is pulled from the server module to the worker modules of the four nodes.


A volume of data processed by all the worker modules in each iteration process is set to 256. The four worker modules calculate gradients based on W˜(0, 0.01), and obtained accumulated gradients are Δw1_1 to Δw4_1. (A CPU corresponding to a worker module preprocesses a next image, that is, preprocesses sample data of a second iteration, while a GPU of a server module calculates a gradient. This example provides an optional calculation formula (4) for each worker module to calculate a local gradient of the first iteration:





Δw1_1=(Δw1_11+Δw1_12+ . . . +Δw1_164)/64





Δw2_1=(Δw2_11+Δw2_12+ . . . +Δw2_164)/64





Δw3_1=(Δw3_11+Δw3_12+ . . . +Δw3_164)/64





Δw4_1=(Δw4_11+Δw4_12+ . . . +Δw4_164)/64  formula (4)


In the formula (4), Δw1_1 is a local gradient of the first iteration of the worker module 1; w2_1 is a local gradient of the first iteration of the worker module 2; Δw3_1 is a local gradient of the first iteration of the worker module 3; and Δw4_1 is a local gradient of the first iteration of the worker module 4.


The second iteration is performed.


Optionally, the worker module performs in parallel the following steps: calculating a model parameter of the second iteration, calculating a local gradient of the second iteration, and pushing the local gradient of the first iteration to the server module. Optionally, after the server module calculates a global gradient of the first iteration, the worker module may pull the global gradient of the first iteration from the server module.


A model parameter of each worker module in the second iteration is calculated based on the foregoing formula (1), and η in the formula (1) is set to 0.01. A result shown in a formula (5) is obtained:






w
1_1
=w
1_0+0.01Δw1_1






w
2_1
=w
1_0+0.01Δw2_1






w
3_1
=w
1_0+0.01Δw3_1






w
4_1
=w
1_0+0.01Δw4_1  formula (5)


In a process of the second iteration, the worker modules calculate respective local gradients of the second iteration based on the respective model parameters of the second iteration, and simultaneously push the local gradients of the first iteration to the server module, and CPUs corresponding to the worker modules preprocess a next image, that is, preprocess sample data of a third iteration. This example provides an optional calculation formula (6) for each worker module to calculate the local gradient of the second iteration:





Δw1_2=(Δw1_21+Δw1_22+ . . . +Δw1_264)/64





Δw2_2=(Δw2_21+Δw2_22+ . . . +Δw2_264)/64





Δw3_2=(Δw3_21+Δw3_22+ . . . +Δw3_264)/64





Δw4_2=(Δw4_21+Δw4_22+ . . . +Δw4_264)/64  formula (6)


In the formula (6):


Δw1_2 is a local gradient of the second iteration of the worker module 1;


Δw2_2 is a local gradient of the second iteration of the worker module 2;


Δw3_2 is a local gradient of the second iteration of the worker module 3; and


Δw4_2 is a local gradient of the second iteration of the worker module 4.


The third iteration is performed.


Optionally, if the worker module has not pulled the global gradient of the first iteration from the server module, the worker module performs in parallel the following steps: calculating a model parameter of the third iteration, calculating a local gradient of the third iteration, and pulling the global gradient Δω1 of the first iteration from the server module. If the worker module has not pulled the global gradient of the first iteration from the server module, the worker module calculates a model parameter of each worker module in the third iteration based on the foregoing formula (1), and η in the formula (1) is set to 0.01. A result shown in a formula (7) is obtained:






w
1_2
=w
1_1+0.01Δw1_2






w
2_2
=w
2_1+0.01Δw2_2






w
3_2
=w
3_1+0.01Δw3_2






w
4_2
=w
4_1+0.01Δw4_2  formula (7)


In the formula (7):


w1_2 is a model parameter of the third iteration of the worker module 1; w1_1 is a model parameter of the second iteration of the worker module 1; and Δw1_2 is the local gradient of the second iteration of the worker module 1;


w2_2 is a model parameter of the third iteration of the worker module 2; w2_1 is a model parameter of the second iteration of the worker module 2; and Δw2_2 is the local gradient of the second iteration of the worker module 2;


w3_2 is a model parameter of the third iteration of the worker module 3; w3_1 is a model parameter of the second iteration of the worker module 3; and Δw3_2 is the local gradient of the second iteration of the worker module 3; and


w4_2 is a model parameter of the third iteration of the worker module 4; w4_1 is a model parameter of the second iteration of the worker module 3; and Δw4_2 is the local gradient of the second iteration of the worker module 4.


Optionally, if the worker module has pulled the global gradient of the first iteration from the server module, the worker module calculates a model parameter of each worker module in the third iteration based on the foregoing formula (2). λ in the formula (2) is set to 0.01, and χ is set to 0.4. A result shown in a formula (8) is obtained:






w
1_2
=w
1_1+0.01·Δw1_2+0.4·Δw1






w
2_2
=w
2_1+0.01·Δw2_2+0.4·Δw1






w
3_2
=w
3_1+0.01·Δw3_2+0.4·Δw1






w
4_2
=w
4_1+0.01·Δw4_2+0.4·Δw1  formula ( )


In the formula (8):


w1_2 is a model parameter of the third iteration of the worker module 1; w1_1 is a model parameter of the second iteration of the worker module 1; and Δw1_2 is the local gradient of the second iteration of the worker module 1;


w2_2 is a model parameter of the third iteration of the worker module 2; w2_1 is a model parameter of the second iteration of the worker module 2; and Δw2_2 is the local gradient of the second iteration of the worker module 2;


w3_2 is a model parameter of the third iteration of the worker module 3; w3_1 is a model parameter of the second iteration of the worker module 3; and Δw3_2 is the local gradient of the second iteration of the worker module 3;


w4_2 is a model parameter of the third iteration of the worker module 4; w4_1 is a model parameter of the second iteration of the worker module 4; and Δw4_2 is the local gradient of the second iteration of the worker module 4; and


Δw1 is the global gradient of the first iteration.


In a process of the third iteration, the worker modules calculate respective local gradients of the third iteration based on the respective model parameters of the third iteration, and simultaneously pull the global gradient of the first iteration from the server module, and the CPUs corresponding to the worker modules preprocess a next image, that is, preprocess sample data of a fourth iteration. This example provides an optional calculation formula (9) for each worker module to calculate the local gradient of the third iteration:





Δw1_3=(w1_31+Δw1_32+ . . . +Δw1_364)/64





Δw2_3=(w2_31+Δw2_32+ . . . +Δw2_364)/64





Δw3_3=(w3_31+Δw3_32+ . . . +Δw3_364)/64





Δw4_3=(w4_31+Δw4_32+ . . . +Δw4_364)/64  formula (9)


In the formula (9):


Δw1_3 is a local gradient of the third iteration of the worker module 1;


Δw2_3 is a local gradient of the third iteration of the worker module 2;


Δw3_3 is a local gradient of the third iteration of the worker module 3; and


Δw4_3 is a local gradient of the third iteration of the worker module 4.


The process of the third iteration ends. A process of the fourth iteration starts.


Optionally, if the worker module has not pulled the global gradient of the first iteration from the server module, the worker module performs in parallel the following steps: calculating a model parameter of the fourth iteration, calculating a local gradient of the fourth iteration, and pulling the global gradient Δω1 of the first iteration from the server module.


If the worker module has not pulled the global gradient of the first iteration from the server module, the worker module calculates a model parameter of each worker module in the fourth iteration based on the foregoing formula (1).


Optionally, if the worker module has pulled the global gradient of the first iteration from the server module, the worker module calculates a model parameter of each worker module in the fourth iteration based on the foregoing formula (2). The model parameter of each worker module in the fourth iteration is calculated based on the foregoing formula (2), λ in the formula (2) is set to 0.01, and χ is set to 0.4. A result shown in a formula (10) is obtained:






w
1_3
=w
1_2+0.01Δw1_3+0.4Δw1






w
2_3
=w
2_2+0.01Δw2_3+0.4Δw1






w
3_3
=w
3_2+0.01Δw3_3+0.4Δw1






w
4_3
=w
4_2+0.01Δw4_3+0.4Δw1  formula (10)


In the formula (10):


w1_3 is a model parameter of the fourth iteration of the worker module 1; w1_2 is the model parameter of the third iteration of the worker module 1; and Δw1_3 is the local gradient of the third iteration of the worker module 1;


w2_3 is a model parameter of the fourth iteration of the worker module 2; w2_2 is the model parameter of the third iteration of the worker module 2; and Δ2_3 is the local gradient of the third iteration of the worker module 2;


w3_3 is a model parameter of the fourth iteration of the worker module 3; w3_2 is the model parameter of the third iteration of the worker module 3; and w3_3 is the local gradient of the third iteration of the worker module 3;


w4_3 is a model parameter of the fourth iteration of the worker module 4; w4_2 is the model parameter of the third iteration of the worker module 4; and Δw4_3 is the local gradient of the third iteration of the worker module 4; and


Δw1 is the global gradient of the first iteration.


Then the local gradient of the fourth iteration is calculated based on the model parameter of the fourth iteration. A process of a remaining iteration is similar to the foregoing content and is not further described herein.


Optionally, the worker module pushes the local gradients to the server module, and the server module calculates the global gradient based on the local gradient, and optionally, may calculate an average value of the local gradients, as the global gradient. This embodiment of this application provides a formula (11) for calculating the global gradient:





Δw1=(w1_1+w2_1+ . . . wn_1. . . +wN_1)/N  formula (11)


In the formula (11):


Δw1 is the global gradient of the first iteration;


w1_1 is a local gradient of the first iteration of the worker module 1;


w2_1 is a local gradient of the first iteration of the worker module 2;


wn_1 is a local gradient of the first iteration of the worker module n, where a value range of n is [1, N]; and


wN_1 is a local gradient of the first iteration of the worker module N, where N is a total quantity of worker modules.


It can be learned from the foregoing content that, in this embodiment of this application, information about the global gradient is used to adjust model update of each worker module without adding additional communication time overheads, thereby resolving a problem of consistent model convergence caused by relatively weak synchronization in a conventional communication mode. This application effectively resolves a problem of a communication bottleneck caused by a large model while ensuring stable convergence of a large-scale distributed neural network model (including a deep learning model). This is also the first time for the industry to propose a solution of completely overlapping communication time overheads and calculation time overheads of large-scale distributed machine learning. In this way, the communication bottleneck is avoided, and near-linear acceleration can be achieved in an optimal case.



FIG. 6 is an example of a schematic structural diagram of a training apparatus for a neural network model according to an embodiment of this application.


Based on a same concept, this embodiment of this application provides the training apparatus for a neural network model. As shown in FIG. 6, the training apparatus includes N worker modules, and the training apparatus is applicable to a training system that includes a server module and the N worker modules. The server module and the N worker modules are configured to train a model parameter within at least one training period, and each of the at least one training period includes K iterations. A worker module is one of the N worker modules, and the worker module includes a communications module and a calculation module. For an ith iteration of one of the N worker modules within each training period, where N and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K: Each of the N worker modules includes a communications module 603 and a calculation module 602, and optionally, may further include a storage module 601. Optionally, the storage module is further configured to store information such as a pulled global gradient.


The communications module 603 and the calculation module 602 of each worker module run in parallel.


The calculation module 602 is configured to calculate a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculate a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration.


The communications module 603 is configured to: pull a global gradient of an rth iteration from the server module and/or push a local gradient of an fth iteration to the server module, where r and f each are a positive integer less than or equal to i.


In this embodiment of this application, the communications module and the calculation module run in parallel in each iteration process, the communications module executes a first process, and the calculation module executes a second process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


Optionally, the calculation module 602 is configured to: calculate, if it is determined that a global gradient of a jth iteration that meets a first condition has been pulled from the server module, the model parameter of the (i+1)th iteration based on the global gradient of the jth iteration, the local gradient of the ith iteration, and the model parameter of the ith iteration, where j is a positive integer less than or equal to i, and the first condition includes: the global gradient of the jth iteration has not been used to calculate a model parameter in any iteration between a first iteration and the ith iteration. In this way, there is no need to wait for the communication process, thereby further reducing the iteration duration and improving the model parameter training efficiency.


Optionally, the calculation module 602 is configured to: calculate, if it is determined that a global gradient of a jth iteration that meets a first condition has not been pulled from the server module, the model parameter of the (i+1)th iteration based on the local gradient of the ith iteration and the model parameter of the ith iteration. In this way, a model parameter can be updated based on a global gradient in an iteration nearest to a current iteration process, thereby accelerating model parameter convergence.


Optionally, the first condition further includes: the global gradient of the jth iteration is a global gradient in an iteration with a largest iteration batch number in all global gradients that have been pulled from the server module.


Optionally, the global gradient of the jth iteration is determined based on the following content: one or more local gradients of the jth iteration that are reported by M of the N worker modules, where M is an integer greater than or equal to 1 and less than or equal to N. In this way, the model parameter of the (i+1)th iteration can be calculated based on the global gradient of the jth iteration that meets the first condition and that has been pulled from the server module, thereby improving accuracy of calculating the model parameter of the (i+1)th iteration. On the other hand, the global gradient of the jth iteration that meets the first condition is selected from global gradients that have been pulled from the server module, and there is no need to wait for the communication process, thereby further reducing iteration duration and improving the model parameter training efficiency.


Optionally, the communications module 603 is configured to: pull the global gradient of the rth iteration from the server module; or pull the global gradient of the rth iteration from the server module, and push a local gradient of an (i−1)th iteration to the server module; or pull the global gradient of the rth iteration from the server module, and push the local gradient of the ith iteration to the server module; or push a local gradient of an (i−1)th iteration to the server module; or push the local gradient of the ith iteration to the server module. In this way, flexibility of the worker module can be improved, and on the other hand, a local gradient in an iteration nearest to a current iteration process can be pushed to the server module as much as possible, thereby accelerating model parameter convergence.


Optionally, if i is K, the communications module 603 is further configured to: push a model parameter of a (K+1)th iteration to the server module after the calculation module is used to calculate a local gradient of a Kth iteration and calculate the model parameter of the (K+1)th iteration based on the local gradient of the Kth iteration and a model parameter of the Kth iteration, where the model parameter of the (K+1)th iteration is used to enable the server module to determine a model parameter of a first iteration within a next training period based on the iteration quantity K and the model parameter of the (K+1)th iteration that is pushed by each of the N worker modules to the server module. In this way, accuracy of a model parameter of a training period is improved.


It can be learned from the foregoing content that: in this embodiment of this application, the first process and the second process are executed in parallel in each iteration process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


It should be noted that unit division in this embodiment of this application is an example and is merely logical function division. During actual implementation, there may be another division manner. Functional units in the embodiments of this application may be integrated into one processing unit, or each of the units may exist alone physically, or two or more units are integrated into one unit. The integrated unit may be implemented in a form of hardware, or may be implemented in a form of a software functional unit.



FIG. 7 is an example of a schematic structural diagram of a training apparatus for a neural network model according to an embodiment of this application.


Based on a same concept, this embodiment of this application provides the training apparatus for a neural network model, for performing the foregoing method procedure. As shown in FIG. 7, the training apparatus includes a transceiver 701 and a processor 702. The processor 702 includes N processor cores. Optionally, a memory 704 and a communications interface 703 may further be included. Optionally, a bus 705 may further be included.


The processor, the memory, and the transceiver are connected to one another by using the bus. The bus may be a peripheral component interconnect (PCI) bus, an extended industry standard architecture (EISA) bus, or the like. The bus may be classified into an address bus, a data bus, a control bus, and the like. For ease of representation, only one thick line is used to represent the bus in FIG. 7, but this does not mean that there is only one bus or only one type of bus.


The memory 704 may include a volatile memory, for example, a random-access memory (RAM). The memory may alternatively include a non-volatile memory, for example, a flash memory, a hard disk drive (HDD), or a solid-state drive (SSD). The memory 704 may alternatively include a combination of the foregoing types of memories.


The N processor cores included in the processor 702 may include GPUs, or may include a GPU and a CPU. The processor core may further include a hardware chip. The hardware chip may be an application-specific integrated circuit (ASIC), a programmable logic device (PLD), or a combination thereof. The foregoing PLD may be a complex programmable logic device (CPLD), a field-programmable logic gate array (FPGA), a generic array logic (GAL), or any combination thereof.


The transceiver is configured to implement data transmission between each worker module and a server module.


The memory is configured to store an instruction. Optionally, the memory is further configured to store information such as a pulled global gradient.


The processor includes N processor cores. The training apparatus is applicable to a training system that includes a server module and N processor cores. The server module and the N processor cores are configured to train a model parameter within at least one training period. Each of the at least one training period includes K iterations. For an ith iteration of one of the N worker modules within each training period, where N and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K, the transceiver 701 and the processor 702 operate in parallel for each worker module.


The processor 702 is configured to calculate a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculate a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration.


The transceiver 701 is configured to: pull a global gradient of an rth iteration from the server module and/or push a local gradient of an fth iteration to the server module, where r and f each are a positive integer less than or equal to i.


The memory is configured to store the global gradient pulled from the server module and the calculated local gradient.


In this embodiment of this application, the transceiver and the processor run in parallel in each iteration process, the processor executes a first process, and the transceiver executes a second process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


Optionally, the processor 702 is configured to: calculate, if it is determined that a global gradient of a jth iteration that meets a first condition has been pulled from the server module, the model parameter of the (i+1)th iteration based on the global gradient of the jth iteration, the local gradient of the ith iteration, and the model parameter of the ith iteration, where j is a positive integer less than or equal to i, and the first condition includes: the global gradient of the jth iteration has not been used to calculate a model parameter in any iteration between a first iteration and the ith iteration. In this way, there is no need to wait for the communication process, thereby further reducing the iteration duration and improving the model parameter training efficiency.


Optionally, the processor 702 is configured to: calculate, if it is determined that a global gradient of a jth iteration that meets a first condition has not been pulled from the server module, the model parameter of the (i+1)th iteration based on the local gradient of the ith iteration and the model parameter of the ith iteration. In this way, a model parameter can be updated based on a global gradient in an iteration nearest to a current iteration process, thereby accelerating model parameter convergence.


Optionally, the first condition further includes: the global gradient of the jth iteration is a global gradient in an iteration with a largest iteration batch number in all global gradients that have been pulled from the server module. In this way, the model parameter of the (i+1)th iteration can be calculated based on the global gradient of the jth iteration that meets the first condition and that has been pulled from the server module, thereby improving accuracy of calculating the model parameter of the (i+1)th iteration. On the other hand, the global gradient of the jth iteration that meets the first condition is selected from global gradients that have been pulled from the server module, and there is no need to wait for the communication process, thereby further reducing iteration duration and improving the model parameter training efficiency.


Optionally, the global gradient of the jth iteration is determined based on the following content: one or more local gradients of the jth iteration that are reported by M of the N worker modules, where M is an integer greater than or equal to 1 and less than or equal to N. In this way, the worker module and the server module can work more flexibly, and an amount of communication between the worker module and the server module is further reduced.


Optionally, the transceiver 701 is configured to: pull the global gradient of the rth iteration from the server module; or pull the global gradient of the rth iteration from the server module, and push a local gradient of an (i−1)th iteration to the server module; or pull the global gradient of the rth iteration from the server module, and push the local gradient of the ith iteration to the server module; or push a local gradient of an (i−1)th iteration to the server module; or push the local gradient of the ith iteration to the server module. In this way, flexibility of the worker module can be improved, and on the other hand, a local gradient in an iteration nearest to a current iteration process can be pushed to the server module as much as possible, thereby accelerating model parameter convergence.


Optionally, if i is K, the transceiver 701 is further configured to: push a model parameter of a (K+1)th iteration to the server module after the processor is used to calculate a local gradient of a Kth iteration and calculate the model parameter of the (K+1)th iteration based on the local gradient of the Kth iteration and a model parameter of the Kth iteration, where the model parameter of the (K+1)th iteration is used to enable the server module to determine a model parameter of a first iteration within a next training period based on the iteration quantity K and the model parameter of the (K+1)th iteration that is pushed by each of the N worker modules to the server module. In this way, accuracy of a model parameter of a training period is improved.


It can be learned from the foregoing content that: in this embodiment of this application, the first process and the second process are executed in parallel in each iteration process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


Based on a same concept, an embodiment of this application provides a training chip for a neural network model. The chip is applicable to a training system that includes N chips and a server. The server module and the N chips are configured to train a model parameter within at least one training period. Each of the at least one training period includes K iterations. Each of the N chips is configured to perform the method performed by the worker module in the foregoing embodiment.



FIG. 8 is an example of a schematic structural diagram of a training system for a neural network model according to an embodiment of this application.


Based on a same concept, this embodiment of this application provides the schematic structural diagram of the training system for a neural network model. As shown in FIG. 8, the system includes a server module 800 and N worker modules: a worker module 801 and a worker module 802 to a worker module 80n. The server module 800 and the N worker modules: the worker module 801 and the worker module 802 to the worker module 80n are configured to train a model parameter within at least one training period. Each of the at least one training period includes K iterations.


For an ith iteration of one of the N worker modules within each training period, each of the N worker modules: the worker module 801 and the worker module 802 to the worker module 80n is configured to perform in parallel the following steps: calculating a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculating a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration; and pulling a global gradient of an rth iteration from the server module and/or pushing a local gradient of an fth iteration to the server module, where r and f each are a positive integer less than or equal to i, where N and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K.


The server module 800 is configured to: calculate the global gradient of the rth iteration based on a received local gradient of the rth iteration that is pushed by the worker module, and pull the global gradient of the rth iteration to the worker module; and receive the local gradient of the fth iteration that is pushed by the worker module, and calculate a global gradient of the fth iteration based on the local gradient of the fth iteration that is pushed by the worker module.


It can be learned from the foregoing content that: in this embodiment of this application, the first process and the second process are executed in parallel in each iteration process. The first process is a calculation process, and specifically includes calculating the model parameter of the (i+1)th iteration and calculating the local gradient of the (i+1)th iteration. The second process is a communication process, and specifically includes pulling the global gradient of the rth iteration from the server module and/or pushing the local gradient of the fth iteration to the server module. In the first process, the model parameter of the (i+1)th iteration is calculated based on the local gradient of the ith iteration and the model parameter of the ith iteration. This avoids a prior-art solution in which a model parameter of an (i+1)th iteration can be calculated only after waiting until a global gradient of an ith iteration is pulled from a server module, thereby reducing duration of an iteration and improving model parameter training efficiency.


All or some of the foregoing embodiments may be implemented by means of software, hardware, firmware, or any combination thereof. When software is used to implement the embodiments, the embodiments may be implemented completely or partially in a form of a computer program product. The computer program product includes one or more computer instructions. When the computer program instructions are loaded and executed on a computer, the procedure or functions according to the embodiments of the present invention are all or partially generated. The computer may be a general-purpose computer, a dedicated computer, a computer network, or other programmable apparatuses. The computer instructions may be stored in a computer-readable storage medium or may be transmitted from a computer-readable storage medium to another computer-readable storage medium. For example, the computer instructions may be transmitted from a website, computer, server, or data center to another website, computer, server, or data center in a wired (for example, a coaxial cable, an optical fiber, or a digital subscriber line (DSL)) or wireless (for example, infrared, radio, and microwave, or the like) manner. The computer storage medium may be any usable medium accessible by a computer, or a data storage device, such as a server or a data center, integrating one or more usable media. The usable medium may be a magnetic medium (for example, a soft disk, a hard disk, or a magnetic tape), an optical medium (for example, a digital versatile disc (DVD)), a semiconductor medium (for example, a solid state disk (SSD)), or the like.


Persons skilled in the art should understand that the embodiments of this application may be provided as a method, or a computer program product. Therefore, this application may use a form of hardware only embodiments, software only embodiments, or embodiments with a combination of software and hardware. Moreover, this application may use a form of a computer program product that is implemented on one or more computer-usable storage media (including but not limited to a magnetic disk memory, a CD-ROM, an optical memory, and the like) that include computer usable program code.


This application is described with reference to the flowcharts and/or block diagrams of the method, the device (system), and the computer program product according to the embodiments of this application. It should be understood that computer program instructions may be used to implement each process and/or each block in the flowcharts and/or the block diagrams and a combination of a process and/or a block in the flowcharts and/or the block diagrams. These computer program instructions may be provided for a general-purpose computer, a dedicated computer, an embedded processor, or a processor of any other programmable data processing device to generate a machine, so that the instructions executed by a computer or a processor of any other programmable data processing device generate an apparatus for implementing a specific function in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.


These computer program instructions may be stored in a computer readable memory that can instruct the computer or any other programmable data processing device to work in a specific manner, so that the instructions stored in the computer readable memory generate an artifact that includes an instruction apparatus. The instruction apparatus implements a specific function in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.


These computer program instructions may be loaded onto a computer or another programmable data processing device, so that a series of operations and steps are performed on the computer or the another programmable device, thereby generating computer-implemented processing. Therefore, the instructions executed on the computer or the another programmable device provide steps for implementing a specific function in one or more processes in the flowcharts and/or in one or more blocks in the block diagrams.


Although some embodiments of this application have been described, persons skilled in the art can make changes and modifications to these embodiments once they learn the basic inventive concept. Therefore, the following claims are intended to be construed as to cover the preferred embodiments and all changes and modifications falling within the scope of this application.


Obviously, persons skilled in the art can make various modifications and variations to this application without departing from the scope of this application. This application is intended to cover these modifications and variations of this application provided that they fall within the scope of protection defined by the following claims and their equivalent technologies.

Claims
  • 1. A method for training a neural network model, wherein the method is applicable to a training system that comprises a server module and N worker modules, the server module and the N worker modules are configured to train a model parameter within at least one training period, each of the at least one training period comprises K iterations, and for an ith iteration of one of the N worker modules within each training period, each worker module performs in parallel the following steps: calculating a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculating a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration; andpulling a global gradient of an rth iteration from the server module and/or pushing a local gradient of an fth iteration to the server module, wherein r and f each are a positive integer less than or equal to i, whereinN and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K.
  • 2. The method according to claim 1, wherein the calculating, by the worker module, a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration comprises: calculating, by the worker module if determining that a global gradient of a jth iteration that meets a first condition has been pulled from the server module, the model parameter of the (i+1)th iteration based on the global gradient of the jth iteration, the local gradient of the ith iteration, and the model parameter of the ith iteration, wherein j is a positive integer less than or equal to i, and the first condition comprises: the global gradient of the jth iteration has not been used to calculate a model parameter in any iteration between a first iteration and the ith iteration; orcalculating, by the worker module if determining that a global gradient of a jth iteration that meets a first condition has not been pulled from the server module, the model parameter of the (i+1)th iteration based on the local gradient of the ith iteration and the model parameter of the ith iteration.
  • 3. The method according to claim 2, wherein the first condition further comprises: the global gradient of the jth iteration is a global gradient in an iteration with a largest iteration batch number in all global gradients that have been pulled from the server module.
  • 4. The method according to claim 2, wherein the global gradient of the jth iteration is determined based on the following step: one or more local gradients of the jth iteration that are reported by M of the N worker modules, wherein M is an integer greater than or equal to 1 and less than or equal to N.
  • 5. The method according to claim 1, wherein the pulling, by the worker module, a global gradient of an rth iteration from the server module and/or pushing, by the worker module, a local gradient of an fth iteration to the server module comprises two or any one of the following step: pulling the global gradient of the rth iteration from the server module; andpushing a local gradient of an (i−1)th iteration to the server module; or pushing the local gradient of the ith iteration to the server module.
  • 6. The method according to claim 1, wherein if i is K, the method further comprises: pushing, by the worker module, a model parameter of a (K+1)th iteration to the server module after the worker module calculates a local gradient of a Kth iteration and calculates the model parameter of the (K+1)th iteration based on the local gradient of the Kth iteration and a model parameter of the Kth iteration, whereinthe model parameter of the (K+1)th iteration is used to enable the server module to determine a model parameter of a first iteration within a next training period based on the iteration quantity K and the model parameter of the (K+1)th iteration that is pushed by each of the N worker modules to the server module.
  • 7. A apparatus for training a neural network model, wherein the training apparatus comprises N worker modules, the apparatus is applicable to a training system that comprises a server module and the apparatus, the server module and the N worker modules are configured to train a model parameter within at least one training period, and each of the at least one training period comprises K iterations; each of the N worker modules comprises a communicator and a calculator; and for an ith iteration of one of the N worker modules within each training period: the communicator and the calculator of each worker module run in parallel, whereinthe calculator is configured to: calculate a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculate a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration; andthe communicator is configured to: pull a global gradient of an rth iteration from the server module and/or push a local gradient of an fth iteration to the server module, wherein r and f each are a positive integer less than or equal to i, whereinN and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K.
  • 8. The apparatus according to claim 7, wherein the calculator is configured to: calculate, if a global gradient of a jth iteration that meets a first condition has been pulled from the server module, the model parameter of the (i+1)th iteration based on the global gradient of the jth iteration, the local gradient of the ith iteration, and the model parameter of the ith iteration, wherein j is a positive integer less than or equal to i, and the first condition comprises: the global gradient of the jth iteration has not been used to calculate a model parameter in any iteration between a first iteration and the ith iteration; orcalculate, if a global gradient of a jth iteration that meets a first condition has not been pulled from the server module, the model parameter of the (i+1)th iteration based on the local gradient of the ith iteration and the model parameter of the ith iteration.
  • 9. The apparatus according to claim 8, wherein the first condition further comprises: the global gradient of the jth iteration is a global gradient in an iteration with a largest iteration batch number in all global gradients that have been pulled from the server module.
  • 10. The apparatus according to claim 8, wherein the global gradient of the jth iteration is determined based on the following step: one or more local gradients of the jth iteration that are reported by M of the N worker modules, wherein M is an integer greater than or equal to 1 and less than or equal to N.
  • 11. The apparatus according to claim 7, wherein the communicator is configured to perform two or any one of the following step: pulling the global gradient of the rth iteration from the server module; andpushing a local gradient of the (i−1)th iteration to the server module; or pushing the local gradient of the ith iteration to the server module.
  • 12. The apparatus according to claim 7, wherein if i is K, the communicator is further configured to: push a model parameter of a (K+1)th iteration to the server module after the calculation module is used to calculate a local gradient of a Kth iteration and calculate the model parameter of the (K+1)th iteration based on the local gradient of the Kth iteration and a model parameter of the Kth iteration, whereinthe model parameter of the (K+1)th iteration is used to enable the server module to determine a model parameter of a first iteration within a next training period based on the iteration quantity K and the model parameter of the (K+1)th iteration that is pushed by each of the N worker modules to the server module.
  • 13. A apparatus for training a neural network model, wherein the training apparatus comprises a processor, a memory, and a transceiver, the processor comprises N processor cores, the training apparatus is applicable to a training system that comprises a server module and the apparatus, the server module and the N processor cores are configured to train a model parameter within at least one training period, and each of the at least one training period comprises K iterations; and the memory is configured to store an instruction;the processor is configured to: execute the instruction stored in the memory, and control the transceiver to transmit data to the server module; and when the processor executes the instruction stored in the memory, each of the N processor cores is configured to perform the method performed by the worker module according to claim 1.
  • 14. A chip for training a neural network model, wherein the chip is applicable to a training system that comprises N chips and a server module, the server module and the N chips are configured to train a model parameter within at least one training period, and each of the at least one training period comprises K iterations; and the chip is configured to perform the method performed by the worker module according to claim 1.
  • 15. A non-transitory computer storage medium, wherein the computer storage medium stores a computer executable instruction, and when being called by a training system comprising a server module and N worker modules, wherein the server module and the N worker modules are configured to train a model parameter within at least one training period, each of the at least one training period comprises K iterations, and for an ith iteration of one of the N worker modules within each training period, the computer executable instruction causes each worker module performs in parallel the following steps: calculating a model parameter of an (i+1)th iteration based on a local gradient of the ith iteration and a model parameter of the ith iteration, and if i is less than K, calculating a local gradient of the (i+1)th iteration based on the model parameter of the (i+1)th iteration and sample data of the (i+1)th iteration; andpulling a global gradient of an rth iteration from the server module and/or pushing a local gradient of an fth iteration to the server module, wherein r and f each are a positive integer less than or equal to i, whereinN and K each are an integer greater than or equal to 1, and i is an integer greater than or equal to 1 and less than or equal to K.
Priority Claims (1)
Number Date Country Kind
201611073994.5 Nov 2016 CN national
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation of International Application No. PCT/CN2017/092091, filed on Jul. 6, 2017, which claims priority to Chinese Patent Application No. 201611073994.5, filed on Nov. 29, 2016. The disclosures of the aforementioned applications are hereby incorporated by reference in their entireties.

Continuations (1)
Number Date Country
Parent PCT/CN2017/092091 Jul 2017 US
Child 16424760 US