A library for working with phylogenetic and population genetic data.
v0.32.0
cog.hpp
Go to the documentation of this file.
1
#ifndef GENESIS_PLACEMENT_FUNCTION_COG_H_
2
#define GENESIS_PLACEMENT_FUNCTION_COG_H_
3
4
/*
5
Genesis - A toolkit for working with phylogenetic data.
6
Copyright (C) 2014-2018 Lucas Czech and HITS gGmbH
7
8
This program is free software: you can redistribute it and/or modify
9
it under the terms of the GNU General Public License as published by
10
the Free Software Foundation, either version 3 of the License, or
11
(at your option) any later version.
12
13
This program is distributed in the hope that it will be useful,
14
but WITHOUT ANY WARRANTY; without even the implied warranty of
15
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
GNU General Public License for more details.
17
18
You should have received a copy of the GNU General Public License
19
along with this program. If not, see <http://www.gnu.org/licenses/>.
20
21
Contact:
22
Lucas Czech <lucas.czech@h-its.org>
23
Exelixis Lab, Heidelberg Institute for Theoretical Studies
24
Schloss-Wolfsbrunnenweg 35, D-69118 Heidelberg, Germany
25
*/
26
34
#include "
genesis/placement/placement_tree.hpp
"
35
36
namespace
genesis
{
37
namespace
placement {
38
39
// =================================================================================================
40
// Forward Declarations
41
// =================================================================================================
42
43
class
Sample;
44
45
// =================================================================================================
46
// Center of Gravity
47
// =================================================================================================
48
72
std::pair<PlacementTreeEdge const*, double>
center_of_gravity
(
73
Sample
const
& smp,
74
bool
const
with_pendant_length =
false
75
);
76
87
double
center_of_gravity_variance
(
88
Sample
const
& smp,
89
bool
const
with_pendant_length =
false
90
);
91
98
double
center_of_gravity_distance
(
99
Sample
const
& smp_a,
100
Sample
const
& smp_b,
101
bool
const
with_pendant_length =
false
102
);
103
104
}
// namespace placement
105
}
// namespace genesis
106
107
#endif // include guard
placement_tree.hpp
genesis::placement::center_of_gravity_variance
double center_of_gravity_variance(Sample const &smp, bool const with_pendant_length)
Calculate the variance of the PqueryPlacements of a Sample around its Center of Gravity.
Definition:
cog.cpp:538
genesis::placement::center_of_gravity_distance
double center_of_gravity_distance(Sample const &smp_a, Sample const &smp_b, bool const with_pendant_length)
Calculate the distance between the two Centers of Gravity of two Samples.
Definition:
cog.cpp:605
genesis
Container namespace for all symbols of genesis in order to keep them separate when used as a library.
Definition:
placement/formats/edge_color.cpp:42
genesis::placement::center_of_gravity
std::pair< PlacementTreeEdge const *, double > center_of_gravity(Sample const &smp, bool const with_pendant_length)
Calculate the Center of Gravity of the placements on a tree.
Definition:
cog.cpp:57
lib
genesis
placement
function
cog.hpp
Generated on Mon Aug 5 2024 16:57:51 for genesis by
1.8.17