public class SAMRecord extends java.lang.Object implements java.lang.Cloneable, Locatable, java.io.Serializable
Modifier and Type | Class and Description |
---|---|
static class |
SAMRecord.SAMTagAndValue
Tag name and value of an attribute, for getAttributes() method.
|
Modifier and Type | Field and Description |
---|---|
static int |
MAX_INSERT_SIZE
abs(insertSize) must be <= this
|
protected java.lang.Integer |
mMateReferenceIndex |
protected java.lang.Integer |
mReferenceIndex |
static java.lang.String |
NO_ALIGNMENT_CIGAR
Cigar string for an unaligned read.
|
static int |
NO_ALIGNMENT_REFERENCE_INDEX
If a read has this reference index, it is unaligned, but not all unaligned reads have
this reference index (see above).
|
static java.lang.String |
NO_ALIGNMENT_REFERENCE_NAME
If a read has this reference name, it is unaligned, but not all unaligned reads have
this reference name (see above).
|
static int |
NO_ALIGNMENT_START
If a read has reference name "*", it will have this value for position.
|
static int |
NO_MAPPING_QUALITY
Alignment score for an unaligned read.
|
static byte[] |
NULL_QUALS
This should rarely be used, since all reads should have quality scores.
|
static java.lang.String |
NULL_QUALS_STRING |
static byte[] |
NULL_SEQUENCE
This should rarely be used, since a read with no sequence doesn't make much sense.
|
static java.lang.String |
NULL_SEQUENCE_STRING |
static long |
serialVersionUID |
static int |
UNKNOWN_MAPPING_QUALITY
Alignment score for a good alignment, but where computing a Phred-score is not feasible.
|
Constructor and Description |
---|
SAMRecord(SAMFileHeader header) |
Modifier and Type | Method and Description |
---|---|
void |
clearAttributes()
Removes all attributes.
|
java.lang.Object |
clone()
Note that this does a shallow copy of everything, except for the attribute list, for which a copy of the list
is made, but the attributes themselves are copied by reference.
|
protected void |
eagerDecode()
Force all lazily-initialized data members to be initialized.
|
boolean |
equals(java.lang.Object o) |
java.lang.String |
format()
Deprecated.
This method is not guaranteed to return a valid SAM text representation of the SAMRecord.
To get standard SAM text representation, use htsjdk.samtools.SAMRecord#getSAMString().
|
java.util.List<AlignmentBlock> |
getAlignmentBlocks()
Returns blocks of the read sequence that have been aligned directly to the
reference sequence.
|
int |
getAlignmentEnd() |
int |
getAlignmentStart() |
java.lang.Object |
getAttribute(short tag) |
java.lang.Object |
getAttribute(java.lang.String tag)
Get the value for a SAM tag.
|
java.util.List<SAMRecord.SAMTagAndValue> |
getAttributes() |
int |
getAttributesBinarySize()
Depending on the concrete implementation, the binary file size of attributes may be known without
computing them all.
|
byte[] |
getBaseQualities()
Do not modify the value returned by this method.
|
java.lang.String |
getBaseQualityString() |
protected SAMBinaryTagAndValue |
getBinaryAttributes() |
byte[] |
getByteArrayAttribute(java.lang.String tag)
Will work for signed byte array, unsigned byte array, or old-style hex array
|
java.lang.Byte |
getByteAttribute(java.lang.String tag)
Get the tag value and attempt to coerce it into the requested type.
|
java.lang.Character |
getCharacterAttribute(java.lang.String tag) |
Cigar |
getCigar()
Do not modify the value returned by this method.
|
int |
getCigarLength()
This method is preferred over getCigar().getNumElements(), because for BAMRecord it may be faster.
|
java.lang.String |
getCigarString() |
java.lang.String |
getContig()
Gets the contig name for the contig this is mapped to.
|
boolean |
getDuplicateReadFlag()
the read is either a PCR duplicate or an optical duplicate.
|
int |
getEnd()
an alias of
getAlignmentEnd() |
SAMFileSource |
getFileSource()
Gets the source of this SAM record -- both the reader that retrieved the record and the position on disk from
whence it came.
|
boolean |
getFirstOfPairFlag()
the read is the first read in a pair.
|
int |
getFlags()
It is preferable to use the get*Flag() methods that handle the flag word symbolically.
|
float[] |
getFloatArrayAttribute(java.lang.String tag) |
java.lang.Float |
getFloatAttribute(java.lang.String tag) |
SAMFileHeader |
getHeader() |
int |
getInferredInsertSize() |
java.lang.Integer |
getIntegerAttribute(java.lang.String tag)
Get the tag value and attempt to coerce it into the requested type.
|
int |
getMappingQuality() |
int |
getMateAlignmentStart() |
boolean |
getMateNegativeStrandFlag()
strand of the mate (false for forward; true for reverse strand).
|
java.lang.Integer |
getMateReferenceIndex() |
java.lang.String |
getMateReferenceName() |
boolean |
getMateUnmappedFlag()
the mate is unmapped.
|
boolean |
getNotPrimaryAlignmentFlag()
the alignment is not primary (a read having split hits may have multiple primary alignment records).
|
byte[] |
getOriginalBaseQualities()
If the original base quality scores have been store in the "OQ" tag will return the numeric
score as a byte[]
|
java.lang.String |
getPairedReadName() |
boolean |
getProperPairFlag()
the read is mapped in a proper pair (depends on the protocol, normally inferred during alignment).
|
byte[] |
getReadBases()
Do not modify the value returned by this method.
|
boolean |
getReadFailsVendorQualityCheckFlag()
the read fails platform/vendor quality checks.
|
SAMReadGroupRecord |
getReadGroup()
Get the SAMReadGroupRecord for this SAMRecord.
|
int |
getReadLength()
This method is preferred over getReadBases().length, because for BAMRecord it may be faster.
|
java.lang.String |
getReadName() |
int |
getReadNameLength()
This method is preferred over getReadName().length(), because for BAMRecord
it may be faster.
|
boolean |
getReadNegativeStrandFlag()
strand of the query (false for forward; true for reverse strand).
|
boolean |
getReadPairedFlag()
the read is paired in sequencing, no matter whether it is mapped in a pair.
|
java.lang.String |
getReadString() |
boolean |
getReadUnmappedFlag()
the query sequence itself is unmapped.
|
java.lang.Integer |
getReferenceIndex() |
java.lang.String |
getReferenceName() |
int |
getReferencePositionAtReadPosition(int offset) |
java.lang.String |
getSAMString()
Returns the record in the SAM line-based text format.
|
boolean |
getSecondOfPairFlag()
the read is the second read in a pair.
|
java.lang.Short |
getShortAttribute(java.lang.String tag)
Get the tag value and attempt to coerce it into the requested type.
|
byte[] |
getSignedByteArrayAttribute(java.lang.String tag)
Will work for signed byte array or old-style hex array
|
int[] |
getSignedIntArrayAttribute(java.lang.String tag) |
short[] |
getSignedShortArrayAttribute(java.lang.String tag) |
int |
getStart()
an alias of {@link #getAlignmentStart()
|
java.lang.String |
getStringAttribute(java.lang.String tag) |
boolean |
getSupplementaryAlignmentFlag()
the alignment is supplementary (TODO: further explanation?).
|
int |
getUnclippedEnd() |
int |
getUnclippedStart() |
byte[] |
getUnsignedByteArrayAttribute(java.lang.String tag) |
int[] |
getUnsignedIntArrayAttribute(java.lang.String tag) |
short[] |
getUnsignedShortArrayAttribute(java.lang.String tag) |
ValidationStringency |
getValidationStringency() |
byte[] |
getVariableBinaryRepresentation()
If this record has a valid binary representation of the variable-length portion of a binary record stored,
return that byte array, otherwise return null.
|
int |
hashCode() |
protected void |
initializeCigar(Cigar cigar)
For setting the Cigar string when BAMRecord has decoded it.
|
boolean |
isSecondaryOrSupplementary()
Tests if this record is either a secondary and/or supplementary alignment;
equivalent to
(getNotPrimaryAlignmentFlag() || getSupplementaryAlignmentFlag()) . |
boolean |
isUnsignedArrayAttribute(java.lang.String tag) |
java.util.List<SAMValidationError> |
isValid()
Perform various validations of SAMRecord.
|
java.util.List<SAMValidationError> |
isValid(boolean firstOnly)
Perform various validations of SAMRecord.
|
void |
setAlignmentStart(int value) |
protected void |
setAttribute(short tag,
java.lang.Object value) |
protected void |
setAttribute(short tag,
java.lang.Object value,
boolean isUnsignedArray) |
void |
setAttribute(java.lang.String tag,
java.lang.Object value)
Set a named attribute onto the SAMRecord.
|
protected void |
setAttributes(SAMBinaryTagAndValue attributes)
Replace any existing attributes with the given linked item.
|
void |
setBaseQualities(byte[] value) |
void |
setBaseQualityString(java.lang.String value) |
void |
setCigar(Cigar cigar) |
void |
setCigarString(java.lang.String value) |
void |
setDuplicateReadFlag(boolean flag)
the read is either a PCR duplicate or an optical duplicate.
|
protected void |
setFileSource(SAMFileSource fileSource)
Sets a marker providing the source reader for this file and the position in the file from which the read originated.
|
void |
setFirstOfPairFlag(boolean flag)
the read is the first read in a pair.
|
void |
setFlags(int value) |
void |
setHeader(SAMFileHeader header)
Setting header into SAMRecord facilitates conversion btw reference sequence names and indices
|
void |
setInferredInsertSize(int inferredInsertSize) |
void |
setMappingQuality(int value) |
void |
setMateAlignmentStart(int mateAlignmentStart) |
void |
setMateNegativeStrandFlag(boolean flag)
strand of the mate (false for forward; true for reverse strand).
|
void |
setMateReferenceIndex(int referenceIndex) |
void |
setMateReferenceName(java.lang.String mateReferenceName) |
void |
setMateUnmappedFlag(boolean flag)
the mate is unmapped.
|
void |
setNotPrimaryAlignmentFlag(boolean flag)
the alignment is not primary (a read having split hits may have multiple primary alignment records).
|
void |
setOriginalBaseQualities(byte[] oq)
Sets the original base quality scores into the "OQ" tag as a String.
|
void |
setProperPairFlag(boolean flag)
the read is mapped in a proper pair (depends on the protocol, normally inferred during alignment).
|
void |
setReadBases(byte[] value) |
void |
setReadFailsVendorQualityCheckFlag(boolean flag)
the read fails platform/vendor quality checks.
|
void |
setReadName(java.lang.String value) |
void |
setReadNegativeStrandFlag(boolean flag)
strand of the query (false for forward; true for reverse strand).
|
void |
setReadPairedFlag(boolean flag)
the read is paired in sequencing, no matter whether it is mapped in a pair.
|
void |
setReadString(java.lang.String value) |
void |
setReadUmappedFlag(boolean flag)
Deprecated.
|
void |
setReadUnmappedFlag(boolean flag)
the query sequence itself is unmapped.
|
void |
setReferenceIndex(int referenceIndex) |
void |
setReferenceName(java.lang.String value) |
void |
setSecondOfPairFlag(boolean flag)
the read is the second read in a pair.
|
void |
setSupplementaryAlignmentFlag(boolean flag)
the alignment is supplementary (TODO: further explanation?).
|
void |
setUnsignedArrayAttribute(java.lang.String tag,
java.lang.Object value)
Because Java does not support unsigned integer types, we think it is a bad idea to encode them in SAM
files.
|
void |
setValidationStringency(ValidationStringency validationStringency)
Control validation of lazily-decoded elements.
|
java.lang.String |
toString()
Simple toString() that gives a little bit of useful info about the read.
|
java.util.List<SAMValidationError> |
validateCigar(long recordNumber)
Run all validations of CIGAR.
|
public static final long serialVersionUID
public static final int UNKNOWN_MAPPING_QUALITY
public static final int NO_MAPPING_QUALITY
public static final java.lang.String NO_ALIGNMENT_REFERENCE_NAME
public static final int NO_ALIGNMENT_REFERENCE_INDEX
public static final java.lang.String NO_ALIGNMENT_CIGAR
public static final int NO_ALIGNMENT_START
public static final byte[] NULL_SEQUENCE
public static final java.lang.String NULL_SEQUENCE_STRING
public static final byte[] NULL_QUALS
public static final java.lang.String NULL_QUALS_STRING
public static final int MAX_INSERT_SIZE
protected java.lang.Integer mReferenceIndex
protected java.lang.Integer mMateReferenceIndex
public SAMRecord(SAMFileHeader header)
public java.lang.String getReadName()
public int getReadNameLength()
public void setReadName(java.lang.String value)
public java.lang.String getReadString()
public void setReadString(java.lang.String value)
public byte[] getReadBases()
public void setReadBases(byte[] value)
public int getReadLength()
public java.lang.String getBaseQualityString()
public void setBaseQualityString(java.lang.String value)
public byte[] getBaseQualities()
public void setBaseQualities(byte[] value)
public byte[] getOriginalBaseQualities()
public void setOriginalBaseQualities(byte[] oq)
public java.lang.String getReferenceName()
public void setReferenceName(java.lang.String value)
public java.lang.Integer getReferenceIndex()
public void setReferenceIndex(int referenceIndex)
referenceIndex
- Must either equal -1 (indicating no reference), or exist in the sequence dictionary
in the header associated with this record.public java.lang.String getMateReferenceName()
public void setMateReferenceName(java.lang.String mateReferenceName)
public java.lang.Integer getMateReferenceIndex()
public void setMateReferenceIndex(int referenceIndex)
referenceIndex
- Must either equal -1 (indicating no reference), or exist in the sequence dictionary
in the header associated with this record.public int getAlignmentStart()
public void setAlignmentStart(int value)
value
- 1-based inclusive leftmost position of the clipped sequence, or 0 if there is no position.public int getAlignmentEnd()
public int getUnclippedStart()
public int getUnclippedEnd()
public int getReferencePositionAtReadPosition(int offset)
public int getMateAlignmentStart()
public void setMateAlignmentStart(int mateAlignmentStart)
public int getInferredInsertSize()
public void setInferredInsertSize(int inferredInsertSize)
public int getMappingQuality()
public void setMappingQuality(int value)
public java.lang.String getCigarString()
public void setCigarString(java.lang.String value)
public Cigar getCigar()
public int getCigarLength()
public void setCigar(Cigar cigar)
protected void initializeCigar(Cigar cigar)
public SAMReadGroupRecord getReadGroup()
java.lang.NullPointerException
- if this.getHeader() returns null.java.lang.ClassCastException
- if RG tag does not have a String value.public int getFlags()
public void setFlags(int value)
public boolean getReadPairedFlag()
public boolean getProperPairFlag()
public boolean getReadUnmappedFlag()
public boolean getMateUnmappedFlag()
public boolean getReadNegativeStrandFlag()
public boolean getMateNegativeStrandFlag()
public boolean getFirstOfPairFlag()
public boolean getSecondOfPairFlag()
public boolean getNotPrimaryAlignmentFlag()
public boolean getSupplementaryAlignmentFlag()
public boolean getReadFailsVendorQualityCheckFlag()
public boolean getDuplicateReadFlag()
public void setReadPairedFlag(boolean flag)
public void setProperPairFlag(boolean flag)
public void setReadUmappedFlag(boolean flag)
public void setReadUnmappedFlag(boolean flag)
public void setMateUnmappedFlag(boolean flag)
public void setReadNegativeStrandFlag(boolean flag)
public void setMateNegativeStrandFlag(boolean flag)
public void setFirstOfPairFlag(boolean flag)
public void setSecondOfPairFlag(boolean flag)
public void setNotPrimaryAlignmentFlag(boolean flag)
public void setSupplementaryAlignmentFlag(boolean flag)
public void setReadFailsVendorQualityCheckFlag(boolean flag)
public void setDuplicateReadFlag(boolean flag)
public boolean isSecondaryOrSupplementary()
(getNotPrimaryAlignmentFlag() || getSupplementaryAlignmentFlag())
.public ValidationStringency getValidationStringency()
public void setValidationStringency(ValidationStringency validationStringency)
public java.lang.Object getAttribute(java.lang.String tag)
tag
- Two-character tag name.public java.lang.Integer getIntegerAttribute(java.lang.String tag)
tag
- The requested tag.java.lang.RuntimeException
- If the value is not an integer type, or will not fit in an Integer.public java.lang.Short getShortAttribute(java.lang.String tag)
tag
- The requested tag.java.lang.RuntimeException
- If the value is not an integer type, or will not fit in a Short.public java.lang.Byte getByteAttribute(java.lang.String tag)
tag
- The requested tag.java.lang.RuntimeException
- If the value is not an integer type, or will not fit in a Byte.public java.lang.String getStringAttribute(java.lang.String tag)
public java.lang.Character getCharacterAttribute(java.lang.String tag)
public java.lang.Float getFloatAttribute(java.lang.String tag)
public byte[] getByteArrayAttribute(java.lang.String tag)
public byte[] getUnsignedByteArrayAttribute(java.lang.String tag)
public byte[] getSignedByteArrayAttribute(java.lang.String tag)
public short[] getUnsignedShortArrayAttribute(java.lang.String tag)
public short[] getSignedShortArrayAttribute(java.lang.String tag)
public int[] getUnsignedIntArrayAttribute(java.lang.String tag)
public int[] getSignedIntArrayAttribute(java.lang.String tag)
public float[] getFloatArrayAttribute(java.lang.String tag)
public boolean isUnsignedArrayAttribute(java.lang.String tag)
SAMException
- if the tag is not present.public java.lang.Object getAttribute(short tag)
tag
- Binary representation of a 2-char String tag as created by SAMTagUtil.getAttribute(java.lang.String)
public void setAttribute(java.lang.String tag, java.lang.Object value)
tag
- two-character tag name. See http://samtools.sourceforge.net/SAM1.pdf for standard and user-defined tags.value
- Supported types are String, Char, Integer, Float, byte[], short[]. int[], float[].
If value == null, tag is cleared.
Byte and Short are allowed but discouraged. If written to a SAM file, these will be converted to Integer,
whereas if written to BAM, getAttribute() will return as Byte or Short, respectively.
Long with value between 0 and MAX_UINT is allowed for BAM but discouraged. Attempting to write such a value
to SAM will cause an exception to be thrown.
To set unsigned byte[], unsigned short[] or unsigned int[] (which is discouraged because of poor Java language
support), setUnsignedArrayAttribute() must be used instead of this method.
String values are not validated to ensure that they conform to SAM spec.public void setUnsignedArrayAttribute(java.lang.String tag, java.lang.Object value)
value
- must be one of byte[], short[], int[]protected void setAttribute(short tag, java.lang.Object value)
tag
- Binary representation of a 2-char String tag as created by SAMTagUtil.setAttribute(java.lang.String, java.lang.Object)
protected void setAttribute(short tag, java.lang.Object value, boolean isUnsignedArray)
public void clearAttributes()
protected void setAttributes(SAMBinaryTagAndValue attributes)
protected SAMBinaryTagAndValue getBinaryAttributes()
public java.lang.String getContig()
Locatable
public int getStart()
public int getEnd()
getAlignmentEnd()
public java.util.List<SAMRecord.SAMTagAndValue> getAttributes()
public SAMFileHeader getHeader()
public void setHeader(SAMFileHeader header)
header
- contains sequence dictionary for this SAMRecordpublic byte[] getVariableBinaryRepresentation()
public int getAttributesBinarySize()
public java.lang.String format()
protected void eagerDecode()
public java.util.List<AlignmentBlock> getAlignmentBlocks()
public java.util.List<SAMValidationError> validateCigar(long recordNumber)
recordNumber
- For error reporting. -1 if not known.public boolean equals(java.lang.Object o)
equals
in class java.lang.Object
public int hashCode()
hashCode
in class java.lang.Object
public java.util.List<SAMValidationError> isValid()
public java.util.List<SAMValidationError> isValid(boolean firstOnly)
firstOnly
- return only the first error if true, false otherwisepublic SAMFileSource getFileSource()
protected void setFileSource(SAMFileSource fileSource)
fileSource
- source of the given file.public java.lang.Object clone() throws java.lang.CloneNotSupportedException
clone
in class java.lang.Object
java.lang.CloneNotSupportedException
public java.lang.String toString()
toString
in class java.lang.Object
public java.lang.String getSAMString()
public java.lang.String getPairedReadName()