|
Calling Sequence
|
|
DynamicTimeWarping( signal1, signal2, options )
|
|
Parameters
|
|
signal1, signal2
|
-
|
1-D rtables or lists of data of type complexcons
|
|
|
|
|
Options
|
|
•
|
method: Either standard or pruning, specifies the algorithm used. The default is pruning.
|
•
|
metric: One of canberra, chebyshev, entropy, euclidean, and taxicab, specifies the metric used when computing the optimal path. The default is taxicab.
|
•
|
radius: Either a non-negative integer or infinity, specifies the index radius used when computing the optimal path. The default is infinity.
|
•
|
unwarpedplotoptions: Additional plot options to be passed when creating the plot(s) of the original signals. The default is [].
|
•
|
unwarpedplotimaginaryoptions: Additional plot options to be passed when creating the plot of the imaginary parts of the original signals when they are complex. Note unwarpedplotoptions is applied first, followed by unwarpedplotimaginaryoptions. The default is [].
|
•
|
unwarpedplotrealoptions: Additional plot options to be passed when creating the plot of the real parts of the original signals when they are complex. Note unwarpedplotoptions is applied first, followed by unwarpedplotrealoptions. The default is [].
|
•
|
warpedplotoptions: Additional plot options to be passed when creating the plot(s) of the time-warped signals. The default is [].
|
•
|
warpedplotimaginaryoptions: Additional plot options to be passed when creating the plot of the imaginary parts of the time-warped signals when they are complex. Note warpedplotoptions is applied first, followed by warpedplotimaginaryoptions. The default is [].
|
•
|
warpedplotrealoptions: Additional plot options to be passed when creating the plot of the real parts of the time-warped signals when they are complex. Note warpedplotoptions is applied first, followed by warpedplotrealoptions. The default is [].
|
•
|
warpingpathplotoptions: Additional plot options to be passed when creating the plot of the time-warping path. The default is [].
|
•
|
warpingvectorsplotoptions: Additional plot options to be passed when creating the plot of the time-warping Vectors. The default is [].
|
•
|
output: The type of output. Let and be, respectively, signal1 and signal2, and let and be their respective sizes. The supported options are:
|
–
|
costmatrix: Matrix, of datatype float[8], with element representing the cost (with respect to metric) of matching with .
|
–
|
cost: The cost of matching to , that is, , where is the cost Matrix.
|
–
|
rmse: The root-mean-square (RMS) error between (the time-warped version of ) and (the time-warped version of ).
|
–
|
signal1: Vector, of size and datatype float[8] or complex[8], containing the first original signal .
|
–
|
signal2: Vector, of size and datatype float[8] or complex[8], containing the second original signal .
|
–
|
size: The size of the time-warped signals.
|
–
|
unwarpedplot: Plot of the original signals.
|
–
|
warpedplot: Plot of the time-warped signals.
|
–
|
warpedsignal1: Vector, of size and datatype float[8] or complex[8], containing the first time-warped signal .
|
–
|
warpedsignal2: Vector, of size and datatype float[8] or complex[8], containing the second time-warped signal .
|
–
|
warpingpathplot: Plots of the path which time-warps to and to and the time-warping Vectors and .
|
–
|
warpingvector1: Vector, of size and datatype integer[4], containing the indices of (with repeats) which are used to create .
|
–
|
warpingvector2: Vector, of size and datatype integer[4], containing the indices of (with repeats) which are used to create .
|
–
|
record: Returns a record with the previous options.
|
–
|
list of any of the above options: Returns an expression sequence with the corresponding outputs, in the same order.
|
|
The default is [warpedsignal1,warpedsignal2].
|
|
|
Description
|
|
•
|
The DynamicTimeWarping command takes two signals and , of respective size and , and determines the time-warped signals and , both of some common size , which are closest with respect to the given metric.
|
•
|
To match signals, the DynamicTimeWarping command inserts zero or more successive copies of every sample for each signal in such a way that the time-warped signals have the same length and the error between them (as measured by metric) is as small as possible. Note that if two signals are identical except for the number of copies of successive samples, then they can be matched exactly. More precisely, the command "warps" into and into by computing Vectors of indices and , both of the same length which satisfy , , , , and and for each .
|
•
|
For the signals and , both require two or more elements each, and all the elements must be defined and finite.
|
•
|
For the algorithm to work, the signals need to agree at their endpoints, that is, and . If the passed signal do not already match at their endpoints, the values there are averaged, that is, and are replaced with , and and are replaced with .
|
•
|
When method=standard, the regular algorithm for Dynamic Time Warping (DTW), based on techniques of Dynamic Programming, is used:
|
1.
|
Construct the -by- cost Matrix , with element representing the cost of matching with . First, set each element to infinity. Then, recursively take , where is the given metric, and when and , when and , when and , and when and . The value of is the optimal cost of the best match between and .
|
2.
|
Construct the time-warping vectors and , which store the indices for the optimal path. Starting at the end, namely , for each index , take to be the index pair which gives the smallest value in , and append to and to . Continue this process recursively until index pair is reached.
|
3.
|
Compute the time-warped signals, U=X[G] and V=Y[H].
|
•
|
When method=pruning, the Pruning Method is employed, which is a variation of the above method whereby index pairs are pruned (skipped) during construction of the cost Matrix when the values are too large for the pairs to be a part of the optimal path. This method is exact, in the sense that the optimal path found is the same as for the standard method, and tends to execute a fair bit faster than the standard method. Note that when this method is used, the cost Matrix will (likely) still have elements that are infinity, corresponding to index pairs that have been pruned.
|
•
|
Let be the larger of and the value of radius. For a given index , is computed only for indices that satisfy . The component of is needed to ensure that the index pair can be reached. The method is inexact, in the sense that the optimal path found is (likely) not the same as for the standard method, with a larger total cost for the optimal path. Note that when this method is used with a lower value of , the cost Matrix will (likely) still have elements that are infinity, corresponding to index pairs that fall outside of the window.
|
•
|
The metric option is used by the optimizer to determine the optimal match for the two signals. Consider two Vectors and , both of size . For the error between them, we have a few options. See below.
|
•
|
For metric=entropy, which requires that and both have real and positive elements:
|
•
|
Maple attempts to coerce signal1 and signal2 to 1-D Vectors that are either both of float[8] datatype or both of complex[8] datatype, and an error is thrown if this is not possible. For this reason, it is most efficient for the passed input to use the appropriate datatypes.
|
•
|
The inputs signal1 and signal2 cannot have an indexing function, and must use rectangular storage.
|
•
|
The DynamicTimeWarping command is not thread safe.
|
|
|
Examples
|
|
|
Example 1
|
|
|
|
Example 2
|
|
|
|
Example 3
|
|
•
|
Consider two signals from the same source, with the second signal having twice the sample rate as the first:
|
•
|
We expect that to match the two signals, will have to double-up its samples:
|
|
|
Example 4
|
|
|
|
Example 5
|
|
•
|
The DynamicTimeWarping command can also match noisy signals (and a noisy signal to its pure source):
|
|
|
Example 6
|
|
•
|
Here, we will match a pair of larger signals:
|
memory used=24.18MiB, alloc change=19.36MiB, cpu time=79.00ms, real time=79.00ms, gc time=0ns
| |
|
|
Example 7
|
|
•
|
Consider two complex signals, with the first having a constant sample rate and the second having a sample rate that increases with time:
|
•
|
Now, match the signals:
|
•
|
As we can see from the plot of the time-warping path, the matching is achieved by slowing down , with more slowing at the beginning:
|
•
|
We used the Euclidean metric to obtain the matched signals, and the cumulative cost determined during the computation equals the Euclidean distance between the two final signals:
|
|
|
|
References
|
|
|
Silva, Diego F., and Gustavo E.A.P.A. Batista. "Speeding up all-pairwise dynamic time warping matrix calculation". Proceedings of the 2016 SIAM International Conference on Data Mining, pp. 837-845. Society for Industrial and Applied Mathematics, 2016.
|
|
|
Compatibility
|
|
•
|
Starting with Maple 2023, external C code is used for the auxiliary procedures that were formerly implemented in Maple and could be compiled by passing the compiled option. The compiled option is now deprecated, but it is still accepted for backwards compatibility.
|
•
|
The SignalProcessing[DynamicTimeWarping] command was introduced in Maple 2022.
|
•
|
The SignalProcessing[DynamicTimeWarping] command was updated in Maple 2023.
|
|
|
|