-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdemo.sh
executable file
·37 lines (32 loc) · 2.07 KB
/
demo.sh
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
#!/bin/sh
# This script will compile cnF2freq using the Intel compiler (recommended, recent GCC is good, but Intel auto-vectorization is nice for performance)
##g++ -O2 cnF2freq.cpp -ffast-math -o cnF2freq -fopenmp -I boost_1_57_0 -g
## Make sure to adapt the path to the boost version you need
g++ cnF2freq.cpp -O2 --fast-math -fopenmp -I boost_1_61_0 --std=c++14 -DDOEXTERNFORGCC -lboost_program_options -o cnF2freq
icc -openmp -openmp-linkstatic -fast -ftz cnF2freq.cpp -lboost_program_options -o cnF2freq
# PlantImpute is using three demo files, a marker map, a pedigree and genotype data.
# Markers are simple top down cM locations. The pedigree is a list of individuals
# <ind id> <parent 1 id> <parent 2 id> [<generation>]
# Generation is 0 if missing. Parent ID 0 also means missing.
# Generation >=2 are those individuals that are actually processed.
# If generation 0 individuals are listed as parents, an implicit F1 generation
# is generated.
# A backcross can be generated by introducing a gen-1 individual in this list.
# Generation numbers larger than 2 mean implicit selfing, so the listed pedigree
# should be the ancestors for a generation 2 individual, and then further selfing
# is assumed from generation 2 down.
# The very last marker is a dummy, if not included, some results for the last marker
# will be wrong (sorry about that)
#
# Genotypes are specified as allele count 0,1,2. 9 for missing genotypes. An alternative
# format is <count-1>/<count-2> such as 5/0 for 5 reads of allele 1 and 0 reads for allele 2.
#
# During iterations (iteration count 10 in this example) most output is written to
# stdout. Pipe to file if this gets excessive.
# The final output file contains genotype probabilities for 11, 12, 21, 22 respectively,
# i.e. imputed individuals.
#
# g++ puts a lot of thread private storage on the stack
# This is large enough for at least some use cases. The defaults on some implementations will be too low.
export OMP_STACKSIZE=128M
./cnF2freq --mapfile demoplantimpute.map --pedfile demoplantimpute.ped --genfile demoplantimpute.gen --output demooutput --count 10