SYSTEM AND METHOD FOR DEEP CUSTOMIZED NEURAL NETWORKS FOR TIME SERIES FORECASTING

Information

  • Patent Application
  • 20220129747
  • Publication Number
    20220129747
  • Date Filed
    October 28, 2020
    4 years ago
  • Date Published
    April 28, 2022
    2 years ago
Abstract
The present teaching relates to method, system, medium, and implementations for machine learning for time series via hierarchical learning. First, global model parameters of a base model are learned via deep learning for forecasting time series measurements of a plurality of time series. Based on the learned base model, target model parameters of a target model are obtained by customizing the base model, wherein the target model corresponds to a specific target time series from the plurality of time series for forecasting time series measurements of the specific target time series.
Description
BACKGROUND
1. Technical Field

The present teaching generally relates to a computer, and, more specifically, relates to machine learning.


2. Technical Background

In recent decades, the ubiquitous presence of the Internet and data access in electronic forms have facilitated advancement of various technologies, including big data analytics and machine learning. Artificial intelligence (AI) technologies and applications thereof usually rely on machine learning based on big data. For example, machine learning techniques have been used for learning preferences of users via contents consumed and forecasting specific behavior based on historic time series data. In recent years, time series forecasting has drawn substantial attention with a wide range of applications, such as forecasting sales volume and click traffic. The goal of time series forecasting includes to predict future measurements of a target time series by leveraging temporal patterns identified from historical observations.


With the proliferation and success of artificial neural networks, recurrent neural networks (RNNs) are widely adopted for capturing complex non-linear temporal dependencies. To further enhance the relation extraction and representation, some research works focus on integrating more appropriate modules or features, such as attention mechanisms and multiple resolutions aggregation. Existing state-of-the-arts works aim at improving what can be achieved using basic RNN-based methods by sharing temporal patterns globally across different time series. This is illustrated in FIG. 1 (PRIOR ART), which depicts a typical framework 100 of traditional approach to forecasting temporal pattern via machine learning. As seen, training data archive 110 includes training data of multiple time series X1, X2, . . . , Xm, which are used by a deep learning mechanism 120 as training data to learn model parameters 130. Such learned model parameters 130 are then used by a tie series forecaster 140 so that whenever it receives a time series from time 1−t, say X11-t, it can predict or forecast the time series measurement at time t+1 or {circumflex over (X)}1t based on the model parameters 130.


In this framework, training data from different time series may be used to train the model parameters, attempting to capture the characteristics of all of these time series. However, different time series, especially those collected from different data sources, likely exhibit very different temporal patterns. For example, daily sales for a store located in the downtown may follow a very different pattern than that of a store located in suburbs. Thus, purely relying on pattern generalization across different time series and encoding their characteristics via global modeling does not work well.


In some applications, the desire is towards embracing pattern specialization, which trains specialized model parameters using training data of that special type of time series. This mode of operation also presents data deficiency problems. To achieve such customized treatments, a straightforward solution is to train a forecasting model for each target time series. However, a well-trained model, especially a model based on neural networks, tends to significantly rely on massive training data, which may not be available or accessible in real-world scenarios. Another issue has to do with long-range temporal patterns. A time series may start at any time and span across variable time periods. Temporal patterns between existing observations and the ones in predictions may not be well-captured by the learned model if such patterns are not observed in the target time series. For instance, the forecasting for stores with one year data is expected to be easier than the ones with less data, such as only a couple of months, as the more data we have, the more underlying temporal patterns could be identified. However, how to capture long-range historical temporal patterns remains a daunting task.


Thus, there is a need for methods and systems that address the deficiency of existing approaches.


SUMMARY

The teachings disclosed herein relate to methods, systems, and programming for advertising. More particularly, the present teaching relates to methods, systems, and programming related to exploring sources of advertisement and utilization thereof.


In one example, a method, implemented on a machine having at least one processor, storage, and a communication platform capable of connecting to a network for machine learning for time series via hierarchical learning is provided. First, global model parameters of a base model are learned via deep learning for forecasting time series measurements of a plurality of time series. Based on the learned base model, target model parameters of a target model are obtained by customizing the base model, wherein the target model corresponds to a specific target time series from the plurality of time series for forecasting time series measurements of the specific target time series.


In a different example, a system is disclosed for machine learning of time series forecasting, which comprises a general deep machine learning mechanism and a customized deep learning mechanism. The general deep machine learning mechanism is configured for deep learning global model parameters of a base model for forecasting time series measurements of a plurality of time series. The customized deep learning mechanism configured for obtaining target model parameters of a target model by customizing the base model, wherein the target model corresponds to a target time series from the plurality of time series and is for forecasting time series measurements of the target time series.


Other concepts relate to software for implementing the present teaching. A software product, in accord with this concept, includes at least one machine-readable non-transitory medium and information carried by the medium. The information carried by the medium may be executable program code data, parameters in association with the executable program code, and/or information related to a user, a request, content, or other additional information.


In one example, a machine-readable, non-transitory and tangible medium having data recorded thereon for machine learning for time series via hierarchical learning. First, global model parameters of a base model are learned via deep learning for forecasting time series measurements of a plurality of time series. Based on the learned base model, target model parameters of a target model are obtained by customizing the base model, wherein the target model corresponds to a specific target time series from the plurality of time series for forecasting time series measurements of the specific target time series.


Additional advantages and novel features will be set forth in part in the description which follows, and in part will become apparent to those skilled in the art upon examination of the following and the accompanying drawings or may be learned by production or operation of the examples. The advantages of the present teachings may be realized and attained by practice or use of various aspects of the methodologies, instrumentalities and combinations set forth in the detailed examples discussed below.





BRIEF DESCRIPTION OF THE DRAWINGS

The methods, systems and/or programming described herein are further described in terms of exemplary embodiments. These exemplary embodiments are described in detail with reference to the drawings. These embodiments are non-limiting exemplary embodiments, in which like reference numerals represent similar structures throughout the several views of the drawings, and wherein:



FIG. 1 (PRIOR ART) depicts a traditional framework for learning time series forecasting;



FIG. 2A shows a conceptual exemplary schematic for enriched time series forecasting learning with customization, in accordance with an exemplary embodiment of the preset teaching;



FIG. 2B shows a conceptual exemplary schematic for a single time-series prediction process of an enriched customized deep learning mechanism, in accordance with an exemplary embodiment of the preset teaching;



