[med-svn] [Git][med-team/kma][upstream] New upstream version 1.3.9

Nilesh Patra gitlab at salsa.debian.org
Fri Dec 4 14:40:16 GMT 2020



Nilesh Patra pushed to branch upstream at Debian Med / kma


Commits:
45e840d8 by Nilesh Patra at 2020-12-04T20:07:00+05:30
New upstream version 1.3.9
- - - - -


8 changed files:

- kma.c
- runinput.c
- runinput.h
- sparse.c
- sparse.h
- stdstat.c
- stdstat.h
- version.h


Changes:

=====================================
kma.c
=====================================
@@ -132,6 +132,7 @@ static void helpMessage(int exeStatus) {
 	fprintf(helpOut, "#\t-matrix\t\tPrint assembly matrix\t\tFalse\n");
 	fprintf(helpOut, "#\t-a\t\tPrint all best mappings\t\tFalse\n");
 	fprintf(helpOut, "#\t-mp\t\tMinimum phred score\t\t20\n");
+	fprintf(helpOut, "#\t-eq\t\tMinimum avg. quality score\t0\n");
 	fprintf(helpOut, "#\t-5p\t\tCut a constant number of\n#\t\t\tnucleotides from the 5 prime.\t0\n");
 	fprintf(helpOut, "#\t-3p\t\tCut a constant number of\n#\t\t\tnucleotides from the 3 prime.\t0\n");
 	fprintf(helpOut, "#\t-Sparse\t\tOnly count kmers\t\tFalse\n");
@@ -180,11 +181,28 @@ static void helpMessage(int exeStatus) {
 
 int kma_main(int argc, char *argv[]) {
 	
-	static int minPhred, fiveClip, threeClip, ConClave, mem_mode, sparse_run;
+	static const double prob[128] = {
+		1.0000000000000000, 0.7943282347242815, 0.6309573444801932, 0.5011872336272722, 0.3981071705534972, 0.3162277660168379, 0.2511886431509580, 0.1995262314968880,
+		0.1584893192461113, 0.1258925411794167, 0.1000000000000000, 0.0794328234724281, 0.0630957344480193, 0.0501187233627272, 0.0398107170553497, 0.0316227766016838,
+		0.0251188643150958, 0.0199526231496888, 0.0158489319246111, 0.0125892541179417, 0.0100000000000000, 0.0079432823472428, 0.0063095734448019, 0.0050118723362727,
+		0.0039810717055350, 0.0031622776601684, 0.0025118864315096, 0.0019952623149689, 0.0015848931924611, 0.0012589254117942, 0.0010000000000000, 0.0007943282347243,
+		0.0006309573444802, 0.0005011872336273, 0.0003981071705535, 0.0003162277660168, 0.0002511886431510, 0.0001995262314969, 0.0001584893192461, 0.0001258925411794,
+		0.0001000000000000, 0.0000794328234724, 0.0000630957344480, 0.0000501187233627, 0.0000398107170553, 0.0000316227766017, 0.0000251188643151, 0.0000199526231497,
+		0.0000158489319246, 0.0000125892541179, 0.0000100000000000, 0.0000079432823472, 0.0000063095734448, 0.0000050118723363, 0.0000039810717055, 0.0000031622776602,
+		0.0000025118864315, 0.0000019952623150, 0.0000015848931925, 0.0000012589254118, 0.0000010000000000, 0.0000007943282347, 0.0000006309573445, 0.0000005011872336,
+		0.0000003981071706, 0.0000003162277660, 0.0000002511886432, 0.0000001995262315, 0.0000001584893192, 0.0000001258925412, 0.0000001000000000, 0.0000000794328235,
+		0.0000000630957344, 0.0000000501187234, 0.0000000398107171, 0.0000000316227766, 0.0000000251188643, 0.0000000199526231, 0.0000000158489319, 0.0000000125892541,
+		0.0000000100000000, 0.0000000079432823, 0.0000000063095734, 0.0000000050118723, 0.0000000039810717, 0.0000000031622777, 0.0000000025118864, 0.0000000019952623,
+		0.0000000015848932, 0.0000000012589254, 0.0000000010000000, 0.0000000007943282, 0.0000000006309573, 0.0000000005011872, 0.0000000003981072, 0.0000000003162278,
+		0.0000000002511886, 0.0000000001995262, 0.0000000001584893, 0.0000000001258925, 0.0000000001000000, 0.0000000000794328, 0.0000000000630957, 0.0000000000501187,
+		0.0000000000398107, 0.0000000000316228, 0.0000000000251189, 0.0000000000199526, 0.0000000000158489, 0.0000000000125893, 0.0000000000100000, 0.0000000000079433,
+		0.0000000000063096, 0.0000000000050119, 0.0000000000039811, 0.0000000000031623, 0.0000000000025119, 0.0000000000019953, 0.0000000000015849, 0.0000000000012589,
+		0.0000000000010000, 0.0000000000007943, 0.0000000000006310, 0.0000000000005012, 0.0000000000003981, 0.0000000000003162, 0.0000000000002512, 0.0000000000001995};
+	static int minPhred, minQ, fiveClip, threeClip, ConClave, mem_mode;
 	static int fileCounter, fileCounter_PE, fileCounter_INT, Ts, Tv, minlen;
 	static int extendedFeatures, spltDB, thread_num, kmersize, targetNum, mq;
 	static int ref_fsa, print_matrix, print_all, sam, vcf, Mt1, bcd, one2one;
-	static int **d, status = 0;
+	static int sparse_run, **d, status = 0;
 	static unsigned xml, nc, nf, shm, exhaustive, verbose;
 	static char *outputfilename, *templatefilename, **templatefilenames;
 	static char **inputfiles, **inputfiles_PE, **inputfiles_INT, ss;
@@ -220,6 +238,7 @@ int kma_main(int argc, char *argv[]) {
 		spltDB = 0;
 		extendedFeatures = 0;
 		minPhred = 20;
+		minQ = 0;
 		fiveClip = 0;
 		threeClip = 0;
 		sparse_run = 0;
@@ -499,6 +518,15 @@ int kma_main(int argc, char *argv[]) {
 						exit(1);
 					}
 				}
+			} else if(strcmp(argv[args], "-eq") == 0) {
+				++args;
+				if(args < argc) {
+					minQ = strtoul(argv[args], &exeBasic, 10);
+					if(*exeBasic != 0) {
+						fprintf(stderr, "# Invalid average quality score parsed\n");
+						exit(1);
+					}
+				}
 			} else if(strcmp(argv[args], "-mq") == 0) {
 				++args;
 				if(args < argc) {
@@ -896,7 +924,7 @@ int kma_main(int argc, char *argv[]) {
 			} else if(strcmp(argv[args], "-mint3") == 0) {
 				/* equivalent to:
 				-1t1, -mem_mode, -ca, -mq 1, -ref_fsa, -dense, 
-				-bcNano, -bcd 10 -bc 0.7  -vcf -ef */
+				-bcNano, -bcd 10, -bc 0.7, -vcf -ef */
 				kmerScan = &save_kmers;
 				one2one = 1;
 				mem_mode = 1;
@@ -1193,7 +1221,7 @@ int kma_main(int argc, char *argv[]) {
 				fprintf(stderr, "Interleaved information is not considered in Sparse mode.\n");
 			}
 			
-			run_input_sparse(templates, inputfiles, fileCounter, minPhred, fiveClip, threeClip, kmersize, to2Bit, ioStream);
+			run_input_sparse(templates, inputfiles, fileCounter, minPhred, minQ, fiveClip, threeClip, kmersize, to2Bit, prob, ioStream);
 			hashMapKMA_destroy(templates);
 			free(myTemplatefilename);
 		} else {
@@ -1215,17 +1243,17 @@ int kma_main(int argc, char *argv[]) {
 			
 			/* SE */
 			if(fileCounter > 0) {
-				totFrags += run_input(inputfiles, fileCounter, minPhred, fiveClip, threeClip, minlen, to2Bit, ioStream);
+				totFrags += run_input(inputfiles, fileCounter, minPhred, minQ, fiveClip, threeClip, minlen, to2Bit, prob, ioStream);
 			}
 			
 			/* PE */
 			if(fileCounter_PE > 0) {
-				totFrags += run_input_PE(inputfiles_PE, fileCounter_PE, minPhred, fiveClip, threeClip, minlen, to2Bit, ioStream);
+				totFrags += run_input_PE(inputfiles_PE, fileCounter_PE, minPhred, minQ, fiveClip, threeClip, minlen, to2Bit, prob, ioStream);
 			}
 			
 			/* INT */
 			if(fileCounter_INT > 0) {
-				totFrags += run_input_INT(inputfiles_INT, fileCounter_INT, minPhred, fiveClip, threeClip, minlen, to2Bit, ioStream);
+				totFrags += run_input_INT(inputfiles_INT, fileCounter_INT, minPhred, minQ, fiveClip, threeClip, minlen, to2Bit, prob, ioStream);
 			}
 			
 			status |= errno;


=====================================
runinput.c
=====================================
@@ -24,13 +24,14 @@
 #include "runinput.h"
 #include "qseqs.h"
 #include "seqparse.h"
+#include "stdstat.h"
 
 void (*printFsa_ptr)(Qseqs*, Qseqs*, CompDNA*, FILE*) = &printFsa;
 void (*printFsa_pair_ptr)(Qseqs*, Qseqs*, Qseqs*, Qseqs*, CompDNA*, FILE*) = &printFsa_pair;
 
-long unsigned run_input(char **inputfiles, int fileCount, int minPhred, int fiveClip, int threeClip, int minlen, char *trans, FILE *out) {
+long unsigned run_input(char **inputfiles, int fileCount, int minPhred, int minQ, int fiveClip, int threeClip, int minlen, char *trans, const double *prob, FILE *out) {
 	
-	int fileCounter, phredCut, start, end;
+	int fileCounter, phredScale, phredCut, start, end;
 	unsigned FASTQ;
 	long unsigned count;
 	char *filename;
@@ -58,9 +59,9 @@ long unsigned run_input(char **inputfiles, int fileCount, int minPhred, int five
 		/* parse the file */
 		if(FASTQ & 1) {
 			/* get phred scale */
-			phredCut = getPhredFileBuff(inputfile);
-			fprintf(stderr, "# Phred scale:\t%d\n", phredCut);
-			phredCut += minPhred;
+			phredScale = getPhredFileBuff(inputfile);
+			fprintf(stderr, "# Phred scale:\t%d\n", phredScale);
+			phredCut = phredScale + minPhred;
 			
 			/* parse reads */
 			while(FileBuffgetFq(inputfile, header, qseq, qual, trans)) {
@@ -85,7 +86,7 @@ long unsigned run_input(char **inputfiles, int fileCount, int minPhred, int five
 				*/
 				qseq->len = end - start;
 				/* print */
-				if(qseq->len > minlen) {
+				if(qseq->len > minlen && minQ <= eQual(seq + start, qseq->len, minQ, prob - phredScale)) {
 					/* dump seq */
 					qseq->seq += start;
 					printFsa_ptr(header, qseq, compressor, out);
@@ -134,13 +135,14 @@ long unsigned run_input(char **inputfiles, int fileCount, int minPhred, int five
 	return count;
 }
 
-long unsigned run_input_PE(char **inputfiles, int fileCount, int minPhred, int fiveClip, int threeClip, int minlen, char *trans, FILE *out) {
+long unsigned run_input_PE(char **inputfiles, int fileCount, int minPhred, int minQ, int fiveClip, int threeClip, int minlen, char *trans, const double *prob, FILE *out) {
 	
-	int fileCounter, phredCut, start, start2, end;
+	int fileCounter, phredScale, phredCut, start, start2, end;
 	unsigned FASTQ, FASTQ2;
 	long unsigned count;
 	char *filename;
 	unsigned char *seq;
+	double eq1, eq2;
 	Qseqs *header, *qseq, *qual, *header2, *qseq2, *qual2;
 	FileBuff *inputfile, *inputfile2;
 	CompDNA *compressor;
@@ -179,12 +181,12 @@ long unsigned run_input_PE(char **inputfiles, int fileCount, int minPhred, int f
 		/* parse the file */
 		if(FASTQ & 1) {
 			/* get phred scale */
-			phredCut = getPhredFileBuff(inputfile);
-			if(phredCut == 0) {
-				phredCut = getPhredFileBuff(inputfile2);
+			phredScale = getPhredFileBuff(inputfile);
+			if(phredScale == 0) {
+				phredScale = getPhredFileBuff(inputfile2);
 			}
-			fprintf(stderr, "# Phred scale:\t%d\n", phredCut);
-			phredCut += minPhred;
+			fprintf(stderr, "# Phred scale:\t%d\n", phredScale);
+			phredCut = phredScale + minPhred;
 			
 			/* parse reads */
 			//while(FileBuffgetFq(inputfile, header, qseq, qual) && FileBuffgetFq(inputfile2, header2, qseq2, qual2)) {
@@ -210,6 +212,7 @@ long unsigned run_input_PE(char **inputfiles, int fileCount, int minPhred, int f
 				}
 				*/
 				qseq->len = end - start;
+				eq1 = eQual(seq + start, qseq->len, minQ, prob - phredScale);
 				
 				/* trim reverse */
 				seq = qual2->seq;
@@ -230,21 +233,22 @@ long unsigned run_input_PE(char **inputfiles, int fileCount, int minPhred, int f
 				}
 				*/
 				qseq2->len = end - start2;
+				eq2 = eQual(seq + start2, qseq2->len, minQ, prob - phredScale);
 				
 				/* print */
-				if(qseq->len > minlen && qseq2->len > minlen) {
+				if(qseq->len > minlen && qseq2->len > minlen && minQ <= eq1 && minQ <= eq2) {
 					qseq->seq += start;
 					qseq2->seq += start2;
 					printFsa_pair_ptr(header, qseq, header2, qseq2, compressor, out);
 					qseq->seq -= start;
 					qseq2->seq -= start2;
 					++count;
-				} else if(qseq->len > minlen) {
+				} else if(qseq->len > minlen && minQ <= eq1) {
 					qseq->seq += start;
 					printFsa_ptr(header, qseq, compressor, out);
 					qseq->seq -= start;
 					++count;
-				} else if(qseq2->len > minlen) {
+				} else if(qseq2->len > minlen && minQ <= eq2) {
 					qseq2->seq += start2;
 					printFsa_ptr(header2, qseq2, compressor, out);
 					qseq2->seq -= start2;
@@ -328,13 +332,14 @@ long unsigned run_input_PE(char **inputfiles, int fileCount, int minPhred, int f
 	return count;
 }
 
-long unsigned run_input_INT(char **inputfiles, int fileCount, int minPhred, int fiveClip, int threeClip, int minlen, char *trans, FILE *out) {
+long unsigned run_input_INT(char **inputfiles, int fileCount, int minPhred, int minQ, int fiveClip, int threeClip, int minlen, char *trans, const double *prob, FILE *out) {
 	
-	int fileCounter, phredCut, start, start2, end;
+	int fileCounter, phredScale, phredCut, start, start2, end;
 	unsigned FASTQ;
 	long unsigned count;
 	char *filename;
 	unsigned char *seq;
+	double eq1, eq2;
 	Qseqs *header, *qseq, *qual, *header2, *qseq2, *qual2;
 	FileBuff *inputfile;
 	CompDNA *compressor;
@@ -365,9 +370,9 @@ long unsigned run_input_INT(char **inputfiles, int fileCount, int minPhred, int
 		/* parse the file */
 		if(FASTQ & 1) {
 			/* get phred scale */
-			phredCut = getPhredFileBuff(inputfile);
-			fprintf(stderr, "# Phred scale:\t%d\n", phredCut);
-			phredCut += minPhred;
+			phredScale = getPhredFileBuff(inputfile);
+			fprintf(stderr, "# Phred scale:\t%d\n", phredScale);
+			phredCut = phredScale + minPhred;
 			
 			/* parse reads */
 			while((FileBuffgetFq(inputfile, header, qseq, qual, trans) | FileBuffgetFq(inputfile, header2, qseq2, qual2, trans))) {
@@ -391,6 +396,7 @@ long unsigned run_input_INT(char **inputfiles, int fileCount, int minPhred, int
 				}
 				*/
 				qseq->len = end - start;
+				eq1 = eQual(seq + start, qseq->len, minQ, prob - phredScale);
 				
 				/* trim reverse */
 				seq = qual2->seq;
@@ -411,21 +417,22 @@ long unsigned run_input_INT(char **inputfiles, int fileCount, int minPhred, int
 				}
 				*/
 				qseq2->len = end - start2;
+				eq2 = eQual(seq + start2, qseq2->len, minQ, prob - phredScale);
 				
 				/* print */
-				if(qseq->len > minlen && qseq2->len > minlen) {
+				if(qseq->len > minlen && qseq2->len > minlen && minQ <= eq1 && minQ <= eq2) {
 					qseq->seq += start;
 					qseq2->seq += start2;
 					printFsa_pair_ptr(header, qseq, header2, qseq2, compressor, out);
 					qseq->seq -= start;
 					qseq2->seq -= start2;
 					++count;
-				} else if(qseq->len > minlen) {
+				} else if(qseq->len > minlen && minQ <= eq1) {
 					qseq->seq += start;
 					printFsa_ptr(header, qseq, compressor, out);
 					qseq->seq -= start;
 					++count;
-				} else if(qseq2->len > minlen) {
+				} else if(qseq2->len > minlen && minQ <= eq2) {
 					qseq2->seq += start2;
 					printFsa_ptr(header2, qseq2, compressor, out);
 					qseq2->seq -= start2;


=====================================
runinput.h
=====================================
@@ -23,9 +23,9 @@
 /* pointers determining how to deliver the input */
 extern void (*printFsa_ptr)(Qseqs*, Qseqs*, CompDNA*, FILE*);
 extern void (*printFsa_pair_ptr)(Qseqs*, Qseqs*, Qseqs*, Qseqs*, CompDNA*, FILE*);
-long unsigned run_input(char **inputfiles, int fileCount, int minPhred, int fiveClip, int threeClip, int minlen, char *trans, FILE *out);
-long unsigned run_input_PE(char **inputfiles, int fileCount, int minPhred, int fiveClip, int threeClip, int minlen, char *trans, FILE *out);
-long unsigned run_input_INT(char **inputfiles, int fileCount, int minPhred, int fiveClip, int threeClip, int minlen, char *trans, FILE *out);
+long unsigned run_input(char **inputfiles, int fileCount, int minPhred, int minQ, int fiveClip, int threeClip, int minlen, char *trans, const double *prob, FILE *out);
+long unsigned run_input_PE(char **inputfiles, int fileCount, int minPhred, int minQ, int fiveClip, int threeClip, int minlen, char *trans, const double *prob, FILE *out);
+long unsigned run_input_INT(char **inputfiles, int fileCount, int minPhred, int minQ, int fiveClip, int threeClip, int minlen, char *trans, const double *prob, FILE *out);
 void bootFsa(Qseqs *header, Qseqs *qseq, CompDNA *compressor, FILE *out);
 void printFsa(Qseqs *header, Qseqs *qseq, CompDNA *compressor, FILE *out);
 void printFsa_pair(Qseqs *header, Qseqs *qseq, Qseqs *header_r, Qseqs *qseq_r, CompDNA *compressor, FILE *out);


=====================================
sparse.c
=====================================
@@ -226,9 +226,9 @@ void save_kmers_sparse(const HashMapKMA *templates, HashMap_kmers *foundKmers, C
 	}
 }
 
-void run_input_sparse(const HashMapKMA *templates, char **inputfiles, int fileCount, int minPhred, int fiveClip, int threeClip, int kmersize, char *trans, FILE *out) {
+void run_input_sparse(const HashMapKMA *templates, char **inputfiles, int fileCount, int minPhred, int minQ, int fiveClip, int threeClip, int kmersize, char *trans, const double *prob, FILE *out) {
 	
-	int FASTQ, fileCounter, phredCut, start, end;
+	int FASTQ, fileCounter, phredScale, phredCut, start, end;
 	char *filename;
 	unsigned char *seq;
 	Qseqs *qseq, *qual;
@@ -254,9 +254,9 @@ void run_input_sparse(const HashMapKMA *templates, char **inputfiles, int fileCo
 		Kmers->n = 0;
 		if(FASTQ & 1) {
 			/* get phred scale */
-			phredCut = getPhredFileBuff(inputfile);
-			fprintf(stderr, "# Phred scale:\t%d\n", phredCut);
-			phredCut += minPhred;
+			phredScale = getPhredFileBuff(inputfile);
+			fprintf(stderr, "# Phred scale:\t%d\n", phredScale);
+			phredCut = phredScale + minPhred;
 			
 			/* parse reads */
 			while(FileBuffgetFqSeq(inputfile, qseq, qual, trans)) {
@@ -275,7 +275,7 @@ void run_input_sparse(const HashMapKMA *templates, char **inputfiles, int fileCo
 				qseq->len = end - start;
 				
 				/* print */
-				if(qseq->len > kmersize) {
+				if(qseq->len > kmersize && minQ <= eQual(seq + start, qseq->len, minQ, prob - phredScale)) {
 					/* translate to kmers */
 					Kmers->n = translateToKmersAndDump(Kmers->kmers, Kmers->n, Kmers->size, qseq->seq + start, qseq->len, kmersize, templates->mask, templates->prefix, templates->prefix_len, out);
 				}


=====================================
sparse.h
=====================================
@@ -24,5 +24,5 @@
 int translateToKmersAndDump(long unsigned *Kmers, int n, int max, unsigned char *qseq, int seqlen, int kmersize, long unsigned mask, long unsigned prefix, int prefix_len, FILE *out);
 char ** load_DBs_Sparse(char *templatefilename, unsigned **template_lengths, unsigned **template_ulengths, unsigned shm);
 void save_kmers_sparse(const HashMapKMA *templates, HashMap_kmers *foundKmers, CompKmers *compressor);
-void run_input_sparse(const HashMapKMA *templates, char **inputfiles, int fileCount, int minPhred, int fiveClip, int threeClip, int kmersize, char *trans, FILE *out);
+void run_input_sparse(const HashMapKMA *templates, char **inputfiles, int fileCount, int minPhred, int minQ, int fiveClip, int threeClip, int kmersize, char *trans, const double *prob, FILE *out);
 int save_kmers_sparse_batch(char *templatefilename, char *outputfilename, char *exePrev, int ID_t, double evalue, char ss, unsigned shm);


=====================================
stdstat.c
=====================================
@@ -210,3 +210,68 @@ unsigned minimum(unsigned *src, unsigned n) {
 	
 	return min;
 }
+
+/*
+double eQual(unsigned char *qual, int len, int phredScale, int minQ) {
+	
+	//E(Q) = -10 * log_10(sum(10^(-Q/10)) / |Q|) 
+	unsigned i;
+	double sum;
+	
+	if(!len || !minQ) {
+		return 0;
+	}
+	
+	// sum quality scores
+	i = len;
+	sum = pow(10, (phredScale - *qual) / 10.0);
+	while(--i) {
+		sum += pow(10, (phredScale - *++qual) / 10.0);
+	}
+	
+	// return average
+	return -10 * log10(((double)(sum)) / len);
+}
+*/
+
+double eQual(unsigned char *qual, const int len, const int minQ, const double *prob) {
+	
+	/*
+	static const double prob[128] = {
+		1.0000000000000000, 0.7943282347242815, 0.6309573444801932, 0.5011872336272722, 0.3981071705534972, 0.3162277660168379, 0.2511886431509580, 0.1995262314968880,
+		0.1584893192461113, 0.1258925411794167, 0.1000000000000000, 0.0794328234724281, 0.0630957344480193, 0.0501187233627272, 0.0398107170553497, 0.0316227766016838,
+		0.0251188643150958, 0.0199526231496888, 0.0158489319246111, 0.0125892541179417, 0.0100000000000000, 0.0079432823472428, 0.0063095734448019, 0.0050118723362727,
+		0.0039810717055350, 0.0031622776601684, 0.0025118864315096, 0.0019952623149689, 0.0015848931924611, 0.0012589254117942, 0.0010000000000000, 0.0007943282347243,
+		0.0006309573444802, 0.0005011872336273, 0.0003981071705535, 0.0003162277660168, 0.0002511886431510, 0.0001995262314969, 0.0001584893192461, 0.0001258925411794,
+		0.0001000000000000, 0.0000794328234724, 0.0000630957344480, 0.0000501187233627, 0.0000398107170553, 0.0000316227766017, 0.0000251188643151, 0.0000199526231497,
+		0.0000158489319246, 0.0000125892541179, 0.0000100000000000, 0.0000079432823472, 0.0000063095734448, 0.0000050118723363, 0.0000039810717055, 0.0000031622776602,
+		0.0000025118864315, 0.0000019952623150, 0.0000015848931925, 0.0000012589254118, 0.0000010000000000, 0.0000007943282347, 0.0000006309573445, 0.0000005011872336,
+		0.0000003981071706, 0.0000003162277660, 0.0000002511886432, 0.0000001995262315, 0.0000001584893192, 0.0000001258925412, 0.0000001000000000, 0.0000000794328235,
+		0.0000000630957344, 0.0000000501187234, 0.0000000398107171, 0.0000000316227766, 0.0000000251188643, 0.0000000199526231, 0.0000000158489319, 0.0000000125892541,
+		0.0000000100000000, 0.0000000079432823, 0.0000000063095734, 0.0000000050118723, 0.0000000039810717, 0.0000000031622777, 0.0000000025118864, 0.0000000019952623,
+		0.0000000015848932, 0.0000000012589254, 0.0000000010000000, 0.0000000007943282, 0.0000000006309573, 0.0000000005011872, 0.0000000003981072, 0.0000000003162278,
+		0.0000000002511886, 0.0000000001995262, 0.0000000001584893, 0.0000000001258925, 0.0000000001000000, 0.0000000000794328, 0.0000000000630957, 0.0000000000501187,
+		0.0000000000398107, 0.0000000000316228, 0.0000000000251189, 0.0000000000199526, 0.0000000000158489, 0.0000000000125893, 0.0000000000100000, 0.0000000000079433,
+		0.0000000000063096, 0.0000000000050119, 0.0000000000039811, 0.0000000000031623, 0.0000000000025119, 0.0000000000019953, 0.0000000000015849, 0.0000000000012589,
+		0.0000000000010000, 0.0000000000007943, 0.0000000000006310, 0.0000000000005012, 0.0000000000003981, 0.0000000000003162, 0.0000000000002512, 0.0000000000001995};
+	*/
+	/*
+	E(Q) = -10 * log_10(sum(10^(-Q/10)) / |Q|) 
+	*/
+	unsigned i;
+	double sum;
+	
+	if(!len || !minQ) {
+		return 0;
+	}
+	
+	/* sum quality scores */
+	i = len;
+	sum = prob[*qual];
+	while(--i) {
+		sum += prob[*++qual];
+	}
+	
+	/* return average */
+	return -10 * log10(sum / len);
+}


=====================================
stdstat.h
=====================================
@@ -28,3 +28,4 @@ double p_chisqr(long double q);
 double power(double x, unsigned n);
 double binP(int n, int k, double p);
 unsigned minimum(unsigned *src, unsigned n);
+double eQual(unsigned char *qual, const int len, const int minQ, const double *prob);


=====================================
version.h
=====================================
@@ -17,4 +17,4 @@
  * limitations under the License.
 */
 
-#define KMA_VERSION "1.3.8"
+#define KMA_VERSION "1.3.9"



View it on GitLab: https://salsa.debian.org/med-team/kma/-/commit/45e840d81b2475212eecbc8a371d7ee587aa6c71

-- 
View it on GitLab: https://salsa.debian.org/med-team/kma/-/commit/45e840d81b2475212eecbc8a371d7ee587aa6c71
You're receiving this email because of your account on salsa.debian.org.


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/debian-med-commit/attachments/20201204/dffc11af/attachment-0001.html>


More information about the debian-med-commit mailing list