-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathexample.c
78 lines (68 loc) · 2.35 KB
/
example.c
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
#include <stdio.h>
#include <stdlib.h>
#include <tskit.h>
#include <err.h>
/* A simple example of using the tskit API, to demonstrate
* how we can build programs that depend on tskit using
* various different approaches.
*
* We build the tree sequence consisting of the following
* tree, and write it out to a file "example.trees".
*
* 4 time=2
* +-++
* | |
* | 3 time=1
* | +++
* | | |
* 2 0 1 time=0
*
*/
#define check_tsk_error(val) if (val < 0) {\
fprintf(stderr, "line %d: %s\n", __LINE__, tsk_strerror(val));\
exit(EXIT_FAILURE);\
}
int main()
{
int ret;
tsk_table_collection_t tables;
ret = tsk_table_collection_init(&tables, 0);
check_tsk_error(ret);
tables.sequence_length = 1.0;
/* Add the samples */
ret = tsk_node_table_add_row(&tables.nodes, TSK_NODE_IS_SAMPLE,
0, TSK_NULL, TSK_NULL, NULL, 0);
check_tsk_error(ret);
ret = tsk_node_table_add_row(&tables.nodes, TSK_NODE_IS_SAMPLE,
0, TSK_NULL, TSK_NULL, NULL, 0);
check_tsk_error(ret);
ret = tsk_node_table_add_row(&tables.nodes, TSK_NODE_IS_SAMPLE,
0, TSK_NULL, TSK_NULL, NULL, 0);
check_tsk_error(ret);
/* Add internal nodes */
ret = tsk_node_table_add_row(&tables.nodes, TSK_NODE_IS_SAMPLE,
1, TSK_NULL, TSK_NULL, NULL, 0);
check_tsk_error(ret);
ret = tsk_node_table_add_row(&tables.nodes, TSK_NODE_IS_SAMPLE,
2, TSK_NULL, TSK_NULL, NULL, 0);
check_tsk_error(ret);
/* Add edges */
ret = tsk_edge_table_add_row(&tables.edges, 0, 1, 3, 0, NULL, 0);
check_tsk_error(ret);
ret = tsk_edge_table_add_row(&tables.edges, 0, 1, 4, 3, NULL, 0);
check_tsk_error(ret);
ret = tsk_edge_table_add_row(&tables.edges, 0, 1, 3, 1, NULL, 0);
check_tsk_error(ret);
ret = tsk_edge_table_add_row(&tables.edges, 0, 1, 4, 2, NULL, 0);
/* Edges must be sorted in a specific order for efficiency. Sort the
* tables to make sure that this requirement is fulfilled. */
ret = tsk_table_collection_sort(&tables, NULL, 0);
check_tsk_error(ret);
/* Print out some debug info on the tables */
tsk_table_collection_print_state(&tables, stdout);
/* Write out to file */
ret = tsk_table_collection_dump(&tables, "example.trees", 0);
check_tsk_error(ret);
tsk_table_collection_free(&tables);
return 0;
}