File: PolymerTrimmer.java

package info (click to toggle)
bbmap 39.01%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 21,760 kB
  • sloc: java: 267,418; sh: 15,163; python: 5,247; ansic: 2,074; perl: 96; xml: 38; makefile: 38
file content (76 lines) | stat: -rwxr-xr-x 1,827 bytes parent folder | download | duplicates (4)
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
package icecream;

public class PolymerTrimmer {
	
	public static boolean parse(String arg, String a, String b){
		if(a.equalsIgnoreCase("minPolymer")){
			minPolymer=Integer.parseInt(b);
		}else if(a.equalsIgnoreCase("minFraction")){
			float f=Float.parseFloat(b);
			setMinFraction(f);
		}else if(a.equalsIgnoreCase("polyerror")){
			float f=Float.parseFloat(b);
			setMinFraction(1-f);
		}else{
			return false;
		}
		return true;
	}
	
	public static int testLeft(byte[] bases, char symbol){return testLeft(bases, (byte)symbol);}
	
	public static int testLeft(byte[] bases, byte symbol){
		float score=0;
		float max=0;
		int maxPos=-1;
		for(int i=0; i<bases.length && score>=minScore; i++){
			byte b=bases[i];
			if(b==symbol){
				score++;
				if(score>max){
					max=score;
					maxPos=i;
				}
			}else{
				score-=penalty;
			}
		}
		int trim=maxPos+1;
		return (trim<minPolymer ? 0 : trim);
	}
	
	public static int testRight(byte[] bases, char symbol){return testRight(bases, (byte)symbol);}
	
	public static int testRight(byte[] bases, byte symbol){
		float score=0;
		float max=0;
		int maxPos=bases.length;
		for(int i=bases.length-1; i>=0 && score>=minScore; i--){
			byte b=bases[i];
			if(b==symbol){
				score++;
				if(score>max){
					max=score;
					maxPos=i;
				}
			}else{
				score-=penalty;
			}
		}
		int trim=bases.length-maxPos;
		return (trim<minPolymer ? 0 : trim);
	}
	
	public static void setMinFraction(float f){
		assert(f>=0 && f<=1) : f;
		minFraction=f;
		penalty=(f>=1 ? 99 : ((1f/(1-minFraction))-1));
		minScore=(f>=1 ? 0 : -4*penalty);
	}
	
	static int minPolymer=5;
	private static float minFraction=0.8f;
	private static float penalty=(1f/(1-minFraction))-1;
	private static float minScore=-4*penalty;
	
}