Struct tskit::TreeSequence[][src]

pub struct TreeSequence { /* fields omitted */ }
Expand description

A tree sequence.

This is a thin wrapper around the C type tsk_treeseq_t.

When created from a TableCollection, the input tables are moved into the TreeSequence object.

Examples

let mut tables = tskit::TableCollection::new(1000.).unwrap();
tables.add_node(0, 1.0, tskit::TSK_NULL, tskit::TSK_NULL).unwrap();
tables.add_node(0, 0.0, tskit::TSK_NULL, tskit::TSK_NULL).unwrap();
tables.add_node(0, 0.0, tskit::TSK_NULL, tskit::TSK_NULL).unwrap();
tables.add_edge(0., 1000., 0, 1).unwrap();
tables.add_edge(0., 1000., 0, 2).unwrap();

// index
tables.build_index();

// tables gets moved into our treeseq variable:
let treeseq = tables.tree_sequence(tskit::TreeSequenceFlags::default()).unwrap();

Implementations

impl TreeSequence[src]

pub fn new(
    tables: TableCollection,
    flags: TreeSequenceFlags
) -> Result<Self, TskitError>
[src]

Create a tree sequence from a TableCollection. In general, TableCollection::tree_sequence may be preferred. The table collection is moved/consumed.

Parameters

Errors

Examples

let mut tables = tskit::TableCollection::new(1000.).unwrap();
tables.build_index();
let tree_sequence = tskit::TreeSequence::new(tables, tskit::TreeSequenceFlags::default()).unwrap();

The following may be preferred to the previous example, and more closely mimics the Python tskit interface:

let mut tables = tskit::TableCollection::new(1000.).unwrap();
tables.build_index();
let tree_sequence = tables.tree_sequence(tskit::TreeSequenceFlags::default()).unwrap();

The following raises an error because the tables are not indexed:

let mut tables = tskit::TableCollection::new(1000.).unwrap();
let tree_sequence = tskit::TreeSequence::new(tables,
tskit::TreeSequenceFlags::default()).unwrap();

pub fn dump(
    &self,
    filename: &str,
    options: TableOutputOptions
) -> TskReturnValue
[src]

Dump the tree sequence to file.

Note

  • options is currently not used. Set to default value. This behavior may change in a future release, which could break API.

pub fn load(filename: &str) -> Result<Self, TskitError>[src]

Load from a file.

pub fn dump_tables(&self) -> Result<TableCollection, TskitError>[src]

Obtain a copy of the TableCollection. The result is a “deep” copy of the tables.

Errors

TskitError will be raised if the underlying C library returns an error code.

pub fn tree_iterator(&self, flags: TreeFlags) -> Result<Tree, TskitError>[src]

Create an iterator over trees.

Parameters

Errors

Examples

// You must include streaming_iterator as a dependency
// and import this type.
use streaming_iterator::StreamingIterator;
// Import this to allow .next_back() for reverse
// iteration over trees.
use streaming_iterator::DoubleEndedStreamingIterator;

let mut tables = tskit::TableCollection::new(1000.).unwrap();
tables.build_index();
let tree_sequence = tables.tree_sequence(tskit::TreeSequenceFlags::default()).unwrap();
let mut tree_iterator = tree_sequence.tree_iterator(tskit::TreeFlags::default()).unwrap();
while let Some(tree) = tree_iterator.next() {
}

Warning

The following code results in an infinite loop. Be sure to note the difference from the previous example.

use streaming_iterator::StreamingIterator;

let mut tables = tskit::TableCollection::new(1000.).unwrap();
tables.build_index();
let tree_sequence = tables.tree_sequence(tskit::TreeSequenceFlags::default()).unwrap();
while let Some(tree) = tree_sequence.tree_iterator(tskit::TreeFlags::default()).unwrap().next() {
}

pub fn samples_to_vec(&self) -> Vec<tsk_id_t>[src]

👎 Deprecated since 0.2.3:

Please use TreeSequence::sample_nodes instead

Get the list of samples as a vector.

pub fn sample_nodes(&self) -> &[tsk_id_t][src]

Get the list of sample nodes as a slice.

pub fn num_trees(&self) -> tsk_size_t[src]

Get the number of trees.