FIG. 2C shows a conceptual exemplary schematic for an aggregation operation through which the time series forecasting is based on both the input sequence and relevant historical patterns to broaden the time scope;



FIGS. 3A-3C depict different exemplary frameworks for enriched/customized deep learning of time series forecasting, in accordance with embodiments of the present teaching;



FIGS. 4A-4D are flowcharts of exemplary processes of different time series forecasting learning frameworks, in accordance with exemplary embodiments of the present teaching;



FIG. 5 depicts an exemplary high level system diagram of an enriched customized deep learning mechanism, in accordance with an exemplary embodiment of the preset teaching;



FIG. 6 is a flowchart of an exemplary process of an enriched customized deep learning mechanism, in accordance with an exemplary embodiment of the preset teaching;



FIG. 7 is an illustrative diagram of an exemplary mobile device architecture that may be used to realize a specialized system implementing the present teaching in accordance with various embodiments; and



FIG. 8 is an illustrative diagram of an exemplary computing device architecture that may be used to realize a specialized system implementing the present teaching in accordance with various embodiments.





DETAILED DESCRIPTION

In the following detailed description, numerous specific details are set forth by way of examples in order to facilitate a thorough understanding of the relevant teachings. However, it should be apparent to those skilled in the art that the present teachings may be practiced without such details. In other instances, well known methods, procedures, components, and/or circuitry have been described at a relatively high-level, without detail, in order to avoid unnecessarily obscuring aspects of the present teachings.


The present teaching aims to address the deficiencies of the traditional approaches in learning time series forecasting. The present teaching discloses a solution that overcomes the challenge and deficiency of the traditional solutions via a framework that is able to enrich the training data by enhancing the expressiveness of encoded temporal patterns via historic patterns. In addition, model parameters learned from general time series data can be customized efficiently in the CTSF framework to remedy the problems associated with data deficiency and long-range pattern modeling. For enrichment of training data, historical patterns may be queried to enrich the pattern information and broaden time span of the input sequence. With respect to customization, the CTSF framework enables explicit combination of generalization among time series and specialization of target time series forecasting. The CTSF framework as disclosed herein is configured with a bidirectional recurrent neural network (RNN) (such as a gated recurrent unit neural network or GRU) to encode target time series.


The framework includes three components: a bi-GRU base model, a historical temporal pattern (HTP) graph, and a customized forecasting module. The base model is used to encode a time series. The HTP graph is used in enriching the representation of a time series based on historical time series. The customized forecasting module is configured to initially learn optimal globally-shared model parameters and then adjust such learned global model parameters to derive customized model parameters for each time series. First, the based model maps an observation sequence into an embedding vector, which expresses the underlying patterns and then outputs predicted values based on the learned embedding. This is shown in FIG. 2A below. Second, the HTP graphs is provided to enhance the forecasting capability. This is achieved by extracting relevant temporal pattern across time series and interacting learned embedding vector with a memory network, which organizes the pattern information through clustering historical temporal patterns of all series during a training process. This is shown in FIG. 2A as forward and backward HTP Graph. Third, the model customization module optimizes the globally-shared parameters of the base model and adjust them to derive adaptive model parameters for each individual time series. This is shown in FIG. 2B.


These concepts associated with the CTSF framework are illustrated schematically in FIGS. 2A-2B. FIG. 2A shows an exemplary conceptual schematic for enriched time series forecasting learning with customization, in accordance with an exemplary embodiment of the preset teaching. This schematic shows the pipeline of CTSF, which includes two tracks. One track on the top is for training phase and one on the bottom is for testing phase. The Bi-LSTM represents a bidirectional long and short-term memory. Model parameters θ0 represent the model parameters of the base model learned during the training track, which are used by the Bi-LSTM during testing to generate predictions of time series measurements given testing data. During the training phase, the training time series data are enriched via forward HTP and backward HTP graphs, as shown. The base model parameters are updated during training by minimizing two types of errors, Lmse and Lgraph. Details of enrichment via HTP graphs will be provided below.



FIG. 2B shows an exemplary conceptual schematic for customized deep learning mechanism, in accordance with an exemplary embodiment of the preset teaching. In this schematic, hidden representations learned in training based on time series data from multiple sources represent the base model, which is to be customized based on specific time series training data. The learned based model parameters are used to query forward and backward HTP Graph to further enhance the representation. All information is then aggregated to make a prediction. Below, more details on enrichment of training data and mode customization are provided.


Before the detailed discussion, some definitions are provided first. Time series information from a source is defined as one time series, which is composed of a set of chronologically ordered observations that are collected at equal-space time intervals. Suppose there are m time series data sources, X=(X1, . . . , X, . . . , Xm) denotes the corresponding m time series and Xi=(custom-character, . . . , custom-character, . . . custom-character) (custom-charactercustom-character) denotes the ith time series, where |custom-character| represents the number of measurements in the ith time series. Each measurement custom-character is also associated with a timestamp t. In general, different time series may vary in number of involved measurements. The concept of time series forecasting is to infer or predict a future measurement based on or by leveraging temporal patterns from historical (previously occurred) observations. That is, given K previous observations (custom-character, . . . , custom-character) in the ith time series, the objective of forecasting is to predict, e.g., the next measurement custom-character of the time series at time t.


Based on such definitions and notations, the problem of customized time series forecasting via knowledge transfer can be defined as follows. Given time series data X, the objective is to provide a customized time series forecasting model, which is formulated as:










min





i
=
1

𝒥










j
=
1


𝒯
i












x
i
t

-


x
^

i
t




2
2




=

min





i
=
1

𝒥










j
=
1


𝒯
i












x
i
t

-



(

[


x
i

t
-
k


,

.



.



.





,

x
i

t
-
1



]

)






2


2








(
1
)







where custom-character represents the learned time series forecasting model for time series custom-character.


To derive customized model parameters for forecasting with respect to time series from a specific source in the framework of CTSF, a base model may first be established using training time series data from multiple sources. The base model aims to forecast future observations by understanding the time-ordered pattern of input sequence. It may be constructed using neural networks, e.g., a bi-directional GRU (bi-GRU) followed by several fully connected layers. For each time series i, the output representation of bi-GRU may be represented as custom-character=[custom-charactercustom-character]=[GRU (custom-character, custom-character), GRU(custom-character, custom-character)], where hk is the hidden representation of bi-GRU at time stamp k. For each time stamp k, custom-character is fed into several fully connected layers, which generates a predicted value custom-character, which is defined as custom-character=FC(custom-character). The parameters of the base model f is optimized by minimizing some type of error, e.g., the mean-squared-error (MSE) loss as:











