/*
* The MIT License (MIT)
*
* Copyright (c) 2007-2015 Broad Institute
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package org.broad.igv.tdf;
import org.broad.igv.util.StringUtils;
import java.io.IOException;
import java.nio.ByteBuffer;
/**
* @author jrobinso
*/
public class TDFBedTile implements TDFTile {
int tileStart;
private int[] start;
private int[] end;
private float[][] data;
private String[] names;
public TDFBedTile(ByteBuffer byteBuffer, int nSamples, TDFTile.Type type) throws IOException {
this.fill(byteBuffer, nSamples, type);
}
public TDFBedTile(int tileStart, int[] start, int[] end, float[][] data) {
this.tileStart = tileStart;
this.start = start;
this.end = end;
this.data = data;
}
public TDFBedTile(int tileStart, int[] start, int[] end, float[][] data, String[] name) {
this(tileStart, start, end, data);
this.names = name;
}
public int getSize() {
return start.length;
}
public int getTileStart() {
return tileStart;
}
public int getTileEnd() {
return getSize() == 0 ? 0 : getEndPosition(getSize() - 1);
}
public int getStartPosition(int idx) {
return start[idx];
}
public int getEndPosition(int idx) {
return end[idx];
}
public String getName(int idx) {
return names == null ? null : names[idx];
}
public float getValue(int row, int idx) {
return data[row][idx];
}
public void writeTo(BufferedByteWriter fos) throws IOException {
// File type
TDFTile.Type type = names == null ? TDFTile.Type.bed : TDFTile.Type.bedWithName;
fos.putNullTerminatedString(type.toString());
int nPositions = start.length;
int nSamples = data.length;
fos.putInt(nPositions);
for (int i = 0; i < nPositions; i++) {
fos.putInt(start[i]);
}
for (int i = 0; i < nPositions; i++) {
fos.putInt(end[i]);
}
fos.putInt(nSamples);
for (int i = 0; i < data.length; i++) {
for (int j = 0; j < data[i].length; j++) {
fos.putFloat(data[i][j]);
}
}
// Optionally record feature names
if (type == TDFTile.Type.bedWithName) {
for (int i = 0; i < nPositions; i++) {
fos.putNullTerminatedString(names[i]);
}
}
}
private void fill(ByteBuffer byteBuffer, int nSamples, TDFTile.Type type) throws IOException {
int nPositions = byteBuffer.getInt();
start = new int[nPositions];
for (int i = 0; i < nPositions; i++) {
start[i] = byteBuffer.getInt();
}
end = new int[nPositions];
for (int i = 0; i < nPositions; i++) {
end[i] = byteBuffer.getInt();
}
int nS = byteBuffer.getInt();
//assert (nS == nSamples);
data = new float[nS][nPositions];
for (int row = 0; row < nS; row++) {
data[row] = new float[nPositions];
for (int i = 0; i < nPositions; i++) {
data[row][i] = byteBuffer.getFloat();
}
}
// Optionally read feature names
if (type == TDFTile.Type.bedWithName) {
names = new String[nPositions];
for (int i = 0; i < nPositions; i++) {
names[i] = StringUtils.readString(byteBuffer);
}
}
}
public int[] getStart() {
return start;
}
public int[] getEnd() {
return end;
}
public float[] getData(int trackNumber) {
return data[trackNumber];
}
public String[] getNames() {
return names;
}
}