The Wearables Development Toolkit (WDK) is a framework and set of tools to facilitate the iterative development of activity recognition applications with wearable and IoT devices. It supports the annotation of time series data, the analysis and visualization of data to identify patterns and the development and performance assessment of activity recognition algorithms. At the core of the WDK is a repository of high-level components that encapsulate functionality used across activity recognition applications. These components can be used within a Matlab script or within a visual flo-based programming platform (i.e. Node-RED).
To get a first insight into the WDK, watch this demo video: https://www.youtube.com/embed/Ow0b0vkciDs and read my paper.
To install and use the WDK, refer to the Documentation.
An annotated data set is needed to train a machine learning algorithm and to assess its performance. The Data Annotation App offers functionality to annotate time series data. Depending on the particular application, one might want to annotate events that occurr at a specific moment in time or activities that have a duration in time, called ranges. The following image shows the squared magnitude of the accelerometer signal collected by a motion sensor attached at a hind leg of a cow. The individual strides of the cow have been annotated as event annotations (red) and the walking and running activities as ranges (black rectangles).
The Data Annotation App can load and display videos next to the data wich is synchronized by specifying at least two data samples and two video frames that correspond to the same event in time. The frames in the video file are displayed by the Movie Player at the bottom right of the window:
In this application, we asked the subject to applaud three times in front of the camera while wearing an armband with an Inertial Measurement Unit (IMU). We matched the samples at the peak of squared magnitude of acceleration to the video frames where the subject's hands make contact with each other.
Please note:
The Data Annotation App offers two features to facilitate the annotation of sensor signals.
The unsupervised feature analyzes the entire data set, clusters similar portions of data and suggests annotations for some of the portions of data. This feature requires a segmentation algorithm to be provided by application developers. A set of heuristic features are extracted for each segment extracted. Finally kmeans is used to cluster the feature vectors using as many labels as defined in the current project. The N feature vectors closest in distance to a centroid are suggested to the user together with a cluster id. With a single click, the user can modify the suggested cluster into the appropriate class. The parameter N is configurable over the user interface.
The supervised feature searches for portions of data similar to previously added range annotations. When a range annotation is added while the supervised auto-annotation is enabled, the Data Annotation App scans the current file for segments of data of the same length and compares the segments to the range annotation using Dynamic Time Warping. The resulting segments are sorted and the N most similar segments are suggested to the user. The parameter N is configurable over the user interface.
The Data Analysis App displays segments of data grouped by class. This is useful to study the differences across classes to design a recognition algorithm able to discriminate between classes. Segments can be plotted either on top of each other or sequentially (i.e. after each other).
In order to visualize data:
Most wearable device applications execute a sequence of computations to recognize specific patterns based on sensor signals. This sequence of computations is called the Activity Recognition Chain and consists of the following stages:
Activity recognition applications can be developed directly in Matlab using the WDK's framework of reusable components.
The following text snippet creates a chain of computations and saves it to the goalkeeperChain.mat file. This chain of computations detects events using a peak detector on the squared magnitude of the accelerometer signal, segments the data around the detected events (200 samples to the left of the event and 30 sampels to the right) and extracts the features defined in the goalkeeperFeatureChain.mat file.
%select first three axes of acceleration
axisSelector = AxisSelector(1:3);%AX AY AZ
%compute the magnitude of acceleration
magnitudeSquared = MagnitudeSquared();
%detect peaks on the magnitude of acceleration
simplePeakDetector = SimplePeakDetector();
simplePeakDetector.minPeakHeight = single(0.8);
simplePeakDetector.minPeakDistance = int32(100);
%create segments around detected peaks
eventSegmentation = EventSegmentation();
eventSegmentation.segmentSizeLeft = 200;
eventSegmentation.segmentSizeRight = 30;
%label created segments
labeler = EventSegmentsLabeler();
%load feature extraction algorithm
featureExtractor = DataLoader.LoadComputer('goalkeeperFeatureChain.mat');
%create the recognition algorithm
arcChain = Computer.ComputerWithSequence({FileLoader(),PropertyGetter('data'),...
axisSelector,magnitudeSquared,simplePeakDetector,eventSegmentation,labeler,...
featureExtractor});
%export the recognition algorithm
DataLoader.SaveComputer(arcChain,'goalkeeperChain.mat');
This chain of computations produces a feature table that can be used within the Assessment App to study the performance of different machine learning algorithms.
Activity recognition applications can also be developed visually in Node-RED using the nodes available in the WDK-RED platform. The following image shows an activity recognition chain for detecting and classifying soccer goalkeeper training exercises using a wearable motion sensor attached to a glove worn by a goalkeeper:
Activity Recognition Chains can be imported and executed in the WDK as follows:
The development and assessement / evaluation of an activity recognition algorithm usually represents a large fraction of the effort to develop the entire application. The Assessment App enables developers to design algorithms by selecting reusable components at each stage of the activity recognition chain and to assess their performance. The recognition performance metrics provided by this tool are:
and the computational performance metrics are:
The following image shows the configuration and classification results of an algorithm to detect and classify exercises performed by patients after a hip replacement surgery.
The Performance Asessment Detail View displays the classification results on top of the data and next to the corresponding video. Green overlays indicate correctly classified segments and red overlays indicate misclassified segments.
Note: Feature tables generated with a particular activity recognition algorithm can be exported to .txt formats to study the classification on other platforms such as Python / tensorFlow and WEKA.
Here you can find a list of the reusable components, their configurable properties and their performance metrics relative to an input of size n.
Invocations to preprocessing algorithms produce n values. The memory consumption of most preprocessing algorithms is 1 if the inPlaceComputation property is set to true or n otherwise.
Name | Description | Flops | Memory |
---|---|---|---|
SimplePeakDetector | Threshold-based peak detector. Properties are: minPeakheight and minPeakDistance. Note: this algorithm is more suitable for deployment into an embedded device than the MatlabPeakDetector | 11 n | 1 |
MatlabPeakDetector | Matlab's peak detector. Properties are: minPeakheight and minPeakDistance. | 1787 n | n |
Note: The flops metrics shown above have been calculated with random values in the range [0 1] using minPeakHeight = 0.8, minPeakDist = 100. The performance metrics will vary depending on how often peaks are detected based on the input data and minPeakHeight and minPeakDist properties.
The event detection algorithms output a single value.
An invocation to an event detection algorithm produces 0 or 1 value.
Name | Description | Flops | Memory |
---|---|---|---|
SlidingWindow | Creates a segment of size segmentSize after every sampleInterval samples. E.g. segmentSize = 200 and sampleInterval = 100 creates segments with a 50% overlapping. Note: receives a signal as input. | segmentSize | segmentSize |
EventSegmentation | Creates a segment around an event by taking segmentSizeLeft samples to the left and segmentSizeRight to the right of the event. Note: receives an event as input. | segmentSizeLeft + segmentSizeRight | segmentSizeLeft + segmentSizeRight |
ManualSegmentation | Creates segments for each annotation (converts RangeAnnotations to segments and creates segments around each EventAnnotations). This segmentation strategy cannot be used in a real application, but is useful to study the quality of the annotations | - | - |
An invocation to a segmentation algorithm produces a segment (of segmentSize or segmentSizeLeft + segmentSizeRight values).
Name | Description |
---|---|
EventsLabeler | Labels events as the closest event annotation under a specified tolerance |
EventSegmentsLabeler | Labels segments generated from an event using the EventsLabeler |
RangeSegmentsLabeler | Labels segments based on range annotations. If the shouldContainEntireSegment is set to true, segments are labeled if they are fully contained in an annotation. Otherwise, segments are labeled if their middle point is contained within a range annotation |
LabelMapper | Maps labels to groups |
Invocations to time-domain feature extraction algorithms produce a single value except for the Quantile component which produces numQuantileParts values.
Invocations to frequency-domain feature extraction algorithms output a single value except for the FFT and PowerSpectrum which produce n/2 and n values respectively.
Name | Description |
---|---|
LDClassifier | Linear Discriminant classifier |
TreeClassifier | Properties: maxNumSplits |
KNNClassifier | K Nearest Neighbors classifier. Properties: nNeighbors, distanceMetric |
EnsembleClassifier | Properties: nLearners |
SVMClassifier | Support Vector Machine. Properties: order, boxConstraint |
The performance metrics of each classifier depend on its configuration and are calculated at runtime.
Name | Description |
---|---|
LabelMapper | maps classified labels to different labels. Can be used to group classified labels when a greater level of detail was used in the classification. |
LabelSlidingWindowMaxSelector | replaces every label at index labelIndex in an array of predicted labels with the most frequent label in the range [labelIndex −windowSize/2,labelIndex +windowSize/2, or with the NULL-class if no label occurs at least minimumCount times in the range |
The postprocessing components produce a label as output.
Name | Description | Flop | Memory | Communication |
---|---|---|---|---|
FeatureExtractor | Generates a table from an array of segments using the feature extraction method set in the computers property | - | - | - |
FeatureNormalizer | Normalizes a features table by subtracting the means property and dividing by the stds property. If the shouldComputeNormalizationValues poperty is set to true, it computes the means and *stds * properties from the input table | - | - | - |
FeatureSelector | Returns a table with the columns in selectedFeatureIdxs property. The findBestFeaturesForTable(f) method can be used to identify the f most relevant features. The mRMR feature selection algorithm is used for this purpose | - | - | - |
ConstantMultiplier | Multiplies an input by the constant property | n | n | n |
Substraction | Subtracts the second column from the first column of the input signal | 2 n | n | n |
AxisMerger | Merges m signals of size n into an nxm matrix. Outputs the merged signal as soon as m signals have been received. The nAxes property indicates how many signals are expected | 3 n | m n | m n |
AxisSelector | Selects the axes columns of the provided input matrix. Returns a new matrix | - | m n | m n |
Merger | Merges m objects into a cell array. Generates an output as soon as m objects have been received | 1 | 1 | 1 |
NoOp | Outputs the input object without modification. Can be useful when connected to several nodes to start an execution graph with multiple entry points | 1 | 1 | * |
PropertyGetter | Outputs the value of the property property of the input object | 1 | * | * |
PropertySetter | Sets the property property of the node object to the input value. Outputs an empty object | 1 | 1 | - |
RangeSelector | Outputs a signal with the values in the range [rangeStart - rangeEnd] of the input signal | 2 n | rangeEnd - rangeStart | rangeEnd - rangeStart |
SegmentsGrouper | Receives an array of segments and outputs the segments grouped by their class in a cell array. Each cell at index i contains an array of the segments of class i in the input | - | - | - |
TableRowSelector | Selects the rows with selectedLabels labels in the input Table. Returns the filtered input Table | - | - | - |
The amount of memory and output size of the PropertyGetter and NoOp modules depend on their input and configuraton values and are computed at runtime.
Applications developed with the WDK:
My name is Juan Haladjian. I developed the Wearables Development Toolkit as part of my post-doc at the Technical University of Munich. Feel free to contact me with questions or feature requests. The project is under an MIT license. You are welcome to use the WDK, extend it and redistribute it for any purpose, as long as you give credit for it by copying the LICENSE.txt file to any copy you make.
Feel free to contact me with feedback or feature requests.
Website: www.jhaladjian.com
Academic Website: http://in.tum.de/~haladjia
LinkedIn: www.linkedin.com/in/juan-haladjian
Email: haladjia@in.tum.de
@misc{haladjian2019,
author = {Juan Haladjian},
title = {{The Wearables Development Toolkit (WDK)}},
howpublished = {\url{https://github.com/avenix/WDK}},
year = {2019}
}
Microsoft Windows Driver Kit (WDK) 包含几个单独的组件。如果您了解 WDK 的结构,您就将知道各种支持文件和信息的查找位置。 默认情况下,WDK 组件将安装到计算机硬盘驱动器上的 WDKInstallationPath\BuildNumber\ 文件夹中,其中 WDKInstallationPath 为 WDK 安装到的计算机上的根目录位置(例如,C:\Win
VC6.0 +WDK 开发驱动的环境配置 1.安装好VC6和DWK,先后顺序无关。 从开始菜单找到WDK的程序目录,进入“Windows XP Checked Build Environment”,输入命令"build",此时WDK将会把自己进行编译,大约需要1分钟。 2.VC6设置Include/Lib/Executable目录。 设置为自己需要编译的平台的各个目录即可, Inc
可能是SDK版本号和WDK版本号不同,应选前三个数字相同,如要卸载,可以打开控制面板卸载程序。
项目场景: 1.WDK一直循环安装 2.WDK报桌面找不到sdk 解决方案: 1.要下载正确的版本,我下了多个版本一一测试才发现只有一个有用,我是虚拟机里面运行的,要在虚拟机里面下载才行,不能直接从主机复制进去 2.不用管它,继续
作者 QQ群:852283276 微信:arm80x86 微信公众号:青儿创客基地 B站:主页 https://space.bilibili.com/208826118 2022 好久不开发Windows驱动,现在又变天了,微软的工具更新的非常快,Visual Studio和WDK都发了新版本,推荐安装新版本,但如果非想安装老版本,也可以。Visual Studio 2022不支持Windows