1
//---------------------------------------------------------------------------
3
// Project: OpenWalnut ( http://www.openwalnut.org )
5
// Copyright 2009 OpenWalnut Community, BSV@Uni-Leipzig and CNCF@MPI-CBS, Copyright 2010 RRZK University of Cologne
6
// For more information see http://www.openwalnut.org/copying
8
// This file is part of OpenWalnut.
10
// OpenWalnut is free software: you can redistribute it and/or modify
11
// it under the terms of the GNU Lesser General Public License as published by
12
// the Free Software Foundation, either version 3 of the License, or
13
// (at your option) any later version.
15
// OpenWalnut is distributed in the hope that it will be useful,
16
// but WITHOUT ANY WARRANTY; without even the implied warranty of
17
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18
// GNU Lesser General Public License for more details.
20
// You should have received a copy of the GNU Lesser General Public License
21
// along with OpenWalnut. If not, see <http://www.gnu.org/licenses/>.
23
//---------------------------------------------------------------------------
25
#ifndef WMDETTRACTCLUSTERINGCUDAKERNEL_H
26
#define WMDETTRACTCLUSTERINGCUDAKERNEL_H
28
class ProgressWrapper;
31
* Initialize upper trigonal matrix distmat with Zhang metric. The longest tract has a length of maxlength points.
33
* \param distmat Upper trigonal matrix with Zhang metric.
34
* \param ncoords Total number of coords (x,y,z interleaved)
35
* \param ntracts How many tracts
36
* \param sizes Array of number of coords per tract
37
* \param offsets Where the coords of the tracts do start
38
* \param threshold The 'proximity threshold
39
* \param progress Wrapped WProgress indicator for reporting the progress
41
* \return True on success, false otherwise (e.g. if maxlength is longer than can be handled by the CUDA kernel)
43
extern "C" bool distCuda( float *distmat,
49
const float threshold,
50
ProgressWrapper *progress );
52
#endif // WMDETTRACTCLUSTERINGCUDAKERNEL_H