mse

=


1

2


Σ

i
=
1

𝒥



𝒯
i








i
=
1

𝒥










t
=
1


𝒯
i













x
^

i
t

-

x
i
t





2


2








(
2
)







where custom-character is the real observation at t-th time of time series xi.


Next, the enrichment via HTP graph is disclosed. Based on the above definitions of the base model, the extracted hidden representations are encoded based on the fixed-length input. Because information contained in a fixed length input may be limited (in some situations may be severely limited), this configuration likely may not capture long-term temporal patterns in some situations. For example, in some situations, the observation time series used for prediction may be truncated to the latest K observations (input time steps K). In some situations, the target time series (e.g., a newly emerged time series) may span over only a very short time frame. Such issues leads to failure of capturing long-term temporal patterns and degrades the predicted accuracy within a limited time scope. The hidden representation may be enriched by incorporating relevant historical information to address such issues. The purpose is to broaden the time scope of input sequence by dynamically querying relevant historical information across all time series archived.


In querying/retrieving the relevant patterns, the goal is to enhance the expressiveness of custom-character by using the hidden representations {custom-character. . . , custom-character} to query the HTP Graph. This involves three steps. The first step is to query space projection. The second step is to aggregate relevant historical information. The third step is to aggregate features. The first step is for query space projection, the hidden representation H is projected into the query space, which is denoted as:






custom-character=custom-character+custom-character  (3)


where custom-charactercustom-characterand custom-charactercustom-character are learnable parameters. For illustration purposes, the query process described herein is in the forward direction. The backward query process is similar but using a separate set of trainable parameters.


After the relevant information query, the next step is to aggregate the queried historical patterns by replacing relevant scores. If the representation of a vertex set in the HTP graph, e.g., a forward graph, is custom-character={custom-character, . . . , custom-character}, to get the relevant information from the HTP graph, the most intuitive is to aggregate custom-character={custom-character, . . . custom-character} into custom-character (e.g., using mean pooling) and then query the HTP graph. C is the total number of vertices in the vertex set in the HTP graph. Both c and c′ refers to a specific vertex in this set such as Vf=vf1, . . . , vfc′, . . . , vfc, . . . , vfC}, where vfc is the cth vertex among a set of C vertices in total, and similarly vfc′ refers to the c′th vertex. Pooling as discussed herein corresponds to an aggregation operator in neural networks, which may be pooling using some exemplary potential functions such as min, max, sum, average/mean, etc. For example, by “mean pooling”, it may be that {q1, . . . , qk, . . . , qk′, . . . , qK } are aggregated into q by taking the mean of their values. Since qk is a projected version of hk at timestamp/step k (for a particular time series), this aggregation would get a single embedding representation q for the whole time series (from timestamps 1 to K).


The queried information may be aggregated by attention mechanism as follows:









=


Σ
c




exp


(



,



)





exp


(



,



)










(
4
)







where custom-character.,.custom-character represents an inner product. Equation (4) defines the forward (hence the f) historical pattern vector rf as a weighted summation of all vfc (hence the summation with c). The weight of the cth forward pattern graph vertex vfc is defined by its similarity to q, e.g., via the inner product in the numerator, that is normalized by the denominator (c′ loop) to make the sum of weights 1.



q in equation (4) is the aggregation of {q1, . . . , qk, . . . , qk′, . . . , qK} via “mean pooling” and is used to query the historical pattern graph Vf={vf1, . . . vfc′, . . . , vfc, . . . , vfC}, that includes the hidden representations of other time series in the dataset. qk and qk′ represent query space projections of hk and hk′ (as shown in Equation (3)), that are embeddings/hidden representations of a particular time series (that need to be enriched and do forecasts for later) at different timestamps/steps k and k′. As simple mean pooling aggregation is averaging the information across all timestamps within a time series, it may lead to loss of temporal information within this particular time series.


Representation aggregation before information query may fail to distill effective information without exploring the relevance between different time step representations and HTP graph. To reduce information loss, a graph query method is adopted to simultaneously consider interactions of custom-charactercustom-character, and custom-charactercustom-character, and custom-character−vc, leading to three types of edge weights. The first edge weight corresponds to custom-charactercustom-character which represents the interaction of different timestamps/steps within a time series to use its own past to enrich its recent past representations and vice versa to capture seasonality. Therefore, custom-character and custom-character are added into the HTP graph as:





ε(custom-character,custom-character,)=σ(custom-character|custom-charactercustom-character|+custom-character)


where







σ


(
x
)


=


1

1
+

e

-
x




.





The edge weight is higher/stronger if qk and qk′ are very similar to each other and lower/weaker if they are not. Weqf is a simple learnable parameter vector, and beqf is a learnable scalar (intercept).


The second edge weight is directed to interaction between vertices vfc and vfc′ in the historical pattern graph and is related to the hidden representations of other time series in the dataset to enrich each other. This type of edge weight is defined in a similar manner.







ɛ


(

,

)


=

σ


(






,




+

)






where







σ


(
x
)


=


1

1
+

e

-
x




.





Note that the weight of the edge will be higher/stronger if hidden representations of two different time series in the database are similar to f each other, lower/weaker if they are not. Wevf is a simple learnable f parameter vector, and bevf is a learnable scalar (intercept).


The third edge weight is directed to interaction between qk and vfc, aiming to characterize the interaction of the query-space representation qk of a particular time series at the kth timestamp vs. any hidden representations vfc of other time series in the historic dataset. This way, qk can be enriched if it is similar to some other time series in the historic dataset. This edge weight is defined as:





ε(qk,vcf)=exp(−∥qkvcf22)


It may also be defined the same way as the first and the second edge weight functions above as:





ε(qk,vcf)=σ(Weqvf|qkvcf|+beqvf)


where







σ


(
x
)


=


1

1
+

e

-
x




.





The choice of an edge weight function may differ, which may not matter that much so long as it makes the edge weight higher when qk and vfc are similar to each other, and lower when they are not. custom-character, custom-charactercustom-character and custom-character, custom-charactercustom-character are learnable parameters.


