File: ProcessFragMerging.java

package info (click to toggle)
bbmap 39.20%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 26,024 kB
  • sloc: java: 312,743; sh: 18,099; python: 5,247; ansic: 2,074; perl: 96; makefile: 39; xml: 38
file content (56 lines) | stat: -rwxr-xr-x 1,727 bytes parent folder | download | duplicates (2)
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
package driver;

import fileIO.TextFile;
import shared.Tools;

/**
 * For BBMerge comparison data collation
 * @author Brian Bushnell
 * @date Mar 15, 2016
 *
 */
public class ProcessFragMerging {
	
	public static void main(String[] args){
		
		String sym="\t";
		
		String fname=args[0];
		TextFile tf=new TextFile(fname);
		for(String line=tf.nextLine(); line!=null; line=tf.nextLine()){
			String[] split=line.split("\\p{javaWhitespace}+");
			if(line.startsWith("***")){
				System.out.print("\n"+split[1]+sym);
//				System.out.println("\n"+line);
			}else if(line.startsWith("real")){
				String time=line.split("\t")[1];
				double seconds=toSeconds(time);
				System.out.print(Tools.format("%.3f", seconds)+sym);
			}else if(line.startsWith("Reads Used:")){
				System.out.print(split[2]+sym+split[3].substring(1)+sym);
			}else if(line.startsWith("mapped:")){
				System.out.print(split[2]+sym+split[4]+sym);
			}else if(line.startsWith("Error Rate:")){
				System.out.print(split[3]+sym+split[5]+sym);
			}else if(line.startsWith("Sub Rate:")){
				System.out.print(split[3]+sym+split[5]+sym);
			}else if(line.startsWith("Del Rate:")){
				System.out.print(split[3]+sym+split[5]+sym);
			}else if(line.startsWith("Ins Rate:")){
				System.out.print(split[3]+sym+split[5]+sym);
			}
//				Del Rate:        	  0.0161% 	      168 	  0.0276% 	       64385
//				Ins Rate:        	  0.0017% 	       18 	  0.0002% 	         366
			
		}
		
	}
	
	public static double toSeconds(String s){
		s=s.replaceAll("s", "");
		String[] split=s.split("m");
		String seconds=split[1], minutes=split[0];
		return 60*Double.parseDouble(minutes)+Double.parseDouble(seconds);
	}
	
}