本文整理汇总了C++中alignment类的典型用法代码示例。如果您正苦于以下问题:C++ alignment类的具体用法?C++ alignment怎么用?C++ alignment使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了alignment类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: get_path_counts
ublas::matrix<int> get_path_counts(const alignment& A,int node1, int node2)
{
using namespace A2;
int state1 = states::S;
ublas::matrix<int> counts(5,5);
counts.clear();
for(int column=0;column<A.length();column++)
{
int state2 = -1;
if (A.gap(column,node1)) {
if (A.gap(column,node2))
continue;
else
state2 = states::G1;
}
else {
if (A.gap(column,node2))
state2 = states::G2;
else
state2 = states::M;
}
counts(state1,state2)++;
state1 = state2;
}
counts(state1,states::E)++;
return counts;
}
示例2: add_internal
alignment add_internal(alignment A,const SequenceTree& T)
{
// Complain if A and T don't correspond
if (A.n_sequences() != T.n_leaves())
throw myexception()<<"Number of sequence in alignment doesn't match number of leaves in tree"
<<"- can't add internal sequences";
// Add empty sequences
vector<sequence> S;
for(int i=T.n_leaves();i<T.n_nodes();i++)
{
sequence s;
if (T.label(i) == "")
throw myexception()<<"Adding internal sequences: Tree has missing internal node name!";
s.name = T.label(i);
S.push_back(s);
}
A.add_sequences(S);
return A;
}
示例3: reorder_sequences
alignment reorder_sequences(const alignment& A, const vector<string>& names)
{
// Check the names and stuff.
vector<string> n2 = sequence_names(A);
if (names == n2) return A;
alignment A2;
try {
vector<int> new_order = compute_mapping(names,n2);
A2 = reorder_sequences(A,new_order);
}
catch(bad_mapping<string>& e)
{
e.clear();
if (e.size2 < e.size1)
e<<"Alignment has too few sequences! (Got "<<A.n_sequences()<<", expected "<<names.size()<<")\n";
if (e.size1 < e.size2)
e<<"Alignmnent has too many sequences! (Got "<<A.n_sequences()<<", expected "<<names.size()<<")\n";
if (e.from == 0)
e<<"Alignment is missing sequence \""<<e.missing<<"\".";
else
e<<"Alignment has extra sequence \""<<e.missing<<"\".";
throw e;
}
return A2;
}
示例4: find_major_character
std::pair<vector<int>,vector<int> > find_major_character(const alignment& A,int allowed_differences)
{
const alphabet& a = A.get_alphabet();
vector<int> majority(A.length(), alphabet::unknown);
vector<int> safe(A.length(), 0);
for(int c=0;c<majority.size();c++)
{
vector<int> count = column_count(A,c);
int max_letter = argmax(count);
majority[c] = max_letter;
// NOTE! Major character is gap if there is more than 1 gap!
if (count[a.size()] > 1)
majority[c] = alphabet::gap;
else if (A.n_sequences() - count[max_letter] <= allowed_differences)
safe[c] = 1;
/*
if (safe[c] == 1) {
std::cerr<<"Column "<<c+1<<" is safe: "<<a.lookup(max_letter)<<"\n";
}
*/
}
return std::pair<vector<int>,vector<int> >(majority,safe);
}
示例5: prob_of_target_and_alignment_given_source_1
LogProb transpair_model4::prob_of_target_and_alignment_given_source(const alignment&al, short distortionType,bool verb)const
{
LogProb total = 1.0 ;
static const LogProb almostZero = 1E-299 ;
if( distortionType&1 )
{
total *= prob_of_target_and_alignment_given_source_1(al,verb);
}
if( distortionType&2 )
{
for(WordIndex j=1;j<=m;j++)
if( al(j) )
if( al.get_head(al(j))==j)
{
int ep=al.prev_cept(al(j));
float x2=probFirst[ep](j,al.get_center(ep));
massert(x2<=1.0);
total*=x2;
if( verb) cerr << "IBM-4: d=1 of " << j << ": " << x2 << " -> " << total << endl;
}
else
{
float x2=probSecond(j,al.prev_in_cept(j));
massert(x2<=1.0);
total*=x2;
if( verb) cerr << "IBM-4: d>1 of " << j << ": " << x2 << " -> " << total << endl;
}
}
return total?total:almostZero;
}
示例6: load_A_and_T
/// \brief Load a tree and an alignment based on command line parameters.
///
/// \param args The command line parameters.
/// \param alignments The alignments.
/// \param T The leaf-labelled tree.
/// \param internal_sequences Should each resulting alignment have sequences for internal nodes on the tree?
///
void load_A_and_T(const variables_map& args,alignment& A,RootedSequenceTree& T,bool internal_sequences)
{
A = load_A(args,internal_sequences);
T = load_T(args);
//------------- Link Alignment and Tree -----------------//
link(A,T,internal_sequences);
//---------------- Randomize alignment? -----------------//
if (args.count("randomize-alignment"))
A = randomize(A,T.n_leaves());
else if (args.count("unalign-all"))
A = unalign_all(A,T.n_leaves());
//------------------ Analyze 'internal'------------------//
if ((args.count("internal") and args["internal"].as<string>() == "+")
or args.count("randomize-alignment"))
for(int column=0;column< A.length();column++) {
for(int i=T.n_leaves();i<A.n_sequences();i++)
A.set_value(column,i, alphabet::not_gap );
}
//---- Check that internal sequence satisfy constraints ----//
check_alignment(A,T,internal_sequences);
}
示例7: get_alignment
alignment get_alignment(const ublas::matrix<int>& M, alignment& A1)
{
alignment A2 = A1;
A2.changelength(M.size1());
// get letters information
vector<vector<int> > sequences;
for(int i=0;i<A1.n_sequences();i++) {
vector<int> sequence;
for(int c=0;c<A1.length();c++) {
if (not A1.gap(c,i))
sequence.push_back(A1(c,i));
}
sequences.push_back(sequence);
}
for(int i=0;i<A2.n_sequences();i++) {
for(int c=0;c<A2.length();c++) {
int index = M(c,i);
if (index >= 0)
index = sequences[i][index];
A2.set_value(c,i, index);
}
}
return A2;
}
示例8: randomize
/// \brief Create an alignment with randomized homology
///
/// \param A An alignment containing the sequences to re-align
alignment randomize(const alignment& A,int n) {
if (n == -1)
n = A.n_sequences();
int maxlength = -1;
for(int s=0; s<n; s++) {
if (A.seqlength(s) > maxlength)
maxlength = A.seqlength(s);
}
// Choose the length of the new alignment
alignment A2 = A;
int newlength = int( maxlength + 2 + 0.1*maxlength);
A2.changelength(newlength);
// For each row of the alignment
const int temp = alphabet::gap;
for(int i=0; i<n; i++)
{
/// Collect the letters of the row
vector<int> s = alignment_row_letters(A,i);
/// Randomly insert gaps until the row is filled
while(s.size() < newlength) {
int pos = myrandom(s.size()+1);
s.insert(s.begin()+pos,temp);
}
for(int c=0; c<A2.length(); c++)
A2(c,i) = s[c];
}
remove_empty_columns(A2);
return A2;
}
示例9: BOOST_THROW_EXCEPTION
/// \brief TODOCUMENT
///
/// \relates display_colourer
display_colour_spec cath::get_colour_spec(const display_colourer &arg_colourer, ///< TODOCUMENT
const pdb_list &arg_pdbs, ///< TODOCUMENT
const str_vec &arg_names, ///< TODOCUMENT
const alignment &arg_alignment ///< TODOCUMENT
) {
const alignment::size_type num_entries = arg_alignment.num_entries();
const alignment::size_type aln_length = arg_alignment.length();
if ( aln_length <= 0 || num_entries <= 0 ) {
BOOST_THROW_EXCEPTION(invalid_argument_exception("Unable to colour the alignment_context because the alignment is empty"));
}
if ( num_entries != arg_pdbs.size() ) {
BOOST_THROW_EXCEPTION(invalid_argument_exception("Unable to colour the alignment_context because the number of entries doesn't match the number of PDBs"));
}
if ( num_entries != arg_names.size() ) {
BOOST_THROW_EXCEPTION(invalid_argument_exception("Unable to colour the alignment_context because the number of entries doesn't match the number of names"));
}
auto &&result_spec = arg_colourer.get_colour_spec( alignment_context(
arg_pdbs,
arg_names,
arg_alignment
) );
return has_score_colour_handler( arg_colourer )
? adjust_display_colour_spec_copy(
std::forward< decltype( result_spec ) >( result_spec ),
get_score_colour_handler( arg_colourer ),
arg_alignment
)
: result_spec;
}
示例10: load_A_and_random_T
/// \brief Load an alignment based on command line parameters and generate a random tree.
///
/// \param args The command line parameters.
/// \param alignments The alignments.
/// \param T The leaf-labelled tree.
/// \param internal_sequences Should each resulting alignment have sequences for internal nodes on the tree?
///
void load_A_and_random_T(const variables_map& args,alignment& A,SequenceTree& T,bool internal_sequences)
{
// NO internal sequences, yet!
A = load_A(args,internal_sequences);
//------------- Load random tree ------------------------//
SequenceTree TC = star_tree(sequence_names(A));
if (args.count("t-constraint"))
TC = load_constraint_tree(args["t-constraint"].as<string>(),sequence_names(A));
T = TC;
RandomTree(T,1.0);
//------------- Link Alignment and Tree -----------------//
link(A,T,internal_sequences);
//---------------- Randomize alignment? -----------------//
if (args.count("randomize-alignment"))
A = randomize(A,T.n_leaves());
//------------------ Analyze 'internal'------------------//
if ((args.count("internal") and args["internal"].as<string>() == "+")
or args.count("randomize-alignment"))
for(int column=0;column< A.length();column++) {
for(int i=T.n_leaves();i<A.n_sequences();i++)
A(column,i) = alphabet::not_gap;
}
//---- Check that internal sequence satisfy constraints ----//
check_alignment(A,T,internal_sequences);
}
示例11: intersect
bool intersect(int c1, int c2, const alignment& A) {
for(int i=0;i<A.n_sequences();i++) {
if (not A.gap(c1,i) and not A.gap(c2,i))
return true;
}
return false;
}
示例12: n_characters
int n_characters(const alignment& A, int column)
{
int count=0;
for(int i=0;i<A.n_sequences();i++)
if (A.character(column,i))
count++;
return count;
}
示例13: alignment_row_letters
vector<int> alignment_row_letters(const alignment& A, int i)
{
vector<int> s;
for(int c=0;c<A.length();c++)
if (A.character(c,i))
s.push_back(A(c,i));
return s;
}
示例14: has_score
/// \brief TODOCUMENT
float_score_type score_colour_handler::get_score_of_postion(const alignment &arg_alignment, ///< TODOCUMENT
const size_t &arg_entry, ///< TODOCUMENT
const size_t &arg_index ///< TODOCUMENT
) const {
const bool using_scores = show_scores_if_present && arg_alignment.is_scored();
const bool using_this_score = using_scores && has_score( arg_alignment.get_alignment_residue_scores(), arg_entry, arg_index );
return using_this_score ? get_score( arg_alignment.get_alignment_residue_scores(), arg_entry, arg_index, ! scores_to_equivs, normalise_scores )
: 1.0;
}
示例15: check_names_unique
void check_names_unique(const alignment& A)
{
// check that names are all unique
for(int i=0;i<A.n_sequences();i++) {
for(int j=0;j<i;j++)
if (A.seq(i).name == A.seq(j).name)
throw myexception()<<"Sequence name '"<<A.seq(i).name<<"' occurs multiple times in the alignment!";
}
}