Based on the above defined edge weights, a new graph may be constructed with the vertex set with the following vertices (projected hidden representations of a particular time series as well as all other time series) V0f={q1, . . . , qk, . . . , qk′, . . . , qK, vf1, . . . , vfc′, . . . , vfc′, . . . , vfC} and edge weights ε0f. Each of the vertices in V0f includes vector representations (embeddings) and the edge weights ε0f, calculated using the edge weight formulas as discussed above. Then, a Graph Neural Network (GNN) may be leveraged with ReLU activation to aggregate the most relevant historical information. That is, over the constructed pattern graph, a Graph Neural Network (GNN) with ReLU activation that has nu layers is utilized to enrich the information in each vertex (vector) by aggregating the information in its neighboring/connected vertices via the weighted edges that connect them in the graph. In some embodiments, the aggregation may use three types of links at the same time. That is,






custom-character=ReLU(GNN(custom-character,custom-character;custom-character)),  (5)


where custom-character is the layer index, custom-character are trainable parameters on custom-character-th layer. After custom-character stacked GNN layer, we get the relevant historical patterns custom-character from the K-th row of custom-character.


The third step is on feature aggregation, during which the queried forward pattern vector custom-character and backward pattern vector custom-character are projected to the same feature space and concatenated with custom-character as:






h
k′=(custom-character,custom-character+custom-character)⊕(custom-character,custom-character+custom-character)⊕custom-charactercustom-character  (6)


where custom-character, custom-character are learnable parameters and ⊕ is a concatenation operation. In this operation, hk is replaced with hk′ which is ultimately fed into fully connected layers of the base model for predictions.


Through such aggregation operation, the time series forecasting is based on both the input sequence and relevant historical patterns to broaden the time scope. With this aggregation, as any vertex that has higher weighted edges with other vertices that are more similar with it, this propagation scheme enables to aggregate the most relevant historical information in the pattern graph utilizing these three types of edge definitions. Thus, each vertex vector in the initial graph's vertex set V0f is utilized by the 1st hidden layer of the GNN to construct the new/enriched vertex vector representations of the next hidden graph layer—and the set of all vertex vectors after the 1st layer is V1f. Similarly, vertex vectors of V1+1f are constructed as an aggregation over the vertex vectors of V1f, using the edge weights ε0f and the corresponding GNN parameters of the 1th layer W1′. Ultimately, after the last GNN layer nL′ each vertex vector derives its final enriched representations using all three types of edge definitions. And qk vs qk′ that represent query space projections of hk and hk′ (which are embeddings/hidden representations of a particular time series at different timestamps/steps k and k′, i.e., xk and xk+1) will be more and more enriched through each layer of the GNN, and finally become rfk and rbk′ after the last layer nL′. Then, for each time stamp k, the forward hk, backward hk, forward rfk, and backward rbk are concatenated all together to construct the final hkfinal via Equation (6). This final hk′ is then fed into FC (full connected layers in a neural network) to predict {circumflex over (x)}k+1. This is shown in FIG. 2C.


Improving the expressiveness of the hidden representation via historic data query and enrichment enables better forecasting ability without having to be trained on a massive amount of data. This addresses the challenge of inadequate training data. FIG. 3A depicts an exemplary high level system diagram of a configuration 300 for enhanced time series forecasting via enrichment, in accordance with an exemplary embodiment of the present teaching. The configuration 300 of the CTSF framework includes a training data archive 310, an enriched deep learning mechanism 320, and a time series forecaster 350. The enriched deep learning mechanism 320 is deployed for learning from input time series training data X1, X2, . . . , Xm. When the time series training data are received by the enriched deep learning mechanism 320, it queries, based on its learned representations, the historic time series data (which may represent more varieties and longer time series) stored in a supporting historic information archive 330 to enrich the expressiveness of the representation by leveraging the HTP graph, in accordance with the formulations discussed herein. After enrichment, enriched feature vectors are generated that incorporate relevant historic information and, hence, representing enriched time series information. With such enriched feature vectors for training, it enables the enriched deep learning mechanism 320 to capture characteristics of information that has more breadth and depth.



FIG. 4A is a flowchart of an exemplary process of the enriched deep learning mechanism 320, in accordance with an exemplary embodiment of the present teaching. Upon receiving training time series input at 400, the enriched deep learning mechanism 320 queries, based on its learned hidden representations, the historic information (stored in the support historical information archive 330) at 405. Based on the queried historical patterns, the enriched deep learning mechanism 320 obtains, at 410, enriched or aggregated feature vectors in accordance with the exemplary formulations shown in Equations (3)-(6). The aggregated feature vectors are then fed to the neural network(s) in the 320 mechanism to generate, at 415, predictions of the time series input data. Based on such generated predictions, the enriched deep learning mechanism 320 then updates, at 420, the global model parameters 340 for the base model. Such updated model parameters obtained based on the enriched vectors can then be used by the time series forecaster 350 to predict a measurement of a time series based on past occurred time series data.


The effectiveness of HTP graph may heavily depend on how well the historical knowledge stored is extracted in forward graph representation custom-character and backward graph representation custom-character. In some situations, it may be difficult to learn well by minimizing merely the MSE loss defined in Equation (2). To enhance the learning efficiency, a triplet loss function is used to optimize custom-character and custom-character by leveraging the intrinsic property contained in time series. It is based on the observation that two extracted historical patterns may show different distance influenced by whether each other come from the same time series or not. Such a distance may be small when the two extracted historical patterns are generated in different time periods of a same time series. That is, the intrinsic characteristics may exhibit over time in a consistent way. Conversely, such a distance may be large if two query embeddings are derived from different time series. A triple loss is formulated as follows:












graph

=


θ
0
*

=

arg







min

θ
0





Σ
i



Σ
j



Σ

t
1




max


(

0
,





r
i

t

,


r
i

t




,

r
t
i

,

-





r
i

t

,


r
i

t





,

+
m


)







,




(
7
)







where rit=[custom-character, custom-character] is the extracted relevant historical patterns of time series i at time step t, m is the margin value to control the difference strength between intra-distance and inter-distance. As seen, this formulation of the triplet loss is to enforce that the distance between rit and rit′ (extracted relevant historical pattern of time series i at different timestamps t vs. t′) are small while the distance between rit vs. rjt are large (extracted relevant historical pattern of time series i vs. time series j at the same timestamp t).


