-
Notifications
You must be signed in to change notification settings - Fork 25
/
Dsuite.cpp
81 lines (72 loc) · 2.49 KB
/
Dsuite.cpp
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
//
// Dsuite.cpp
// Dsuite
//
// Created by Milan Malinsky on 02/04/2019.
//
#include <iostream>
#include "Dsuite_utils.h"
#include "Dmin.h"
#include "D.h"
#include "Dmin_combine.h"
#include "Dsuite_fBranch.h"
#include "Dquartets.h"
#define AUTHOR "Milan Malinsky"
#define PACKAGE_VERSION "0.5 r58"
static const char *VERSION_MESSAGE =
"Dsuite software Version " PACKAGE_VERSION "\n"
"Written by Milan Malinsky.\n"
"\n";
static const char *USAGE_MESSAGE =
"Program: " PROGRAM_BIN "\n"
"Version: " PACKAGE_VERSION "\n"
"Contact: " AUTHOR " [" PACKAGE_BUGREPORT "]\n"
"Usage: " PROGRAM_BIN " <command> [options]\n\n"
"Commands:\n"
" Dtrios Calculate D (ABBA-BABA) and f4-ratio statistics for all possible trios of populations/species\n"
" DtriosCombine Combine results from Dtrios runs across genomic regions (e.g. per-chromosome)\n"
" Dinvestigate Follow up analyses for trios with significantly elevated D:\n"
" calculates f_d, f_dM, and d_f in windows along the genome\n"
" Fbranch Calculate D and f statistics for branches on a tree that relates the populations/species\n"
"\n"
"Experimental:\n"
" Dquartets Calculate D (ABBA-BABA) and f4-ratio statistics for all possible quartets of populations/species\n"
" (no outgroup specified)\n"
"\nReport bugs to " PACKAGE_BUGREPORT "\n\n";
int main(int argc, char **argv) {
if(argc <= 1)
{
std::cout << USAGE_MESSAGE;
return 0;
}
else
{
std::string command(argv[1]);
if(command == "help" || command == "--help" || command == "-h")
{
std::cout << USAGE_MESSAGE;
return 0;
}
else if(command == "version" || command == "--version")
{
std::cout << VERSION_MESSAGE;
return 0;
}
if(command == "Dinvestigate")
abbaBabaMain(argc - 1, argv + 1);
else if (command == "Dtrios")
DminMain(argc - 1, argv + 1);
else if (command == "DtriosCombine")
DminCombineMain(argc - 1, argv + 1);
else if (command == "Fbranch")
fBranchMain(argc - 1, argv + 1);
else if (command == "Dquartets")
DquartetsMain(argc - 1, argv + 1);
else
{
std::cerr << "Unrecognized command: " << command << "\n";
return 1;
}
return 0;
}
}