https://github.com/ZhiGroup/bi-PBWT
Raw File
Tip revision: 5ca3dadac4bca9c44185e116182cd520198dadc2 authored by William Yue on 18 July 2021, 02:28:48 UTC
changed pass by value to reference
Tip revision: 5ca3dad
run.sh
#!/bin/bash

if [ $# -eq 0 ]; then
	echo "Program: PBWT (Positional Burrows-Wheeler Transform)"
	echo ""
	echo "Contact: Shaojie Zhang [shzhang@cs.ucf.edu] or Degui Zhi [degui.zhi@uth.tmc.edu]"
	echo ""
	echo "Usage: ./run.sh [options] parameters"
	echo ""
	echo "Required Parameters:"
	echo -e "\t--readVcf <file>\tVCF file"
	echo -e "\t--map <file>\t\tGenetic Mapping file"
	echo ""
	echo "Optional Parameters:"
	echo -e "\t--writeTo <filename>\tOutput filename and location (parameter can be full file path or just filename) [Default = VCF filename]"
	echo -e "\t--length <integer>\tBlock length (in units of centimorgans (cM)) [Default = 1]"
	echo -e "\t--width <integer>\tNumber of haplotypes in block [Default = 100]"
	exit 1
fi

OPTIONS=r:m:o:l:w:
LONGOPTS=readVcf:,map:,writeTo:,length:,width:

PARSED=$(getopt --options=$OPTIONS --longoptions=$LONGOPTS --name "$0" -- "$@")
eval set -- "$PARSED" 

readVcf="" map="" writeTo="" length=1 width=100 
while true; do
	case "$1" in
		-r|--readVcf)
			readVcf="$2"
			shift 2
			;;
		-m|--map)
			map="$2"
			shift 2
			;;
		-o|--writeTo)
			writeTo="$2"
			shift 2
			;;
		-l|--length)
			length="$2"
			shift 2
			;;
		-w|--width)
			width="$2"
			shift 2
			;;
		--)
			shift
			break
			;;
	esac
done

if [ "$readVcf" == "" ]; then
	echo "The VCF input file must be specified with the required option --readVcf <file>"
	exit 1
fi

if [ "$map" == "" ]; then
	echo "The Genetic Mapping file must be specified with the required option --map <file>"
	exit 1
fi

basename=$(basename $readVcf)
filename="${basename%.*}"
if [ "$writeTo" = "" ]; then
	writeTo="$filename"
fi

echo "Running PBWT..."
./PBWT "$readVcf" "$writeTo" "$length" "$width" "$map"
echo "PBWT Finished."

back to top