13 #include "trg/trg/Utilities.h"
14 #include "trg/trg/State.h"
25 TRGState::_su =
sizeof(unsigned);
28 TRGState::_bsu = 8 *
sizeof(unsigned);
30 TRGState::TRGState(
unsigned bitSize)
51 for (
unsigned i = 0; i < bitSize; i++) {
52 const unsigned wp = i /
_bsu;
53 const unsigned bp = i %
_bsu;
69 for (
unsigned i = 0; i <
_size; i++) {
70 const unsigned wp = i /
_bsu;
71 const unsigned bp = i %
_bsu;
85 _size = states.size();
90 for (
unsigned i = 0; i <
_size; i++) {
91 const unsigned wp = i /
_bsu;
92 const unsigned bp = i %
_bsu;
114 for (
unsigned i = 0; i <
_n; i++) {
116 if (order == 0)
_state[i] = states[i];
117 else _state[
_n - 1 - i] = states[i];
131 _size = strlen(inChar);
133 for (
unsigned iBit = 0; iBit <
_size; iBit++) {
134 if (!(inChar[iBit] ==
'0' || inChar[iBit] ==
'1')) {
136 cout <<
"TRGState::TRGState !!! invalid char found : aborted"
138 cout <<
" invalid char = [" << inChar[iBit]
144 }
else if (inType == 1) {
145 _size = strlen(inChar) * 4;
147 for (
unsigned iChar = 0; iChar <
_size / 4; iChar++) {
148 if (!isxdigit(inChar[iChar])) {
150 cout <<
"TRGState::TRGState !!! invalid char found : aborted"
152 cout <<
" invalid char = ["
153 << inChar[iChar] <<
"]" << endl;
160 cout <<
"TRGState::TRGState !!! invalid type : aborted"
162 cout <<
" invalid type = " << inType
172 for (
unsigned iBit = 0; iBit <
_size; iBit++) {
173 const unsigned wp = iBit /
_bsu;
174 const unsigned bp = iBit %
_bsu;
175 if (inChar[
_size - 1 - iBit] ==
'1')
180 }
else if (inType == 1) {
181 for (
unsigned iChar = 0; iChar <
_size / 4; iChar++) {
182 if (iChar % 8 == 0)
_state[iChar / 8] = 0;
183 short unsigned t_int;
184 unsigned charP =
_size / 4 - 1 - iChar;
185 if (inChar[charP] > 47 && inChar[charP] < 58) t_int = inChar[charP] - 48;
186 else t_int = inChar[charP] - 97 + 10;
187 _state[iChar / 8] += t_int << ((iChar % 8) * 4);
200 const string& pre)
const
204 bool large = (
_size > 60) || msg.find(
"large") != string::npos;
207 cout << pre <<
"size=" <<
_size <<
",";
208 for (
unsigned i = 0; i <
_size; i++) {
209 const unsigned j =
_size - i - 1;
219 cout << pre <<
"size=" <<
_size << endl;
221 const unsigned nPerLines = 64;
222 const unsigned lines =
_size / nPerLines + 1;
223 const unsigned rem =
_size % nPerLines;
225 cout <<
"TRGState" <<
226 " +56 +48 +40 +32 +24 +16 +8"
229 bool skipLast =
false;
230 for (
unsigned i = 0; i < lines; i++) {
231 const unsigned n0 = (i == 0) ? rem - 1 : nPerLines - 1;
233 const int os = (lines - i - 1) * nPerLines;
247 cout <<
"... (all zero)" << endl;
261 unsigned n = nPerLines - rem + (nPerLines - rem) / 8;
263 for (
unsigned j = 0; j < n; j++)
267 for (
int j = n0; j >= n1; --j) {
268 const unsigned v = (* this)[j + os];
319 const unsigned sizeNew =
_size + a.size();
320 const unsigned sizeMax =
_n *
_bsu;
321 const unsigned oldSize =
_size;
324 if (sizeNew > sizeMax) {
325 unsigned nNew = sizeNew /
_bsu;
326 if (sizeNew %
_bsu) ++nNew;
327 unsigned* tmp = (
unsigned*) calloc(nNew,
_su);
328 for (
unsigned i = 0; i <
_n; i++) {
338 for (
unsigned i = 0; i < a.size(); i++) {
339 unsigned j = i + oldSize;
340 const unsigned wp = j /
_bsu;
341 const unsigned bp = j %
_bsu;
359 for (
unsigned i = s; i < s + n; i++) {
361 stack.push_back(
true);
363 stack.push_back(
false);
376 for (
unsigned i = 0; i <
_n; i++) {
386 const unsigned long long n0(*
this);
387 const unsigned long long n1(a);
401 for (
unsigned i = 0; i < s.size(); i++) {
402 const unsigned j = s.size() - i - 1;
A class to represent a state of multi bits.
unsigned _n
bit storage size.
unsigned * _state
bit state.
std::ostream & operator<<(std::ostream &output, const IntervalOfValidity &iov)
virtual ~TRGState()
Destructor.
TRGState(unsigned bitSize=0)
Default constructor.
TRGState subset(unsigned i, unsigned n) const
returns subset from i with n bits.
static const unsigned _bsu
bit size of unsigned.
bool operator<(const TRGState &) const
Copy operator.
static const unsigned _su
size of unsigned.
static std::string itostring(int i)
converts int to string. (Use boost::lexical_cast)
TRGState & operator+=(const TRGState &)
appends TRGState (as MSB).
TRGState & operator=(const TRGState &)
Copy operator.
void dump(const std::string &message="", const std::string &pre="") const
dumps contents.
Abstract base class for different kinds of events.