All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Utils.cpp
Go to the documentation of this file.
1 /* Copyright (C) 2008 National Institute For Space Research (INPE) - Brazil.
2 
3  This file is part of the TerraLib - a Framework for building GIS enabled applications.
4 
5  TerraLib is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published by
7  the Free Software Foundation, either version 3 of the License,
8  or (at your option) any later version.
9 
10  TerraLib is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with TerraLib. See COPYING. If not, write to
17  TerraLib Team at <terralib-team@terralib.org>.
18  */
19 
20 /*!
21  \file terralib/classification/Utils.cpp
22 
23  \brief Utility functions for Classification.
24 */
25 
26 // TerraLib
27 #include "../common/Translator.h"
28 #include "../dataaccess/dataset/DataSet.h"
29 #include "Config.h"
30 #include "Enums.h"
31 #include "Exception.h"
32 #include "Utils.h"
33 
34 // STL
35 #include <math.h>
36 
37 double te::cl::GetEuclideanDistance(std::vector<double> v1, std::vector<double> v2)
38 {
39  assert(v1.size() == v2.size());
40 
41  double distance = 0.0;
42  double v1minusv2;
43  for (unsigned int i = 0; i < v1.size(); i++)
44  {
45  v1minusv2 = v1[i] - v2[i];
46  distance += v1minusv2 * v1minusv2;
47  }
48  if (distance < 0)
49  distance = 0.0;
50 
51  return sqrt(distance);
52 }
Enumerations related to the Classification module.
TECLEXPORT double GetEuclideanDistance(std::vector< double > v1, std::vector< double > v2)
Computes euclidean distance between two double vectors.
Definition: Utils.cpp:37
Configuration flags for the Terrralib Classification module.
Utility functions for Classification.
An exception class for the Classification module.