As discussed herein, another aspect of the CTSF framework is related to customization of a globally learned base model using input data specific to a particular time series to generate model parameters that are optimized with respect to that particular time series for forecasting. As discussed herein, globally sharing model across different time series usually fail to capture individual temporal dependencies of each time series. Such as approach is usually not effective because different time series, e.g., xi vs xj, can be quite different in nature so that and globally sharing the parameters does not work well.


To enhance the base model on its expressiveness with respect to each time series, the base model may be used as a basis for customization for each time series. With the customization in accordance with the present teaching, the forecasting capability in the field of time series prediction can be significantly enhanced. Although model customization can be achieved by separately training the models for different time series prediction using corresponding time series data, this approach is impractical in real-world scenarios for various reasons. For instance, deep learning models in the forecasting field need a large training dataset (as usual) to learn model parameters effectively. However, in reality individual time series usually do not have sufficient data to train a deep learning and well-performed network.


A solution to solve the dilemma as discussed herein is to leverage pretrained model parameters obtained based on a large shared dataset as model initialization and then adapt specific tasks by fine-tuning parameters using smaller datasets. Specifically, meta learning described with two phases: i) model initialization and ii) model customization. During the first phase for model initialization, a global deep learning based forecasting model or base model is trained using data typically from a large set of time series likely encompassing a long history. This set of time series training data is called source time series set denoted by custom-character. This custom-character data set provides usually much more information, e.g., yearly seasonality, and enables the global base model to capture significant events such as Christmas, Thanksgiving, Mother's Day, July 4th, etc. Base model parameters are shared across all time series, hence represent the across time series knowledge or meta-knowledge. Source dataset custom-character is used for this task.


During the model customization phase, based on the base model, target time series set custom-character (usually limited without a long history) is used to learn customized deep learning based forecasting models with respect to individual time series in the target set custom-character. The base model parameters learned from the first phase serve as starting point so that although time series training data in target set custom-character do not have enough data to train a deep learning model, they are adequate for customizing the model parameters.


Formally, in supervised machine learning, a predictive model ŷ=fθ(x) parameterized by θ can be learned via training as follows:





θ*=argminθL(fθ,S)


where L is a loss function that measures the degree of match between true labels and those predicted by the predictive model fθ(.) based on the training dataset custom-character. In accordance with the present teaching, two types of losses are defined: Lmse (Equation (2)) and Lgraph (Equation (7)). A combined loss is defined as:





θ*=argminθLmse(fθ,S)+γLgraph


γ is a weight for Lgraph, which can be learned during training. Parameter set θ* corresponds to learned parameters during the first phase of training to obtain an initialized prediction model using cross time series data set custom-character. That is, θ* is not customized and thus will not be effective for target time series (in target set custom-character).


In meta-learning according to the present teaching, the source set custom-character is divided into custom-character={custom-charactersupport, custom-characterquery} or abbreviated as custom-character={custom-characters, custom-characterq}. Similarly, the target set custom-character={custom-charactersupport, custom-characterquery} or abbreviated as custom-character={custom-characters, custom-characterq}. If following the naming convention in machine learning, custom-character can be described as custom-character={custom-charactertrain, custom-charactervalidation} and custom-character as custom-character={custom-charactertrain, custom-charactertest}, respectively. The subscript denotes a specific time series in those sets, hence the final notation in the paper custom-character={custom-characteris, custom-characteriq} and custom-character={custom-characteris, custom-characteriq}.


The base model is first learned from source time series set custom-character (shared training data) and then the base model parameters are modulated using target time series set custom-character. The goal is to learn the base/global model parameters θ*0 on the custom-characters dataset such that the customized time-series specific parameters θi are good for the ith time series in the source set custom-characteriq. Thus, it is a hierarchical (bi-level) optimization problem with outer and inner optimizations. Specifically, this hierarchical optimization problem is formulated as follows. The first level of optimization is formulated as:





θ*0=argminθ0ΣiLmse(fθi,Siq)+γLgraph  (8)





where





θ*i=argminθiΣiLmse(fθ0,Sis)  (9)


with γ being a weight for Lgraph, Lmse (Equation (2)) and Lgraph (Equation (7)) being the two types of losses as disclosed herein, and θ0 is fixed in Equation (8).


In the above formulation, Equation (8) is an outer loss function and is for searching for a global θ0 that serves as a good initialization for Equation (9) on each time series Sis. Equation (9) is an inner loss function for searching a time series specific θi that minimizes the outer loss function in Equation (8) for the customized model fθi on the ith time series of the source validation (query) set Siq. The triple loss function Lgraph has an effect only on the outer optimization that searches for the global θ0 and has no effect on time series specific process searching for θi. This is because Lgraph needs a large dataset to train and is an integral part of the overall deep learning model that needs a large dataset with a long history to train, while Lmse is the main prediction loss, and can effectively customize the parameters to learn the time-specific parameters θi, for each time series. Optimization of θi is typically with a few gradient updates given the fixed global parameter θ0 utilizing the data in Sis.


Equation (9) can be re-written as





θi0−α∇θLmse(fθ0,SiS)  (10)


where α is the learning rate for gradient descend.


Upon meta-training being complete and θ0 being finally converged as θ*0 based on the source set custom-character={custom-character, custom-character}), the learned base model parameter θ*0 is used as the initialization for training the target/test dataset custom-character as follows:





θi=θ*0−α∇θLmse(fθ0,custom-character)  (11)


Then the customized parameter θi can be used to make a prediction for custom-character.



FIG. 3B depicts an exemplary framework 305 for customized deep learning of time series forecasting scheme, in accordance with an embodiment of the present teaching. In this exemplary depiction, the system is for carrying out deep learning by performing the meta-learning as discussed herein and comprises the training data archive 310, a general/customized deep learning mechanism 360, and a time series forecaster 380. In this illustrated embodiment, the general/customized deep learning mechanism 360 conducts deep learning in the model initialization and model customization phases, based on source data set S and target data set custom-character. The global model parameters obtained via deep learning based on training data across multiple time series in source S are stored in the global model parameters 340, while the customized model parameters obtained by customizing learned general model parameters based on training data from the target source custom-character are stored in a customized model parameters archive 370. With both sets of model parameters via meta-learning, the time series forecaster 380 may perform general forecast of a measurement at time t based on time series input at time instants 1−t using the global model parameters 340 and/or special forecast of a measurement for a particular time series at time t based on the particular time series input at time instants 1−t using the customized model parameters 370.



