forked from cnettel/cnF2freq
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsettings.h
executable file
·101 lines (85 loc) · 3.4 KB
/
settings.h
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
// Do forward-backward, value 1
// Do original cnF2freq tree evaluation, value 0
#define DOFB 1
#define DOTOULBAR 1
const int SELFBITS = 2;
const int INDCOUNT = 1000000;
const bool DOREMAPDISTANCES = false;
const bool DOINFPROBS = true;
const bool DOIMPOSSIBLE = false;
const bool SELFING = false;
const bool RELSKEWS = true;
const bool RELSKEWSTATES = false;
// F2 with haplotyping
const int NUMGEN = 3;
const int TYPEBITS = (1 << NUMGEN) - 2;
const int TYPESEXES[TYPEBITS + SELFING * SELFBITS + RELSKEWSTATES] = { 0, 0, 1, 1, 0, 1/*, 0, 0*//*, 0*/ };
//const int TYPEGENS[TYPEBITS] = {1, 0, 0, 1, 0, 0};
const int TYPEGENS[TYPEBITS + SELFING * 2] = { 1, 0, 0, 1, 0, 0/*, 2, 2*//*, 3*/ };
const int BITS_W_SELF = TYPEBITS + (SELFING ? SELFBITS : 0);
const int TOTBITS = BITS_W_SELF + (RELSKEWSTATES ? 1 : 0);
const int NUMTYPES = 1 << TOTBITS;
const double EVENGEN = 1.0 / NUMTYPES;
const float MINFACTOR = -1e15;
const unsigned int NUMFLAG2GEN = NUMGEN;
const unsigned int HALFNUMPATHS = 1 << (TYPEBITS / 2);
const unsigned int NUMPATHS = 1 << (TYPEBITS + 1);
const unsigned int NUMSHIFTGEN = NUMGEN - 1;
const unsigned int HALFNUMSHIFTS = 1 << ((1 << (NUMSHIFTGEN - 1)) - 1);
const unsigned int NUMSHIFTS = 1 << ((1 << NUMSHIFTGEN) - 1);
const bool HAPLOTYPING = true;
const int SELFMASK = ((1 << SELFBITS) - 1);
const int NONSELFNUMTYPES = 1 << TYPEBITS /*NUMTYPES >> (RELSKEWS + SELFING * 2)*/;
const int TURNBITS = TYPEBITS + 1;
const int NUMTURNS = 1 << TURNBITS;
// Only NUMTYPES * 3 unless we have RELSKEWS messing things up as well
// TODO: Reorder bits...
const int VALIDSELFNUMTYPES = RELSKEWSTATES ? NUMTYPES : (NUMTYPES - SELFING * (NUMTYPES >> 2));
// This should really be a proper build system
#define READHAPSSAMPLE
//#define READALPHADATA
//#define DOEXTERNFORGCC
#ifdef DOEXTERNFORGCC
#define EXTERNFORGCC extern
#else
#define EXTERNFORGCC
#endif
// F2 with no haplotyping
/*const int NUMGEN = 2;
const int TYPEBITS = (1 << NUMGEN) - 2;
const int TYPESEXES[TYPEBITS] = {0, 1};
const int NUMTYPES = 1 << TYPEBITS;
const double EVENGEN = 1.0 / NUMTYPES;
const float MINFACTOR = -1e15;
const unsigned int NUMFLAG2GEN = 1;
const unsigned int HALFNUMPATHS = 1;
const unsigned int NUMPATHS = 2;
const unsigned int NUMSHIFTGEN = 0;
const unsigned int HALFNUMSHIFTS = 1;
const unsigned int NUMSHIFTS = 1;
const bool HAPLOTYPING = false;*/
// USED IN QTLMAS15
/*
const int NUMGEN = 2;
const int TYPEBITS = (1 << NUMGEN) - 2;
const int TYPESEXES[TYPEBITS] = {0, 1};
const int NUMTYPES = 1 << TYPEBITS;
const double EVENGEN = 1.0 / NUMTYPES;
const float MINFACTOR = -1e15;
const unsigned int NUMFLAG2GEN = NUMGEN;
const unsigned int HALFNUMPATHS = 1 << (TYPEBITS / 2);
const unsigned int NUMPATHS = NUMTYPES << 1;
const unsigned int NUMSHIFTGEN = NUMGEN - 1;
const unsigned int HALFNUMSHIFTS = 1 << ((1 << (NUMSHIFTGEN - 1)) - 1);
const unsigned int NUMSHIFTS = 1 << ((1 << NUMSHIFTGEN) - 1);
/*const unsigned int NUMSHIFTGEN = 0;
const unsigned int HALFNUMSHIFTS = 1;
const unsigned int NUMSHIFTS = 1;*/
//const bool HAPLOTYPING = true;
const int HALFNUMTYPES = 1 << (TYPEBITS / 2);
// Infer corrections for impossible genotypes according to the pedigree
// Also infer values for missing markers from existing information in offspring
// When enabled, results similar to QTL Express without data reduction
// ccoeff does not provide correction inference, so exact result reproduction
// is achieved when this flag is disabled.
bool CORRECTIONINFERENCE = true;