pub fn kc_distance(
    &self,
    other: &TreeSequence,
    lambda: f64
) -> Result<f64, TskitError>
[src]

Calculate the average Kendall-Colijn (K-C) distance between pairs of trees whose intervals overlap.

Note

Parameters

  • lambda specifies the relative weight of topology and branch length. See Tree::kc_distance for more details.

pub fn num_samples(&self) -> tsk_size_t[src]

pub fn simplify(
    &self,
    samples: &[tsk_id_t],
    options: SimplificationOptions,
    idmap: bool
) -> Result<(Self, Option<Vec<tsk_id_t>>), TskitError>
[src]

Simplify tables and return a new tree sequence.

Parameters

  • samples: a slice containing non-null node ids. The tables are simplified with respect to the ancestry of these nodes.
  • options: A SimplificationOptions bit field controlling the behavior of simplification.
  • idmap: if true, the return value contains a vector equal in length to the input node table. For each input node, this vector either contains the node’s new index or TSK_NULL if the input node is not part of the simplified history.

Trait Implementations

impl Drop for TreeSequence[src]

fn drop(&mut self)[src]

Executes the destructor for this type. Read more

impl NodeListGenerator for TreeSequence[src]

fn samples_as_vector(&self) -> Vec<tsk_id_t>[src]

Obtain a vector containing the indexes (“ids”) of all nodes for which crate::TSK_NODE_IS_SAMPLE is true. Read more

fn create_node_id_vector(
    &self,
    f: impl FnMut(&NodeTableRow) -> bool
) -> Vec<tsk_id_t>
[src]

Obtain a vector containing the indexes (“ids”) of all nodes satisfying a certain criterion. Read more

impl Provenance for TreeSequence[src]

fn add_provenance(&mut self, record: &str) -> TskReturnValue[src]

Add provenance record with a time stamp. Read more

fn provenances(&self) -> ProvenanceTable<'_>[src]

Return an immutable reference to the table, type ProvenanceTable

fn provenances_iter(&self) -> TableIterator<ProvenanceTable<'_>>[src]

Return an iterator over the rows of the ProvenanceTable. See ProvenanceTable::iter for details. Read more

impl TableAccess for TreeSequence[src]

fn edges(&self) -> EdgeTable<'_>[src]

Get reference to the EdgeTable.

fn individuals(&self) -> IndividualTable<'_>[src]

Get reference to the IndividualTable.

fn migrations(&self) -> MigrationTable<'_>[src]

Get reference to the MigrationTable.

fn nodes(&self) -> NodeTable<'_>[src]

Get reference to the NodeTable.

fn sites(&self) -> SiteTable<'_>[src]

Get reference to the SiteTable.

fn mutations(&self) -> MutationTable<'_>[src]

Get reference to the MutationTable.

fn populations(&self) -> PopulationTable<'_>[src]

Get reference to the PopulationTable.

fn edges_iter(&self) -> TableIterator<EdgeTable<'_>>[src]

Return an iterator over the edges. See EdgeTable::iter for details. Read more

fn nodes_iter(&self) -> TableIterator<NodeTable<'_>>[src]

Return an iterator over the nodes. See NodeTable::iter for details. Read more

fn mutations_iter(&self) -> TableIterator<MutationTable<'_>>[src]

Return an iterator over the mutations. See MutationTable::iter for details. Read more

fn sites_iter(&self) -> TableIterator<SiteTable<'_>>[src]

Return an iterator over the sites. See SiteTable::iter for details. Read more

fn populations_iter(&self) -> TableIterator<PopulationTable<'_>>[src]

Return an iterator over the populations. See PopulationTable::iter for details. Read more

fn migrations_iter(&self) -> TableIterator<MigrationTable<'_>>[src]

Return an iterator over the migration events. See MigrationTable::iter for details. Read more

fn individuals_iter(&self) -> TableIterator<IndividualTable<'_>>[src]

Return an iterator over the individuals. See IndividualTable::iter for details. Read more

impl TskitTypeAccess<tsk_treeseq_t> for TreeSequence[src]

fn as_ptr(&self) -> *const tsk_treeseq_t[src]

Return const pointer

fn as_mut_ptr(&mut self) -> *mut tsk_treeseq_t[src]

Return mutable pointer

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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

Performs the conversion.