1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
|
<HTML>
<HEAD>
<TITLE>ClusterAnalyzer.h Source File</TITLE>
<LINK HREF="doxygen.css" REL="stylesheet" TYPE="text/css">
<LINK HREF="style_ini.css" REL="stylesheet" TYPE="text/css">
</HEAD>
<BODY BGCOLOR="#FFFFFF">
<A href="index.html">Home</A> ·
<A href="classes.html">Classes</A> ·
<A href="annotated.html">Annotated Classes</A> ·
<A href="modules.html">Modules</A> ·
<A href="functions_func.html">Members</A> ·
<A href="namespaces.html">Namespaces</A> ·
<A href="pages.html">Related Pages</A>
<HR style="height:1px; border:none; border-top:1px solid #c0c0c0;">
<!-- Generated by Doxygen 1.8.5 -->
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="dir_e770f0cf77e550adde3f44739ef529fe.html">include</a></li><li class="navelem"><a class="el" href="dir_6a63c4937d4da007e55fff5dcf71e0f8.html">OpenMS</a></li><li class="navelem"><a class="el" href="dir_d5c86c02180db504975e24557b30e7a8.html">COMPARISON</a></li><li class="navelem"><a class="el" href="dir_cb8dd6e02b22bc637c17697ac03360d1.html">CLUSTERING</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="headertitle">
<div class="title">ClusterAnalyzer.h</div> </div>
</div><!--header-->
<div class="contents">
<a href="ClusterAnalyzer_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span> <span class="comment">// --------------------------------------------------------------------------</span></div>
<div class="line"><a name="l00002"></a><span class="lineno"> 2</span> <span class="comment">// OpenMS -- Open-Source Mass Spectrometry</span></div>
<div class="line"><a name="l00003"></a><span class="lineno"> 3</span> <span class="comment">// --------------------------------------------------------------------------</span></div>
<div class="line"><a name="l00004"></a><span class="lineno"> 4</span> <span class="comment">// Copyright The OpenMS Team -- Eberhard Karls University Tuebingen,</span></div>
<div class="line"><a name="l00005"></a><span class="lineno"> 5</span> <span class="comment">// ETH Zurich, and Freie Universitaet Berlin 2002-2013.</span></div>
<div class="line"><a name="l00006"></a><span class="lineno"> 6</span> <span class="comment">//</span></div>
<div class="line"><a name="l00007"></a><span class="lineno"> 7</span> <span class="comment">// This software is released under a three-clause BSD license:</span></div>
<div class="line"><a name="l00008"></a><span class="lineno"> 8</span> <span class="comment">// * Redistributions of source code must retain the above copyright</span></div>
<div class="line"><a name="l00009"></a><span class="lineno"> 9</span> <span class="comment">// notice, this list of conditions and the following disclaimer.</span></div>
<div class="line"><a name="l00010"></a><span class="lineno"> 10</span> <span class="comment">// * Redistributions in binary form must reproduce the above copyright</span></div>
<div class="line"><a name="l00011"></a><span class="lineno"> 11</span> <span class="comment">// notice, this list of conditions and the following disclaimer in the</span></div>
<div class="line"><a name="l00012"></a><span class="lineno"> 12</span> <span class="comment">// documentation and/or other materials provided with the distribution.</span></div>
<div class="line"><a name="l00013"></a><span class="lineno"> 13</span> <span class="comment">// * Neither the name of any author or any participating institution</span></div>
<div class="line"><a name="l00014"></a><span class="lineno"> 14</span> <span class="comment">// may be used to endorse or promote products derived from this software</span></div>
<div class="line"><a name="l00015"></a><span class="lineno"> 15</span> <span class="comment">// without specific prior written permission.</span></div>
<div class="line"><a name="l00016"></a><span class="lineno"> 16</span> <span class="comment">// For a full list of authors, refer to the file AUTHORS.</span></div>
<div class="line"><a name="l00017"></a><span class="lineno"> 17</span> <span class="comment">// --------------------------------------------------------------------------</span></div>
<div class="line"><a name="l00018"></a><span class="lineno"> 18</span> <span class="comment">// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"</span></div>
<div class="line"><a name="l00019"></a><span class="lineno"> 19</span> <span class="comment">// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE</span></div>
<div class="line"><a name="l00020"></a><span class="lineno"> 20</span> <span class="comment">// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE</span></div>
<div class="line"><a name="l00021"></a><span class="lineno"> 21</span> <span class="comment">// ARE DISCLAIMED. IN NO EVENT SHALL ANY OF THE AUTHORS OR THE CONTRIBUTING</span></div>
<div class="line"><a name="l00022"></a><span class="lineno"> 22</span> <span class="comment">// INSTITUTIONS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,</span></div>
<div class="line"><a name="l00023"></a><span class="lineno"> 23</span> <span class="comment">// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,</span></div>
<div class="line"><a name="l00024"></a><span class="lineno"> 24</span> <span class="comment">// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;</span></div>
<div class="line"><a name="l00025"></a><span class="lineno"> 25</span> <span class="comment">// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,</span></div>
<div class="line"><a name="l00026"></a><span class="lineno"> 26</span> <span class="comment">// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR</span></div>
<div class="line"><a name="l00027"></a><span class="lineno"> 27</span> <span class="comment">// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF</span></div>
<div class="line"><a name="l00028"></a><span class="lineno"> 28</span> <span class="comment">// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.</span></div>
<div class="line"><a name="l00029"></a><span class="lineno"> 29</span> <span class="comment">//</span></div>
<div class="line"><a name="l00030"></a><span class="lineno"> 30</span> <span class="comment">// --------------------------------------------------------------------------</span></div>
<div class="line"><a name="l00031"></a><span class="lineno"> 31</span> <span class="comment">// $Maintainer: Mathias Walzer $</span></div>
<div class="line"><a name="l00032"></a><span class="lineno"> 32</span> <span class="comment">// $Authors: $</span></div>
<div class="line"><a name="l00033"></a><span class="lineno"> 33</span> <span class="comment">// --------------------------------------------------------------------------</span></div>
<div class="line"><a name="l00034"></a><span class="lineno"> 34</span> </div>
<div class="line"><a name="l00035"></a><span class="lineno"> 35</span> <span class="preprocessor">#ifndef OPENMS_COMPARISON_CLUSTERING_CLUSTERANALYZER_H</span></div>
<div class="line"><a name="l00036"></a><span class="lineno"> 36</span> <span class="preprocessor"></span><span class="preprocessor">#define OPENMS_COMPARISON_CLUSTERING_CLUSTERANALYZER_H</span></div>
<div class="line"><a name="l00037"></a><span class="lineno"> 37</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span> <span class="preprocessor">#include <<a class="code" href="DistanceMatrix_8h.html">OpenMS/DATASTRUCTURES/DistanceMatrix.h</a>></span></div>
<div class="line"><a name="l00039"></a><span class="lineno"> 39</span> <span class="preprocessor">#include <<a class="code" href="String_8h.html">OpenMS/DATASTRUCTURES/String.h</a>></span></div>
<div class="line"><a name="l00040"></a><span class="lineno"> 40</span> <span class="preprocessor">#include <<a class="code" href="BinaryTreeNode_8h.html">OpenMS/DATASTRUCTURES/BinaryTreeNode.h</a>></span></div>
<div class="line"><a name="l00041"></a><span class="lineno"> 41</span> </div>
<div class="line"><a name="l00042"></a><span class="lineno"> 42</span> <span class="preprocessor">#include <vector></span></div>
<div class="line"><a name="l00043"></a><span class="lineno"> 43</span> <span class="preprocessor">#include <set></span></div>
<div class="line"><a name="l00044"></a><span class="lineno"> 44</span> <span class="preprocessor">#include <list></span></div>
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span> <span class="preprocessor">#include <iostream></span></div>
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span> <span class="preprocessor">#include <fstream></span></div>
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span> <span class="preprocessor">#include <cfloat></span></div>
<div class="line"><a name="l00048"></a><span class="lineno"> 48</span> </div>
<div class="line"><a name="l00049"></a><span class="lineno"> 49</span> <span class="keyword">namespace </span>OpenMS</div>
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span> {</div>
<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>  <span class="keyword">class </span>String;</div>
<div class="line"><a name="l00052"></a><span class="lineno"> 52</span> </div>
<div class="line"><a name="l00058"></a><span class="lineno"><a class="line" href="classOpenMS_1_1ClusterAnalyzer.html"> 58</a></span>  <span class="keyword">class </span>OPENMS_DLLAPI <a class="code" href="classOpenMS_1_1ClusterAnalyzer.html">ClusterAnalyzer</a></div>
<div class="line"><a name="l00059"></a><span class="lineno"> 59</span>  {</div>
<div class="line"><a name="l00060"></a><span class="lineno"> 60</span> <span class="keyword">public</span>:</div>
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>  <a class="code" href="classOpenMS_1_1ClusterAnalyzer.html">ClusterAnalyzer</a>();</div>
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span> </div>
<div class="line"><a name="l00065"></a><span class="lineno"> 65</span>  <a class="code" href="classOpenMS_1_1ClusterAnalyzer.html">ClusterAnalyzer</a>(<span class="keyword">const</span> <a class="code" href="classOpenMS_1_1ClusterAnalyzer.html">ClusterAnalyzer</a> & source);</div>
<div class="line"><a name="l00066"></a><span class="lineno"> 66</span> </div>
<div class="line"><a name="l00068"></a><span class="lineno"> 68</span>  <span class="keyword">virtual</span> ~<a class="code" href="classOpenMS_1_1ClusterAnalyzer.html">ClusterAnalyzer</a>();</div>
<div class="line"><a name="l00069"></a><span class="lineno"> 69</span> </div>
<div class="line"><a name="l00080"></a><span class="lineno"> 80</span>  std::vector<Real> averageSilhouetteWidth(<span class="keyword">const</span> std::vector<BinaryTreeNode> & tree, <span class="keyword">const</span> <a class="code" href="classOpenMS_1_1DistanceMatrix.html">DistanceMatrix<Real></a> & original);</div>
<div class="line"><a name="l00081"></a><span class="lineno"> 81</span> </div>
<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>  std::vector<Real> dunnIndices(<span class="keyword">const</span> std::vector<BinaryTreeNode> & tree, <span class="keyword">const</span> <a class="code" href="classOpenMS_1_1DistanceMatrix.html">DistanceMatrix<Real></a> & original, <span class="keyword">const</span> <span class="keywordtype">bool</span> tree_from_singlelinkage = <span class="keyword">false</span>);</div>
<div class="line"><a name="l00091"></a><span class="lineno"> 91</span> </div>
<div class="line"><a name="l00099"></a><span class="lineno"> 99</span>  std::vector<Real> cohesion(<span class="keyword">const</span> std::vector<std::vector<Size> > & clusters, <span class="keyword">const</span> <a class="code" href="classOpenMS_1_1DistanceMatrix.html">DistanceMatrix<Real></a> & original);</div>
<div class="line"><a name="l00100"></a><span class="lineno"> 100</span> </div>
<div class="line"><a name="l00110"></a><span class="lineno"> 110</span>  <a class="code" href="group__Concept.html#gab685845059e8a2c92743427d9a698c70">Real</a> averagePopulationAberration(<a class="code" href="group__Concept.html#gaf9ecec2d692138fab9167164a457cbd4">Size</a> cluster_quantity, std::vector<BinaryTreeNode> & tree);</div>
<div class="line"><a name="l00111"></a><span class="lineno"> 111</span> </div>
<div class="line"><a name="l00127"></a><span class="lineno"> 127</span>  <span class="keywordtype">void</span> cut(<span class="keyword">const</span> <a class="code" href="group__Concept.html#gaf9ecec2d692138fab9167164a457cbd4">Size</a> cluster_quantity, <span class="keyword">const</span> std::vector<BinaryTreeNode> & tree, std::vector<std::vector<Size> > & clusters);</div>
<div class="line"><a name="l00128"></a><span class="lineno"> 128</span> </div>
<div class="line"><a name="l00140"></a><span class="lineno"> 140</span>  <span class="keywordtype">void</span> cut(<span class="keyword">const</span> <a class="code" href="group__Concept.html#gaf9ecec2d692138fab9167164a457cbd4">Size</a> cluster_quantity, <span class="keyword">const</span> std::vector<BinaryTreeNode> & tree, std::vector<std::vector<BinaryTreeNode> > & subtrees);</div>
<div class="line"><a name="l00141"></a><span class="lineno"> 141</span> </div>
<div class="line"><a name="l00150"></a><span class="lineno"> 150</span>  <a class="code" href="classOpenMS_1_1String.html">String</a> newickTree(<span class="keyword">const</span> std::vector<BinaryTreeNode> & tree, <span class="keyword">const</span> <span class="keywordtype">bool</span> include_distance = <span class="keyword">false</span>);</div>
<div class="line"><a name="l00151"></a><span class="lineno"> 151</span> </div>
<div class="line"><a name="l00152"></a><span class="lineno"> 152</span> <span class="keyword">private</span>:</div>
<div class="line"><a name="l00154"></a><span class="lineno"> 154</span>  <a class="code" href="classOpenMS_1_1ClusterAnalyzer.html">ClusterAnalyzer</a> & operator=(<span class="keyword">const</span> <a class="code" href="classOpenMS_1_1ClusterAnalyzer.html">ClusterAnalyzer</a> & source);</div>
<div class="line"><a name="l00155"></a><span class="lineno"> 155</span> </div>
<div class="line"><a name="l00156"></a><span class="lineno"> 156</span>  };</div>
<div class="line"><a name="l00158"></a><span class="lineno"> 158</span>  <span class="keywordtype">bool</span> <a class="code" href="namespaceOpenMS.html#a58a825f137e452fa91ed983fddd61c8a">compareBinaryTreeNode</a>(<span class="keyword">const</span> <a class="code" href="classOpenMS_1_1BinaryTreeNode.html">BinaryTreeNode</a> & x, <span class="keyword">const</span> <a class="code" href="classOpenMS_1_1BinaryTreeNode.html">BinaryTreeNode</a> & y);</div>
<div class="line"><a name="l00159"></a><span class="lineno"> 159</span> </div>
<div class="line"><a name="l00160"></a><span class="lineno"> 160</span> }</div>
<div class="line"><a name="l00161"></a><span class="lineno"> 161</span> <span class="preprocessor">#endif //OPENMS_COMPARISON_CLUSTERING_CLUSTERANALYZER_H</span></div>
<div class="ttc" id="group__Concept_html_gab685845059e8a2c92743427d9a698c70"><div class="ttname"><a href="group__Concept.html#gab685845059e8a2c92743427d9a698c70">OpenMS::Real</a></div><div class="ttdeci">float Real</div><div class="ttdoc">Real type. </div><div class="ttdef"><b>Definition:</b> Types.h:109</div></div>
<div class="ttc" id="classOpenMS_1_1String_html"><div class="ttname"><a href="classOpenMS_1_1String.html">OpenMS::String</a></div><div class="ttdoc">A more convenient string class. </div><div class="ttdef"><b>Definition:</b> String.h:56</div></div>
<div class="ttc" id="classOpenMS_1_1ClusterAnalyzer_html"><div class="ttname"><a href="classOpenMS_1_1ClusterAnalyzer.html">OpenMS::ClusterAnalyzer</a></div><div class="ttdoc">Bundles analyzing tools for a clustering (given as sequence of BinaryTreeNode&#39;s) </div><div class="ttdef"><b>Definition:</b> ClusterAnalyzer.h:58</div></div>
<div class="ttc" id="classOpenMS_1_1DistanceMatrix_html"><div class="ttname"><a href="classOpenMS_1_1DistanceMatrix.html">OpenMS::DistanceMatrix</a></div><div class="ttdoc">A two-dimensional distance matrix, similar to OpenMS::Matrix. </div><div class="ttdef"><b>Definition:</b> DistanceMatrix.h:57</div></div>
<div class="ttc" id="namespaceOpenMS_html_a58a825f137e452fa91ed983fddd61c8a"><div class="ttname"><a href="namespaceOpenMS.html#a58a825f137e452fa91ed983fddd61c8a">OpenMS::compareBinaryTreeNode</a></div><div class="ttdeci">bool compareBinaryTreeNode(const BinaryTreeNode &x, const BinaryTreeNode &y)</div><div class="ttdoc">returns the value of (x.distance &lt; y.distance) for use with sort </div></div>
<div class="ttc" id="DistanceMatrix_8h_html"><div class="ttname"><a href="DistanceMatrix_8h.html">DistanceMatrix.h</a></div></div>
<div class="ttc" id="BinaryTreeNode_8h_html"><div class="ttname"><a href="BinaryTreeNode_8h.html">BinaryTreeNode.h</a></div></div>
<div class="ttc" id="group__Concept_html_gaf9ecec2d692138fab9167164a457cbd4"><div class="ttname"><a href="group__Concept.html#gaf9ecec2d692138fab9167164a457cbd4">OpenMS::Size</a></div><div class="ttdeci">size_t Size</div><div class="ttdoc">Size type e.g. used as variable which can hold result of size() </div><div class="ttdef"><b>Definition:</b> Types.h:144</div></div>
<div class="ttc" id="classOpenMS_1_1BinaryTreeNode_html"><div class="ttname"><a href="classOpenMS_1_1BinaryTreeNode.html">OpenMS::BinaryTreeNode</a></div><div class="ttdoc">Elements of a binary tree used to represent a hierarchical clustering process. </div><div class="ttdef"><b>Definition:</b> BinaryTreeNode.h:50</div></div>
<div class="ttc" id="String_8h_html"><div class="ttname"><a href="String_8h.html">String.h</a></div></div>
</div><!-- fragment --></div><!-- contents -->
<HR style="height:1px; border:none; border-top:1px solid #c0c0c0;">
<TABLE width="100%" border="0">
<TR>
<TD><font color="#c0c0c0">OpenMS / TOPP release 1.11.1</font></TD>
<TD align="right"><font color="#c0c0c0">Documentation generated on Thu Nov 14 2013 11:19:12 using doxygen 1.8.5</font></TD>
</TR>
</TABLE>
</BODY>
</HTML>
|