/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package data.cerevisiae.histmod.cai2011;
import fork.lib.base.file.FileName;
import fork.lib.base.file.io.txt.MarkEntry;
import fork.lib.base.file.io.txt.MarkReader;
import fork.lib.base.file.management.Dirs;
import fork.lib.bio.anno.genomic.BedGraphExporter;
import fork.lib.bio.anno.genomic.LandscapeBuilder;
import fork.lib.math.algebra.elementary.set.continuous.Region;
import java.io.File;
import java.util.ArrayList;
/**
*
* @author forksapien
*/
public class ToWig {
public static void main(String[] args) throws Exception { //debug
File dir= Dirs.getFile("dir");
File d= new File(dir+"/other_datasets/cai_2011_h3k9ac");
File f= new File(d+"/GSM711896.wig"), out=new File(d+"/h3k9ac_cai2011.wig");
MarkReader mr= new MarkReader(f, "variableStep");
MarkEntry en;
LandscapeBuilder lb= new LandscapeBuilder();
while((en=mr.nextEntry())!=null){
String chr= en.tit.split("chrom=")[1].split("\t")[0];
if(!chr.equals("chrM")){
ArrayList<String> rs= en.chunk;
int ps= 1;
for( int i=0; i<rs.size(); i++ ){
String l=rs.get(i);
if(l.length()>0 && l.charAt(0)!='#'){
String[] ss= l.split("\t");
if(ss.length==2){
int p= Integer.parseInt(ss[0]);
double v= Double.parseDouble(ss[1]);
if(p<ps){
System.out.println(chr+" "+ p+" "+ v);
}
Region reg= new Region(ps, p);
reg.setAttribute(v);
lb.add(chr, reg);
ps= p+1;
}
}
}
}
}
BedGraphExporter be =new BedGraphExporter(lb);
be.param().tit= FileName.getBaseName(out);
be.writeToFile(out);
}
}