Struct bio_types::annot::spliced::Spliced

source ·
pub struct Spliced<R, S> { /* private fields */ }
Expand description

Spliced sequence annotation on a particular, named sequence (e.g. a chromosome).

Parameterized over the type of the reference sequence identifier and over the strandedness of the position.

The display format for a Spliced is chr:start_0-end_0;start_1-end_1;…;start_N-end_N(+/-/.). The boundaries for each individual exon are given as a half-open 0-based interval, like the Rust Range and BED format.

let tad3 = Spliced::with_lengths_starts("chrXII".to_owned(), 765265,
                                        &vec![808,52,109], &vec![0,864,984],
                                        ReqStrand::Reverse)?;
assert_eq!(tad3.to_string(), "chrXII:765265-766073;766129-766181;766249-766358(-)");
let tad3_exons = tad3.exon_contigs();
assert_eq!(tad3_exons.len(), 3);
assert_eq!(tad3_exons[0].to_string(), "chrXII:766249-766358(-)");
assert_eq!(tad3_exons[1].to_string(), "chrXII:766129-766181(-)");
assert_eq!(tad3_exons[2].to_string(), "chrXII:765265-766073(-)");

Implementations§

source§

impl<R, S> Spliced<R, S>

source

pub fn new(refid: R, start: isize, exon_0_length: usize, strand: S) -> Self

Construct a new, single-exon “spliced” location

use std::rc::Rc;
use bio_types::annot::spliced::Spliced;
use bio_types::strand::ReqStrand;
let chr = Rc::new("chrX".to_owned());
let tma22 = Spliced::new(chr, 461829, 462426 - 461829, ReqStrand::Forward);
source

pub fn with_lengths_starts( refid: R, start: isize, exon_lengths: &[usize], exon_starts: &[usize], strand: S, ) -> Result<Self, SplicingError>

Construct a multi-exon “spliced” location using BED-style exon starts and lengths.

source

pub fn exon_count(&self) -> usize

Number of exons

source

pub fn exon_starts(&self) -> Vec<usize>

Vector of exon starting positions, relative to the start of the location overall.

These positions run from left to right on the reference sequence, regardless of the location’s strand.

source

pub fn exon_lengths(&self) -> Vec<usize>

Vector of exon lengths.

Exon lengths are given from left to right on the reference sequence, regardless of the location’s strand.

source

pub fn exon_total_length(&self) -> usize

Total length of exons only.

The length method from the Loc trait returns the total length spanned by the annotation, including both introns and exons.

source

pub fn into_stranded(self, strand: ReqStrand) -> Spliced<R, ReqStrand>

Convert into a stranded sequence location on the specified strand

source

pub fn contig_cover(self) -> Contig<R, S>

source§

impl<R> Spliced<R, ReqStrand>

source

pub fn exon_contigs(&self) -> Vec<Contig<R, ReqStrand>>
where R: Clone,

Trait Implementations§

source§

impl<R: Clone, S: Clone> Clone for Spliced<R, S>

source§

fn clone(&self) -> Spliced<R, S>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<R: Debug, S: Debug> Debug for Spliced<R, S>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<R, S> Display for Spliced<R, S>
where R: Display, S: Display + Clone + Into<Strand>,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<R> From<Spliced<R, NoStrand>> for Spliced<R, Strand>

source§

fn from(x: Spliced<R, NoStrand>) -> Self

Converts to this type from the input type.
source§

impl<R> From<Spliced<R, ReqStrand>> for Spliced<R, NoStrand>

source§

fn from(x: Spliced<R, ReqStrand>) -> Self

Converts to this type from the input type.
source§

impl<R> From<Spliced<R, ReqStrand>> for Spliced<R, Strand>

source§

fn from(x: Spliced<R, ReqStrand>) -> Self

Converts to this type from the input type.
source§

impl<R> From<Spliced<R, Strand>> for Spliced<R, NoStrand>

source§

fn from(x: Spliced<R, Strand>) -> Self

Converts to this type from the input type.
source§

impl<R, S> FromStr for Spliced<R, S>
where R: From<String>, S: FromStr<Err = StrandError>,

§

type Err = ParseAnnotError

The associated error which can be returned from parsing.
source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
source§

impl<R: Hash, S: Hash> Hash for Spliced<R, S>

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<R, S> Loc for Spliced<R, S>

§

type RefID = R

§

type Strand = S

source§

fn refid(&self) -> &R

Name of the reference sequence (chromosome name, etc.)
source§

fn start(&self) -> isize

Starting (lowest, left-most, 5’-most) position on the reference sequence (0-based).
source§

fn length(&self) -> usize

Length of the region
source§

fn strand(&self) -> S
where S: Copy,

Strand of the position
source§

fn pos_into<T>(&self, pos: &Pos<Self::RefID, T>) -> Option<Pos<(), T>>
where Self::RefID: Eq, Self::Strand: Into<ReqStrand> + Copy, T: Neg<Output = T> + Copy,

Map a sequence position on a reference sequence into a relative position within an annotated location on the reference sequence. Read more
source§

fn pos_outof<Q, T>(&self, pos: &Pos<Q, T>) -> Option<Pos<Self::RefID, T>>
where Self::RefID: Clone, Self::Strand: Into<ReqStrand> + Copy, T: Neg<Output = T> + Copy,

Map a relative position within an annotated location out of that location onto the enclosing reference sequence. Read more
source§

fn contig_intersection<T>( &self, contig: &Contig<Self::RefID, T>, ) -> Option<Self>
where Self::RefID: PartialEq + Clone, Self::Strand: Copy,

source§

impl<R: PartialEq, S: PartialEq> PartialEq for Spliced<R, S>

source§

fn eq(&self, other: &Spliced<R, S>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<R: Eq, S: Eq> Eq for Spliced<R, S>

source§

impl<R, S> StructuralPartialEq for Spliced<R, S>

Auto Trait Implementations§

§

impl<R, S> Freeze for Spliced<R, S>
where R: Freeze, S: Freeze,

§

impl<R, S> RefUnwindSafe for Spliced<R, S>

§

impl<R, S> Send for Spliced<R, S>
where R: Send, S: Send,

§

impl<R, S> Sync for Spliced<R, S>
where R: Sync, S: Sync,

§

impl<R, S> Unpin for Spliced<R, S>
where R: Unpin, S: Unpin,

§

impl<R, S> UnwindSafe for Spliced<R, S>
where R: UnwindSafe, S: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.