annotate CSP2/CSP2_env/env-d9b9114564458d9d-741b3de822f2aaca6c6caa4325c4afce/opt/bbmap-39.01-1/idmatrix.sh @ 69:33d812a61356

planemo upload commit 2e9511a184a1ca667c7be0c6321a36dc4e3d116d
author jpayne
date Tue, 18 Mar 2025 17:55:14 -0400
parents
children
rev   line source
jpayne@69 1 #!/bin/bash
jpayne@69 2
jpayne@69 3 usage(){
jpayne@69 4 echo "
jpayne@69 5 Written by Brian Bushnell
jpayne@69 6 Last modified November 25, 2014
jpayne@69 7
jpayne@69 8 Description: Generates an identity matrix via all-to-all alignment.
jpayne@69 9
jpayne@69 10 *** WARNING: This program may produce incorrect results in some cirumstances.
jpayne@69 11 *** It is not advisable to use until fixed.
jpayne@69 12
jpayne@69 13 Usage: idmatrix.sh in=<file> out=<file>
jpayne@69 14
jpayne@69 15 Parameters:
jpayne@69 16 in=<file> File containing reads. in=stdin.fa will pipe from stdin.
jpayne@69 17 out=<file> Matrix output. out=stdout will pipe to stdout.
jpayne@69 18 threads=auto (t) Set number of threads to use; default is number of
jpayne@69 19 logical processors.
jpayne@69 20 percent=f Output identity as percent rather than a fraction.
jpayne@69 21 edits= Allow at most this much edit distance. Default is the
jpayne@69 22 length of the longest input sequence. Lower is faster.
jpayne@69 23 width= Alignment bandwidth, lower is faster. Default: 2*edits+1.
jpayne@69 24 usejni=f (jni) Do alignments faster, in C code. Requires
jpayne@69 25 compiling the C code; details are in /jni/README.txt.
jpayne@69 26
jpayne@69 27 Java Parameters:
jpayne@69 28 -Xmx This will set Java's memory usage, overriding automatic
jpayne@69 29 memory detection. -Xmx20g will specify
jpayne@69 30 20 gigs of RAM, and -Xmx200m will specify 200 megs.
jpayne@69 31 The max is typically 85% of physical memory.
jpayne@69 32 -eoom This flag will cause the process to exit if an out-of-memory
jpayne@69 33 exception occurs. Requires Java 8u92+.
jpayne@69 34 -da Disable assertions.
jpayne@69 35
jpayne@69 36 Please contact Brian Bushnell at bbushnell@lbl.gov if you encounter any problems.
jpayne@69 37 "
jpayne@69 38 }
jpayne@69 39
jpayne@69 40 #This block allows symlinked shellscripts to correctly set classpath.
jpayne@69 41 pushd . > /dev/null
jpayne@69 42 DIR="${BASH_SOURCE[0]}"
jpayne@69 43 while [ -h "$DIR" ]; do
jpayne@69 44 cd "$(dirname "$DIR")"
jpayne@69 45 DIR="$(readlink "$(basename "$DIR")")"
jpayne@69 46 done
jpayne@69 47 cd "$(dirname "$DIR")"
jpayne@69 48 DIR="$(pwd)/"
jpayne@69 49 popd > /dev/null
jpayne@69 50
jpayne@69 51 #DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )/"
jpayne@69 52 CP="$DIR""current/"
jpayne@69 53 JNI="-Djava.library.path=""$DIR""jni/"
jpayne@69 54 JNI=""
jpayne@69 55
jpayne@69 56 z="-Xmx2g"
jpayne@69 57 z2="-Xms2g"
jpayne@69 58 set=0
jpayne@69 59
jpayne@69 60 if [ -z "$1" ] || [[ $1 == -h ]] || [[ $1 == --help ]]; then
jpayne@69 61 usage
jpayne@69 62 exit
jpayne@69 63 fi
jpayne@69 64
jpayne@69 65 calcXmx () {
jpayne@69 66 source "$DIR""/calcmem.sh"
jpayne@69 67 setEnvironment
jpayne@69 68 parseXmx "$@"
jpayne@69 69 if [[ $set == 1 ]]; then
jpayne@69 70 return
jpayne@69 71 fi
jpayne@69 72 freeRam 3200m 84
jpayne@69 73 z="-Xmx${RAM}m"
jpayne@69 74 z2="-Xms${RAM}m"
jpayne@69 75 }
jpayne@69 76 calcXmx "$@"
jpayne@69 77
jpayne@69 78 idmatrix() {
jpayne@69 79 local CMD="java $EA $EOOM $z $z2 $JNI -cp $CP jgi.IdentityMatrix $@"
jpayne@69 80 echo $CMD >&2
jpayne@69 81 eval $CMD
jpayne@69 82 }
jpayne@69 83
jpayne@69 84 idmatrix "$@"