The present disclosure relates to the field of computing technologies, and in particular, to a tree topology based computing system and method.
Artificial intelligence (AI) application grows explosively. The AI application is based on a deep neural network. Recently, the deep neural network has been applied to fields such as speech recognition, image recognition, and a complex game in a breakthrough manner, and is deployed in many fields such as face recognition, a safe city, automatic driving, medical image detection, an AI intelligent Go, and a conference recording system. Performance of the deep neural network is good and even better than that of a human. This benefits from that the deep neural network can extract a higher-layer feature from raw data and can effectively learn from massive data.
To further improve performance of the deep neural network, a depth of the network, a quantity of network parameters, calculation algorithm strength, and a quantity of training datasets are all increased. Consequently, computing complexity and a training time are both greatly increased. A typical ResNet-50 network is used as an example. 44 hours are required to complete 90 epochs of training based on an ImageNet training dataset using a high-performance server including eight common K80s. Even if a high-performance server including eight V100s that are quickest currently is used, about eight hours are required to complete the 90 epochs of training. This training time is still very long, and deep neural network model and algorithm research personnel need to wait for a long time to obtain a feedback. This severely affects development efficiency of a model and an algorithm. Especially for a new field, a new model, and a new algorithm, a plurality of groups of hyperparameters usually need to be tried, and adjustment and optimization are repeatedly performed to obtain an ideal result. This process is longer, and has become a key bottleneck in a process of development→verification→deployment.
Therefore, promotion, deployment, and application of the deep neural network in a large-scale manner in many fields impose a higher and faster requirement for training efficiency. Training efficiency of a single server node is far from enough to meet a requirement of a production environment. To resolve this problem, large-scale distributed training is usually used in the other approaches. For this model, a training process is distributed to a plurality of computing nodes for execution, and a final training result is obtained through aggregation, to alleviate computing pressure on the single server node and improve computing efficiency. However, because bandwidth between computing nodes in the large-scale distributed training is limited, when there is a large amount of training data, an aggregation process may be slow, and computing efficiency is low.
Embodiments of the present disclosure provide a tree topology based computing system and method in order to resolve a problem of low computing efficiency of a computing system in large-scale distributed training.
According to a first aspect, an embodiment of the present disclosure provides a tree topology based computing system, where the system may include a plurality of node clusters, where the plurality of node clusters constitute a multi-layer network structure in a tree topology manner, any minimum tree in the network structure includes a second node cluster serving as a parent node and at least one first node cluster serving as a child node, and the second node cluster is connected to the at least one first node cluster through a physical link, where each of the at least one first node cluster is configured to obtain a first computing result based on a first computing input, and send the first computing result to the second node cluster through the physical link, and the second node cluster is configured to receive, through the physical link, at least one first computing result sent by the at least one first node cluster, and aggregate the at least one first computing result and a second computing result to obtain a third computing result, where the second computing result is a result obtained by the second node cluster based on a second computing input.
According to the computing system provided in this embodiment of the present disclosure, each node cluster is responsible for aggregating computing results of the node cluster and is also responsible for aggregating computing results of a lower-layer node cluster connected to the node cluster such that not only transmission of data from a lower layer to an upper layer is completed, but also data aggregation between node clusters is completed layer by layer in a transmission process, thereby reducing an amount of data that is to be aggregated and that is transmitted in bandwidth. In addition, because a tree networking topology is used in this embodiment of the present disclosure, computing and aggregation are performed between different node clusters at a same layer in parallel, thereby further improving computing and aggregation efficiency. In this way, a problem of low computing efficiency in large-scale distributed training is resolved.
In a possible implementation, the second node cluster includes at least one second computing node, and the second computing node is a neural network accelerator (NNA), and the first node cluster includes at least one first computing node, and the first computing node is an NNA. In this embodiment of the present disclosure, one or more NNAs are disposed in a node cluster in order to implement parallel computing in a neural network.
In a possible implementation, the second node cluster is further configured to send the third computing result to a third node cluster for aggregation, where the third node cluster is a parent node of the second node cluster. In this embodiment of the present disclosure, the second node cluster aggregates computing results of the first node cluster at a lower layer, and then sends an aggregated third result to a parent node of the second node cluster serving as a child node in a minimum tree in order to perform upper-layer aggregation.
In a possible implementation, any minimum tree in the network structure includes one second node cluster and k first node clusters, where k is an integer greater than or equal to 1. In this embodiment of the present disclosure, it is set that each minimum tree is converged according to a proportion of k:1, to facilitate management and expansion.
In a possible implementation, the second node cluster includes k second computing nodes, and any one of the k first node clusters includes k first computing nodes, and in any minimum tree in the network structure, the k second computing nodes in the second node cluster one-to-one correspond to the k first node clusters, and any one of the k second computing nodes is connected to the k first computing nodes in the corresponding first node cluster through the physical link. In this embodiment of the present disclosure, each node cluster includes k computing nodes, to facilitate distributed computing and distributed aggregation. In addition, the k second computing nodes in the second node cluster serving as a parent node one-to-one correspond to the k first node clusters, to be specific, one second computing node is responsible for performing upstream aggregation on one first node cluster, to balance an aggregation process. This helps further improve computing efficiency of a computing system.
In a possible implementation, any one of the k first node clusters is configured to distribute the first computing input to the k first computing nodes for distributed computing, to obtain k first distributed computing results, perform distributed aggregation on the k first computing nodes based on the k first distributed computing results respectively, to obtain one slice of the first computing result on each first computing node, and synchronously or asynchronously send, using the k first computing nodes, k slices of the first computing result to a corresponding second computing node for aggregation. In this embodiment of the present disclosure, computing tasks of the first node cluster serving as a child node are distributed to the k first computing nodes for parallel processing, and after a computing result of each first computing node is obtained, parallel aggregation is performed between the k first computing nodes, thereby greatly improving computing and aggregation efficiency.
In a possible implementation, the second node cluster is configured to distribute the second computing input to the k second computing nodes for distributed computing, to obtain k second distributed computing results, where the k second distributed computing results are the second computing result, receive, respectively using the k second computing nodes, the k slices of the first computing result that are sent by the k first computing nodes in the corresponding first node cluster, aggregate, respectively using the k second computing nodes, the second distributed computing result obtained through computation by each second computing node and the k slices of the first computing result of the corresponding first node cluster, and perform distributed aggregation on results obtained through aggregation using all of the k second computing nodes, to obtain one slice of the third computing result on each second computing node. In this embodiment of the present disclosure, computing tasks of the second node cluster serving as a parent node are distributed to the k second computing nodes for parallel processing, and after a computing result of each second computing node is obtained, the second computing node aggregates computing results sent by the corresponding k first node clusters. In addition, the process between the k second computing nodes is a parallel operation. Finally, distributed aggregation between nodes is performed once again between the k second computing nodes, to obtain a final aggregation result of the second node cluster, thereby greatly improving computing and aggregation efficiency.
In a possible implementation, any one of the k first node clusters is configured to distribute the first computing input to the k first computing nodes for distributed computing, to obtain k first distributed computing results, perform aggregation on a specified first computing node in the k first computing nodes based on the k first distributed computing results, to obtain the first computing result, and send, using the specified first computing node, the first computing result to a corresponding second computing node for aggregation. In this embodiment of the present disclosure, computing tasks of the first node cluster serving as a child node are distributed to the k first computing nodes for parallel processing, after a computing result of each first computing node is obtained, aggregation is performed on the specified first computing node in the k first computing nodes, and then an aggregation result is sent to the second computing node for upper-layer aggregation, thereby greatly improving computing and aggregation efficiency.
In a possible implementation, the second node cluster is configured to distribute the second computing input to the k second computing nodes for distributed computing, to obtain k second distributed computing results, receive, using each of the k second computing nodes, the first computing result sent by the specified first computing node in the corresponding first node cluster, and aggregate the first computing result and the obtained second distributed computing results, and aggregate, using a specified second computing node in the k second computing nodes, results obtained through aggregation using all of the k second computing nodes, to obtain the third computing result. In this embodiment of the present disclosure, computing tasks of the second node cluster serving as a parent node are distributed to the k second computing nodes for parallel processing, and after a computing result of each second computing node is obtained, the second computing node aggregates computing results sent by the corresponding k first node clusters. In addition, the process between the k second computing nodes is a parallel operation. Finally, distributed aggregation between nodes is performed once again using the specified second computing node in the k second computing nodes, to obtain a final aggregation result of the second node cluster, thereby greatly improving computing and aggregation efficiency.
In a possible implementation, the first computing input includes a first parameter, and the second node cluster is further configured to send the first parameter to the k first node clusters respectively using the k second computing nodes. In this embodiment of the present disclosure, the second node cluster serving as a parent node delivers, in parallel, related computing input parameters of the k first computing nodes to the corresponding first node cluster using the first computing nodes in order to increase a speed of obtaining the related parameters by the first node cluster, thereby improving parameter synchronization efficiency of an entire system.
In a possible implementation, the second node cluster is configured to send, using each second computing node, the first parameter divided into k slices respectively to the k first computing nodes in the corresponding first node cluster such that the first parameter is broadcast between the k first computing nodes, or send the first parameter to the k first computing nodes in the corresponding first node cluster in parallel respectively using the k second computing nodes, or send the first parameter to one first computing node in the corresponding first node cluster using the k second computing nodes such that the one first computing node broadcasts the first parameter between other first computing nodes in the same cluster. In this embodiment of the present disclosure, in a process of delivering a related parameter of the computing system, the first parameter is divided into k slices and the k slices are sent to the k first computing nodes in parallel, or the first parameter is simultaneously sent to the k first computing nodes, or the first parameter is directly sent to a first computing node, and then the first computing node broadcasts the first parameter between other first computing nodes in the same cluster in order to implement a process of delivering the first parameter.
In a possible implementation, the second node cluster is directly connected to the at least one first node cluster through the physical link. In this embodiment of the present disclosure, in each minimum tree in the computing system, a second node cluster may be directly connected to a first node cluster through a physical link.
In a possible implementation, the computing system further includes a switch, and the switch and each of the plurality of node clusters are directly connected through the physical link, and the second node cluster is connected to the at least one first node cluster through the switch. In this embodiment of the present disclosure, in each minimum tree in the computing system, a second node cluster may be indirectly and physically connected to a first node cluster through a switch.
In a possible implementation, the computing system is a neural network computing system, and the first computing input and the second computing input include a weight, training data, an offset, and a hyperparameter, and the first computing result, the second computing result, and the third computing result are gradients. In this embodiment of the present disclosure, the computing system is applied to a neural network training model, a corresponding computing input is a related parameter in the neural network training model, and a corresponding computing result is a gradient value.
According to a second aspect, an embodiment of the present disclosure provides a computing method, where the method may include receiving, by a second node cluster, a first computing result sent by at least one first node cluster, where the first computing result is a result obtained by each of the at least one first node cluster based on a first computing input, the first node cluster and the second node cluster are in any minimum tree of a same tree network structure, and the second node cluster is a parent node of the at least one first node cluster, aggregating, by the second node cluster, the first computing result and a second computing result, to obtain a third computing result, where the second computing result is a result obtained by the second node cluster based on a second computing input, and sending, by the second node cluster, the third computing result to a third node cluster for aggregation, where the third node cluster is in the tree network topology, and the third node cluster is a parent node of the second node cluster.
In a possible implementation, the second node cluster includes k second computing nodes, and any one of the k first node clusters includes k first computing nodes, and in any minimum tree in the network structure, the k second computing nodes in the second node cluster one-to-one correspond to the k first node clusters, and any one of the k second computing nodes is connected to the k first computing nodes in the corresponding first node cluster through a physical link.
In a possible implementation, aggregating, by the second node cluster, the first computing result and the second computing result, to obtain a third computing result includes distributing, by the second node cluster, the second computing input to the k second computing nodes for distributed computing, to obtain k second distributed computing results, where the k second distributed computing results are the second computing result, receiving, by the second node cluster respectively using the k second computing nodes, k slices of the first computing result that are sent by the k first computing nodes in the corresponding first node cluster, aggregating, by the second node cluster respectively using the k second computing nodes, the second distributed computing result obtained through computation by each second computing node and the k slices of the first computing result of the corresponding first node cluster, and performing, by the second node cluster, distributed aggregation on results obtained through aggregation using all of the k second computing nodes, to obtain one slice of the third computing result on each second computing node.
In a possible implementation, aggregating, by the second node cluster, the first computing result and the second computing result, to obtain a third computing result includes distributing, by the second node cluster, the second computing input to the k second computing nodes for distributed computing, to obtain k second distributed computing results, receiving, by the second node cluster using each of the k second computing nodes, the first computing result sent by the specified first computing node in the corresponding first node cluster, and aggregating the first computing result and the obtained second distributed computing results, and aggregating, by the second node cluster using a specified second computing node in the k second computing nodes, results obtained through aggregation using all of the k second computing nodes, to obtain the third computing result.
In a possible implementation, the method further includes sending, by the second node cluster, the first parameter to the k first node clusters respectively using the k second computing nodes.
In a possible implementation, sending, by the second node cluster, the first parameter to the k first node clusters respectively using the k second computing nodes includes sending, by the second node cluster using each second computing node, the first parameter divided into k slices respectively to the k first computing nodes in the corresponding first node cluster such that the first parameter is broadcast between the k first computing nodes, or sending, by the second node cluster, the first parameter to the k first computing nodes in the corresponding first node cluster in parallel respectively using the k second computing nodes, or sending, by the second node cluster, the first parameter to one first computing node in the corresponding first node cluster using the k second computing nodes such that the one first computing node broadcasts the first parameter between other first computing nodes in the same cluster.
In a possible implementation, the first computing input and the second computing input include a weight, training data, an offset, and a hyperparameter, and the first computing result, the second computing result, and the third computing result are gradients.
According to a third aspect, this application provides a computer storage medium configured to store a computer software instruction used by the computing system provided in the first aspect. The computer software instruction includes a program designed for performing the foregoing aspects.
According to a fourth aspect, an embodiment of the present disclosure provides a computer program. The computer program includes an instruction. When the computer program is executed by a computer, the computer is enabled to execute a procedure in the computing system in the first aspect.
According to a fifth aspect, this application provides a node cluster. The node cluster is configured to support a function implemented by the first node cluster or the second node cluster in the computing system in the first aspect.
To describe the technical solutions in some of the embodiments of the present disclosure more clearly, the following briefly describes the accompanying drawings describing some of the embodiments of the present disclosure.
The following describes the embodiments of the present disclosure with reference to the accompanying drawings in the embodiments of the present disclosure.
In this specification, claims, and accompanying drawings of this application, the terms such as “first”, “second”, “third”, and “fourth” are intended to distinguish between different objects but do not indicate a particular order. In addition, the terms “include”, “have”, or any other variant thereof, are intended to cover a non-exclusive inclusion. For example, a process, a method, a system, a product, or a device that includes a series of steps or units is not limited to the listed steps or units, but optionally further includes an unlisted step or unit, or optionally further includes another inherent step or unit of the process, the method, the product, or the device.
Mentioning an “embodiment” in this specification means that a particular characteristic, structure, or feature described with reference to the embodiment may be included in at least one embodiment of this application. The phrase shown in various locations in this specification may not necessarily refer to a same embodiment, and is not an independent or optional embodiment exclusive from another embodiment. It is explicitly and implicitly understood by persons skilled in the art that the embodiments described in this specification may be combined with another embodiment.
Terminologies such as “component”, “module”, and “system” used in this specification are used to indicate computer-related entities, hardware, firmware, a combination of hardware and software, software, or software being executed. For example, a component may be, but is not limited to, a process that runs on a processor, a processor, an object, an executable file, a thread of execution, a program, and/or a computer. As shown in figures, both a computing device and an application that runs on a computing device may be components. One or more components may reside within a process and/or a thread of execution, and a component may be located on one computer and/or distributed between two or more computers. In addition, these components may be executed from various computer-readable media that store various data structures. For example, the components may communicate using a local and/or remote process and according to, for example, a signal having one or more data packets (for example, data from two components interacting with another component in a local system, a distributed system, and/or across a network such as the internet interacting with other systems using the signal).
Some terms in this application are first described in order to help persons skilled in the art have a better understanding.
(1) A solid-state drive (SSD) is a hard disk made of a solid-state electronic storage chip array, and includes a control unit and a storage unit (a FLASH chip or a dynamic random-access memory (RAM) (DRAM) chip). The solid-state drive is exactly the same as a common hard disk in terms of specifications and a definition of an interface, a function, usage, and a product shape and size.
(2) A network adapter: a desktop computer is generally connected to a network using a built-in network interface card (NIC). The network adapter is also referred to as a “NIC”. The NIC is one of most basic components in a local area network, and is a hardware device that connects a computer and a network. Data communication can be implemented through a connection using a NIC, regardless of whether the connection is a twisted pair connection, a coaxial cable connection, or an optical fiber connection. Main technical parameters of the NIC are bandwidth, a bus mode, an electrical interface mode, and the like. Basic functions of the NIC are as follows: parallel to serial data conversion, packet encoding and decoding, network access control, data buffering, and a network signal interaction.
(3) A Non-Volatile Memory (NVM) Express (NVMe) Protocol is a protocol that is similar to an Advanced Host Controller Interface (AHCI) and that is set up on an M.2 interface, and is a protocol specially designed for a flash storage.
(4) A double data rate (DDR) synchronous DRAM (SDRAM) is referred to as DDR. A DDR memory is developed based on an SDRAM, and still uses an SDRAM production system. Therefore, for a memory vendor, only a device for manufacturing an ordinary SDRAM needs to be slightly improved, to produce a DDR memory, thereby effectively reducing costs. Compared with a conventional single data rate, a DDR technology implements a read/write operation twice in one clock cycle. In other words, one read/write operation is performed at each of a rising edge and a falling edge of a clock.
(5) Peripheral Component Interconnect (PCI) Express (PCI-Express) is referred to as PCIe, and is a high-speed serial PCIe bus. As a local bus of a processor system, the PCIe bus has a function similar to that of a PCI bus, and is mainly used to connect external devices in the processor system. Certainly, the PCIe bus may alternatively be used to connect another processor system. In different processor systems, methods for implementing a PCIe architecture are slightly different. However, in most processor systems, basic modules such as a root complex (RC), a switch, and a PCIe-to-PCI bridge are used to connect PCIe devices and PCI devices. A device based on the PCIe bus is also referred to as an Endpoint (EP).
(6) An NNA is configured to complete computation of forward propagation and back propagation of a neural network. As a processor, the NNA may be a graphics processing unit (GPU), or may be a processor implemented based on a field programmable gate array (FPGA) or an application-specific integrated circuit (ASIC). A specific implementation form of the NNA is not limited in this application.
(7) A neural-network processing unit (NPU) uses a “data-driven parallel computing” architecture, and may be configured to process massive multimedia data of a video type and an image type.
(8) Gradient aggregation: A gradient is a maximum directional derivative of a function based on a point, and the function has a maximum change rate along a gradient direction. The gradient of the function based on the point is a vector, where a direction of the vector is consistent with a direction for obtaining the maximum directional derivative, and a modulus of the vector is a maximum value of the directional derivative. Aggregation means accumulating gradient data obtained through computation by each computing node (worker). A gradient descent method in the neural network is a first-order optimization algorithm, and is usually referred to as a steepest descent method. To find a local minimum value of a function using the gradient descent method, iterative search needs to be performed on a specified step distance point in an opposite direction of a gradient (or an approximate gradient) of the function based on a current point.
Next, a technical problem that needs to be resolved in this application and an application scenario are proposed. In the other approaches, in a large-scale distributed training system, a training manner widely applied in an academic circle and an industrial circle refers to synchronous stochastic gradient descent and data parallelism, and key points of a training algorithm are as follows:
(1) Each computing node in a group independently completes computing of a mini-batch of training data of the computing node, to obtain a gradient.
(2) All computing nodes in the group need to aggregate gradients obtained through computation, to form an aggregated gradient.
(3) Based on the aggregated gradient, calculate a new parameter value with reference to a hyperparameter such as a learning rate.
(4) Distribute the new parameter value to each computing node in the group.
(5) After obtaining the new parameter value, all the computing nodes start a next round of iterative computation.
It can be learned from the foregoing process that deep neural network training is a high-strength computation process that is intensive in computing and network bandwidth and is very sensitive to a latency. The following Table 1 shows a neural network model of a typical deep neural network, and a parameter quantity and a parameter size list that correspond to the model. K=1000, and M=1000×1000=1000000.
It can be learned from the foregoing list that there is a relatively large difference in parameter quantities and parameter sizes of different network models. VGG19-22K is used as an example. A parameter size of the VGG19-22K is up to 916 MB. With reference to the key point (2) and the key point (4) in the foregoing training process, it can be learned that in the training process, gradients and parameters are exchanged very frequently between computing nodes, and traffic is also very high. This becomes worse with an increase of a computing node scale in the group. Therefore, how to effectively and quickly aggregate and synchronize these parameters between all computing nodes in an entire group system is a key problem that needs to be resolved in large-scale distributed training. There are related solutions in the other approaches, for example:
Other Approaches 1:
Currently, a fully connected structure (computing node-parameter server or worker-parameter server) is widely applied to a distributed training system. A topology of the distributed training system is shown in
An entire group includes many workers, and the worker is responsible for gradient computation of the local node. A parameter server (PS) is responsible for collecting gradient data computed by all workers in the entire group, aggregating the gradient data, calculating a new weight based on the aggregated gradient data, and then delivering the new weight to all the workers. To share pressure of network bandwidth and weight calculation, a plurality of PSs are generally used to constitute a group to bear workload. Assuming that a quantity of PSs in the group is P and a quantity of workers in the group is W, a working mechanism is as follows:
1. Each worker evenly divides a calculated gradient into P slices, and separately sends the P slices to all PSs, and each PS obtains an independent slice.
2. Each PS collects gradients sent by all the workers, generates a new weight through calculation, and sends the new weight to all the workers.
3. Each worker accumulates the weights received from all the PSs to form a complete weight for a new round of iterative computation.
Disadvantages of the other approaches 1 are as follows:
(1) Group performance: From a perspective of the foregoing interaction relationship between the workers and the PSs, the group is a fully connected topology, and performance of the group is not high. It is assumed that a quantity of worker nodes in the group is N, a gradient parameter size is M, transmission bandwidth between the nodes is B, and a preparation time for network transmission between the nodes is ts. A time overhead for completing aggregation and synchronization of gradient parameters in a synchronous stochastic gradient descent (SGD) training algorithm is T=2× N×(ts+M/B), and the time complexity is O(N). In this case, a communication latency is relatively large, and the latency has great impact on distributed training efficiency.
(2) Group scalability: In the foregoing fully connected topology, a phenomenon of a “many-to-one traffic pattern” exists. For example, all the workers in the group need to send gradient data to a same PS. With an increase in the quantity N of worker nodes, the group scalability severely deteriorates. A network packet loss and congestion caused by the “many-to-one traffic pattern” seriously affect system performance. In addition, a group speed-up ratio is not high, and scalability of a group scale is limited. Consequently, it is difficult to construct a large training group.
Other Approaches 2:
To resolve the foregoing problem of the “many-to-one traffic pattern”, another solution is to restrict a sending/receiving relationship between worker nodes in a group, to form a logical ring, that is, a ring structure.
1. Each worker node receives data from a pre-order node, processes the received data, and then sends the processed data to a post-order node.
2. In the other approaches, to improve efficiency, the worker usually segments to-be-transmitted data into small slices, and a plurality of transmission channel pipelines perform parallel transmission, to fully use transmission bandwidth resources. For example, as shown by dashed lines in
Disadvantages of the other approaches 2 are as follows:
(1) Group performance: It is assumed that a quantity of worker nodes in the group is N, a gradient parameter size is M, transmission bandwidth between the nodes is B, and a preparation time for network transmission between the nodes is ts. A time overhead for completing aggregation and synchronization of gradient parameters in a synchronous SGD training algorithm is T=2× (N−1)×(ts+M/B), and the time complexity is O(N). In this case, a communication latency is relatively large, and the latency has great impact on distributed training efficiency.
(2) Group scalability: In the ring topology, the data sending/receiving relationship between worker nodes is restricted, to form the logical ring. This solves the problem of the “many-to-one traffic pattern”. However, with an increase in the quantity of nodes, a ring length increases linearly, and an end-to-end latency also increases linearly. In addition, a group speed-up ratio is not high, and scalability of a group scale is limited. Consequently, it is difficult to construct a large training group.
Other Approaches 3:
To resolve the problem of the Ring length in the ring topology, an optimization solution is to adopt the following fat-tree networking.
In a group, a node worker and a parameter server PS constitute a tree structure, and the tree structure is converged in a k:1 manner (as shown in
Disadvantages of the other approaches 3 are as follows:
(1) Group performance: It is assumed that a quantity of worker nodes in the group is N, a gradient parameter size is M, transmission bandwidth between the nodes is B, and a preparation time for network transmission between the nodes is ts. A time overhead required for completing aggregation and synchronization of gradient parameters in a synchronous SGD training algorithm is T=2× Logk(N)×(ts+M/B), where k is a convergence ratio, and the time complexity is O(Logk(N)).
(2) Group scalability: To support a non-blocking network, a node closer to a root node requires higher network bandwidth and needs to have a higher switching capability. This requirement becomes higher linearly with an increase in the quantity of nodes in the group. For a deep neural network, a parameter size is very large, interaction is frequently performed, a requirement on network bandwidth and a switching capability of a root node is higher, and network deployment costs are very high. All gradients in the entire group are aggregated on the root node, and a computing hotspot is formed on the root node. In addition, a group speed-up ratio and scalability of a group scale are limited. Consequently, it is difficult to construct a large training cluster.
In conclusion, the existing solutions have disadvantages regarding a scalability capability of a group. When a group scale increases and a quantity of nodes in the group increases, performance of the group degrades, linearity of the group deteriorates, deployment costs of the group increase, and network performance optimization and group operation overheads increase. This is unfavorable to construction of a large-scale AI group. Therefore, a technical problem to be resolved in this application is how to effectively and quickly aggregate and synchronize related parameters between all computing nodes in an entire group system in a large-scale distributed training system, to implement scalability of the group system, facilitate construction of a large-scale AI group, and improve training efficiency.
Based on the foregoing description, the following first describes an architecture of a computing system provided in an embodiment of the present disclosure.
The first node cluster is configured to obtain a first computing result based on a first computing input, and send the first computing result to the second node cluster through the physical link. The first computing input is a related parameter, training data, or the like of a computing task that is assigned by the computing system to each first node cluster in an initial or iterative case, and the first computing result is a result obtained through computation by the first node cluster based on the first computing input. After completing the computation, the first node cluster needs to send the first computing result to the parent node of the first node cluster through the physical link between the first node cluster and the parent node, namely, the second node cluster for aggregation. It may be understood that the first node cluster in this application refers to all child nodes in each minimum tree in the computing system. In other words, in the network structure in
The second node cluster is configured to receive, through the physical link, at least one first computing result sent by the at least one first node cluster, and aggregate the at least one first computing result and a second computing result to obtain a third computing result, where the second computing result is a result obtained by the second node cluster based on a second computing input. To be specific, the second node cluster serving as the parent node not only needs to perform a computing task assigned by the computing system, to obtain the second computing result, but also needs to aggregate the second computing result and one or more first computing results obtained through computation by all child nodes in the minimum tree to which the second node cluster belongs. Further, when the second node cluster is not a root node, the second node cluster further needs to send the third computing result to a parent node in a corresponding minimum tree in which the second node cluster serves as a child node, that is, send the third computing result to a third node cluster for upper-layer aggregation. It may be understood that the second node cluster in this application refers to a parent node in each minimum tree in the computing system. In other words, in the network structure in
It should be noted that a root node (for example, the L4 layer-cluster 1 in
In a possible implementation, any minimum tree in the network structure includes one second node cluster and k first node clusters, where k is an integer greater than or equal to 1. In other words, any minimum tree in the network structure is converged in a k:1 manner. In
Optionally, the first computing input and the second computing input include a weight, training data, an offset, and a hyperparameter, and the first computing result, the second computing result, and the third computing result are gradients. When the foregoing computing system is applied to an AI neural network, each node cluster in the computing system 10 is configured to obtain a gradient of the node cluster through computation based on a weight, training data, an offset, and a hyperparameter that are allocated, and perform gradient aggregation between the node cluster and a parent node in a minimum tree to which the node cluster belongs. Finally, a final aggregated gradient is obtained on the root node. The root node calculates a new weight based on the final aggregated gradient and a hyperparameter such as a learning rate, and then distributes the new weight to each node cluster in the computing system, to start a next round of iterative computation.
Optionally, the second node cluster includes at least one second computing node, and the second computing node is an NNA, and the first node cluster includes at least one first computing node, and the first computing node is an NNA. In this embodiment of the present disclosure, one or more NNAs are disposed in a node cluster in order to implement parallel computing in a neural network.
In the computing system 10, each node cluster is responsible for aggregating computing results of the node cluster and is also responsible for aggregating computing results of a lower-layer node cluster connected to the node cluster such that not only transmission of data from a lower layer to an upper layer is completed, but also data aggregation between node clusters is completed layer by layer in a transmission process, thereby reducing an amount of data that is to be aggregated and that is transmitted in bandwidth. In addition, because a tree networking topology is used in this embodiment of the present disclosure, computing and aggregation are performed between different node clusters at a same layer in parallel, thereby further improving computing and aggregation efficiency. In this way, a problem of low computing efficiency in large-scale distributed training is resolved.
It may be understood that the connection relationship between the node clusters in
The following uses a parent node and one child node in the foregoing minimum tree as an example, for example, a connection between an NPU 1 in the L1-cluster 0 and the L0-cluster 0, to describe a structure and a connection relationship of the first node cluster and the second node cluster.
A main control central processing unit (CPU) is responsible for management and control of a computing task on a node, control of interaction between nodes, and preprocessing and post-processing of data (if preprocessing or post-processing needs to be performed). For example, the main control CPU may be X86.
An SSD and an NVMe are local high-speed storage, and are configured to store a system and training data such as a first computing input and a second computing input.
A NIC 1, a NIC 2, a NIC 3, and a NIC 4 are network interfaces, and each are configured to be directly connected, through a physical link, to a child node in a node cluster to which the network interface belongs. For example, in
A NIC 0 and a NIC 5 are network interfaces on an NNA, and each are configured to perform interaction and communication between the computing node and the outside. To be specific, the NIC 0 is configured to, when a node cluster serves as a child node, to be directly and physically connected to one of a corresponding NIC 1, NIC 2, NIC 3, and NIC 4 on a parent node, and send the first computing result to the second node cluster through the physical link. The NIC 5 is mainly configured to serve as an interface of another network plane (for example, a user plane, a control plane, or a management plane).
A PCIe switch is a PCIe bus switch, and is configured to interconnect PCIe devices and interconnect X86 main control CPUs.
An NN accelerator is an NNA, may also be referred to as an accelerated NNA, and is usually mounted to a PCIe bus using a PCIe EP device.
An NN accelerator/DDR is a memory on the NNA, and is used for local storage in a computing process.
An NN accelerator/PCIe is a PCIe bus interface on the NNA, and is used for interconnection and communication inside the computing node.
An NN accelerator/link is a high-speed interconnection link between NNAs, and is configured to accelerate high-speed data exchange between NNAs.
An NN accelerator/NPU is an embedded neural network processor on the NNA, and is used for computation of various neural network operators.
When the computing system in this application is applied to an AI neural network field, in an AI training process, a processing process of each functional module in the foregoing node cluster is as follows:
(1) An AI application program and an AI framework are run on the main control CPU. After the CPU runs, the AI application program starts training, obtains necessary inputs such as a neural network model, an initial parameter, and training data, and invokes the AI framework for training.
(2) The main control CPU performs graph analysis and graph optimization on the neural network model using the AI framework, converts the model into a computing graph, and then transmits, based on a graph scheduling algorithm, a computing operator (for example, the first computing input or the second computing input in this application) to the NNA (each first computing node in the first node cluster or each second computing node in the second node cluster) for execution.
(3) After receiving a computing task, the NN accelerator completes, using the NPU, computation described by the operator, and stores a computing result (for example, the first computing result or the second computing result in this application) in a memory DDR of a device.
(4) Data exchange between a plurality of NNAs is generally involved in a computing process. To improve data exchange efficiency, generally, data is exchanged through a high-speed interconnect bus link between devices.
(5) After completing computation, the NN accelerator may send a computing result to the main control CPU through the PCIe bus, or send the computing result to another node using a NIC.
In a specific computing process, based on the structure of the node cluster and the connection relationship between the node clusters in
In a possible implementation, each of k first node clusters in any minimum tree is configured to distribute a first computing input to the k first computing nodes for distributed computing, to obtain k first distributed computing results, perform distributed aggregation on the k first computing nodes based on the k first distributed computing results respectively, to obtain one slice of the first computing result on each first computing node, and finally, synchronously or asynchronously send, using the k first computing nodes, k slices of the first computing result to a corresponding second computing node for aggregation. Correspondingly, a second node cluster is configured to distribute a second computing input to k second computing nodes for distributed computing, to obtain k second distributed computing results, where the k second distributed computing results are the second computing result, receive, respectively using the k second computing nodes, the k slices of the first computing result that are sent by the k first computing nodes in the corresponding first node cluster, aggregate, respectively using the k second computing nodes, the second distributed computing result obtained through computation by each second computing node and the k slices of the first computing result of the corresponding first node cluster, and finally, perform distributed aggregation on results obtained through aggregation using all of the k second computing nodes, to obtain one slice of the third computing result on each second computing node.
In this embodiment of the present disclosure, computing tasks of the first node cluster serving as a child node are distributed to the k first computing nodes for parallel processing, and after a computing result of each first computing node is obtained, parallel aggregation is performed between the k first computing nodes. Moreover, computing tasks of the second node cluster serving as a parent node are distributed to the k second computing nodes for parallel processing, and after a computing result of each second computing node is obtained, the second computing node locally aggregates computing results sent by the corresponding k first node clusters. In addition, the process between the k second computing nodes is a parallel operation. Finally, distributed aggregation between nodes is performed once again between the k second computing nodes, to obtain a final aggregation result of the second node cluster, thereby greatly improving computing and aggregation efficiency.
In the foregoing implementation, based on the interconnection relationship in
L0-cluster 1: NPU 1→PCIe→PCIe switch→NIC 0→L1-cluster 0: NIC 2→NPU 2;
L0-cluster 1: NPU 2→PCIe→PCIe switch→NIC 0→L1-cluster 0: NIC 2→NPU 2;
L0-cluster 1: NPU 3→PCIe→PCIe switch→NIC 0→L1-cluster 0: NIC 2→NPU 2; and
L0-cluster 1: NPU 4→PCIe→PCIe switch→NIC 0→L1-cluster 0: NIC 2→NPU 2.
In another possible implementation, any one of k first node clusters is configured to distribute a first computing input to the k first computing nodes for distributed computing, to obtain k first distributed computing results, perform aggregation on a specified first computing node in the k first computing nodes based on the k first distributed computing results, to obtain the first computing result, and send, using the specified first computing node, the first computing result to a corresponding second computing node for aggregation. Correspondingly, the second node cluster is configured to distribute a second computing input to k second computing nodes for distributed computing, to obtain k second distributed computing results, receive, using each of the k second computing nodes, the first computing result sent by the specified first computing node in the corresponding first node cluster, and aggregate the first computing result and the obtained second distributed computing results, and finally aggregate, using a specified second computing node in the k second computing nodes, results obtained through aggregation using all of the k second computing nodes, to obtain the third computing result.
A difference from the distributed computing and distributed aggregation in the foregoing implementation lies in that, in this implementation, computing tasks of the first node cluster serving as a child node are distributed to the k first computing nodes for parallel processing, and after a computing result of each first computing node is obtained, parallel aggregation is performed on the specified first computing node in the k first computing nodes. Moreover, computing tasks of the second node cluster serving as a parent node are distributed to the k second computing nodes for parallel processing, and after a computing result of each second computing node is obtained, the second computing node aggregates computing results sent by the corresponding k first node clusters. In addition, the process between the k second computing nodes is a parallel operation. Finally, distributed aggregation between nodes is performed once again between the k second computing nodes, to obtain a final aggregation result of the second node cluster.
It should be noted that in the first computing result, the second computing result, and the third computing result, the first computing result is a result obtained after the first node cluster completes computing and aggregation, and the third computing result is obtained by the second node cluster by aggregating the first computing result and the second computing result. Therefore, the third computing result is also an aggregated result. The second computing result is one or more computing results that are obtained through computation by the second node cluster or all the second computing nodes in the second node cluster but have not been aggregated.
Based on the foregoing data, in the computing system, in a process of aggregation from a node cluster at a lower layer to a node cluster at an upper layer, an embodiment of the present disclosure further provides a solution for delivering an initial or updated related parameter (for example, a first computing input or a second computing input) from the node cluster at the upper layer to the node cluster at the lower layer.
Based on the interconnection relationship in
L1-cluster 0: NPU 2→NIC 2→L0-cluster 1: NIC 0→PCIe switch 4 PCIe→NPU 1;
L1-cluster 0: NPU 2→NIC 2→L0-cluster 1: NIC 0→PCIe switch 4 PCIe→NPU 2;
L1-cluster 0: NPU 2→NIC 2→L0-cluster 1: NIC 0→PCIe switch 4 PCIe→NPU 3;
L1-cluster 0: NPU 2→NIC 2→L0-cluster 1: NIC 0→PCIe switch 4 PCIe→NPU 4; and
For example, in a parameter delivering process, when a first computing input includes the first parameter, the second node cluster is further configured to respectively send the first parameter to the k first node clusters using the k second computing nodes. A specific delivering process may include the following three implementations:
Implementation 1: The second node cluster sends the first parameter to the k first computing nodes in the corresponding first node cluster in parallel respectively using the k second computing nodes. That is, the second node cluster simultaneously sends the first parameter to the k first computing nodes in the corresponding first node cluster. Therefore, the k first computing nodes simultaneously receive the first parameter sent by the corresponding second computing nodes. In this implementation, a parameter delivering speed is high, but the second computing node needs to send the complete first parameter for k times.
Implementation 2: The second node cluster sends the first parameter to one first computing node in the corresponding first node cluster using the k second computing nodes such that the one first computing node broadcasts the first parameter between other first computing nodes in the same cluster. That is, the second computing node first sends the first parameter to a specified first computing node in the corresponding first node cluster. Therefore, the specified first computing node in the k first computing nodes first receives the first parameter, then, the first computing node that receives the first parameter broadcasts the first parameter through a high-speed physical link between computing nodes in the same cluster, and finally, each first computing node obtains the complete first parameter.
Implementation 3: The second node cluster sends, using each second computing node, the first parameter divided into k slices respectively to the k first computing nodes in the corresponding first node cluster such that the first parameter is broadcast between the k first computing nodes. That is, the second computing node divides the first parameter into k slices, and then sends each slice to a different first computing node. Therefore, all the k first computing nodes can receive a slice of the first parameter, and then the k first computing nodes each synchronizes a slice with each other through a high-speed physical link. In this way, transmission bandwidth between the second computing node and the first node cluster can be reduced, a parameter delivering time can also be reduced, and parameter delivering efficiency can be improved.
In this application, to reduce a time consumed in end-to-end (E2E) transmission and improve efficiency, in a possible implementation, a pipeline algorithm is used to increase an overlap ratio for computing and transmission. The time consumed in transmission is hidden as much as possible in a computing process. A processing manner is as follows:
1. The computing system in this application performs aggregation and transmission using a gradient as a granularity.
2. After dependency of a gradient parameter is canceled, the gradient parameter enters a pipeline for aggregation and transmission. When the aggregation and transmission is being performed, a new gradient parameter is calculated.
3. The computing system in this application divides a large gradient into small slices for aggregation and transmission, and performs aggregation computing and transmission in parallel.
4. A plurality of small slices are transmitted in parallel, to form a multi-level pipeline.
Based on the foregoing procedures for aggregation and delivering of the parameter in the computing system, in a possible implementation, this application further provides another system connection manner.
It may be understood that in the foregoing minimum tree architecture in
It should be noted that in this embodiment of the present disclosure, scalability of a large-scale distributed neural network training group is implemented based on a tree networking topology, a layer-by-layer accumulation algorithm, and a multi-layer pipeline algorithm. The networking topology and algorithm are also applicable to other similar computing fields. With reference to the idea and algorithm implementation, the networking topology and algorithm are used to implement high-performance computing in this field.
When the computing system in this application is applied to the field of the large-scale distributed neural network training group, existing network plane planning may remain unchanged, to meet requirements of management, access, storage, control, and the like of a group node. Based on an existing network plane, only a distributed deep neural network (DDN) plane needs to be newly planned, and gradient data aggregation and weight parameter synchronization are dedicated using the plane.
Next, NICs between computing nodes in a node cluster are connected in a back-to-back physical direct connection manner, to form a high-bandwidth low-latency channel between the nodes. A plurality of node clusters is converged in a k:1 manner, to form a tree topology. A tree group system may be formed through layered stacking. Then, the DDN plane is mapped to a physical direct connection topology between the node clusters.
In addition, in this application, a plurality of NNAs, that is, computing nodes (for example, four computing nodes) in this application, may be configured for each node cluster, to form one cluster. In a data parallel training method, each NNA (for example, a first computing unit) in a cluster (for example, a first node cluster) first independently completes gradient computing, and then completes gradient aggregation between the plurality of NNAs in the cluster. After the aggregation is completed, an aggregated gradient is transmitted to a parent node (for example, a second node cluster) of the cluster. Each NNA (for example, a second computing unit) in the parent node cluster not only needs to complete gradient computing responsible by the NNA, but also needs to obtain gradient data aggregated by all child nodes, and aggregate the gradient data and a gradient obtained through computation by the NNA to obtain one piece of data. Then, aggregation is performed again between all NNAs in the parent node cluster. After the aggregation is completed, an aggregated gradient is transmitted to a parent node (for example, a third node cluster) of the parent node cluster.
Therefore, each node cluster in this application is responsible for not only gradient computing, but also gradient aggregation, routing, and transfer. Because each node cluster sends an aggregated gradient, amounts of data transmitted between layers in a tree are uniform. In this manner, in the entire group, execution is performed in parallel, and one piece of complete gradient data including computing results of all nodes can be obtained after aggregation is completed on a root node.
A new weight parameter can be calculated based on the foregoing gradient data. Once a new weight is obtained through calculation, the new weight may be transmitted downward along the tree topology, and the new weight is synchronized with all worker nodes (that is, the first computing node and the second computing node in this application). To improve downstream transmission efficiency, a parent node delivers the weight to a child node of the parent node, and after receiving the weight, the child node broadcasts the weight in the cluster. In this case, sending from the parent node to the child node and sending from the child node to a child node are performed in parallel, and a high-speed link in the cluster is fully used. In addition, to increase a ratio of computing to a consumed time and reduce a stall time of an NNA, the foregoing aggregation and synchronization are performed in a pipeline manner. For a deep neural network, after back propagation is performed, gradient data is computed, and dependency is canceled, the gradient data can enter a pipeline. Processing of the gradient aggregation and synchronization and the back propagation are overlapped.
In conclusion, when the computing system in this application is applied to the large-scale distributed neural network training group, the following beneficial effects are achieved:
1. An AI data network plane is provided, and the AI data network plane uses back-to-back direct connection networking and may use remote direct memory access (RDMA) over Converged Ethernet (RoCE) protocol, where the RoCE is a network protocol that allows RDMA using the Ethernet. In this way, bandwidth is high and a latency is low such that a performance requirement of a deep neural network training service is met. The AI data network plane is decoupled from another network plane in order to avoid mutual interference, save a large quantity of switch resources, reduce investment costs, and reduce network performance optimization and operation and maintenance costs.
2. The computing system in this application uses a tree (which may be referred to as a slim tree in this application) networking topology. Each worker node is responsible for not only gradient computing, but also gradient aggregation and parameter synchronization. Amounts of data transmitted between nodes in the entire tree are uniform, and amounts of data transmitted between layers of the tree are also uniform. In this way, neither a traffic hotspot nor a computing hotspot exists globally.
3. If the computing system in this application is used, when a quantity of nodes is increased, a quantity of layers of the tree is increased. Each time a layer is increased, the quantity of nodes is increased fourfold. However, a time consumed in gradient aggregation and parameter synchronization on an E2E path is increased by overheads of a time consumed for passing through one node and two sides. In this way, attenuation of a ratio of computing to a consumed time is low, and linearity of a speed-up ratio is better.
4. The computing system in this application uses a pipeline, to hide a time for gradient aggregation and transmission in a computing time, thereby effectively reducing a stall time of a computing node, increasing the ratio of computing to a consumed time, and further improving efficiency of the entire group.
Therefore, the computing system provided in this application can obtain a stable speed-up ratio in a large-scale group, and is suitable for constructing a large-scale distributed training group.
Step S101: A second node cluster receives a first computing result sent by at least one first node cluster, where the first computing result is a result obtained by each of the at least one first node cluster based on a first computing input, the first node cluster and the second node cluster are in any minimum tree of a same tree network structure, and the second node cluster is a parent node of the at least one first node cluster.
Step S102: The second node cluster aggregates the first computing result and a second computing result, to obtain a third computing result, where the second computing result is a result obtained by the second node cluster based on a second computing input.
Step S103: The second node cluster sends the third computing result to a third node cluster for aggregation, where the third node cluster is in the tree network topology, and the third node cluster is a parent node of the second node cluster.
In a possible implementation, the second node cluster includes k second computing nodes, and any one of the k first node clusters includes k first computing nodes, and in any minimum tree in the network structure, the k second computing nodes in the second node cluster one-to-one correspond to the k first node clusters, and any one of the k second computing nodes is connected to the k first computing nodes in the corresponding first node cluster through a physical link.
In a possible implementation, that the second node cluster aggregates the first computing result and the second computing result, to obtain a third computing result includes distributing, by the second node cluster, the second computing input to the k second computing nodes for distributed computing, to obtain k second distributed computing results, where the k second distributed computing results are the second computing result, receiving, by the second node cluster respectively using the k second computing nodes, k slices of the first computing result that are sent by the k first computing nodes in the corresponding first node cluster, aggregating, by the second node cluster respectively using the k second computing nodes, the second distributed computing result obtained through computation by each second computing node and the k slices of the first computing result of the corresponding first node cluster, and performing, by the second node cluster, distributed aggregation on results obtained through aggregation using all of the k second computing nodes, to obtain one slice of the third computing result on each second computing node.
In a possible implementation, that the second node cluster aggregates the first computing result and the second computing result, to obtain a third computing result includes distributing, by the second node cluster, the second computing input to the k second computing nodes for distributed computing, to obtain k second distributed computing results, receiving, by the second node cluster using each of the k second computing nodes, the first computing result sent by the specified first computing node in the corresponding first node cluster, and aggregating the first computing result and the obtained second distributed computing results, and aggregating, by the second node cluster using a specified second computing node in the k second computing nodes, results obtained through aggregation using all of the k second computing nodes, to obtain the third computing result.
In a possible implementation, the computing method further includes a step of sending, by the second node cluster, the first parameter to the k first node clusters respectively using the k second computing nodes.
In a possible implementation, the sending, by the second node cluster, the first parameter to the k first node clusters respectively using the k second computing nodes includes the following three implementations:
Implementation 1: The second node cluster sends, using each second computing node, the first parameter divided into k slices respectively to the k first computing nodes in the corresponding first node cluster such that the first parameter is broadcast between the k first computing nodes.
Implementation 2: The second node cluster sends the first parameter to the k first computing nodes in the corresponding first node cluster in parallel respectively using the k second computing nodes.
Implementation 3: The second node cluster sends the first parameter to one first computing node in the corresponding first node cluster using the k second computing nodes such that the one first computing node broadcasts the first parameter between other first computing nodes in the same cluster.
In a possible implementation, the first computing input and the second computing input include a weight, training data, an offset, and a hyperparameter, and the first computing result, the second computing result, and the third computing result are gradients.
It should be noted that, for a specific procedure of the computing method described in this embodiment of the present disclosure and a related function of the second node cluster serving as an execution body, refer to related descriptions in the embodiments of the computing system in
It should be noted that, for brief description, the foregoing method embodiments are represented as a series of actions. However, persons skilled in the art should appreciate that this application is not limited to the described order of the actions, because according to this application, some steps may be performed in other orders or simultaneously. It should be further appreciated by persons skilled in the art that the embodiments described in this specification all belong to example embodiments, and the involved actions and modules are not necessarily required by this application.
In the several embodiments provided in this application, it should be understood that the disclosed apparatus may be implemented in other manners. For example, the described apparatus embodiment is merely an example. For example, the unit division is merely logical function division and may be other division in actual implementation. For example, a plurality of units or components may be combined or integrated into another system, or some features may be ignored or not performed. In addition, the displayed or discussed mutual couplings or direct couplings or communication connections may be implemented through some interfaces. The indirect couplings or communication connections between the apparatuses or units may be implemented in electronic or other forms.
The foregoing units described as separate parts may or may not be physically separate, and parts displayed as units may or may not be physical units, may be located in one position, or may be distributed on a plurality of network units. Some or all of the units may be selected based on actual requirements to achieve the objectives of the solutions of the embodiments.
In addition, 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.
When the foregoing integrated unit is implemented in the form of a software functional unit and sold or used as an independent product, the integrated unit may be stored in a computer-readable storage medium. Based on such an understanding, the technical solutions of this application essentially, or the part contributing to the other approaches, or all or some of the technical solutions may be implemented in the form of a software product. The computer software product is stored in a storage medium and includes several instructions for instructing a computer device (which may be a personal computer, a server, or a network device) to perform all or some of the steps of the methods described in the embodiments of this application. The foregoing storage medium includes any medium that can store program code, such as a Universal Serial Bus (USB) flash drive, a removable hard disk, a magnetic disk, an optical disc, a read-only memory (ROM), or a RAM.
The foregoing embodiments are merely intended for describing the technical solutions of this application, but not for limiting this application. Although this application is described in detail with reference to the foregoing embodiments, persons of ordinary skill in the art should understand that they may still make modifications to the technical solutions described in the foregoing embodiments or make equivalent replacements to some technical features thereof, without departing from the spirit and scope of the technical solutions of the embodiments of this application.
Number | Date | Country | Kind |
---|---|---|---|
201810033391.5 | Jan 2018 | CN | national |
This application is a continuation of International Patent Application No. PCT/CN2019/071116 filed on Jan. 10, 2019, which claims priority to Chinese Patent Application No. 201810033391.5 filed on Jan. 12, 2018. The disclosures of the aforementioned applications are hereby incorporated by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2019/071116 | Jan 2019 | US |
Child | 16926121 | US |