68 #ifndef __SYSTEMC_EXT_DT_FX_SCFX_REP_HH__ 69 #define __SYSTEMC_EXT_DT_FX_SCFX_REP_HH__ 90 void multiply(scfx_rep &,
const scfx_rep &,
const scfx_rep &,
95 scfx_rep *
div_scfx_rep(
const scfx_rep &,
const scfx_rep &,
97 scfx_rep *
add_scfx_rep(
const scfx_rep &,
const scfx_rep &,
99 scfx_rep *
sub_scfx_rep(
const scfx_rep &,
const scfx_rep &,
166 void *
operator new (std::size_t);
167 void operator delete (
void *, std::size_t);
169 void from_string(
const char *,
int);
171 double to_double()
const;
198 bool is_zero()
const;
201 bool is_normal()
const;
203 void set_zero(
int=1);
207 bool get_bit(
int)
const;
214 void print(::std::ostream &)
const;
215 void dump(::std::ostream &)
const;
217 void get_type(
int &,
int &,
sc_enc &)
const;
224 bool rounding_flag()
const;
231 unsigned int divide_by_ten();
232 int find_lsw()
const;
233 int find_msw()
const;
235 void multiply_by_ten();
239 void set_oct(
int,
int);
240 void set_hex(
int,
int);
241 void shift_left(
int);
242 void shift_right(
int);
260 void resize_to(
int,
int=0);
292 m_wp = m_msw = m_lsw = 0;
300 m_mant.resize_to(min_mant);
301 m_state = not_a_number;
307 m_mant.resize_to(min_mant);
314 m_mant(min_mant), m_wp(2), m_sign(1), m_state(normal),
315 m_msw(0), m_lsw(0), m_r_flag(false)
380 for (
int i = 0;
i <
size();
i++) {
417 int size_incr = new_size -
size();
428 int wi = n / bits_in_word +
m_wp;
448 if (bi != bits_in_word - 1)
450 for (
int i = wi + 1;
i <
size(); ++
i)
454 if (bi != bits_in_word - 1)
456 for (
int i = wi + 1;
i <
size(); ++
i)
457 m_mant[
i] = static_cast<word>(-1);
482 if (bi != bits_in_word - 1)
483 zero = (
m_mant[wi] & (((
word)-1) << (bi + 1))) == 0;
484 for (
int i = wi + 1;
i <
size(); ++
i)
499 for (
int i = wi - 1;
i >= 0; --
i)
537 for (i = 0; i <
size(); ++
i)
538 m_mant[i] = static_cast<word>(-1);
541 for (i = wi + 1; i <
size(); ++
i)
545 for (i = wi2 - 1; i >= 0; --
i)
568 if (bi3 != bits_in_word - 1) {
574 for (
int i = wi3 + 1;
i <
size(); ++
i) {
596 for (
int i = wi2 + 1;
i <
size(); ++
i)
609 return (
m_mant[wi] & (((
word)1) << (bi - 1))) != 0;
611 return (
m_mant[wi - 1] & (((
word)1) << (bits_in_word - 1))) != 0;
625 for (
int i = wi - 1;
i >= 0; --
i)
639 if (
m_mant[wi] <= old_val) {
640 if (wi + 1 ==
size())
643 for (
int i = wi + 1;
i <
size(); ++
i) {
672 zero = (
m_mant[wi] & ~(((
word)-1) << (bi - 1))) == 0;
673 for (
int i = wi - 1;
i >= 0; --
i)
675 }
else if (wi != 0) {
676 zero = (
m_mant[wi - 1] & ~( ((
word)-1) << (bits_in_word - 1))) == 0;
677 for (
int i = wi - 2;
i >= 0; --
i)
689 for (
int i = 0;
i <
size();
i++) {
699 for (
int i =
size() - 1;
i >= 0;
i--) {
724 #endif // __SYSTEMC_EXT_DT_FX_SCFX_REP_HH__
void q_clear(const scfx_index &)
friend scfx_rep * quantization_scfx_rep(const scfx_rep &, const scfx_params &, bool &)
void o_extend(const scfx_index &, sc_enc)
friend scfx_rep * lsh_scfx_rep(const scfx_rep &, int)
bool o_zero_right(const scfx_index &) const
scfx_rep * add_scfx_rep(const scfx_rep &lhs, const scfx_rep &rhs, int max_wl)
bool q_zero(const scfx_index &) const
static void overflow(double &c, const scfx_params ¶ms, bool &o_flag)
scfx_rep * sub_scfx_rep(const scfx_rep &lhs, const scfx_rep &rhs, int max_wl)
static void print_other(scfx_string &s, const scfx_ieee_double &id, sc_numrep numrep, int w_prefix, sc_fmt fmt, const scfx_params *params)
friend scfx_rep * mult_scfx_rep(const scfx_rep &, const scfx_rep &, int)
void lshift(sc_fxval &c, const sc_fxnum &a, int b)
bool o_bit_at(const scfx_index &) const
static void quantization(double &c, const scfx_params ¶ms, bool &q_flag)
void o_set(const scfx_index &, const scfx_index &, sc_enc, bool)
bool o_zero_left(const scfx_index &) const
bool q_odd(const scfx_index &) const
scfx_rep * lsh_scfx_rep(const scfx_rep &, int)
scfx_rep * neg_scfx_rep(const scfx_rep &)
void resize_to(int, int=0)
void from_string(const char *, int)
friend scfx_rep * overflow_scfx_rep(const scfx_rep &, const scfx_params &, bool &)
void o_set_low(const scfx_index &, sc_enc)
void inc(scfx_mant &mant)
void align(const scfx_rep &lhs, const scfx_rep &rhs, int &new_wp, int &len_mant, scfx_mant_ref &lhs_mant, scfx_mant_ref &rhs_mant)
void o_set_high(const scfx_index &, const scfx_index &, sc_enc, int=1)
void quantization(const scfx_params &, bool &)
static std::string normalize(std::string &directory)
scfx_rep * rsh_scfx_rep(const scfx_rep &, int)
scfx_rep * div_scfx_rep(const scfx_rep &lhs, const scfx_rep &rhs, int div_wl)
int compare_msw_ff(const scfx_rep &lhs, const scfx_rep &rhs)
int compare_abs(const scfx_rep &a, const scfx_rep &b)
void q_incr(const scfx_index &)
void complement(scfx_mant &target, const scfx_mant &source, int size)
#define SC_ASSERT_(cnd, msg)
void overflow(const scfx_params &, bool &)
bool rounding_flag() const
scfx_rep * mult_scfx_rep(const scfx_rep &, const scfx_rep &, int max_wl=SC_DEFAULT_MAX_WL_)
void resize_to(int, int=0)
scfx_index(int wi_, int bi_)
friend scfx_rep * rsh_scfx_rep(const scfx_rep &, int)
static void print_dec(scfx_string &s, scfx_ieee_double id, int w_prefix, sc_fmt fmt)
const scfx_index calc_indices(int) const
const int SC_DEFAULT_MAX_WL_
const int SC_DEFAULT_DIV_WL_
void multiply(scfx_rep &result, const scfx_rep &lhs, const scfx_rep &rhs, int max_wl)
friend scfx_rep * neg_scfx_rep(const scfx_rep &)
scfx_rep * quantization_scfx_rep(const scfx_rep &a, const scfx_params ¶ms, bool &q_flag)
void rshift(sc_fxval &c, const sc_fxnum &a, int b)
void dump()
Dump all statistics data to the registered outputs.
void operator=(const scfx_rep &)
scfx_rep * overflow_scfx_rep(const scfx_rep &a, const scfx_params ¶ms, bool &o_flag)
const std::string to_string(sc_enc enc)
int cmp_scfx_rep(const scfx_rep &a, const scfx_rep &b)
void o_invert(const scfx_index &)
const int SC_DEFAULT_CTE_WL_
bool q_bit(const scfx_index &) const