Skip to main content

A simple implementation of DTW(Dynamic Time Warping) in C#/python

DTW(Dynamic Time Warping) is a very useful tools for time series analysis. This is a very simple (but not very efficient) c# implementation of DTW, the source code is available at https://gist.github.com/1966342 .

Use the program as below:
double[] x = {9,3,1,5,1,2,0,1,0,2,2,8,1,7,0,6,4,4,5};
double[] y = {1,0,5,5,0,1,0,1,0,3,3,2,8,1,0,6,4,4,5};
SimpleDTW dtw = new SimpleDTW(x,y);
dtw.calculateDTW();

The python implementation is available at https://gist.github.com/3265694 .

from python-dtw import Dtw
import math
dtw = Dtw([1, 2, 3, 4, 6], [1, 2, 3, 5],
          distance_func=lambda x, y: math.fabs(x - y))
print dtw.calculate() #calculate the distance
print dtw.get_path() #calculate the mapping path

Comments

Xxx said…
I was about to write it by my self. Thanks a lot for that :). Great job.
Unknown said…
Please i want to ask is this program is made on consle app or windows form app

and please i want to ask about the lines written below about the program where can i write them

thanks and please help me because i'm a beginner

and i need this code urgently
thanks
AliBaba said…
hi blogger, I want to know about the computation of this DTW algorithm, in your example you have mentioned calculateDTW but in project there isnt any such function .. secondly U have made 2 more functions in it as Backward and forward, what are these for ... please give us a complete details how to use the code .. regards...
Ruki said…
great help. thank you!
CardStop said…
Would it be possible to update the download link? Thank you in advance.
Darjan said…
Thanks for the code, it saved me some time when I required a simple implementation for some POC software.

Later on I have written something more powerful - if anyone is interested, here is the code: https://github.com/doblak/ndtw
Unknown said…
A simple implementation of DTW(Dynamic Time Warping) in C#/python is really a useful Tool for time analysis. Check DTW Airport Taxi services.
greennn said…
Great job, it is very helpful for myself and thanks for given This DTW code. This implementation is very effective about DTW at it all.
dtw airport taxi
Richard Scott said…
i want to know this code work for Mobile Apps or not and i need for Mobile App i am Living in Detroit Working For DTW Metro Airport To provide Detroit Metro Airport Cars Services
Unknown said…
Good work,Really it is very helpful code for everyone.Detroit Airport Taxi
Unknown said…
This code is very helpful Detroit Airport Taxi
Unknown said…
great piece of information. the post regarding the subject i really informative for the tattoo lovers and the great thing about this is that material use for it is made of organic. keep sharing such kind of informative posts. london gatwick airport parking
Unknown said…
sorry to say but not understand this post can some one explain it for me A simple implementation of DTW(Dynamic Time Warping) in C#/python ? Taxi for Detroit Airport
Unknown said…
Thanks for such a nice and unique content with many tips and ideas for taxi and cab solution. Please Visit:

Detroit Metro Airport Taxi
Metro Airport Taxi Car Services

Popular posts from this blog

Change the default user when start a docker container

When run(start) a docker container from an image, we can specify the default user by passing -u option in command line(In https://docs.docker.com/engine/reference/run/#user ). For example docker run -i -t -u ubuntu ubuntu:latest /bin/bash We can also use the USER instruction in DOCKERFILE to do the same thing(In https://docs.docker.com/engine/reference/builder/#user), note that the option in command line will override the one in the DOCKERFILE. And there is actually another way to start a container with neither DOCKERFILE nor -u option, just by a command like: docker run -i -t ubuntu:latest /bin/bash # with ubuntu as the default user This happens when your start the container from an image committed by a container with ubuntu as the default user. Or in detail: Run a container from some basic images, create ubuntu user inside it, commit the container to CUSTOM_IMAGE:1 . Run a container from CUSTOM_IMAGE:1 with "-u ubuntu" option, and commit the container to CUSTOM...

Notes on Sequential Pattern Mining (2) -- Partial Order Pattern Mining and Contrast Mining

1. In , the authors induce TEIRESIAS algorithms to mining combinatorial patterns with gap constraints in biological sequences. The patterns TEIRESIAS mined is similiar with the common sequential patterns, but it could contain "." the wild card which is also in the alphbel of the sequences database standing for any other item available, for example pattern "A..B" is a length-4 pattern, with two arbitrary items between the first A and the last B. Patterns "AC.B", "AADB" are all said to be more specific than pattern "A..B". TEIRESIAS mining all the maximal patterns () with a support over a min threshold K. There some key points of TEIRESIAS algorithms: 1)The growth of the patterns The growth of the patterns is accomplished by convolute current pattern by a short length pattern. Pattern A and pattern B are convolutable if the last L(very small) characters of pattern A is the same as the first L characters of pattern B, then ...