当前位置: 首页>>代码示例>>C++>>正文


C++ alignment::get_alphabet方法代码示例

本文整理汇总了C++中alignment::get_alphabet方法的典型用法代码示例。如果您正苦于以下问题:C++ alignment::get_alphabet方法的具体用法?C++ alignment::get_alphabet怎么用?C++ alignment::get_alphabet使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在alignment的用法示例。


在下文中一共展示了alignment::get_alphabet方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: frequencies

/// \brief Estimate the empirical frequencies of different letters from the alignment, with pseudocounts
///
/// \param args The command line parameters.
/// \param A The alignment.
///
valarray<double> empirical_frequencies(const variables_map& args,const alignment& A) 
{
  const alphabet& a = A.get_alphabet();

  // Count the occurrence of the different letters
  valarray<double> counts = letter_counts(A);

  valarray<double> frequencies(a.size());

  // empirical frequencies
  frequencies = A.get_alphabet().get_frequencies_from_counts(counts,chop_internal(A).n_sequences());

  return frequencies;
}
开发者ID:,项目名称:,代码行数:19,代码来源:

示例2: count

vector<int> column_count(const alignment& A, int c)
{
  const alphabet& a = A.get_alphabet();
  vector<int> count(a.size()+1,0);

  for(int i=0;i<A.n_sequences();i++) {
    int l = A(c,i);
    if (A.get_alphabet().is_letter(l))
      count[l]++;

    if (l == alphabet::gap or l == alphabet::unknown)
      count.back()++;
  }
  return count;
}
开发者ID:msuchard,项目名称:BAli-Phy,代码行数:15,代码来源:alignment-indices.C

示例3: peel_branch

  void peel_branch(int b0,Likelihood_Cache& cache, const alignment& A, const Tree& T, 
		   const MatCache& transition_P, const MultiModel& MModel)
  {
    total_peel_branches++;

    // compute branches-in
    int bb = T.directed_branch(b0).branches_before().size();

    if (bb == 0) {
      int n_states = cache.scratch(0).size2();
      int n_letters = A.get_alphabet().n_letters();
      if (n_states == n_letters) {
	if (dynamic_cast<const F81_Model*>(&MModel.base_model(0)))
	  peel_leaf_branch_F81(b0, cache, A, T, MModel);
	else
	  peel_leaf_branch(b0, cache, A, T, transition_P, MModel);
      }
      else
	peel_leaf_branch_modulated(b0, cache, A, T, transition_P, MModel);
    }
    else if (bb == 2) {
      if (dynamic_cast<const F81_Model*>(&MModel.base_model(0)))
	peel_internal_branch_F81(b0, cache, A, T, MModel);
      else
	peel_internal_branch(b0, cache, A, T, transition_P, MModel);
    }
    else
      std::abort();

    cache.validate_branch(b0);
  }
开发者ID:msuchard,项目名称:BAli-Phy,代码行数:31,代码来源:substitution.C

示例4: if

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);
}
开发者ID:msuchard,项目名称:BAli-Phy,代码行数:30,代码来源:alignment-indices.C

示例5: if

/// \brief Estimate the empirical frequencies of different letters from the alignment, with pseudocounts
///
/// \param args The command line parameters.
/// \param A The alignment.
///
valarray<double> empirical_frequencies(const variables_map& args,const alignment& A) 
{
  const alphabet& a = A.get_alphabet();

  // Count the occurrence of the different letters
  valarray<double> counts = letter_counts(A);

  valarray<double> frequencies(a.size());

  // empirical frequencies
  if (not args.count("frequencies"))
    frequencies = A.get_alphabet().get_frequencies_from_counts(counts,A.n_sequences()/2);

  // uniform frequencies
  else if (args["frequencies"].as<string>() == "uniform")
    frequencies = 1.0/a.size();

  // triplet frequencies <- nucleotide frequencies
  else if (args["frequencies"].as<string>() == "nucleotides") {
    const Triplets* T = dynamic_cast<const Triplets*>(&a);

    if (not T) throw myexception()<<"You can only specify nucleotide frequencies on Triplet or Codon alphabets.";
    valarray<double> N_counts = get_nucleotide_counts_from_codon_counts(*T,counts);
    valarray<double> fN = T->getNucleotides().get_frequencies_from_counts(N_counts,A.n_sequences()/2);

    frequencies = get_codon_frequencies_from_independent_nucleotide_frequencies(*T,fN);
  }

  // specified frequencies
  else {
    vector<double> f = split<double>(args["frequencies"].as<string>(),',');

    if (f.size() != a.size())
      throw myexception()<<"You specified "<<f.size()<<" frequencies, but there are "
			 <<a.size()<<" letters of the alphabet!";

    for(int i=0;i<f.size();i++)
      frequencies[i] = f[i];
  }

  return frequencies;
}
开发者ID:argriffing,项目名称:BAli-Phy,代码行数:47,代码来源:setup.C