FIG. 4B is a flowchart of an exemplary process for the customized deep learning of time series forecasting scheme, in accordance with an embodiment of the present teaching. At step 400, training data from multiple time series are received and predictions are made based on the input training data using current global model parameters 340. The predictions and ground truth labels for the training data are obtained at 425 and used to compute loss and the global model parameters are updated, at 430, by the general/customized deep learning mechanism 360 via minimizing such loss. To update the customized model parameters for each time series, the predictions directed to the time series are obtained at 435 and corresponding loss for the time series is minimized in order to optimize the update to the customized model parameters at 440. Such optimized model parameters (340 and 370) via the meta-learning process may later be used by the tie series forecaster 380 to predict a measurement at time t of any time series based on input time series data at time instants 1−t.


In the disclosure above, the aspect of enrichment and the aspect of customization are presented separately for the ease of understanding. Either aspect provides improvement over the prior art solutions and represents advancement in the field. In some embodiments, these two aspects of the present teaching may be used individually to enhance the performance of deep learning for time series forecasting. In some embodiments, these two aspects of the present teaching may be combined in applications. FIG. 3C depicts an exemplary framework 315 that deploys enriched customized deep learning of time series forecasting, in accordance with an embodiment of the present teaching. In this embodiment, the framework 315 includes the training data archive 310, an enriched customized deep learning mechanism 390, and a time series forecaster 395. In this framework 315, the enriched customized deep learning mechanism 390 is configured to perform both enrichment operation as disclosed of the framework 300 in FIG. 3A and the customization operation as disclosed of the framework 305 in FIG. 3B.


As shown, the framework 315 combines the components in both FIG. 3A and FIG. 3B. The global model parameters 340 and the customized model parameters 370 are derived via both enrichment and customization and, hence, represent improvement from both aspects of the present invention. In addition, in implementation, the two phases (general and customization) in the hierarchical optimization process may be carried out simultaneously or in sequence. FIG. 4C is a flowchart of an exemplary process of framework 315 in which the optimization in both phases is carried out simultaneously, in accordance with an embodiment of the present teaching. When input time series data are received, at 400, the historic information is queried based on existing embedded parameters at 405. Based on the query results, enriched feature vectors are obtained at 410 by aggregating relevant historic information. Based on the enriched feature vectors, the optimization of both phases are carried simultaneously.


The global optimization in the first phase of the hierarchical process is carried out at 415 and 420 to update the global model parameters 340 according to Equation (8) using the model parameters θi from the other phase for updating customized model parameters. Specifically, to update the global model parameters, the enriched customized deep learning mechanism 390 generate predictions based on current global model parameters at 415 and then updates, at 420, the global model parameters 340 based on the two losses, i.e., Lmse(fθi, Siq) as defined in Equation (2) and the triple loss Lgraph as defined in Equation (7), in accordance with the optimization scheme as shown in Equation (8).


Conversely, the customized optimization of the second phase of the hierarchical process is carried out at 435 and 440 to update the customized model parameters 370 according to Equation (9) using the global model parameters θ0 from the global optimization phase. Specifically, in order to adjust the parameters for each time series, predictions are generated based on the relevant time series input first at 435 based on global model parameters θ0 as updated above. Such generated predictions and the true labels of the time series input are used to compute the loss Lmse(fθ0, Sis) to determine how to update the customized model parameters by minimizing the loss expressed in Equation (9). In this mode of operation, the updates to global and customized model parameters may be performed alternately towards convergence.


As discussed herein, an alternative embodiment is to establish converged model parameters in sequence. FIG. 4D is a flowchart of another exemplary process of framework 315 in which the two phase optimization is carried out in sequence, in accordance with an embodiment of the present teaching. In this mode of operation, the global model parameters are learned first until convergence and then the converged global model parameters are used as the basis for customization. Steps 400-420 are the same as what is described with reference to FIG. 4A. After each iteration of updating the global model parameters 340, it is determined, at 445, whether the global model parameters have converged. If they have not yet converged, the processing goes back to step 400 to repeat the phase of updating the global model parameters. The first phase continues until the step at 445 determines that the optimization of global model parameters have converged. At that point, the customization for each time series is initiated by obtaining, at 440, the predictions of the particular time series based on converged global model parameters θ0. Such predictions and the ground truth labels are then used to compute the loss Lmse(fθ0, Sis) which is minimized in order to determine how to update the customized model parameters 370. The customization process repeats if any of the target models for a particular time series has not converged, determined at 450.



FIG. 5 depicts an exemplary high level system diagram of the enriched customized deep learning mechanism 390, in accordance with an exemplary embodiment of the preset teaching. As discussed herein, the enriched customized deep learning mechanism 390 is configured to be capable of handle both enrichment aspect and the customization aspect of the present teaching. However, it may also be configured to handle either of the aspects when appropriate control is introduced. These are implementation choices and do not serve as limitations to the present teaching.


In this illustrated embodiment, the enriched customized deep learning mechanism 390 comprises an artificial neural network 500, a relevant historic information query engine 510, a graph based historic information aggregator 520, a feature aggregator 530, a triple loss determiner 540, a global MSE loss determiner 550, a global model parameter updater 560, a time series MSE loss determiner 570, and a customized model parameter updater 580. These different components cooperate in the meta-learning framework as disclosed herein to carry out the enrichment of embedded feature vectors based on relevant historic information to improve the expressiveness of the model parameters and deriving both enhanced global model parameters (due to enrichment) and customize specific time series forecasting model parameters.



FIG. 6 is a flowchart of an exemplary process of the enriched customized deep learning mechanism 390, in accordance with an exemplary embodiment of the preset teaching. To deep learn the model parameters of the artificial network 500, input training time series data are received, at 600, by the artificial neural network 500 in order to generate a prediction. To enrich the expressiveness of the embeddings, the relevant historic information query engine 510 generates a query in accordance with Equation (3) and use that to query, at 610 based on the existing embeddings, the support historical information archive 330 to obtain relevant historic information that can be used for enrichment.


The queried relevant historic information is used by the graph based historic info aggregator 520 to aggregate via attention mechanism as shown in Equation (4) in the forward direction. The same operation in the backward direction may also be similarly performed. Multiple types of historic information may be aggregated, at 620, by the graph based historic info aggregator 520 based on Equation (5). In addition, based on the historical information aggregation as shown in Equation (4), the triple loss determiner 540 computes, at 630, the triple loss Lgraph in accordance with Equation (7). The queried pattern vectors in both forward and backward directions as specified in Equation (4) are then projected by the feature aggregator 530 to the same feature space as the embeddings with concatenation with the original features as specified in Equation (6). This is performed by the feature aggregator 530 at 640.


The aggregated feature vectors are then fed, at 650, to the artificial network 500 to generate a forecasted measurement based on the input training time series. When the forecasted measurement (prediction) is received, at 660, by the global MSE loss determiner 550, it computes, at 670, the MSE loss Lmse based on Equation (2). Such computed Lmse and Lgraph are then used by the global model parameter updater 560 to determine how to update, at 680, the global model parameters stored in 340. As discussed herein, the optimization corresponds to a hierarchical process, which may update global and customized model parameters at the same time or in a sequence. If the operational mode is in a simultaneous mode, in order to update the customized model parameters, the time series MSE loss determiner 570 determines the LSE loss for each time series based on the current global model parameters as fixed values. Based on the time series specific MSE loss, the customized model parameter updater 580 may then update, at 690, the customized model parameters stored in 370 by minimizing the MSE loss specific to each time series. As discussed herein, in an alternative embodiment, the customized model parameters may not be updated until the global model parameters converge to their established form.


The process as described herein may continue to iterate on different input time series data so that the model parameters will be learned via this deep learning scheme until convergence. As described herein, enrichment and customization are independent aspects or separate improvement under the present teaching attributed to improvement to the current state of the art in time series forecasting. With the deep learned mode parameters, not only the time series forecasting for cross time series using global model parameters can be improved due to the enrichment, the quality of customization is also enhanced because the base model derived via enrichment incorporate relevant information from related historic data queried. At the same time, the customization as described herein allows rapid adaptation of general model parameters to specific target model parameters suitable and effective for each particular time series in the absence of large sum of training data.



FIG. 7 is an illustrative diagram of an exemplary mobile device architecture that may be used to realize a specialized system implementing the present teaching in accordance with various embodiments. In this example, the user device on which the present teaching may be implemented corresponds to a mobile device 700, including, but is not limited to, a smart phone, a tablet, a music player, a handled gaming console, a global positioning system (GPS) receiver, and a wearable computing device (e.g., eyeglasses, wrist watch, etc.), or in any other form factor. Mobile device 700 may include one or more central processing units (“CPUs”) 740, one or more graphic processing units (“GPUs”) 730, a display 720, a memory 760, a communication platform 710, such as a wireless communication module, storage 790, and one or more input/output (I/O) devices 740. Any other suitable component, including but not limited to a system bus or a controller (not shown), may also be included in the mobile device 700. As shown in FIG. 7, a mobile operating system 770 (e.g., iOS, Android, Windows Phone, etc.), and one or more applications 780 may be loaded into memory 760 from storage 790 in order to be executed by the CPU 740. The applications 780 may include a browser or any other suitable mobile apps for managing a machine learning system according to the present teaching on mobile device 700. User interactions, if any, may be achieved via the I/O devices 740 and provided to the various components connected via network(s).


To implement various modules, units, and their functionalities described in the present disclosure, computer hardware platforms may be used as the hardware platform(s) for one or more of the elements described herein. The hardware elements, operating systems and programming languages of such computers are conventional in nature, and it is presumed that those skilled in the art are adequately familiar therewith to adapt those technologies to appropriate settings as described herein. A computer with user interface elements may be used to implement a personal computer (PC) or other type of workstation or terminal device, although a computer may also act as a server if appropriately programmed. It is believed that those skilled in the art are familiar with the structure, programming, and general operation of such computer equipment and as a result the drawings should be self-explanatory.



FIG. 8 is an illustrative diagram of an exemplary computing device architecture that may be used to realize a specialized system implementing the present teaching in accordance with various embodiments. Such a specialized system incorporating the present teaching has a functional block diagram illustration of a hardware platform, which includes user interface elements. The computer may be a general purpose computer or a special purpose computer. Both can be used to implement a specialized system for the present teaching. This computer 800 may be used to implement any component of the multi-task dual loop learning scheme, as described herein. For example, the learning system as disclosed herein may be implemented on a computer such as computer 800, via its hardware, software program, firmware, or a combination thereof. Although only one such computer is shown, for convenience, the computer functions relating to the conversation management system as described herein may be implemented in a distributed fashion on a number of similar platforms, to distribute the processing load.


Computer 800, for example, includes COM ports 850 connected to and from a network connected thereto to facilitate data communications. Computer 800 also includes a central processing unit (CPU) 820, in the form of one or more processors, for executing program instructions. The exemplary computer platform includes an internal communication bus 810, program storage and data storage of different forms (e.g., disk 870, read only memory (ROM) 830, or random access memory (RAM) 840), for various data files to be processed and/or communicated by computer 800, as well as possibly program instructions to be executed by CPU 820. Computer 800 also includes an I/O component 860, supporting input/output flows between the computer and other components therein such as user interface elements 880. Computer 800 may also receive programming and data via network communications.


Hence, aspects of the methods of dialogue management and/or other processes, as outlined above, may be embodied in programming. Program aspects of the technology may be thought of as “products” or “articles of manufacture” typically in the form of executable code and/or associated data that is carried on or embodied in a type of machine readable medium. Tangible non-transitory “storage” type media include any or all of the memory or other storage for the computers, processors or the like, or associated modules thereof, such as various semiconductor memories, tape drives, disk drives and the like, which may provide storage at any time for the software programming.


All or portions of the software may at times be communicated through a network such as the Internet or various other telecommunication networks. Such communications, for example, may enable loading of the software from one computer or processor into another, for example, in connection with conversation management. Thus, another type of media that may bear the software elements includes optical, electrical, and electromagnetic waves, such as used across physical interfaces between local devices, through wired and optical landline networks and over various air-links. The physical elements that carry such waves, such as wired or wireless links, optical links, or the like, also may be considered as media bearing the software. As used herein, unless restricted to tangible “storage” media, terms such as computer or machine “readable medium” refer to any medium that participates in providing instructions to a processor for execution.


Hence, a machine-readable medium may take many forms, including but not limited to, a tangible storage medium, a carrier wave medium or physical transmission medium. Non-volatile storage media include, for example, optical or magnetic disks, such as any of the storage devices in any computer(s) or the like, which may be used to implement the system or any of its components as shown in the drawings. Volatile storage media include dynamic memory, such as a main memory of such a computer platform. Tangible transmission media include coaxial cables; copper wire and fiber optics, including the wires that form a bus within a computer system. Carrier-wave transmission media may take the form of electric or electromagnetic signals, or acoustic or light waves such as those generated during radio frequency (RF) and infrared (IR) data communications. Common forms of computer-readable media therefore include for example: a floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD-ROM, DVD or DVD-ROM, any other optical medium, punch cards paper tape, any other physical storage medium with patterns of holes, a RAM, a PROM and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave transporting data or instructions, cables or links transporting such a carrier wave, or any other medium from which a computer may read programming code and/or data. Many of these forms of computer readable media may be involved in carrying one or more sequences of one or more instructions to a physical processor for execution.


Those skilled in the art will recognize that the present teachings are amenable to a variety of modifications and/or enhancements. For example, although the implementation of various components described above may be embodied in a hardware device, it may also be implemented as a software only solution—e.g., an installation on an existing server. In addition, the fraudulent network detection techniques as disclosed herein may be implemented as a firmware, firmware/software combination, firmware/hardware combination, or a hardware/firmware/software combination.


While the foregoing has described what are considered to constitute the present teachings and/or other examples, it is understood that various modifications may be made thereto and that the subject matter disclosed herein may be implemented in various forms and examples, and that the teachings may be applied in numerous applications, only some of which have been described herein. It is intended by the following claims to claim any and all applications, modifications and variations that fall within the true scope of the present teachings.

Claims
  • 1. A method implemented on at least one machine including at least one processor, memory, and communication platform capable of connecting to a network for machine learning for time series, the method comprising: performing hierarchical learning, which comprisesdeep learning global model parameters of a base model for forecasting time series measurements of a plurality of time series, andobtaining target model parameters of a target model by customizing the base model, wherein the target model corresponds to a target time series from the plurality of time series and is for forecasting time series measurements of the target time series.
  • 2. The method of claim 1, wherein the base model is learned generically for forecasting a time series measurement of any of the plurality time series;the target model is learned specifically for forecasting a time series measurement of the corresponding target time series.
  • 3. The method of claim 1, wherein the step of deep learning comprises: receiving training data cross the plurality of tine series;forecasting time series measurements of the training data based on the global model parameters of the base model; andupdating the global model parameters by minimizing a first loss determined based on the forecasted time series measurements from the training data and labels of the training data.
  • 4. The method of claim 1, wherein the step of obtaining target model parameters comprises: initializing the target model parameters for the target model based on target time series measurements forecasted based on the base model and labels of training data from the target time series; anditeratively updating the target model parameters by minimizing a second loss determined based on a discrepancy between target time series measurements predicted using time series data from the target time series and labels of the time series data from the target time series.
  • 5. The method of claim 1, wherein the deep learning of the base model and the customizing the base model are performed simultaneously during the hierarchical learning.
  • 6. The method of claim 1, wherein the deep learning of the base model and the customizing the base model are performed in sequence during the hierarchical learning.
  • 7. The method of claim 3, wherein the first loss includes a graph based portion related to enrichment of hidden representations associated with the base model.
  • 8. Machine readable and non-transitory medium having information recorded thereon for machine learning for time series, wherein the information, once read by a machine, causes the machine to perform hierarchical learning by: deep learning global model parameters of a base model for forecasting time series measurements of a plurality of time series; andobtaining target model parameters of a target model by customizing the base model, wherein the target model corresponds to a target time series from the plurality of time series and is for forecasting time series measurements of the target time series.
  • 9. The medium of claim 8, wherein the base model is learned generically for forecasting a time series measurement of any of the plurality time series;the target model is learned specifically for forecasting a time series measurement of the corresponding target time series.
  • 10. The medium of claim 8, wherein the step of deep learning comprises: receiving training data cross the plurality of tine series;forecasting time series measurements of the training data based on the global model parameters of the base model; andupdating the global model parameters by minimizing a first loss determined based on the forecasted time series measurements from the training data and labels of the training data.
  • 11. The medium of claim 8, wherein the step of obtaining target model parameters comprises: initializing the target model parameters for the target model based on target time series measurements forecasted based on the base model and labels of training data from the target time series; anditeratively updating the target model parameters by minimizing a second loss determined based on a discrepancy between target time series measurements predicted using time series data from the target time series and labels of the time series data from the target time series.
  • 12. The medium of claim 8, wherein the deep learning of the base model and the customizing the base model are performed simultaneously during the hierarchical learning.
  • 13. The medium of claim 8, wherein the deep learning of the base model and the customizing the base model are performed in sequence during the hierarchical learning.
  • 14. The medium of claim 10, wherein the first loss includes a graph based portion related to enrichment of hidden representations associated with the base model.
  • 15. A system for machine learning for time series, comprising: a general deep machine learning mechanism configured for deep learning global model parameters of a base model for forecasting time series measurements of a plurality of time series; anda customized deep learning mechanism configured for obtaining target model parameters of a target model by customizing the base model, wherein the target model corresponds to a target time series from the plurality of time series and is for forecasting time series measurements of the target time series.
  • 16. The system of claim 15, wherein the base model is learned generically for forecasting a time series measurement of any of the plurality time series;the target model is learned specifically for forecasting a time series measurement of the corresponding target time series.
  • 17. The system of claim 15, wherein the general deep machine learning mechanism performs deep learning by: receiving training data cross the plurality of tine series;forecasting time series measurements of the training data based on the global model parameters of the base model; andupdating the global model parameters by minimizing a first loss determined based on the forecasted time series measurements from the training data and labels of the training data.
  • 18. The system of claim 15, wherein the customized deep learning mechanism performs obtaining target model parameters by: initializing the target model parameters for the target model based on target time series measurements forecasted based on the base model and labels of training data from the target time series; anditeratively updating the target model parameters by minimizing a second loss determined based on a discrepancy between target time series measurements predicted using time series data from the target time series and labels of the time series data from the target time series.
  • 19. The system of claim 15, wherein the deep learning of the base model and the customizing the base model are performed simultaneously during the hierarchical learning.
  • 20. The system of claim 15, wherein the deep learning of the base model and the customizing the base model are performed in sequence during the hierarchical learning.
CROSS-REFERENCE TO RELATED APPLICATIONS

The present application is related to U.S. patent application Ser. No. 17/083,020, filed Oct. 28, 2020, which is incorporated herein by reference in its entirety.