The present disclosure generally relates to training neural networks and introduces new techniques for training and deploying neural networks or other trained models in ways which protect the training data from various sources from being discoverable and which involve a modified loss function used for further privacy. Another aspect of this disclosure involves a blind-learning approach to generating, by a model-averaging component, an average client-side model from a group of encrypted client-side models in which the averaging component cannot view or access the data of any of the respective client-side models as it performs its averaging operation.
There are existing approaches to training neural networks and the use of a federated training approach or a centralized training approach. Each of the existing approaches to training neural networks based on data from different clients involves data from respective clients that can leak or become discoverable. “Split learning” is a distributed deep learning technique for distributed entities (individual devices/organizations) to collaboratively train a deep learning model without sharing their sensitive raw data.
There are several variants of split learning for different settings/topologies of collaboration such as that of vertical partitioned distributed learning, learning without sharing labels, multi-hop split learning like TOR (named after Tor Syverson), learning with client weight synchronization and so forth. See Split learning for health: Distributed deep learning without sharing raw patient data, Vepakomma et al., 32nd Conference on Neural Information Processing Systems, (NIPS 2018), Montreal, Canada. This document is incorporated herein by reference for background material. The TOR multi-hop split learning involves multiple clients training partial networks in sequence where each client trains up to a cut layer and transmits its outputs to the next client. The final client then sends its activations from its cut layer to a server to complete the training. There are improvements to these training models however than can further improve privacy of data and further prevent leaking.
In order to describe the manner in which the above-recited and other advantages and features of the disclosure can be obtained, a more particular description of the principles briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only exemplary embodiments of the disclosure and are not therefore to be considered to be limiting of its scope, the principles herein are described and explained with additional specificity and detail through the use of the accompanying drawings in which:
Certain aspects and examples of this disclosure are provided below. Some of these aspects and examples may be applied independently and some of them may be applied in combination as would be apparent to those of skill in the art. In the following description, for the purposes of explanation, specific details are set forth in order to provide a thorough understanding of examples of the application. However, it will be apparent that various examples may be practiced without these specific details. The figures and description are not intended to be restrictive.
The ensuing description provides examples only, and is not intended to limit the scope, applicability, or configuration of the disclosure. Rather, the ensuing description of the examples will provide those skilled in the art with an enabling description for implementing the concepts. It should be understood that various changes may be made in the function and arrangement of elements without departing from the spirit and scope of the application as set forth in the appended claims. It is also noted that any feature of an example can be combined or mixed with any other feature of any other example.
One particular variant disclosed herein requires much less synchronization and is more resource efficient when training deep learning neural networks. This technique can be called federated-split learning or blind learning and is described in the patent applications incorporated herein by reference above. Described herein is a training process in the context of federated-split learning. The basic idea in any form of split learning is to split the total deep learning architecture that needs to be trained at one or more layers such that a respective client or node has only access to its share of layers before what are called split layer(s). The split layer to some degree defines the last layer of a respective client or node with the remaining layers of the architecture being configured on a different device, such as a server or generally on another node. The server only has access to the rest of the layers of the network after the split layer. The server's split layers are generally of a single copy, while the clients can have replicated copies (or can be different architectures) of their own layers before the split layer. Therefore the server layers are a shared resource up to an extent.
The approach disclosed below involves calculating an average loss value. The new approach differs from the prior systems which simply compute a loss gradient at a final layer of the server system and back propagates the loss function to refresh weights. In other words, there is no storing of loss functions in a queue and no averaging, at the server system, the plurality of respective weighted client loss functions to yield an average loss value. The disclosed solution addresses a problem rooted in how deep neural networks operate with respect to loss function propagation and proposes a solution that improves the functioning and operation of a neural network in a federated split-learning context.
An example method can include training, at a client system of a plurality of client systems, a part of a deep learning network up to a split layer of the client system. Based on an output of the split layer of the client system, the method can include completing, at a server system, training of the deep learning network by asynchronously forward propagating the output received at a split layer of the server system to a last layer of the server system. The server can calculate a weighted loss function for the client system at the last layer of the server system to yield a calculated loss function for the client system and store the calculated loss function for the client system in a queue.
The method can further include, after each respective client system of the plurality of client systems has a respective loss function stored in the queue to yield a plurality of respective weighted client loss functions, averaging, at the server system, the plurality of respective weighted client loss functions to yield an average loss value. The server back propagates gradients based on the average loss value from the last layer of the server system to the split layer of the server system to yield server system split layer gradients. The server then can transmit just the server system split layer gradients to the client system(s). In one aspect, no weights are shared across different client systems of the plurality of client systems. This is possible because of the averaging that is done at the server side across the plurality of respective weighted client loss functions.
This summary is not intended to identify key or essential features of the claimed subject matter, nor is it intended to be used in isolation to determine the scope of the claimed subject matter. The subject matter should be understood by reference to appropriate portions of the entire specification of this patent, any or all drawings, and each claim.
The foregoing, together with other features and embodiments, will become more apparent upon referring to the following specification, claims, and accompanying drawings.
Disclosed herein is a new system, a platform, compute environment, cloud environment, marketplace, or any other characterization of the system that will enable an improved approach to training neural networks. In one aspect, the approach is called a federated-split leaning approach that combines features from known approaches but that provides a training process that maintains privacy for data used to train the model from various client devices.
DNNs can model complex non-linear relationships. DNN architectures generate compositional models where the object is expressed as a layered composition of primitives. The extra layers enable composition of features from lower layers, potentially modeling complex data with fewer units than a similarly performing shallow network.
DNNs are typically feedforward networks in which data flows from the input layer to the output layer without looping back. At first, the DNN creates a map of virtual neurons and assigns random numerical values, or “weights”, to connections between them. The weights and inputs are multiplied and return an output between 0 and 1. If the network did not accurately recognize a particular pattern, an algorithm would adjust the weights. That way the algorithm can make certain parameters more influential, until it determines the correct mathematical manipulation to fully process the data. Recurrent neural networks (RNNs), in which data can flow in any direction, are used for applications such as language modeling. Long short-term memory is particularly effective for this use. Convolutional deep neural networks (CNNs) are used in computer vision. CNNs also have been applied to acoustic modeling for automatic speech recognition (ASR). The principles disclosed herein with respect to a modification of the loss function in the context of federated-split learning does not have to apply to a specific type of neural network or type of classification task such as image recognition.
In split federated learning, a deep learning model is split across at least two processors, which can be physically separate or can be two virtual machines in the cloud. One processor can be, for example, client 1 and/or client 2 as shown in
An example will make the point of how the DNNs operate. The examiner till use client 1 as the data provider and the server system 104 as the algorithm provider. Typically, in DNNs, the client 1 will initialize weights for its input data 106 and use forward propagation of the data across multiple layers 108 to a split layer 110 on the client. Client 1 then sends the split layer 110 output to the split layer 120 of the server 104. The server 104 propagates its data from the split layer 120 through its layers 122, 124 to the last layer 126 and compute a loss gradient or loss function that is backpropagated through its layers 124, 122 to the split layer 120 and then transmitted to the split layer 110 of the client 1. This disclosure focuses on new approaches with respect to the use of the loss function as well as new concepts regarding how to provide further privacy for the models by generating a weighted average of various client-side models and distributing the new weighted average of the client-side model to each of a plurality of clients.
The first concept disclosed herein related to how to improve the use of the loss function is described first. Disclosed herein is a “loss function” that is used to communicate from “n” data providers 102 to the algorithm server 104. The loss function provides a mechanism that can inject “noise” into the loss function—which adds another layer of “data privacy” for the underlying data. The noise added to the loss function can yield or generate a new loss function. In one aspect, the injection of noise can occur through the averaging step disclosed herein or other approaches to adding noise to the loss values which can be considered an approach to encryption.
An example training process 100 in federated-split learning is disclosed herein. The basic idea in any form of split learning is to split the total deep learning architecture that needs to be trained at one or more layers such that any client 102 (such as Client 1 and Client 2 in
An example training process in federated-split learning is as follows. In the arrangement shown in
Once client 1 and client 2 fill up the queue 128 at the server 104 with their outputs, the server 104 then averages the loss function to obtain a single real-value for the loss. The process can be described is providing a modified loss function. The server 104 then back-propagates its layers 122, 124 up to the server's split layer 120 and then transmits the gradients just from this layer 120 to client 1 and client 2 based on this averaged loss. Each of client 1 and client 2 now performs backpropagation on its own respective layers 110, 108, 106, 116, 114, 112 based on the gradients received from the server 104. The advantage of this approach is that it is relatively more asynchronous than vanilla split learning (see the paper incorporated by reference above). It is also way more communication efficient as there is no peer-to-peer weight sharing across the clients 118.
In machine learning, backpropagation refers to an algorithm in training feedforward neural networks for supervised learning. Generalizations of backpropagation exist for other artificial neural networks (ANNs), and for functions generally—a class of algorithms referred to generically as “backpropagation”. In fitting a neural network, backpropagation computes the gradient of the loss function with respect to the weights of the network for a single input-output example, and does so efficiently, unlike a naive direct computation of the gradient with respect to each weight individually. This efficiency makes it feasible to use gradient methods for training multilayer networks, updating weights to minimize loss. Gradient descent, or variants such as stochastic gradient descent, can be used as well. The backpropagation algorithm works by computing the gradient of the loss function with respect to each weight by the chain rule, computing the gradient one layer at a time, iterating backward from the last layer to avoid redundant calculations of intermediate terms in the chain rule. The term backpropagation in one aspect refers only to the algorithm for computing the gradient, not how the gradient is used. Backpropagation generalizes the gradient computation in the delta rule, which is the single-layer version of backpropagation, and is in turn generalized by automatic differentiation, where backpropagation is a special case of reverse accumulation (or “reverse mode”).
The modified loss function benefits are described next. The proposed modification to the loss function used for federated-split learning can be implemented to achieve a better level of privacy. The loss function that is computed at the server 104 can be modified as the average of losses induced by each of client 1 and client 2, where each of client 1 and client 2 has a loss that is a weighted combination of minimizing a statistical distance between i) the distributions of the activations communicated by any client 102 to the server 104 from just the split layer 110, 116 and ii) the classification loss such as categorical cross-entropy or cross-entropy. In the prior published work on this concept, there was only one weighted loss function for vanilla training of split learning that requires peer-to-peer weight sharing and synchronization between clients. In the disclosed improvement, the loss function is an average of weighted loss functions. This can remove the requirements for weight sharing 118 or synchronization while increasing privacy.
In one example, the process described above relative to
In this example, the process includes processing of the client-side models via either averaging or secure multi-party computation (SMPC) 174 of client-side models such that a new model is generated and transmitted back to the clients 102 prior to transmitting new smashed data to the split layer 120 of the server 104. Here, the server-side model 172 will receive smashed data processed by an average new client-side model generated from a secure multi-party computation (SMPC) component 174 operating on a set of client-side models to generate and distribute a new client-side model to each client 102 which can be a single model which is the average, for example, of two or more client models received from respective split layers (e.g., 110, 116, 117) from respective clients 102. The server-side model 172 can in one case be essentially the same server-side model 142 shown in
The secure multi-party computation component 174 is part of all computational parties (server and clients) that do not trust each other. They jointly compute the average client-side model without ‘seeing’ each others' data by exchanging several encrypted messages about their models, which on their own represent rubbish data that cannot be decrypted into anything useful. When the entire protocol (process) completes, it can then reveal the final averaged client-side model. The forward propagation 154 and backward propagation 156 can proceed in the standard way with or without the need to average the loss functions 152 in that the various models are already averaged 174 prior to being received at the split layer 120 of the server 104. The averaging type can be a weighted average or any type of averaging approach. This averaging method can be done either in plain text or an encrypted space (SMPC) as shown in
In the SMPC approach, the system does not use plain text in that the server 104 is not trusted. In the SMPC approach, each model is encrypted and sent to the server 104 (or other entity) as an encrypted model and the processing or averaging of the encrypted models is done in an encrypted way to maintain privacy. The entire model in one aspect is not sent to each server. Some “rubbish data” is included and the server 104 has only a part of the model. The server cannot decrypt, they cannot steal or see what is inside of the data in this approach. It is impossible in this sense for the server 104 to see into any of the data of the “model” transmitted to the averaging component 174. This process is more secure in that it prevents the averaging component 174 from being able to see the data of the models.
In one example, assume that a first client has a model with value 3, a second client has a model with a value 4, and a third client has a model with value 5. These models can be averaged as shown in
In one example, the weighted averaging method performed at component 174 can use the following formula:
Where W is the final aggregated client-side model, n is the number of clients, Xi is the respective clienti model, and wi is the number of data samples at the respective clienti. The denominator can represent the total number of training samples from all the clients combined or some other value as well. Typically the data (vector, model, etc.) from each client may have the same number of parameters but in some cases the number of parameters might differ across different clients.
In one example, all clients 102 start the training process by submitting the total number of training samples they have locally, which will be used to train the final model. This version of the protocol is explained in the following algorithm.
The algorithm shown above will be further described with respect to
The server 104 processes the smashed data through its layers as well. The data from the various clients 180 is provided to the loss averaging component 152 that averages the loss as described herein (lines 15-16 of the pseudocode) and returns the gradients 182 (lines 17-18 of the pseudo code) through the server's layers for backward propagation 156 as shown in
At this stage, once an epoch has been completed and the various client models are updated based on the received gradients, the clients each send their (updated) client model M1, M2 and/or the total number of samples to the processing component 174 that can average the models or generated a weighted average model and/or perform SMPC on the various models and return the updated model such as updated model M3 196 to client 1 and updated model M4 198 to client 2. Typically, M3 and M4 will be the same updated average model but in some cases they could have some differences based on one or more parameters. Line 19 of the pseudocode indicates the operation of sending the weighted average of the client models to the various clients. This averaging method can be done either in plain text or an encrypted space (secure MPC).
The method can further include, after each respective client system of the plurality of client systems 102 has a respective loss function stored in the queue 128 to yield a plurality of respective weighted client loss functions, averaging, at the server system 104, the plurality of respective weighted client loss functions to yield an average loss value (210), back propagating gradients based on the average loss value from the last layer 126 of the server system 104 to the split layer 120 of the server system 104 to yield server system split layer gradients (212) and transmitting just the server system split layer gradients to the plurality of client systems 102 (to client 1 and client 2), wherein no weights are shared 118 across different client systems of the plurality of client systems 102 (214).
The weighted loss function can further involve a minimizing of a statistical distance between (1) a distribution of activations communicated by the client system 102 to the server system 104 from just the split layer 110, 116 of the client system 102 and (2) a classification loss. In one aspect, the classification loss can include a categorical cross-entropy or a cross-entropy. Cross-entropy loss, or log loss, measures the performance of a classification model whose output is a probability value between 0 and 1. Cross-entropy loss increases as the predicted probability diverges from the actual label. Cross-entropy can be calculated using the probabilities of the events from P and Q, as follows: H(P, Q)=−sum x in X P(x)*log(Q(x)).
There are different names and variations of cross-entropy loss. There are functions that apply transformations to vectors coming out from convolutional neural networks (CNNs(s)) before the loss computation. A sigmoid function forces a vector into a range from 0 to 1 and is applied independently to each element of (s), si. A Softmax function forces a vector into the range of 0 and 1 and all the resulting elements add up to 1. It is applied to the output scores (s) and cannot be applied independently to each since it depends on all the elements of (s). For a given class si, the Softmax function can be computed as:
Where sj are the scores inferred by the net for each loss in C. Note that the Softmax activation for a call si depends on all the scores in s.
The categorical cross-entropy loss is also called Softmax Loss. It is a Softmax activation plus a cross-entropy loss. This approach can be used to train a CNN to output a probability over the C classes for each item and can be used for multi-class classification.
In one aspect, storing the calculated loss function for the client system (client 1 and client 2) in the queue 128 further can include storing a respective calculated loss function for each respective client system of the plurality of client systems 102. In another aspect, storing a respective calculated loss function for each respective client system of the plurality of client systems 102 can be performed asynchronously on a first-come-first-stored manner.
In yet another aspect, transmitting just the server system split layer gradients to the client system 102 further can include transmitting just the server system split layer gradients to each client system (client 1 and client 2) of the plurality of client systems 102.
Another step of the method disclosed above can include back propagating, at the client system 102 and from the split layer 110, 116 of the client system 102 to an input layer 106, 112 of the client system 102, the server system split layer gradients to complete a training epoch of the deep learning network. An epoch is where an entire dataset is passed forward and backward through a neural network once.
Another aspect of this disclosure relates to a scheduler. The choice of every client's individual weights can be data and task dependent. In order to restrict privacy leakage during tuning or after the first epoch's forward propagation step when a back propagation step has not been performed yet, a scheduler is proposed to prevent leakage of privacy. The scheduler can be a software module operating on one or both of a client 102 and/or a server 104 or may be configured as a separate device. The scheduler ensures the weight for the privacy during the early epochs is very high and it reduces gradually up to a specified point, as the epochs go by, and then stagnates and makes sure it doesn't fall below a specific value, to ensure the privacy weight is not too low to induce leakage.
A simulated reconstruction attack can be performed on the client system 102 before releasing any activations to the server 104 at the split layer 110, 116 of the client system 102. In order to squeeze out more accuracy, the accuracy weight can gradually be increased and tuned by the server 104, followed by the simulation of the reconstruction attack, prior to transmitting the activations from the split layer 110, 116 to the server 104. The following is some example code which can be deployed by a scheduler:
def decay Scheduler(epoch, lr, maxLR, totalEpochs):
A variation of
After each respective client system of the plurality of client systems has a respective loss function stored in the queue to yield a plurality of respective weighted client loss functions, the server 104 can perform the operations of averaging, at the server system, the plurality of respective weighted client loss functions to yield an average loss value, back propagating gradients based on the average loss value from the last layer of the server system to the split layer of the server system to yield server system split layer gradients and transmitting, from the server system, the server system split layer gradients to the plurality of client systems, wherein no weights are shared across different client systems of the plurality of client systems.
In another variation, the method can be performed from the standpoint of a client 102 in which the smashed data 158 is transmitted to the split layer 120 of the server 104. The server 104 performs the operations described herein to generate the gradients that include the averaged loss function 152. Each respective client receives the gradients 160 and updates its respective model 144B based on the received gradients 160. The processing can occur such that each batch of data input to the respective client-side model 144B is processed for all the clients 102 both for both forward and backward propagation through the neural network to achieve an “epoch”, at which point the other processing can occur which is described below to perform a blind learning process of receiving the various updated client-side models 144B at a secure multi-party calculation (SMPC) component 174 to generate in a secure manner an average of the client-side models. The SMPC component 174 can then redistribute the weighted average of the client-side models 196, 198 to each respective client 102.
More than two client models can be received and averaged and there can be various algorithms for generating the average. The use of weighted average approach can help to maintain the privacy and security of the data from the various clients 102 or data providers. As noted above, the method can include transmitting a modified version of each client-side model such that the modified model to be processed or averaged includes some rubbish data, a portion of the full data of the client-side model, and can be encrypted. The portion of the data of each client-side model, for example, can represent less than all of the available data of each client-side model. Which portion is transmitted to the averaging component 174 and which portion is not can be determined based on a percentage, which part of the model data should be kept back, or based on some other parameter(s) to determine how to select the portion of the client-side data in the client-side model to use for the averaging process. The process above involves how to train a new model on decentralized data in a privacy-learning way in a blind-learning approach. In blind-learning approach, the averaging component 174 does not see or cannot view the various client-side models 144B that it receives because they are sent to the averaging component 174 in such a way so as to preserver privacy.
As noted above, the client-side models can be processed such that they are one or more of encrypted, inclusive of some rubbish data, a portion of each respective client-side model or a combination of these and other ways in which the respective client-side models can be modified such that as they are processed by the averaging component 174, the respective data of each model is kept private and unsearchable. This is because typically the averaging component 174 is part of the server 104 and not trusted or generally is not trusted and needs to perform its processing without being able to probe into the data associated with the respective client-side model.
Receiving a first model from a first client and a second model from a second client can occur after an epoch in which all batches of data for the first client and the second client are processed by respectively by each of the first client, the second client, and a server-side model 142 to generate gradients received at the first client and the second client to update their respective models to yield the first model and the second model, which are then averaged by the averaging component 174.
The process can also in one example be performed from the clients 102. In this case, the clients 102 transmit their respective smashed data to the server 104 and receive gradients back from the server 104. The clients 102 then update their respective models based on the gradients received from the server 104. This can conclude one epoch. The gradients may or may not include the averaged loss function described above. The clients 102 then each send their updated client-side models to an averaging component 174 which may or may not be part of the server 104. The client-side models might be encrypted or modified such that not all of the model data is transmitted. In another aspect, the client-side models can include some rubbish data as well. The averaging component 174 generates in a secure way a weighted average client-side model and each client of the clients 102 receives the weighted average client-side model from the averaging component 174.
The architecture 300 makes it possible and convenient for two or more parties (318, 314) To participate in a variety of collaborative activities involving data at an algorithm and processes. Part of the novelty of the system is the orchestration technique which allows this to occur between the different parties (318, 314).
The components shown in
The parties 318, 314 can represent any individual or organization or the computer or server associated with that party. An asset as defined as a digital file or collection of the digital files that belong to a single party 314, 318. Shown in
An “agreement” is a codification of rules which can be used to determine whether a usage of assets should be granted permission. As noted above, the router 312, per item 2 in
The operation of the system is as follows. Each party 318, 314 can independently register the existence of assets which are stored behind their access point 302, 304. The registration creates an entry in the router 312 and creates a unique asset identifier (ID) from which the owner and location of the asset can be determined. Any node can be used for storing or registering the assets. The router or other node 312 can provide both graphical and programmatic mechanisms for finding and obtaining information about the registered assets. The unique identifier for each asset is thus available. However, the exact content of the asset remains hidden behind respective access point 302, 304. The asset owners 318, 314 can provide or expose metadata information about the respective assets such as a name, a textual description, various types of summaries such as an exploratory data analysis and/or a pseudo sample of the asset. Next, with its data in place, the system initiates the operation of secure multi-party computation. One party will identify the assets involved in the operation. Typically, this will be a data asset 320 from the data owner 318 and an algorithm asset 316 from the service provider 314. However, this could also be two models 316 that are to be averaged or processed in some way together. The specifics of the proposed operation are bundled and submitted to the router 312. However, in the context of model averaging and using SMPC for model averaging as shown in
A validation of operation occurs next. The router 312 can verify the existence of the assets, and then will confirm that permission exists to use them per step 2 of
Until permission is granted for all assets involved in the operation, the operation will not begin execution. After the operation is validated, the router 312 contacts the initiating party's access point 302, 304 to notify it that the operation can begin. That access point 302, 304 will reach out to the other party's access point 302, 304 to create a temporary connection for the operation. The other access point 302, 304 will verify the identity of the initiator of the operation and the specific operation with the router 312 before accepting the connection.
Next, the operation is executed. The computation can now begin between the access points 302, 304 of the parties 314, 318. During an SMPC operation, portions of the one-way encrypted version of both the data and the algorithm are exchanged. Then the computation proceeds jointly, with each of the access points 302, 304 providing some of the computational resources and exchanging intermediate one-way encrypted state data as the algorithm progresses. Once the algorithm completes, the result emerges un-encrypted and is stored as a new asset behind the initiating party's access points 302, 304.
Note that the discussion above suggests that the assets involved in the operation must only be in one case data and another case an algorithm. This disclosure is broader than that. In one case, both of the assets might be an algorithm or a model 316. In this case, with reference to
In one aspect, the new asset emerges un-encrypted and this stored as a new asset behind the initiating party's access point 302, 304. In the context of model averaging, the new asset represents an average of the models 316 provided to the node or to the operation from different entities such as different clients 102. In this case, the new asset or new version of the model is distributed to each respective client that provided an initial model for the model averaging operation. Note that the example above involves the use of two different assets or models in this case but the model averaging could also occur with more than two entities providing assets (models, algorithms or data).
This disclosure explicitly notes that the method can include any combination of the steps outlined above. The steps can also be performed in any order. The patent application 63/226,135, filed on Jul. 27, 2021, incorporated herein by reference, provides further details regarding the SMPC process. Note as well that in that document, there are examples which suggest that the process only occurs for data as one asset and an algorithm as the other asset. The assets could also both be models such as the client side models 144A that are transferred to the client computers as models 144B shown in
The SMPC process can also be used to enable n parties (clients 102) to securely average their models 192, 194 with the server 104 without peer-to-peer socket communication. Specifically, the system or clients 102 can encrypt each model using a Diffie-Hellman key. The server 104 or averaging component 174 acts as the communication channel for the key exchange using Diffie Hellman. It is proven that the Diffie Hellman is secure in case of the corrupted communication channel; so clearly, the server 104 does not learn the actual key.
Those of skill in the art will understand the Diffie-Hellman key exchange. This key exchange establishes a shared secret between two parties that can be used for secret communication for exchanging data over a public network. An analogy illustrates the concept of public key exchange by using colors instead of very large numbers:
The process begins by having the two parties, Alice and Bob, publicly agree on an arbitrary starting color that does not need to be kept secret. In this example, the color is yellow. Each person also selects a secret color that they keep to themselves—in this case, red and blue-green. An important part of the process is that Alice and Bob each mix their own secret color together with their mutually shared color, resulting in orange-tan and light-blue mixtures respectively, and then publicly exchange the two mixed colors. Finally, each of them mixes the color they received from the partner with their own private color. The result is a final color mixture (yellow-brown in this case) that is identical to the partner's final color mixture.
If a third party listened to the exchange, it would only know the common color (yellow) and the first mixed colors (orange-tan and light-blue), but it would be difficult for this party to determine the final secret color (yellow-brown). Bringing the analogy back to a real-life exchange using large numbers rather than colors, this determination is computationally expensive. It is impossible to compute in a practical amount of time even for modern supercomputers. This is a simple example of the Diffie-Hellman key exchange. Other key exchanges could be used of course as well in this process and this disclosure is not limited to the Diffie-Hellman key exchange.
Next, the disclosure explains the approach for how n clients 102 and one server 104 can securely average a set of models d. The approach is shown as
The example computer system 500 includes a processor 505, a memory 510, a graphical device 515, a network device 520, interface 525, and a storage device 530 that are connected to operate via a bus 535. The processor 505 reads causes machine instructions (e.g., reduced instruction set (RISC), complex instruction set (CISC), etc.) that are loaded into the memory 510 via a bootstrapping process and executes an operating system (OS) for executing application within frameworks provided by the OS. For example, the processor 505 may execute an application that executes an application provided by a graphical framework such as Winforms, Windows Presentation Foundation (WPF), Windows User Interface (WinUI), or a cross platform user interface such as Xamarin or QT. In other examples, the processor 505 may execute an application that is written for a sandbox environment such as a web browser.
The processor 505 controls the memory 510 to store instructions, user data, operating system content, and other content that cannot be stored within the processor 505 internally (e.g., within the various caches). The processor 505 may also control a graphical device 515 (e.g., a graphical processor) that outputs graphical content to a display 540. In some example, the graphical device 515 may be integral within the processor 505. In yet another example, the display 540 may be integral with the computer system 500 (e.g., a laptop, a tablet, a phone, etc.). The memory can be a non-transitory memory in that it is not the air interface that can “store” electromagnetic signals but would be a man-made storage device such as random access memory (RAM), read-only memory (ROM), a hard drive, or some other hardware, physical memory component. Such a memory or combination of different memory components can store computer instructions which cause the processor to perform various operations as described herein.
The graphical device 515 may be optimized to perform floating point operations such as graphical computations, and may be configured to execute other operations in place of the processor 505. For example, controlled by instructions to perform mathematical operations optimized for floating point math. For example, the processor 505 may allocate instructions to the graphical device 515 for operations that are optimized for the graphical device 515. For instance, the graphical device 515 may execute operations related to artificial intelligence (AI), natural language processing (NLP), vector math. The results may be returned to the processor 505. In another example, the application executing in the processor 505 may provide instructions to cause the processor 505 to request the graphical device 515 to perform the operations. In other examples, the graphical device 515 may return the processing results to another computer system (i.e, distributed computing).
The processor 505 may also control a network device 520 for transmits and receives data using a plurality of wireless channels 545 and at least one communication standard (e.g., Wi-Fi (i.e., 802.11ax, 802.11e, etc.), Bluetooth®, various standards provided by the 3rd Generation Partnership Project (e.g., 3G, 4G, 5G), or a satellite communication network (e.g., Starlink). The network device 520 may wirelessly connect to a network 550 to connect to servers 555 or other service providers. The network device 520 may also be connected to the network 550 via a physical (i.e., circuit) connection. The network device 520 may also directly connect to local electronic device 560 using a point-to-point (P2P) or a short range radio connection.
The processor 505 may also control an interface 525 that connects with an external device 570 for bidirectional or unidirectional communication. The interface 525 is any suitable interface that forms a circuit connection and can be implemented by any suitable interface (e.g., universal serial bus (USB), Thunderbolt, and so forth). The external device 565 is able to receive data from the interface 525 to process the data or perform functions for different applications executing in the processor 505. For example, the external device 565 may be another display device, a musical instrument, a computer interface device (e.g., a keyboard, a mouse, etc.), an audio device (e.g., an analog-to-digital converter (ADC), a digital-to-analog converter (DAC)), a storage device for storing content, an authentication device, an external network interface (e.g., a 5G hotspot), a printer, and so forth.
It is noted that in one aspect, the steps disclosed herein can be practiced by a “system.” The system can include the server and one or more clients together, or might just be functionality performed by the server. The system could also be a client or a group of clients, such as clients in a particular geographic area or clients groups in some manner that are performing the client-based functions disclosed herein. Claims can be included which outline the steps that occur from the standpoint of any device disclosed herein. For example, the steps of transmission, calculation, and receiving of data can be claimed from the standpoint of a server device, a client device, or group of client devices depending on which embodiment is being covered. All such communication from the standpoint of an individual component or device can be included as within the scope of a particular embodiment focusing on that device.
In another aspect, the system can include a platform as disclosed in the patent applications incorporated by reference also performing steps in coordination with the concept disclosed above. Therefore, the platform as used to provide the federated-split learning process described herein is also an embodiment of this disclosure and steps can be recited in connection with the use of that platform for training models in a manner that maintains privacy of the data as described herein.
Although a variety of examples and other information was used to explain aspects within the scope of the appended claims, no limitation of the claims should be implied based on particular features or arrangements in such examples, as one of ordinary skill would be able to use these examples to derive a wide variety of implementations. Further and although some subject matter may have been described in language specific to examples of structural features and/or method steps, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to these described features or acts. For example, such functionality can be distributed differently or performed in components other than those identified herein. Rather, the described features and steps are disclosed as examples of components of systems and methods within the scope of the appended claims.
Claim language reciting “at least one of” a set indicates that one member of the set or multiple members of the set satisfy the claim. For example, claim language reciting “at least one of A and B” means A, B, or A and B.
Statement 1. A method comprising:
Statement 2. The method of Statement 1, wherein the weighted loss function comprises a minimizing of a statistical distance between (1) a distribution of activations communicated by the client system to the server system from just the split layer of the client system and (2) a classification loss.
Statement 3. The method of any preceding Statement, wherein the classification loss comprises a categorical cross-entropy or a cross-entropy.
Statement 4. The method of any preceding Statement, wherein storing the calculated loss function for the client system in the queue further comprises storing respective calculated loss function for each respective client system of the plurality of client systems.
Statement 5. The method of any preceding Statement, wherein storing respective calculated loss function for each respective client system of the plurality of client systems is performed asynchronously on a first-come-first-stored manner.
Statement 6. The method of any preceding Statement, wherein transmitting just the server system split layer gradients to the plurality of client systems further comprises transmitting just the server system split layer gradients to each client system of the plurality of client systems.
Statement 7. The method of any preceding Statement, further comprising:
Statement 8. A system comprising:
Statement 9. The system of Statement 8, wherein the weighted loss function comprises a minimizing of a statistical distance between (1) a distribution of activations communicated by the client system to the server system from just the split layer of the client system and (2) a classification loss.
Statement 10. The system of any preceding Statement, wherein the classification loss comprises a categorical cross-entropy or a cross-entropy.
Statement 11. The system of claim 8, wherein storing the calculated loss function for the client system in the queue further comprises storing respective calculated loss function for each respective client system of the plurality of client systems.
Statement 12. The system of any preceding Statement, wherein storing respective calculated loss function for each respective client system of the plurality of client systems is performed asynchronously on a first-come-first-stored manner.
Statement 13. The system of any preceding Statement, wherein transmitting just the server system split layer gradients to the client system further comprises transmitting just the server system split layer gradients to each client system of the plurality of client systems.
Statement 14. The system of any preceding Statement, further comprising:
Statement 15. A non-transitory computer readable medium comprising instructions, the instructions, when executed by a computing system, cause the computing system to:
Statement 16. The computer readable medium of Statement 15, wherein the weighted loss function comprises a minimizing of a statistical distance between (1) a distribution of activations communicated by the client system to the server system from just the split layer of the client system and (2) a classification loss.
Statement 17. The computer readable medium of any preceding Statement, wherein the classification loss comprises a categorical cross-entropy or a cross-entropy.
Statement 18. The computer readable medium of any preceding Statement, wherein storing the calculated loss function for the client system in the queue further comprises storing respective calculated loss function for each respective client system of the plurality of client systems.
Statement 19. The computer readable medium of any preceding Statement, wherein storing respective calculated loss function for each respective client system of the plurality of client systems is performed asynchronously on a first-come-first-stored manner.
Statement 20. The computer readable medium of any preceding Statement, wherein transmitting just the server system split layer gradients to the client system further comprises transmitting just the server system split layer gradients to each client system of the plurality of client systems.
Statement 21. A method comprising:
Statement 22. The method of any preceding Statement, further comprising:
Statement 23. The method of any preceding Statement, wherein the first model from the first client and the second model from the second client each are encrypted and have at least a portion of its data being rubbish data.
Statement 23. The method of any preceding Statement, wherein the first model from the first client and the second model from the second client each represent a respective portion of all the available data associated with the first model from the first client and the second model.
Statement 24. The method of any preceding Statement, wherein receiving a first model from a first client and a second model from a second client occurs after an epoch in which all batches of data for the first client and the second client are processed by respectively by each of the first client, the second client, and a server-side model to generate gradients received at the first client and the second client to update their respective models to yield the first model and the second model.
Statement 21. A system comprising:
Statement 22. The system of any preceding Statement, further comprising:
Statement 23. The system of any preceding Statement, wherein the first model from the first client and the second model from the second client each are encrypted and have at least a portion of its data being rubbish data.
Statement 23. The system of any preceding Statement, wherein the first model from the first client and the second model from the second client each represent a respective portion of all the available data associated with the first model from the first client and the second model.
Statement 24. The system of any preceding Statement, wherein receiving a first model from a first client and a second model from a second client occurs after an epoch in which all batches of data for the first client and the second client are processed by respectively by each of the first client, the second client, and a server-side model to generate gradients received at the first client and the second client to update their respective models to yield the first model and the second model.
Statement 25. A method comprising:
Statement 26. The method of Statement 25, wherein the updated client-side model is encrypted or modified such that not all of the updated client-side model data is sent to the averaging component.
Statement 27. The method of any preceding Statement, wherein the updated client-side model includes some rubbish data and/or does not include all of the available data of the updated client-side model.
Statement 27. The method of any preceding Statement, wherein the weighted average client-side model is generated from at least one other updated client-side model from a different client.
Statement 28. The method of any preceding Statement, wherein the gradients generated by the server include an averaged loss function from loss values of a plurality of clients.
Statement 28. A system comprising:
sending the updated client-side model to an averaging component which generates in a weighted average client-side model; and
Statement 29. The system of Statement 28, wherein the updated client-side model is encrypted or modified such that not all of the updated client-side model data is sent to the averaging component.
Statement 30. The method of any preceding Statement, wherein the updated client-side model includes some rubbish data and/or does not include all of the available data of the updated client-side model.
Statement 31. The method of any preceding Statement, wherein the weighted average client-side model is generated from at least one other updated client-side model from a different client.
Statement 32. The method of any preceding Statement, wherein the gradients generated by the server include an averaged loss function from loss values of a plurality of clients.
Statement 33. A method comprising:
Statement 35. The method of Statement 35, wherein the weighted loss function comprises a minimizing of a statistical distance between (1) a distribution of activations communicated by the client system to the server system from just the split layer of the client system and (2) a classification loss.
Statement 36. The method of any preceding Statement, wherein the classification loss comprises a categorical cross-entropy or a cross-entropy.
Statement 37. The method of any preceding Statement, wherein storing the calculated loss function for the client system in the queue further comprises storing respective calculated loss function for each respective client system of the plurality of client systems.
Statement 38. The method of any preceding Statement, wherein storing respective calculated loss function for each respective client system of the plurality of client systems is performed asynchronously on a first-come-first-stored manner.
Statement 39. The method of any preceding Statement, wherein transmitting just the server system split layer gradients to the plurality of client systems further comprises transmitting just the server system split layer gradients to each client system of the plurality of client systems.
Statement 40. The method of any preceding Statement, further comprising:
Statement 41. A method comprising:
Statement 42. The method of Statement 41, wherein the weighted loss function comprises a minimizing of a statistical distance between (1) a distribution of activations communicated by the client system to the server system from just the split layer of the client system and (2) a classification loss.
Statement 43. The method of any preceding Statement, wherein the classification loss comprises a categorical cross-entropy or a cross-entropy.
Statement 44. The method of any preceding Statement, wherein storing the calculated loss function for the client system in the queue further comprises storing respective calculated loss function for each respective client system of the plurality of client systems.
Statement 45. The method of any preceding Statement, wherein storing respective calculated loss function for each respective client system of the plurality of client systems is performed asynchronously on a first-come-first-stored manner.
Statement 46. The method of any preceding Statement, wherein transmitting just the server system split layer gradients to the plurality of client systems further comprises transmitting just the server system split layer gradients to each client system of the plurality of client systems.
Statement 47. The method of any preceding Statement, further comprising:
Statement 48. A method comprising:
Statement 49. A system performing any of the methods of any preceding Statement.
The present application is a continuation of U.S. patent application Ser. No. 17/499,153, filed Oct. 12, 2021, which is a non-provisional patent application of U.S. Provisional Application No. 63/090,904, filed on Oct. 13, 2020, which is incorporated herein by reference. The present application is a continuation of U.S. patent application Ser. No. 17/499,153, filed Oct. 12, 2021, which is a continuation-in-part of U.S. patent application Ser. No. 16/828,085, filed Mar. 24, 2020, which claims the benefit of U.S. Provisional Application No. 62/948,105, filed Dec. 13, 2019, which is incorporated herein by reference. The present application is a continuation of U.S. patent application Ser. No. 17/499,153, filed Oct. 12, 2021, which is a continuation-in-part of U.S. patent application Ser. No. 16/828,216, filed Mar. 24, 2020, which claims the benefit of U.S. Provisional Application No. 62/948,105, filed Dec. 13, 2019, which is incorporated herein by reference. The present application is a continuation of U.S. patent application Ser. No. 17/499,153, filed Oct. 12, 2021, which is a continuation-in-part of U.S. patent application Ser. No. 17/176,530, filed Feb. 16, 2021, which is a continuation of U.S. patent application Ser. No. 16/828,354, filed Mar. 24, 2020, now U.S. Pat. No. 10,924,460, issued on Feb. 16, 2021, which claims the benefit of U.S. Provisional Application No. 62/948,105, filed Dec. 13, 2019, which is incorporated herein by reference. The present application is a continuation of U.S. patent application Ser. No. 17/499,153, filed Oct. 12, 2021, which is a continuation-in-part of U.S. patent application Ser. No. 16/828,420, filed Mar. 24, 2020, which claims the benefit of U.S. Provisional Application No. 62/948,105, filed Dec. 13, 2019, which is incorporated herein by reference. The present application is a continuation of U.S. patent application Ser. No. 17/499,153, filed Oct. 12, 2021, which is a non-provisional of U.S. Provisional Application No. 63/226,135, filed on Jul. 27, 2021, the contents of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
1045208 | Spencer | Nov 1912 | A |
5410696 | Seki et al. | Apr 1995 | A |
6353816 | Tsukimoto | Mar 2002 | B1 |
6668325 | Collberg | Dec 2003 | B1 |
9464043 | Roberge et al. | Oct 2016 | B2 |
9646043 | Aronvich | May 2017 | B1 |
10002029 | Bequet | Jun 2018 | B1 |
10311372 | Hotchkies | Jun 2019 | B1 |
10360220 | Gupta | Jul 2019 | B1 |
10362001 | Yan | Jul 2019 | B2 |
10419360 | Dawson | Sep 2019 | B2 |
10592012 | Dawson | Jan 2020 | B2 |
10560872 | Dawson | Feb 2020 | B2 |
10594623 | Dawson | Mar 2020 | B2 |
10623998 | Dawson | Apr 2020 | B2 |
10833871 | Ranellucci | Nov 2020 | B2 |
10902302 | Fu | Jan 2021 | B2 |
10924460 | Storm | Feb 2021 | B2 |
11195099 | Luo | Dec 2021 | B2 |
11316676 | Kinjo | Apr 2022 | B2 |
20030009482 | Benerjee | Jan 2003 | A1 |
20060233377 | Chang | Oct 2006 | A1 |
20070192864 | Bryant | Aug 2007 | A1 |
20080082636 | Hofmann | Apr 2008 | A1 |
20080201721 | Little | Aug 2008 | A1 |
20090063485 | Schneider | Mar 2009 | A1 |
20100100864 | Plants | Apr 2010 | A1 |
20100281254 | Carro | Nov 2010 | A1 |
20110161091 | Freishtat | Jun 2011 | A1 |
20120047097 | Sengupta et al. | Feb 2012 | A1 |
20130124491 | Pepper | May 2013 | A1 |
20130272377 | Karczewicz | Oct 2013 | A1 |
20140108813 | Pauker | Apr 2014 | A1 |
20140371902 | McClelland | Dec 2014 | A1 |
20150089243 | Veugen | Mar 2015 | A1 |
20150156204 | Resch | Jun 2015 | A1 |
20150242136 | Lin | Aug 2015 | A1 |
20150288662 | Bilogrevic | Oct 2015 | A1 |
20150371132 | Gemello | Dec 2015 | A1 |
20160103901 | Kadav | Apr 2016 | A1 |
20160156595 | Wu | Jun 2016 | A1 |
20160205095 | Morel | Jul 2016 | A1 |
20160294550 | French | Oct 2016 | A1 |
20160335440 | Clark | Nov 2016 | A1 |
20160342608 | Burshteyn | Nov 2016 | A1 |
20170026342 | Sidana | Jan 2017 | A1 |
20170116520 | Min | Apr 2017 | A1 |
20170149796 | Gvili | May 2017 | A1 |
20170228547 | Smith | Aug 2017 | A1 |
20170323196 | Gibson | Nov 2017 | A1 |
20170359321 | Rindal | Dec 2017 | A1 |
20170372201 | Gupta | Dec 2017 | A1 |
20180039884 | Dalton | Feb 2018 | A1 |
20180041477 | Shaposhnik | Feb 2018 | A1 |
20180330237 | Yoshiyama | Feb 2018 | A1 |
20180129900 | Kiraly | May 2018 | A1 |
20180157972 | Hu | Jun 2018 | A1 |
20180205707 | Bellala | Jul 2018 | A1 |
20180212770 | Costa | Jul 2018 | A1 |
20180227296 | Joshi | Aug 2018 | A1 |
20180367509 | O'Hare | Dec 2018 | A1 |
20190005399 | Noguchi | Jan 2019 | A1 |
20190050204 | Hutter | Feb 2019 | A1 |
20190073580 | Dzhulgakov | Mar 2019 | A1 |
20190073586 | Chen | Mar 2019 | A1 |
20190073590 | Wu | Mar 2019 | A1 |
20190114511 | Gao et al. | Apr 2019 | A1 |
20190130265 | Ling | May 2019 | A1 |
20190208417 | Kang | Jul 2019 | A1 |
20190228299 | Chandran | Jul 2019 | A1 |
20190286973 | Kovvuri | Sep 2019 | A1 |
20190294805 | Taylor | Sep 2019 | A1 |
20190312772 | Zhao | Oct 2019 | A1 |
20190318421 | Lyonnet | Oct 2019 | A1 |
20190332944 | Bai | Oct 2019 | A1 |
20190372760 | Zheng | Dec 2019 | A1 |
20200036510 | Gomez | Jan 2020 | A1 |
20200044862 | Yadlin | Feb 2020 | A1 |
20200104670 | Seo | Apr 2020 | A1 |
20200125933 | Aldea Lopez | Apr 2020 | A1 |
20200158745 | Tian | May 2020 | A1 |
20200167127 | Lokappa | May 2020 | A1 |
20200167834 | Matsuoka | May 2020 | A1 |
20200184044 | Zatloukal | Jun 2020 | A1 |
20200186528 | Fan | Jun 2020 | A1 |
20200193279 | Hostetler | Jun 2020 | A1 |
20200202184 | Shrestha | Jun 2020 | A1 |
20200226284 | Yin et al. | Jul 2020 | A1 |
20200228313 | Storm | Jul 2020 | A1 |
20200242492 | Goel | Jul 2020 | A1 |
20200265301 | Burger | Aug 2020 | A1 |
20200286145 | Storm | Sep 2020 | A1 |
20200296128 | Wentz | Sep 2020 | A1 |
20200304293 | Gama | Sep 2020 | A1 |
20200322141 | Kinjo | Oct 2020 | A1 |
20200342288 | Xi | Oct 2020 | A1 |
20200342394 | Moore et al. | Oct 2020 | A1 |
20200358599 | Baracaldo Angel | Nov 2020 | A1 |
20200364608 | Anwar | Nov 2020 | A1 |
20200372360 | Vu | Nov 2020 | A1 |
20200387797 | Ryan et al. | Dec 2020 | A1 |
20200394316 | Boehler | Dec 2020 | A1 |
20200402625 | Aravamudan | Dec 2020 | A1 |
20210019605 | Rouhani | Jan 2021 | A1 |
20210026860 | Wang | Jan 2021 | A1 |
20210035330 | Xie | Feb 2021 | A1 |
20210064760 | Sharma | Mar 2021 | A1 |
20210073036 | Kim | Mar 2021 | A1 |
20210089878 | Greenwald | Mar 2021 | A1 |
20210117578 | Cheruvu | Apr 2021 | A1 |
20210142177 | Mallya | May 2021 | A1 |
20210150024 | Zhang | May 2021 | A1 |
20210157912 | Kruthiveti Subrahmanyeswara Sai | May 2021 | A1 |
20210192279 | Laaksonen et al. | Jun 2021 | A1 |
20210194668 | Masters | Jun 2021 | A1 |
20210209247 | Mohassel | Jul 2021 | A1 |
20210209514 | Kim et al. | Jul 2021 | A1 |
20210248268 | Ardhanari | Aug 2021 | A1 |
20210264271 | Gebre | Aug 2021 | A1 |
20210266170 | Rossi | Aug 2021 | A1 |
20210314140 | Stephenson | Oct 2021 | A1 |
20210334621 | Shimizu | Oct 2021 | A1 |
20210350357 | Lafontaine | Nov 2021 | A1 |
20210357859 | Malvankar | Nov 2021 | A1 |
20210374502 | Roth | Dec 2021 | A1 |
20210385069 | Reid | Dec 2021 | A1 |
20210406386 | Ortiz | Dec 2021 | A1 |
20210406406 | Hutter | Dec 2021 | A1 |
20220004654 | Patel | Jan 2022 | A1 |
20220012672 | Inman | Jan 2022 | A1 |
20220038271 | Ranellucci | Feb 2022 | A1 |
20220050921 | LaFever | Feb 2022 | A1 |
20220051276 | Zelocchi | Feb 2022 | A1 |
20220108026 | Ortiz | Apr 2022 | A1 |
20220121731 | Growth | Apr 2022 | A1 |
20220247548 | Boehler | Aug 2022 | A1 |
20220351039 | Satheesh Kumar | Nov 2022 | A1 |
Number | Date | Country |
---|---|---|
WO 2021119365 | Jun 2021 | WO |
WO 2021119367 | Jun 2021 | WO |
Entry |
---|
Brisimi et al. “Federated learning of predictive models from federated electronic health records”, International Journal of Medical Informatics, Apr. 2018, retrieved on Jan. 18, 2021 from http://www.ncbi.nlm.nih/gov/pmc/articles/PMC5836813/pdf/nihms936798.pdf. |
Thapa et al., “SplitFed: When Federated Learning Meets Split Learning”, Cornell University Library/Computer Science/Machine Learning, Apr. 25, 2020, [online] [retrieved on Dec. 15, 2021] Retrieved from the Internet URL:arXiv:2004.12088v, entire document. |
Abedi, Ali, and Shehroz S. Khan. “FedSL: Federated Split Learning on Distributed Sequential Data in Recurrent Neural Networks”, arXiv preprint arXiv:2011.03180 (Year 2021). |
Nir Bitansky et al., “Post-quantum Zero Knowledge in Constant Rounds”; Jun. 2020; 48 pages (Year 2020). |
Chandiramani, et al., “Performance Analysis and Distributed and Federated Learning Models on Private Data”, Procedia Computer Science, 165(2019), pp. 349-355. (Year: 2019). |
Lui et al., “Federated Forest”, Arxiv.org, Cornell University Library, May 24, 2019, XP081662771, DOI: 10.1109/TBDATA.2020.2992755, Sections 3, 4, 5; Figure 1. (Year: 2019). |
Number | Date | Country | |
---|---|---|---|
20220417225 A1 | Dec 2022 | US |
Number | Date | Country | |
---|---|---|---|
63090904 | Oct 2020 | US | |
62948105 | Dec 2019 | US | |
63226135 | Jul 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17499153 | Oct 2021 | US |
Child | 17897884 | US | |
Parent | 17499153 | Oct 2021 | US |
Child | 17499153 | US | |
Parent | 17499153 | Oct 2021 | US |
Child | 16828085 | US | |
Parent | 17499153 | Oct 2021 | US |
Child | 16828216 | US | |
Parent | 16828354 | Mar 2020 | US |
Child | 17176530 | US | |
Parent | 17499153 | Oct 2021 | US |
Child | 16828354 | US | |
Parent | 17499153 | Oct 2021 | US |
Child | 16828420 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16828085 | Mar 2020 | US |
Child | 17499153 | US | |
Parent | 16828216 | Mar 2020 | US |
Child | 17499153 | US | |
Parent | 17176530 | Feb 2021 | US |
Child | 17499153 | US | |
Parent | 16828420 | Mar 2020 | US |
Child | 17499153 | US |