Zhiling Zhou (Talk | contribs) |
Zhiling Zhou (Talk | contribs) |
||
Line 158: | Line 158: | ||
margin: auto; | margin: auto; | ||
max-height: 250px; | max-height: 250px; | ||
− | width: auto | + | width: auto; |
} | } | ||
Line 586: | Line 586: | ||
high interpretability? First we try LDA algorithm to compress the 10dimensions data into 2 | high interpretability? First we try LDA algorithm to compress the 10dimensions data into 2 | ||
dimensions.</p> | dimensions.</p> | ||
− | <p><span class="MathJax_Preview"></span><span class="MathJax_SVG_Display" | + | <p class="PP"><span class="MathJax_Preview"></span><span class="MathJax_SVG_Display" |
style="text-align: center;"><span | style="text-align: center;"><span | ||
class="MathJax_SVG" id="MathJax-Element-3-Frame" tabindex="-1" | class="MathJax_SVG" id="MathJax-Element-3-Frame" tabindex="-1" | ||
Line 692: | Line 692: | ||
</script> | </script> | ||
</p> | </p> | ||
− | <p>We define <span class="MathJax_Preview"></span><span class="MathJax_SVG" | + | <p class="PP">We define <span class="MathJax_Preview"></span><span class="MathJax_SVG" |
id="MathJax-Element-4-Frame" | id="MathJax-Element-4-Frame" | ||
tabindex="-1" | tabindex="-1" | ||
Line 708: | Line 708: | ||
<script type="math/tex" id="MathJax-Element-4">S_w</script> | <script type="math/tex" id="MathJax-Element-4">S_w</script> | ||
as <strong>within-class scatter matrix</strong></p> | as <strong>within-class scatter matrix</strong></p> | ||
− | <p><span class="MathJax_Preview"></span><span class="MathJax_SVG_Display" | + | <p class="PP"><span class="MathJax_Preview"></span><span class="MathJax_SVG_Display" |
style="text-align: center;"><span | style="text-align: center;"><span | ||
class="MathJax_SVG" id="MathJax-Element-5-Frame" tabindex="-1" | class="MathJax_SVG" id="MathJax-Element-5-Frame" tabindex="-1" | ||
Line 808: | Line 808: | ||
</script> | </script> | ||
</p> | </p> | ||
− | <p>We define <span class="MathJax_Preview"></span><span class="MathJax_SVG" | + | <p class="PP">We define <span class="MathJax_Preview"></span><span class="MathJax_SVG" |
id="MathJax-Element-6-Frame" | id="MathJax-Element-6-Frame" | ||
tabindex="-1" | tabindex="-1" | ||
Line 824: | Line 824: | ||
<script type="math/tex" id="MathJax-Element-6">S_b</script> | <script type="math/tex" id="MathJax-Element-6">S_b</script> | ||
as <strong>between-class scatter matrix</strong></p> | as <strong>between-class scatter matrix</strong></p> | ||
− | <p><span class="MathJax_Preview"></span><span class="MathJax_SVG_Display" | + | <p class="PP"><span class="MathJax_Preview"></span><span class="MathJax_SVG_Display" |
style="text-align: center;"><span | style="text-align: center;"><span | ||
class="MathJax_SVG" id="MathJax-Element-7-Frame" tabindex="-1" | class="MathJax_SVG" id="MathJax-Element-7-Frame" tabindex="-1" | ||
Line 876: | Line 876: | ||
</script> | </script> | ||
</p> | </p> | ||
− | <p>So</p> | + | <p class="PP">So</p> |
− | <p><span class="MathJax_Preview"></span><span class="MathJax_SVG_Display" | + | <p class="PP"><span class="MathJax_Preview"></span><span class="MathJax_SVG_Display" |
style="text-align: center;"><span | style="text-align: center;"><span | ||
class="MathJax_SVG" id="MathJax-Element-8-Frame" tabindex="-1" | class="MathJax_SVG" id="MathJax-Element-8-Frame" tabindex="-1" | ||
Line 925: | Line 925: | ||
<script type="math/tex" id="MathJax-Element-9">J</script> | <script type="math/tex" id="MathJax-Element-9">J</script> | ||
</p> | </p> | ||
− | <p>The result of LDA algorithm is as following and <span class="MathJax_Preview"></span><span | + | <p class="PP">The result of LDA algorithm is as following and <span class="MathJax_Preview"></span><span |
class="MathJax_SVG" id="MathJax-Element-10-Frame" tabindex="-1" | class="MathJax_SVG" id="MathJax-Element-10-Frame" tabindex="-1" | ||
style="font-size: 100%; display: inline-block;"><svg | style="font-size: 100%; display: inline-block;"><svg | ||
Line 1,329: | Line 1,329: | ||
<div class="footer" style="background-color: #000000"> | <div class="footer" style="background-color: #000000"> | ||
<div class="copyright container text-center"> | <div class="copyright container text-center"> | ||
+ | <p class="copyright"><br></p> | ||
<p class="copyright">Copyright © 2017 ZJU-IGEM | <a href="http://www.zju.edu.cn/">Zhejiang University</a> | | <p class="copyright">Copyright © 2017 ZJU-IGEM | <a href="http://www.zju.edu.cn/">Zhejiang University</a> | | ||
</p> | </p> | ||
− | <p class="copyright">Contact us:<a class="copyright" href="">WeChat</a></p> | + | <!--<p class="copyright">Contact us:<a class="copyright" href="">WeChat</a></p>--> |
+ | <p class="copyright"><br></p> | ||
</div> | </div> | ||
</div> | </div> |
Revision as of 06:17, 18 October 2017
Modeling
VOC Classification
Overview
The VOC device is designed to judge whether the tobacco is heathy or gets infected. Since this is an inquiry experiment, algorithms in data analysis are widely use in our modeling. We do data preprocessing, data analysis, and algorithm optimization on the data collected by VOC device. Finally, we use Logistic regression and detect the infected tobacco with 91% confidence.
Data preprocessing
First we defragment the raw input data, and reorganize them into a matrix. 10 VOC factors are served as features, and the status(heathy or infected) is served as tag to be predicted.
Then we analysis the data using box plot and discover that most data are normal, but some records are singular, whose box plot are show as folowing:
We remove those records with singular value, and the data left obey normal distribution:
Data analysis
Our target is to create a model and predict tobacco's status according to 10 input features. This is a classic two classification problem, and there are several algrithm to solve it. The sampling algorithm is cross validation and the scoring policy we apply is ridit test.
Decision Tree
First we use decision tree based on information theory. ID3 decision tree is used to reduce the most information gain, and CART tree is used to reduce the GINI index. The performance of these two algorithm is almost the same.
MLP
The second algorithm we apply is Multi-Layer Perception, also called neutral network. In this model, we use more than 100 neurons in each layer and the activation function is relu.
The result of MLP is much better than decision tree.
Leaner Model
Although the performance of MLP has been good enough, it's difficult to extract konwledge learn by algorithm, the interpretability is weak. Why don't we try a simple model with high interpretability? First we try LDA algorithm to compress the 10dimensions data into 2 dimensions.
We define as within-class scatter matrix
We define as between-class scatter matrix
So
, the target of LDA is maxmize the
The result of LDA algorithm is as following and :
This result prove the data are linear separable, then we choose logistics regression algorithm.
We difine
Then we can apply maximum likelihood method algorithm to estimate the paramaters.
The result is as following:
Weight:
[[ 0.1819504 0.38788225 0.01350023 0.39594948 0.17799418
0.42087034
-0.57733395 -0.23876003 -0.00532918 -0.46174515]]
Intercept:
[ 0.00937812]
Effect:
D 35.300735
B 22.596339
F 18.289277
E 10.265025
C 0.393225
I -1.575564
A -10.679026
H -14.398440
G -26.211964
J -39.130542
dtype: float64
Score:
0.894333333333
Algorithm optimization
From the result of logistics regression, factor C and I and etc. are with less important weight, these factors maybe disturb the classifaction. We try to reduce unimportant factors and simplify the model.
Finally, we reserve 4 factors with which we can predict the tobacco in 91% confidence and also reduce the VOC device.
Weight:
[[ 0.53196697 0.3404023 -0.53555988 -0.45588715]]
Intercept:
[-0.01204088]
Effect:
D 33.217011
F 15.492680
G -17.319760
J -33.967849
dtype: float64
Score:
0.912444444444
Summary
In this model, we try different algorithm to abttain a robust, interpretable, and accurate solution to predict whether the tobacco is infected only according to 4 features in 91% confidence. Since there are 6 VOC sensors are meaningless in this model, we the device can also be simplified by reduce them.