示例6: count_letters

void count_letters(const alignment& A, int c, valarray<int>& counts)
{
  const alphabet& a = A.get_alphabet();
  assert(counts.size() == a.size());

  counts = 0;
  for(int i=0;i<A.n_sequences();i++) 
  {
    int l = A(c,i);
    if (a.is_letter(l))
      counts[l]++;
  }
}
开发者ID:sibonli,项目名称:BAli-Phy,代码行数:13,代码来源:alignment-util.C

示例7: peel_leaf_branch_modulated

  void peel_leaf_branch_modulated(int b0,Likelihood_Cache& cache, const alignment& A, 
				  const Tree& T, 
				  const MatCache& transition_P,const MultiModel& MModel)
  {
    total_peel_leaf_branches++;

    const alphabet& a = A.get_alphabet();

    // The number of directed branches is twice the number of undirected branches
    const int B        = T.n_branches();

    // scratch matrix
    Matrix& S = cache.scratch(0);
    const int n_models  = S.size1();
    const int n_states  = S.size2();
    const int n_letters = a.n_letters();
    //    const int N = n_states/n_letters;
    assert(MModel.n_states() == n_states);

    //    std::clog<<"length of subA for branch "<<b0<<" is "<<length<<"\n";
    if (not subA_index_valid(A,b0))
      update_subA_index_branch(A,T,b0);

    const vector<unsigned>& smap = MModel.state_letters();

    for(int i=0;i<subA_length(A,b0);i++)
    {
      // compute the distribution at the parent node
      int l2 = A.note(0,i+1,b0);

      if (a.is_letter(l2))
	for(int m=0;m<n_models;m++) {
	  const Matrix& Q = transition_P[m][b0%B];
	  for(int s1=0;s1<n_states;s1++)
	    cache(i,b0)(m,s1) = sum(Q,smap,n_letters,s1,l2);
	}
      else if (a.is_letter_class(l2)) {
	for(int m=0;m<n_models;m++) {
	  const Matrix& Q = transition_P[m][b0%B];
	  for(int s1=0;s1<n_states;s1++)
	    cache(i,b0)(m,s1) = sum(Q,smap,s1,l2,a);
	}
      }
      else
	for(int m=0;m<n_models;m++)
	  for(int s=0;s<n_states;s++)
	    cache(i,b0)(m,s) = 1;
    }
  }
开发者ID:msuchard,项目名称:BAli-Phy,代码行数:49,代码来源:substitution.C

示例8: counts

// This function ignores information in ambiguous letters
dynamic_bitset<> letter_variable_sites(const alignment& A)
{
  const alphabet& a = A.get_alphabet();

  valarray<int> counts(0, a.size());

  dynamic_bitset<> columns(A.length());
  for(int c=0; c<A.length(); c++)
  {
    count_letters(A,c,counts);
    if (variable_counts(counts))
      columns[c] = true;
  }
  return columns;
}
开发者ID:sibonli,项目名称:BAli-Phy,代码行数:16,代码来源:alignment-util.C

示例9: n_letter_variable_sites

// This function ignores information in ambiguous letters
unsigned n_letter_variable_sites(const alignment& A)
{
  const alphabet& a = A.get_alphabet();

  valarray<int> counts(0, a.size());

  unsigned n=0;
  for(int c=0; c<A.length(); c++)
  {
    count_letters(A,c,counts);
    if (variable_counts(counts))
      n++;
  }
  return n;
}
开发者ID:sibonli,项目名称:BAli-Phy,代码行数:16,代码来源:alignment-util.C

