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
|
// $Id$
//
// Copyright (C) 2003-2006 Rational Discovery LLC
//
// @@ All Rights Reserved @@
// This file is part of the RDKit.
// The contents are covered by the terms of the BSD license
// which is included in the file license.txt, found at the root
// of the RDKit source tree.
//
#include <RDGeneral/test.h>
#include "MetricFuncs.h"
#include "MetricMatrixCalc.h"
#include <cstdlib>
#include <time.h>
using namespace RDDataManip;
int main() {
int n = 10;
int m = 3;
int dlen = n * (n - 1) / 2;
int i, j;
auto *desc = new double[n * m];
auto **desc2D = new double *[n];
for (i = 0; i < n; i++) {
desc2D[i] = desc;
desc += m;
}
desc = desc2D[0];
for (i = 0; i < n; i++) {
for (j = 0; j < m; j++) {
desc[i * m + j] = ((double)rand()) / 10;
}
}
// double x = EuclideanDistanceMetric(desc2D[0], desc2D[1], m);
auto *dmat = new double[dlen];
MetricMatrixCalc<double **, double *> mmCalc;
mmCalc.setMetricFunc(&EuclideanDistanceMetric<double *, double *>);
mmCalc.calcMetricMatrix(desc2D, n, m, dmat);
for (i = 0; i < dlen; i++) {
std::cout << dmat[i] << "\n";
}
delete[] desc2D;
delete[] desc;
delete[] dmat;
exit(0);
}
|