File: parsmultistate.cpp

package info (click to toggle)
iqtree 2.0.7%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 14,620 kB
  • sloc: cpp: 142,571; ansic: 57,789; sh: 275; python: 242; makefile: 95
file content (48 lines) | stat: -rw-r--r-- 2,515 bytes parent folder | download
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
/***************************************************************************
 *   Copyright (C) 2009 by BUI Quang Minh   *
 *   minh.bui@univie.ac.at   *
 *                                                                         *
 *   This program is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU General Public License as published by  *
 *   the Free Software Foundation; either version 2 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 *   This program is distributed in the hope that it will be useful,       *
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
 *   GNU General Public License for more details.                          *
 *                                                                         *
 *   You should have received a copy of the GNU General Public License     *
 *   along with this program; if not, write to the                         *
 *   Free Software Foundation, Inc.,                                       *
 *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
 ***************************************************************************/

#include "tree/phylotree.h"
#include "tree/tinatree.h"
#include "parsmultistate.h"
#include "alignment/alignment.h"
#include "tree/parstree.h"

void doParsMultiState(Params &params) {
    Alignment alignment(params.aln_file, params.sequence_type, params.intype, "");
    alignment.orderPatternByNumChars(PAT_VARIANT);
    ParsTree pars_tree;
    pars_tree.readTree(params.user_file, params.is_rooted);
    if (pars_tree.rooted)
        pars_tree.convertToUnrooted();
    pars_tree.setAlignment(&alignment);
    pars_tree.initCostMatrix(CM_LINEAR);
    pars_tree.setParsimonyKernel(params.SSE);
    pars_tree.initializeAllPartialPars();
    int total_length = pars_tree.computeParsimony();
    cout << "total length: " << total_length << endl;
    pars_tree.initCostMatrix(CM_UNIFORM);
    int pars_score = pars_tree.computeParsimony();
    cout.unsetf(ios::fixed);
    cout.precision(6);
    cout << "mean length: " << double(total_length)/pars_score << endl;
    cout << "Parsimony score is: " << pars_score << endl;
	//cout << "Parsimony score ver2 is: " << tree.computeParsimony() << endl;
	//tree.printParsimonyStates();
}