bpp-seq3  3.0.0
AbstractProbabilisticSequenceContainer.h
Go to the documentation of this file.
1 //
2 // File: AbstractProbabilisticSequenceContainer.h
3 // Authors:
4 // Laurent Guéguen
5 //
6 
7 /*
8  Copyright or © or Copr. Bio++ Development Team, (November 17, 2004)
9 
10  This software is a computer program whose purpose is to provide classes
11  for sequences analysis.
12 
13  This software is governed by the CeCILL license under French law and
14  abiding by the rules of distribution of free software. You can use,
15  modify and/ or redistribute the software under the terms of the CeCILL
16  license as circulated by CEA, CNRS and INRIA at the following URL
17  "http://www.cecill.info".
18 
19  As a counterpart to the access to the source code and rights to copy,
20  modify and redistribute granted by the license, users are provided only
21  with a limited warranty and the software's author, the holder of the
22  economic rights, and the successive licensors have only limited
23  liability.
24 
25  In this respect, the user's attention is drawn to the risks associated
26  with loading, using, modifying and/or developing or reproducing the
27  software by the user in light of its specific status of free software,
28  that may mean that it is complicated to manipulate, and that also
29  therefore means that it is reserved for developers and experienced
30  professionals having in-depth computer knowledge. Users are therefore
31  encouraged to load and test the software's suitability as regards their
32  requirements in conditions enabling the security of their systems and/or
33  data to be ensured and, more generally, to use and operate it in the
34  same conditions as regards security.
35 
36  The fact that you are presently reading this means that you have had
37  knowledge of the CeCILL license and that you accept its terms.
38 */
39 
40 #ifndef BPP_SEQ_CONTAINER_ABSTRACTPROBABILISTICSEQUENCECONTAINER_H
41 #define BPP_SEQ_CONTAINER_ABSTRACTPROBABILISTICSEQUENCECONTAINER_H
42 
43 #include <Bpp/Exceptions.h>
44 
45 #include "../ProbabilisticSequence.h"
48 
49 namespace bpp
50 {
57  virtual public AbstractValuesContainer,
58  virtual public ProbabilisticSequenceContainer
59 {
60 public:
69  AbstractValuesContainer(alpha) {}
70 
73 
75  {
77  return *this;
78  }
79 
81 
82 public:
83  virtual const ProbabilisticSequence& getSequence(std::size_t i) const = 0;
84 
85  virtual const ProbabilisticSequence& getSequence(const std::string& name) const = 0;
86 
97  virtual void addSequence(const ProbabilisticSequence& sequence, bool checkName = true) = 0;
98 
110  virtual void addSequence(const Sequence& sequence, bool checkName = true) = 0;
111 
116  std::string toString(const std::string& name) const
117  {
118  return getSequence(name).toString();
119  }
120 
121  const Comments& getComments(const std::string& name) const
122  {
123  return getSequence(name).getComments();
124  }
125 
126  void setComments(const std::string& name, const Comments& comments)
127  {
128  size_t pos = getSequencePosition(name);
129  setComments(pos, comments);
130  }
131 
137  virtual const std::string& getName(size_t sequenceIndex) const
138  {
139  return getSequence(sequenceIndex).getName();
140  }
141 
142  virtual std::string toString(size_t sequenceIndex) const
143  {
144  return getSequence(sequenceIndex).toString();
145  }
146 
148  {
149  return Commentable::getComments();
150  }
151 
152  void setGeneralComments(const Comments& comments)
153  {
154  Commentable::setComments(comments);
155  }
156 
158  {
160  }
161 
162  virtual const Comments& getComments(size_t sequenceIndex) const
163  {
164  return getSequence(sequenceIndex).getComments();
165  }
166 
167  virtual void setComments(size_t sequenceIndex, const Comments& comments) = 0;
169 };
170 } // end of namespace bpp.
171 #endif // BPP_SEQ_CONTAINER_ABSTRACTPROBABILISTICSEQUENCECONTAINER_H
Partial implementation of the OrderedSequenceContainer interface.
void setGeneralComments(const Comments &comments)
Set the comments of this container.
const Comments & getGeneralComments() const
Get the comments of this container.
AbstractProbabilisticSequenceContainer(const Alphabet *alpha)
This constructor initialize the alphabet pointer.
void setComments(const std::string &name, const Comments &comments)
Set the comments of a particular sequence.
virtual std::string toString(size_t sequenceIndex) const
virtual const Comments & getComments(size_t sequenceIndex) const
std::string toString(const std::string &name) const
Output to string.
virtual const ProbabilisticSequence & getSequence(const std::string &name) const =0
Retrieve a probabilistic sequence object from the container.
virtual void setComments(size_t sequenceIndex, const Comments &comments)=0
virtual void addSequence(const Sequence &sequence, bool checkName=true)=0
Add a basic sequence to the container, through conversion to a probabilistic sequence.
virtual const std::string & getName(size_t sequenceIndex) const
Get the name of a particular row of the alignement (aka sequence).
const Comments & getComments(const std::string &name) const
Get comments of a particular sequence.
virtual void addSequence(const ProbabilisticSequence &sequence, bool checkName=true)=0
Add a probabilistic sequence to the container.
void deleteGeneralComments()
Delete the comments associated to this container.
AbstractProbabilisticSequenceContainer(const AbstractProbabilisticSequenceContainer &sc)
AbstractProbabilisticSequenceContainer & operator=(const AbstractProbabilisticSequenceContainer &sc)
virtual const ProbabilisticSequence & getSequence(std::size_t i) const =0
Partial implementation of the OrderedSequenceContainer interface.
AbstractValuesContainer & operator=(const AbstractValuesContainer &sc)
The Alphabet interface.
Definition: Alphabet.h:133
void clearComments()
Definition: Commentable.h:102
void setComments(const Comments &comments)
Set the comments.
Definition: Commentable.h:100
const Comments & getComments() const
Get the comments.
Definition: Commentable.h:93
virtual const std::string & getName() const =0
Get the name of this sequence.
virtual const Comments & getComments() const =0
Get the comments.
virtual std::string toString() const =0
Convert the list as a string.
virtual size_t getSequencePosition(const std::string &name) const =0
Get the position of a sequence in sequence container from its name.
virtual void setComments(const std::string &name, const Comments &comments)=0
Set the comments of a particular sequence.
The ProbabilisticSequenceContainer interface.
The probabilistic sequence interface.
The sequence interface.
Definition: Sequence.h:71
This alphabet is used to deal NumericAlphabet.
std::vector< std::string > Comments
Declaration of Comments type.
Definition: Commentable.h:58