vg
tools for working with variation graphs
Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
vg::VCFGenotyper Class Reference

#include <graph_caller.hpp>

Inheritance diagram for vg::VCFGenotyper:
vg::GraphCaller vg::VCFOutputCaller

Public Member Functions

 VCFGenotyper (const PathHandleGraph &graph, SnarlCaller &snarl_caller, SnarlManager &snarl_manager, vcflib::VariantCallFile &variant_file, const string &sample_name, const vector< string > &ref_paths={}, FastaReference *ref_fasta=nullptr, FastaReference *ins_fasta=nullptr, ostream &out_stream=cout)
 
virtual ~VCFGenotyper ()
 
virtual bool call_snarl (const Snarl &snarl, int ploidy)
 Call a given snarl, and print the output to out_stream. More...
 
virtual string vcf_header (const PathHandleGraph &graph, const vector< string > &contigs, const vector< size_t > &contig_length_overrides={}) const
 Write the vcf header (version and contigs and basic info) More...
 
- Public Member Functions inherited from vg::GraphCaller
 GraphCaller (SnarlCaller &snarl_caller, SnarlManager &snarl_manager, ostream &out_stream=cout)
 
virtual ~GraphCaller ()
 
virtual void call_top_level_snarls (int ploidy, bool recurse_on_fail=true)
 
- Public Member Functions inherited from vg::VCFOutputCaller
 VCFOutputCaller (const string &sample_name)
 
virtual ~VCFOutputCaller ()
 
void add_variant (vcflib::Variant &var) const
 Add a variant to our buffer. More...
 
void write_variants (ostream &out_stream) const
 Sort then write variants in the buffer. More...
 

Protected Member Functions

tuple< string, size_t, size_t > get_ref_positions (const vector< vcflib::Variant * > &variants) const
 get path positions bounding a set of variants More...
 
virtual unordered_map< string, size_t > scan_contig_lengths () const
 munge out the contig lengths from the VCF header More...
 
- Protected Member Functions inherited from vg::VCFOutputCaller
void emit_variant (const PathPositionHandleGraph &graph, SnarlCaller &snarl_caller, const Snarl &snarl, const vector< SnarlTraversal > &called_traversals, const vector< int > &genotype, int ref_trav_idx, const unique_ptr< SnarlCaller::CallInfo > &call_info, const string &ref_path_name, int ref_offset) const
 print a vcf variant More...
 
tuple< size_t, size_t, bool, step_handle_t, step_handle_tget_ref_interval (const PathPositionHandleGraph &graph, const Snarl &snarl, const string &ref_path_name) const
 
void flatten_common_allele_ends (vcflib::Variant &variant, bool backward) const
 clean up the alleles to not share common prefixes / suffixes More...
 

Protected Attributes

const PathHandleGraphgraph
 the graph More...
 
vcflib::VariantCallFile & input_vcf
 input VCF to genotype, must have been loaded etc elsewhere More...
 
VCFTraversalFinder traversal_finder
 
- Protected Attributes inherited from vg::GraphCaller
SnarlCallersnarl_caller
 Our Genotyper. More...
 
SnarlManagersnarl_manager
 Our snarls. More...
 
ostream & out_stream
 Where all output written. More...
 
- Protected Attributes inherited from vg::VCFOutputCaller
vcflib::VariantCallFile output_vcf
 output vcf More...
 
string sample_name
 Sample name. More...
 
vector< vector< vcflib::Variant > > output_variants
 output buffers (1/thread) (for sorting) More...
 

Detailed Description

VCFGenotyper : Genotype variants in a given VCF file

Constructor & Destructor Documentation

◆ VCFGenotyper()

vg::VCFGenotyper::VCFGenotyper ( const PathHandleGraph graph,
SnarlCaller snarl_caller,
SnarlManager snarl_manager,
vcflib::VariantCallFile &  variant_file,
const string &  sample_name,
const vector< string > &  ref_paths = {},
FastaReference *  ref_fasta = nullptr,
FastaReference *  ins_fasta = nullptr,
ostream &  out_stream = cout 
)

◆ ~VCFGenotyper()

vg::VCFGenotyper::~VCFGenotyper ( )
virtual

Member Function Documentation

◆ call_snarl()

bool vg::VCFGenotyper::call_snarl ( const Snarl snarl,
int  ploidy 
)
virtual

Call a given snarl, and print the output to out_stream.

Implements vg::GraphCaller.

◆ get_ref_positions()

tuple< string, size_t, size_t > vg::VCFGenotyper::get_ref_positions ( const vector< vcflib::Variant * > &  variants) const
protected

get path positions bounding a set of variants

◆ scan_contig_lengths()

unordered_map< string, size_t > vg::VCFGenotyper::scan_contig_lengths ( ) const
protectedvirtual

munge out the contig lengths from the VCF header

◆ vcf_header()

string vg::VCFGenotyper::vcf_header ( const PathHandleGraph graph,
const vector< string > &  contigs,
const vector< size_t > &  contig_length_overrides = {} 
) const
virtual

Write the vcf header (version and contigs and basic info)

Reimplemented from vg::VCFOutputCaller.

Member Data Documentation

◆ graph

const PathHandleGraph& vg::VCFGenotyper::graph
protected

the graph

◆ input_vcf

vcflib::VariantCallFile& vg::VCFGenotyper::input_vcf
protected

input VCF to genotype, must have been loaded etc elsewhere

◆ traversal_finder

VCFTraversalFinder vg::VCFGenotyper::traversal_finder
protected

traversal finder uses alt paths to map VCF alleles from input_vcf back to traversals in the snarl


The documentation for this class was generated from the following files: