File: modelmorphology.cpp

package info (click to toggle)
iqtree 1.5.3%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 9,780 kB
  • ctags: 11,529
  • sloc: cpp: 96,162; ansic: 59,874; python: 242; sh: 189; makefile: 45
file content (39 lines) | stat: -rw-r--r-- 934 bytes parent folder | download | duplicates (2)
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
/*
 * modelmorphology.cpp
 *
 *  Created on: Apr 15, 2014
 *      Author: minh
 */

#include "modelmorphology.h"

ModelMorphology::ModelMorphology(const char *model_name, string model_params, StateFreqType freq, string freq_params, PhyloTree *tree)
: ModelGTR(tree, false)
{
	init(model_name, model_params, freq, freq_params);
}

void ModelMorphology::init(const char *model_name, string model_params, StateFreqType freq, string freq_params)
{
	name = model_name;
	full_name = model_name;
	freq = FREQ_EQUAL;
	if (name == "MK") {
		// all were initialized
	} else if (name == "ORDERED") {
		int k = 0;
		// only allow for substitution from state i to state i+1 and back.
		for (int i = 0; i < num_states-1; i++) {
			rates[k++] = 1.0;
			for (int j = i+2; j < num_states; j++, k++)
				rates[k] = 0.0;
		}
	} else {
		outError("Unknown morphological model name");
	}
	ModelGTR::init(freq);
}

ModelMorphology::~ModelMorphology() {
}