rna.cpp
1.92 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#include <utility>
#include <vector>
#include <string>
#include <iostream>
#include <boost/algorithm/string.hpp>
#include "rna.h"
//typedef std::vector<int> VI;
//typedef std::vector<VI> VVI;
//typedef std::vector<std::pair<int,int> > VII;
typedef std::vector<float> VF;
typedef std::vector<VF> VVF;
Rna::Rna(){}
Rna::Rna(const std::string &name, const std::string &seq)
{
name_ = name;
seq_ = seq;
n_ = uint(seq_.size());
}
Rna::Rna(const std::string &name, const std::string &seq, unsigned int id)
{
name_ = name;
seq_ = seq;
n_ = uint(seq_.size());
id_ = id;
}
Rna::~Rna()
{
}
unsigned int Rna::get_n_() const
{
return n_;
}
std::string Rna::get_name_() const
{
return name_;
}
std::string Rna::get_seq_() const
{
return seq_;
}
unsigned int Rna::get_id_() const
{
return id_;
}
std::vector < float > Rna::get_probingData_() const
{
return probingData_;
}
void Rna::set_name_(const std::string &name)
{
name_ = name;
}
void Rna::set_id_(unsigned int id)
{
id_ = id;
}
void Rna::set_probingData_(const std::vector < float > &probingData)
{
probingData_ = probingData;
}
bool Rna::check_seq(const std::string &seq)
{
bool res = true;
for(unsigned int i = 0; i< seq.size(); i++){
if( seq[i] != 'A' && seq[i] != 'U' && seq[i] != 'C' && seq[i] != 'G'
&& seq[i] != 'I' && seq[i] != 'Q' && seq[i] != 'D' && seq[i] != 'T'
&& seq[i] != 'S' && seq[i] != 'X' && seq[i] != 'B' && seq[i] != 'O'
&& seq[i] != 'N' && seq[i] != 'R' && seq[i] != 'Y' ){
res = false;
break;
}
}
return res;
}
std::string Rna::format(std::string seq)
{
boost::to_upper(seq);
std::replace(seq.begin(), seq.end(), 'T', 'U');
return seq;
}
std::string Rna::chg_seq_sens()
{
std::string str = seq_;
for(unsigned int i = n_, j = 0; j <= n_; i--, j++)
str[i] = seq_[j];
return str;
}