示例10: count_gaps

void count_gaps(const alignment& A, int c, valarray<int>& counts)
{
  const alphabet& a = A.get_alphabet();
  assert(counts.size() == 2);

  counts = 0;
  for(int i=0;i<A.n_sequences();i++) 
  {
    int l = A(c,i);
    if (a.is_feature(l))
      counts[0]++;
    else if (l == alphabet::gap)
      counts[1]++;
  }
}
开发者ID:sibonli,项目名称:BAli-Phy,代码行数:15,代码来源:alignment-util.C

示例11: counts

/// Compute the number of times each letter of the alphabet occurs in \a A.
valarray<double> letter_counts(const alignment& A) 
{
  const alphabet& a = A.get_alphabet();

  // Count the occurrence of the different letters
  valarray<double> counts(0.0, a.size());
  for(int i=0;i<A.length();i++) {
    for(int j=0;j<A.n_sequences();j++) {
      if (a.is_letter(A(i,j)))
	counts[A(i,j)]++;
    }
  }

  return counts;
}
开发者ID:argriffing,项目名称:BAli-Phy,代码行数:16,代码来源:setup.C

示例12: shuffle_alignment

alignment shuffle_alignment(const alignment& A, const vector<int>& order)
{
  unsigned L = A.length();

  alignment A2(A.get_alphabet(), order.size(), L);

  for(int i=0;i<order.size();i++) 
  {
    int j = order[i];
    assert(0 <= j and j < A.n_sequences());

    A2.seq(i) = A.seq(j);
    for(int c=0;c<L;c++)
      A2(c,i) = A(c,j);
  }

  return A2;
}
开发者ID:msuchard,项目名称:BAli-Phy,代码行数:18,代码来源:alignment-util.C

示例13: complement

alignment complement(const alignment& A)
{
  const alphabet& a = A.get_alphabet();

  owned_ptr<Nucleotides> N(dynamic_cast<const Nucleotides&>(a));

  if (not N)
    throw myexception()<<"Sequences have alphabet "<<a.name<<" -- reverse complement not allowed";

  alignment A2 = A;

  // Reverse
  for(int i=0;i<A2.n_sequences();i++) 
    for(int j=0;j<A2.length();j++)
      A2(j,i) = N->complement(A(j,i));

  return A2;
}
开发者ID:sibonli,项目名称:BAli-Phy,代码行数:18,代码来源:alignment-util.C

示例14: check_leaf_sequences

void check_leaf_sequences(const alignment& A,int n_leaves) {

  vector<sequence> sequences = A.convert_to_sequences();

  const alphabet& a = A.get_alphabet();

  for(int i=0;i<n_leaves;i++) {

    sequences[i].strip_gaps();
    if (not (a(sequences[i]) == a(A.seq(i)))) {
      cerr<<"leaf sequence "<<i<<" corrupted!\n";

      cerr<<"orig: "<<A.seq(i)<<endl;

      cerr<<"new : "<<sequences[i]<<endl;

      std::abort();
    }
  }
}
开发者ID:sibonli,项目名称:BAli-Phy,代码行数:20,代码来源:alignment-util.C

示例15: n_mutations

B n_mutations(const alignment& A, const SequenceTree& T,const ublas::matrix<B>& cost)
{
  const alphabet& a = A.get_alphabet();

  vector<int> letters(T.n_leaves());

  int root = T.directed_branch(0).target();

  vector<const_branchview> branches = branches_toward_node(T,root);

  ublas::matrix<B> n_muts(T.n_nodes(), a.size());

  double tree_length = 0;
  for(int c=0;c<A.length();c++) {
    for(int i=0;i<T.n_leaves();i++)
      letters[i] = A(c,i);
    double length = n_mutations<B>(a,letters,T,cost,n_muts,branches);
    tree_length += length;
  }

  return tree_length;
}
开发者ID:sibonli,项目名称:BAli-Phy,代码行数:22,代码来源:parsimony.C


注:本文中的alignment::get_alphabet方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。