blob: 09432257870dff9b0f9fbed7e144cd493d99c137 [file] [log] [blame]
/*****************************************************************************
Licensed to Accellera Systems Initiative Inc. (Accellera) under one or
more contributor license agreements. See the NOTICE file distributed
with this work for additional information regarding copyright ownership.
Accellera licenses this file to you under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with the
License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
implied. See the License for the specific language governing
permissions and limitations under the License.
*****************************************************************************/
/*****************************************************************************
sc_fix.h -
Original Author: Martin Janssen, Synopsys, Inc.
*****************************************************************************/
/*****************************************************************************
MODIFICATION LOG - modifiers, enter your name, affiliation, date and
changes you are making here.
Name, Affiliation, Date:
Description of Modification:
*****************************************************************************/
// $Log: sc_fix.h,v $
// Revision 1.2 2011/01/19 18:57:40 acg
// Andy Goodrich: changes for IEEE_1666_2011.
//
// Revision 1.1.1.1 2006/12/15 20:20:04 acg
// SystemC 2.3
//
// Revision 1.3 2006/01/13 18:53:57 acg
// Andy Goodrich: added $Log command so that CVS comments are reproduced in
// the source.
//
#ifndef __SYSTEMC_EXT_DT_FX_SC_FIX_HH__
#define __SYSTEMC_EXT_DT_FX_SC_FIX_HH__
#include "sc_fxnum.hh"
namespace sc_dt
{
// classes defined in this module
class sc_fix;
class sc_fix_fast;
// ----------------------------------------------------------------------------
// CLASS : sc_fix
//
// "Unconstrained" signed fixed-point class; arbitrary precision.
// ----------------------------------------------------------------------------
class sc_fix : public sc_fxnum
{
public:
// constructors
explicit sc_fix(sc_fxnum_observer * =0);
sc_fix(int, int, sc_fxnum_observer * =0);
sc_fix(sc_q_mode, sc_o_mode, sc_fxnum_observer * =0);
sc_fix(sc_q_mode, sc_o_mode, int, sc_fxnum_observer * =0);
sc_fix(int, int, sc_q_mode, sc_o_mode, sc_fxnum_observer * =0);
sc_fix(int, int, sc_q_mode, sc_o_mode, int, sc_fxnum_observer * =0);
explicit sc_fix(const sc_fxcast_switch &, sc_fxnum_observer * =0);
sc_fix(int, int, const sc_fxcast_switch &, sc_fxnum_observer * =0);
sc_fix(sc_q_mode, sc_o_mode, const sc_fxcast_switch &,
sc_fxnum_observer * =0);
sc_fix(sc_q_mode, sc_o_mode, int, const sc_fxcast_switch &,
sc_fxnum_observer * =0);
sc_fix(int, int, sc_q_mode, sc_o_mode, const sc_fxcast_switch &,
sc_fxnum_observer * =0);
sc_fix(int, int, sc_q_mode, sc_o_mode, int, const sc_fxcast_switch &,
sc_fxnum_observer * =0);
explicit sc_fix(const sc_fxtype_params &, sc_fxnum_observer * =0);
sc_fix(const sc_fxtype_params &, const sc_fxcast_switch &,
sc_fxnum_observer * =0);
#define DECL_CTORS_T(tp) \
sc_fix(tp, int, int, sc_fxnum_observer * =0); \
sc_fix(tp, sc_q_mode, sc_o_mode, sc_fxnum_observer * =0); \
sc_fix(tp, sc_q_mode, sc_o_mode, int, sc_fxnum_observer * =0); \
sc_fix(tp, int, int, sc_q_mode, sc_o_mode, sc_fxnum_observer * =0); \
sc_fix(tp, int, int, sc_q_mode, sc_o_mode, int, sc_fxnum_observer * =0); \
sc_fix(tp, const sc_fxcast_switch &, sc_fxnum_observer * =0); \
sc_fix(tp, int, int, const sc_fxcast_switch &, sc_fxnum_observer * =0); \
sc_fix(tp, sc_q_mode, sc_o_mode, const sc_fxcast_switch &, \
sc_fxnum_observer * =0); \
sc_fix(tp, sc_q_mode, sc_o_mode, int, const sc_fxcast_switch &, \
sc_fxnum_observer * =0); \
sc_fix(tp, int, int, sc_q_mode, sc_o_mode, const sc_fxcast_switch &, \
sc_fxnum_observer * =0); \
sc_fix(tp, int, int, sc_q_mode, sc_o_mode, int, \
const sc_fxcast_switch &, sc_fxnum_observer * =0); \
sc_fix(tp, const sc_fxtype_params &, sc_fxnum_observer * =0); \
sc_fix(tp, const sc_fxtype_params &, const sc_fxcast_switch &, \
sc_fxnum_observer * =0);
#define DECL_CTORS_T_A(tp) \
sc_fix(tp, sc_fxnum_observer * =0); \
DECL_CTORS_T(tp)
#define DECL_CTORS_T_B(tp) \
explicit sc_fix(tp, sc_fxnum_observer * =0); \
DECL_CTORS_T(tp)
DECL_CTORS_T_A(int)
DECL_CTORS_T_A(unsigned int)
DECL_CTORS_T_A(long)
DECL_CTORS_T_A(unsigned long)
DECL_CTORS_T_A(float)
DECL_CTORS_T_A(double)
DECL_CTORS_T_A(const char *)
DECL_CTORS_T_A(const sc_fxval &)
DECL_CTORS_T_A(const sc_fxval_fast &)
DECL_CTORS_T_A(const sc_fxnum &)
DECL_CTORS_T_A(const sc_fxnum_fast &)
DECL_CTORS_T_B(int64)
DECL_CTORS_T_B(uint64)
DECL_CTORS_T_B(const sc_int_base &)
DECL_CTORS_T_B(const sc_uint_base &)
DECL_CTORS_T_B(const sc_signed &)
DECL_CTORS_T_B(const sc_unsigned &)
#undef DECL_CTORS_T
#undef DECL_CTORS_T_A
#undef DECL_CTORS_T_B
// copy constructor
sc_fix(const sc_fix &);
// unary bitwise operators
const sc_fix operator ~ () const;
// unary bitwise functions
friend void b_not(sc_fix &, const sc_fix &);
// binary bitwise operators
friend const sc_fix operator & (const sc_fix &, const sc_fix &);
friend const sc_fix operator & (const sc_fix &, const sc_fix_fast &);
friend const sc_fix operator & (const sc_fix_fast &, const sc_fix &);
friend const sc_fix operator | (const sc_fix &, const sc_fix &);
friend const sc_fix operator | (const sc_fix &, const sc_fix_fast &);
friend const sc_fix operator | (const sc_fix_fast &, const sc_fix &);
friend const sc_fix operator ^ (const sc_fix &, const sc_fix &);
friend const sc_fix operator ^ (const sc_fix &, const sc_fix_fast &);
friend const sc_fix operator ^ (const sc_fix_fast&, const sc_fix &);
// binary bitwise functions
friend void b_and(sc_fix &, const sc_fix &, const sc_fix &);
friend void b_and(sc_fix &, const sc_fix &, const sc_fix_fast &);
friend void b_and(sc_fix &, const sc_fix_fast &, const sc_fix &);
friend void b_or(sc_fix &, const sc_fix &, const sc_fix &);
friend void b_or(sc_fix &, const sc_fix &, const sc_fix_fast &);
friend void b_or(sc_fix &, const sc_fix_fast &, const sc_fix &);
friend void b_xor(sc_fix &, const sc_fix &, const sc_fix &);
friend void b_xor(sc_fix &, const sc_fix &, const sc_fix_fast &);
friend void b_xor(sc_fix &, const sc_fix_fast &, const sc_fix &);
// assignment operators
sc_fix &operator = (const sc_fix &);
#define DECL_ASN_OP_T(op, tp) sc_fix &operator op (tp);
#define DECL_ASN_OP_OTHER(op) \
DECL_ASN_OP_T(op, int64) \
DECL_ASN_OP_T(op, uint64) \
DECL_ASN_OP_T(op, const sc_int_base &) \
DECL_ASN_OP_T(op, const sc_uint_base &) \
DECL_ASN_OP_T(op, const sc_signed &) \
DECL_ASN_OP_T(op, const sc_unsigned &)
#define DECL_ASN_OP(op) \
DECL_ASN_OP_T(op, int) \
DECL_ASN_OP_T(op, unsigned int) \
DECL_ASN_OP_T(op, long) \
DECL_ASN_OP_T(op, unsigned long) \
DECL_ASN_OP_T(op, float) \
DECL_ASN_OP_T(op, double) \
DECL_ASN_OP_T(op, const char *) \
DECL_ASN_OP_T(op, const sc_fxval &) \
DECL_ASN_OP_T(op, const sc_fxval_fast &) \
DECL_ASN_OP_T(op, const sc_fxnum &) \
DECL_ASN_OP_T(op, const sc_fxnum_fast &) \
DECL_ASN_OP_OTHER(op)
DECL_ASN_OP(=)
DECL_ASN_OP(*=)
DECL_ASN_OP(/=)
DECL_ASN_OP(+=)
DECL_ASN_OP(-=)
DECL_ASN_OP_T(<<=, int)
DECL_ASN_OP_T(>>=, int)
DECL_ASN_OP_T(&=, const sc_fix &)
DECL_ASN_OP_T(&=, const sc_fix_fast &)
DECL_ASN_OP_T(|=, const sc_fix &)
DECL_ASN_OP_T(|=, const sc_fix_fast &)
DECL_ASN_OP_T(^=, const sc_fix &)
DECL_ASN_OP_T(^=, const sc_fix_fast &)
#undef DECL_ASN_OP_T
#undef DECL_ASN_OP_OTHER
#undef DECL_ASN_OP
// auto-increment and auto-decrement
const sc_fxval operator ++ (int);
const sc_fxval operator -- (int);
sc_fix& operator ++ ();
sc_fix& operator -- ();
};
// ----------------------------------------------------------------------------
// CLASS : sc_fix_fast
//
// "Unconstrained" signed fixed-point class; limited precision.
// ----------------------------------------------------------------------------
class sc_fix_fast : public sc_fxnum_fast
{
public:
// constructors
explicit sc_fix_fast(sc_fxnum_fast_observer * =0);
sc_fix_fast(int, int, sc_fxnum_fast_observer * =0);
sc_fix_fast(sc_q_mode, sc_o_mode, sc_fxnum_fast_observer * =0);
sc_fix_fast(sc_q_mode, sc_o_mode, int, sc_fxnum_fast_observer * =0);
sc_fix_fast(int, int, sc_q_mode, sc_o_mode, sc_fxnum_fast_observer * =0);
sc_fix_fast(int, int, sc_q_mode, sc_o_mode, int,
sc_fxnum_fast_observer * =0);
explicit sc_fix_fast(const sc_fxcast_switch &,
sc_fxnum_fast_observer * =0);
sc_fix_fast(int, int, const sc_fxcast_switch &,
sc_fxnum_fast_observer * =0);
sc_fix_fast(sc_q_mode, sc_o_mode, const sc_fxcast_switch &,
sc_fxnum_fast_observer * =0);
sc_fix_fast(sc_q_mode, sc_o_mode, int, const sc_fxcast_switch &,
sc_fxnum_fast_observer * =0);
sc_fix_fast(int, int, sc_q_mode, sc_o_mode, const sc_fxcast_switch &,
sc_fxnum_fast_observer * =0);
sc_fix_fast(int, int, sc_q_mode, sc_o_mode, int, const sc_fxcast_switch &,
sc_fxnum_fast_observer * =0);
explicit sc_fix_fast(const sc_fxtype_params &,
sc_fxnum_fast_observer * =0);
sc_fix_fast(const sc_fxtype_params &, const sc_fxcast_switch &,
sc_fxnum_fast_observer * =0);
#define DECL_CTORS_T(tp) \
sc_fix_fast(tp, int, int, sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, sc_q_mode, sc_o_mode, sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, sc_q_mode, sc_o_mode, int, sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, int, int, sc_q_mode, sc_o_mode, \
sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, int, int, sc_q_mode, sc_o_mode, int, \
sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, const sc_fxcast_switch &, sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, int, int, const sc_fxcast_switch &, \
sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, sc_q_mode, sc_o_mode, const sc_fxcast_switch &, \
sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, sc_q_mode, sc_o_mode, int, const sc_fxcast_switch &, \
sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, int, int, sc_q_mode, sc_o_mode, const sc_fxcast_switch &, \
sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, int, int, sc_q_mode, sc_o_mode, int, \
const sc_fxcast_switch &, sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, const sc_fxtype_params &, sc_fxnum_fast_observer * = 0); \
sc_fix_fast(tp, const sc_fxtype_params &, const sc_fxcast_switch &, \
sc_fxnum_fast_observer * = 0);
#define DECL_CTORS_T_A(tp) \
sc_fix_fast(tp, sc_fxnum_fast_observer * =0); \
DECL_CTORS_T(tp)
#define DECL_CTORS_T_B(tp) \
explicit sc_fix_fast(tp, sc_fxnum_fast_observer * =0); \
DECL_CTORS_T(tp)
DECL_CTORS_T_A(int)
DECL_CTORS_T_A(unsigned int)
DECL_CTORS_T_A(long)
DECL_CTORS_T_A(unsigned long)
DECL_CTORS_T_A(float)
DECL_CTORS_T_A(double)
DECL_CTORS_T_A(const char *)
DECL_CTORS_T_A(const sc_fxval &)
DECL_CTORS_T_A(const sc_fxval_fast &)
DECL_CTORS_T_A(const sc_fxnum &)
DECL_CTORS_T_A(const sc_fxnum_fast &)
DECL_CTORS_T_B(int64)
DECL_CTORS_T_B(uint64)
DECL_CTORS_T_B(const sc_int_base &)
DECL_CTORS_T_B(const sc_uint_base &)
DECL_CTORS_T_B(const sc_signed &)
DECL_CTORS_T_B(const sc_unsigned &)
#undef DECL_CTORS_T
#undef DECL_CTORS_T_A
#undef DECL_CTORS_T_B
// copy constructor
sc_fix_fast(const sc_fix_fast &);
// unary bitwise operators
const sc_fix_fast operator ~ () const;
// unary bitwise functions
friend void b_not(sc_fix_fast &, const sc_fix_fast &);
// binary bitwise operators
friend const sc_fix_fast operator & (
const sc_fix_fast &, const sc_fix_fast &);
friend const sc_fix_fast operator ^ (
const sc_fix_fast &, const sc_fix_fast &);
friend const sc_fix_fast operator | (
const sc_fix_fast &, const sc_fix_fast &);
// binary bitwise functions
friend void b_and(sc_fix_fast &, const sc_fix_fast &, const sc_fix_fast &);
friend void b_or(sc_fix_fast &, const sc_fix_fast &, const sc_fix_fast &);
friend void b_xor(sc_fix_fast &, const sc_fix_fast &, const sc_fix_fast &);
// assignment operators
sc_fix_fast &operator = (const sc_fix_fast &);
#define DECL_ASN_OP_T(op,tp) sc_fix_fast &operator op (tp);
#define DECL_ASN_OP_OTHER(op) \
DECL_ASN_OP_T(op, int64) \
DECL_ASN_OP_T(op, uint64) \
DECL_ASN_OP_T(op, const sc_int_base &) \
DECL_ASN_OP_T(op, const sc_uint_base &) \
DECL_ASN_OP_T(op, const sc_signed &) \
DECL_ASN_OP_T(op, const sc_unsigned &)
#define DECL_ASN_OP(op) \
DECL_ASN_OP_T(op, int) \
DECL_ASN_OP_T(op, unsigned int) \
DECL_ASN_OP_T(op, long) \
DECL_ASN_OP_T(op, unsigned long) \
DECL_ASN_OP_T(op, float) \
DECL_ASN_OP_T(op, double) \
DECL_ASN_OP_T(op, const char *) \
DECL_ASN_OP_T(op, const sc_fxval &) \
DECL_ASN_OP_T(op, const sc_fxval_fast &) \
DECL_ASN_OP_T(op, const sc_fxnum &) \
DECL_ASN_OP_T(op, const sc_fxnum_fast &) \
DECL_ASN_OP_OTHER(op)
DECL_ASN_OP(=)
DECL_ASN_OP(*=)
DECL_ASN_OP(/=)
DECL_ASN_OP(+=)
DECL_ASN_OP(-=)
DECL_ASN_OP_T(<<=, int)
DECL_ASN_OP_T(>>=, int)
DECL_ASN_OP_T(&=, const sc_fix &)
DECL_ASN_OP_T(&=, const sc_fix_fast &)
DECL_ASN_OP_T(|=, const sc_fix &)
DECL_ASN_OP_T(|=, const sc_fix_fast &)
DECL_ASN_OP_T(^=, const sc_fix &)
DECL_ASN_OP_T(^=, const sc_fix_fast &)
#undef DECL_ASN_OP_T
#undef DECL_ASN_OP_OTHER
#undef DECL_ASN_OP
// auto-increment and auto-decrement
const sc_fxval_fast operator ++ (int);
const sc_fxval_fast operator -- (int);
sc_fix_fast& operator ++ ();
sc_fix_fast& operator -- ();
};
// IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII
// ----------------------------------------------------------------------------
// CLASS : sc_fix
//
// "Unconstrained" signed fixed-point class; arbitrary precision.
// ----------------------------------------------------------------------------
// constructors
inline sc_fix::sc_fix(sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(), SC_TC_, sc_fxcast_switch(), observer_)
{}
inline sc_fix::sc_fix(int wl_, int iwl_, sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(wl_, iwl_), SC_TC_, sc_fxcast_switch(),
observer_)
{}
inline sc_fix::sc_fix(sc_q_mode qm, sc_o_mode om,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(qm, om), SC_TC_, sc_fxcast_switch(),
observer_ )
{}
inline sc_fix::sc_fix(sc_q_mode qm, sc_o_mode om, int nb,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(qm, om, nb), SC_TC_, sc_fxcast_switch(),
observer_)
{}
inline sc_fix::sc_fix(int wl_, int iwl_, sc_q_mode qm, sc_o_mode om,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_,
sc_fxcast_switch(), observer_)
{}
inline sc_fix::sc_fix(int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, int nb,
sc_fxnum_observer* observer_) :
sc_fxnum(sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_,
sc_fxcast_switch(), observer_)
{}
inline sc_fix::sc_fix(const sc_fxcast_switch &cast_sw,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(), SC_TC_, cast_sw, observer_)
{}
inline sc_fix::sc_fix(int wl_, int iwl_, const sc_fxcast_switch &cast_sw,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(wl_, iwl_), SC_TC_, cast_sw, observer_)
{}
inline sc_fix::sc_fix(sc_q_mode qm, sc_o_mode om,
const sc_fxcast_switch &cast_sw,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(qm, om), SC_TC_, cast_sw, observer_)
{}
inline sc_fix::sc_fix(sc_q_mode qm, sc_o_mode om, int nb,
const sc_fxcast_switch &cast_sw,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(qm, om, nb), SC_TC_, cast_sw, observer_)
{}
inline sc_fix::sc_fix(int wl_, int iwl_, sc_q_mode qm, sc_o_mode om,
const sc_fxcast_switch &cast_sw,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, cast_sw,
observer_)
{}
inline sc_fix::sc_fix(int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, int nb,
const sc_fxcast_switch &cast_sw,
sc_fxnum_observer *observer_) :
sc_fxnum(sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, cast_sw,
observer_)
{}
inline sc_fix::sc_fix(const sc_fxtype_params &type_params_,
sc_fxnum_observer *observer_) :
sc_fxnum( type_params_, SC_TC_, sc_fxcast_switch(), observer_)
{}
inline sc_fix::sc_fix(const sc_fxtype_params &type_params_,
const sc_fxcast_switch &cast_sw,
sc_fxnum_observer *observer_) :
sc_fxnum(type_params_, SC_TC_, cast_sw, observer_)
{}
#define DEFN_CTORS_T_A(tp) \
inline sc_fix::sc_fix(tp a, sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(), SC_TC_, sc_fxcast_switch(), \
observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_), SC_TC_, sc_fxcast_switch(), \
observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, sc_q_mode qm, sc_o_mode om, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(qm, om), SC_TC_, sc_fxcast_switch(), \
observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, sc_q_mode qm, sc_o_mode om, int nb, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(qm, om, nb), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, \
int nb, sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(), SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_), SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, sc_q_mode qm, sc_o_mode om, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(qm, om), SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, sc_q_mode qm, sc_o_mode om, int nb, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(qm, om, nb), SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, cast_sw, \
observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, \
int nb, const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, cast_sw, \
observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, const sc_fxtype_params &type_params_, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, type_params_, SC_TC_, sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, const sc_fxtype_params &type_params_, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, type_params_, SC_TC_, cast_sw, observer_) \
{}
#define DEFN_CTORS_T_B(tp) \
inline sc_fix::sc_fix(tp a, sc_fxnum_observer *observer_) : \
sc_fxnum(a, a.type_params(), SC_TC_, sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(a.type_params(), wl_, iwl_), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, sc_q_mode qm, sc_o_mode om, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(a.type_params(), qm, om), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, sc_q_mode qm, sc_o_mode om, int nb, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(a.type_params(), qm, om, nb), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, \
int nb, sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, a.type_params(), SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(a.type_params(), wl_, iwl_), SC_TC_, \
cast_sw, observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, sc_q_mode qm, sc_o_mode om, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(a.type_params(), qm, om), SC_TC_, \
cast_sw, observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, sc_q_mode qm, sc_o_mode om, int nb, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(a.type_params(), qm, om, nb), SC_TC_, \
cast_sw, observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, cast_sw, \
observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, int wl_, int iwl_, sc_q_mode qm, sc_o_mode om, \
int nb, const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, cast_sw, \
observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, const sc_fxtype_params &type_params_, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, type_params_, SC_TC_, sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix::sc_fix(tp a, const sc_fxtype_params &type_params_, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_observer *observer_) : \
sc_fxnum(a, type_params_, SC_TC_, cast_sw, observer_) \
{}
DEFN_CTORS_T_A(int)
DEFN_CTORS_T_A(unsigned int)
DEFN_CTORS_T_A(long)
DEFN_CTORS_T_A(unsigned long)
DEFN_CTORS_T_A(float)
DEFN_CTORS_T_A(double)
DEFN_CTORS_T_A(const char *)
DEFN_CTORS_T_A(const sc_fxval &)
DEFN_CTORS_T_A(const sc_fxval_fast &)
DEFN_CTORS_T_B(const sc_fxnum &)
DEFN_CTORS_T_B(const sc_fxnum_fast &)
DEFN_CTORS_T_A(int64)
DEFN_CTORS_T_A(uint64)
DEFN_CTORS_T_A(const sc_int_base &)
DEFN_CTORS_T_A(const sc_uint_base &)
DEFN_CTORS_T_A(const sc_signed &)
DEFN_CTORS_T_A(const sc_unsigned &)
#undef DEFN_CTORS_T_A
#undef DEFN_CTORS_T_B
// copy constructor
inline sc_fix::sc_fix(const sc_fix &a) :
sc_fxnum(a, a.type_params(), SC_TC_, sc_fxcast_switch(), 0)
{}
// unary bitwise operators
inline const sc_fix sc_fix::operator ~ () const
{
SC_FXNUM_OBSERVER_READ_(*this)
int iwl_c = iwl();
int wl_c = wl();
sc_fix c(wl_c, iwl_c);
for (int i = iwl_c - wl_c; i < iwl_c; ++i)
c.set_bit(i, !get_bit(i));
return sc_fix(c, wl_c, iwl_c);
}
// unary bitwise functions
inline void
b_not(sc_fix &c, const sc_fix &a)
{
SC_FXNUM_OBSERVER_READ_(a)
int iwl_c = c.iwl();
for (int i = iwl_c - c.wl(); i < iwl_c; ++i)
c.set_bit(i, !a.get_bit(i));
c.cast();
SC_FXNUM_OBSERVER_WRITE_(c)
}
// binary bitwise operators
#define DEFN_BIN_OP_T(op, op2, tp1, tp2) \
inline const sc_fix \
operator op (const tp1 &a, const tp2 &b) \
{ \
a.observer_read(); \
b.observer_read(); \
int iwl_a = a.iwl(); \
int iwl_b = b.iwl(); \
int iwl_c = sc_max(iwl_a, iwl_b); \
int fwl_c = sc_max(a.wl() - iwl_a, b.wl() - iwl_b); \
sc_fix c(iwl_c + fwl_c, iwl_c); \
for (int i = -fwl_c; i < iwl_c; ++ i) \
c.set_bit(i, a.get_bit(i) op2 b.get_bit(i)); \
return sc_fix(c, iwl_c + fwl_c, iwl_c); \
}
DEFN_BIN_OP_T(&, &&, sc_fix, sc_fix)
DEFN_BIN_OP_T(&, &&, sc_fix, sc_fix_fast)
DEFN_BIN_OP_T(&, &&, sc_fix_fast, sc_fix)
DEFN_BIN_OP_T(|, ||, sc_fix, sc_fix)
DEFN_BIN_OP_T(|, ||, sc_fix, sc_fix_fast)
DEFN_BIN_OP_T(|, ||, sc_fix_fast, sc_fix)
DEFN_BIN_OP_T(^, !=, sc_fix, sc_fix)
DEFN_BIN_OP_T(^, !=, sc_fix, sc_fix_fast)
DEFN_BIN_OP_T(^, !=, sc_fix_fast, sc_fix)
#undef DEFN_BIN_OP_T
// binary bitwise functions
#define DEFN_BIN_FNC_T(fnc, op2, tp1, tp2) \
inline void \
fnc (sc_fix &c, const tp1 &a, const tp2 &b) \
{ \
a.observer_read(); \
b.observer_read(); \
int iwl_c = c.iwl(); \
for (int i = iwl_c - c.wl(); i < iwl_c; ++i) \
c.set_bit(i, a.get_bit(i) op2 b.get_bit(i)); \
c.cast(); \
SC_FXNUM_OBSERVER_WRITE_(c) \
}
DEFN_BIN_FNC_T(b_and, &&, sc_fix, sc_fix)
DEFN_BIN_FNC_T(b_and, &&, sc_fix, sc_fix_fast)
DEFN_BIN_FNC_T(b_and, &&, sc_fix_fast, sc_fix)
DEFN_BIN_FNC_T(b_or, ||, sc_fix, sc_fix)
DEFN_BIN_FNC_T(b_or, ||, sc_fix, sc_fix_fast)
DEFN_BIN_FNC_T(b_or, ||, sc_fix_fast, sc_fix)
DEFN_BIN_FNC_T(b_xor, !=, sc_fix, sc_fix)
DEFN_BIN_FNC_T(b_xor, !=, sc_fix, sc_fix_fast)
DEFN_BIN_FNC_T(b_xor, !=, sc_fix_fast, sc_fix)
#undef DEFN_BIN_FNC_T
// assignment operators
inline
sc_fix &
sc_fix::operator = (const sc_fix &a)
{
sc_fxnum::operator = (a);
return *this;
}
#define DEFN_ASN_OP_T(op, tp) \
inline sc_fix & \
sc_fix::operator op (tp a) \
{ \
sc_fxnum::operator op(a); \
return *this; \
}
#define DEFN_ASN_OP_OTHER(op) \
DEFN_ASN_OP_T(op, int64) \
DEFN_ASN_OP_T(op, uint64) \
DEFN_ASN_OP_T(op, const sc_int_base &) \
DEFN_ASN_OP_T(op, const sc_uint_base &) \
DEFN_ASN_OP_T(op, const sc_signed &) \
DEFN_ASN_OP_T(op, const sc_unsigned &)
#define DEFN_ASN_OP(op) \
DEFN_ASN_OP_T(op, int) \
DEFN_ASN_OP_T(op, unsigned int) \
DEFN_ASN_OP_T(op, long) \
DEFN_ASN_OP_T(op, unsigned long) \
DEFN_ASN_OP_T(op, float) \
DEFN_ASN_OP_T(op, double) \
DEFN_ASN_OP_T(op, const char *) \
DEFN_ASN_OP_T(op, const sc_fxval &) \
DEFN_ASN_OP_T(op, const sc_fxval_fast &) \
DEFN_ASN_OP_T(op, const sc_fxnum &) \
DEFN_ASN_OP_T(op, const sc_fxnum_fast &) \
DEFN_ASN_OP_OTHER(op)
DEFN_ASN_OP(=)
DEFN_ASN_OP(*=)
DEFN_ASN_OP(/=)
DEFN_ASN_OP(+=)
DEFN_ASN_OP(-=)
DEFN_ASN_OP_T(<<=, int)
DEFN_ASN_OP_T(>>=, int)
#undef DEFN_ASN_OP_T
#undef DEFN_ASN_OP_OTHER
#undef DEFN_ASN_OP
#define DEFN_ASN_OP_T(op, op2, tp) \
inline sc_fix & \
sc_fix::operator op (const tp &b) \
{ \
SC_FXNUM_OBSERVER_READ_(*this) \
b.observer_read(); \
int iwl_c = iwl(); \
for (int i = iwl_c - wl(); i < iwl_c; ++i) \
set_bit(i, get_bit(i) op2 b.get_bit(i)); \
cast(); \
SC_FXNUM_OBSERVER_WRITE_(*this) \
return *this; \
}
DEFN_ASN_OP_T(&=, &&, sc_fix)
DEFN_ASN_OP_T(&=, &&, sc_fix_fast)
DEFN_ASN_OP_T(|=, ||, sc_fix)
DEFN_ASN_OP_T(|=, ||, sc_fix_fast)
DEFN_ASN_OP_T(^=, !=, sc_fix)
DEFN_ASN_OP_T(^=, !=, sc_fix_fast)
#undef DEFN_ASN_OP_T
// auto-increment and auto-decrement
inline const sc_fxval
sc_fix::operator ++ (int)
{
return sc_fxval(sc_fxnum::operator ++ (0));
}
inline const sc_fxval
sc_fix::operator -- (int)
{
return sc_fxval(sc_fxnum::operator -- (0));
}
inline sc_fix &
sc_fix::operator ++ ()
{
sc_fxnum::operator ++ ();
return *this;
}
inline sc_fix &
sc_fix::operator -- ()
{
sc_fxnum::operator -- ();
return *this;
}
// ----------------------------------------------------------------------------
// CLASS : sc_fix_fast
//
// "Unconstrained" signed fixed-point class; limited precision.
// ----------------------------------------------------------------------------
// constructors
inline sc_fix_fast::sc_fix_fast(sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(), SC_TC_, sc_fxcast_switch(),
observer_)
{}
inline sc_fix_fast::sc_fix_fast(int wl_, int iwl_,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(wl_, iwl_), SC_TC_, sc_fxcast_switch(),
observer_ )
{}
inline sc_fix_fast::sc_fix_fast(sc_q_mode qm, sc_o_mode om,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(qm, om), SC_TC_, sc_fxcast_switch(),
observer_ )
{}
inline sc_fix_fast::sc_fix_fast(sc_q_mode qm, sc_o_mode om, int nb,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(qm, om, nb), SC_TC_, sc_fxcast_switch(),
observer_ )
{}
inline sc_fix_fast::sc_fix_fast(int wl_, int iwl_, sc_q_mode qm, sc_o_mode om,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_,
sc_fxcast_switch(), observer_)
{}
inline sc_fix_fast::sc_fix_fast(int wl_, int iwl_, sc_q_mode qm, sc_o_mode om,
int nb, sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_,
sc_fxcast_switch(), observer_)
{}
inline sc_fix_fast::sc_fix_fast(const sc_fxcast_switch &cast_sw,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(), SC_TC_, cast_sw, observer_)
{}
inline sc_fix_fast::sc_fix_fast(int wl_, int iwl_,
const sc_fxcast_switch &cast_sw,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(wl_, iwl_), SC_TC_, cast_sw, observer_)
{}
inline sc_fix_fast::sc_fix_fast(sc_q_mode qm, sc_o_mode om,
const sc_fxcast_switch &cast_sw,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(qm, om), SC_TC_, cast_sw, observer_)
{}
inline sc_fix_fast::sc_fix_fast(sc_q_mode qm, sc_o_mode om, int nb,
const sc_fxcast_switch &cast_sw,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(qm, om, nb), SC_TC_, cast_sw, observer_)
{}
inline sc_fix_fast::sc_fix_fast(int wl_, int iwl_, sc_q_mode qm, sc_o_mode om,
const sc_fxcast_switch &cast_sw,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, cast_sw,
observer_)
{}
inline sc_fix_fast::sc_fix_fast(int wl_, int iwl_, sc_q_mode qm, sc_o_mode om,
int nb, const sc_fxcast_switch &cast_sw,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, cast_sw,
observer_)
{}
inline sc_fix_fast::sc_fix_fast(const sc_fxtype_params &type_params_,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(type_params_, SC_TC_, sc_fxcast_switch(), observer_)
{}
inline sc_fix_fast::sc_fix_fast(const sc_fxtype_params &type_params_,
const sc_fxcast_switch &cast_sw,
sc_fxnum_fast_observer *observer_) :
sc_fxnum_fast(type_params_, SC_TC_, cast_sw, observer_)
{}
#define DEFN_CTORS_T_A(tp) \
inline sc_fix_fast::sc_fix_fast(tp a, sc_fxnum_fast_observer *observer_ ) : \
sc_fxnum_fast(a, sc_fxtype_params(), SC_TC_, sc_fxcast_switch(), \
observer_ ) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, sc_q_mode qm, sc_o_mode om, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(qm, om), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, sc_q_mode qm, sc_o_mode om, int nb, \
sc_fxnum_fast_observer *observer_ ) : \
sc_fxnum_fast(a, sc_fxtype_params(qm, om, nb), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, sc_q_mode qm, \
sc_o_mode om, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, sc_q_mode qm, \
sc_o_mode om, int nb, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(), SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_), SC_TC_, cast_sw, \
observer_ ) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, sc_q_mode qm, sc_o_mode om, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(qm, om), SC_TC_, cast_sw, \
observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, sc_q_mode qm, sc_o_mode om, int nb, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(qm, om, nb), SC_TC_, cast_sw, \
observer_ ) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, sc_q_mode qm, \
sc_o_mode om, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, \
cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, sc_q_mode qm, \
sc_o_mode om, int nb, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, \
cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, const sc_fxtype_params &type_params_, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, type_params_, SC_TC_, sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, const sc_fxtype_params &type_params_, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, type_params_, SC_TC_, cast_sw, observer_) \
{}
#define DEFN_CTORS_T_B(tp) \
inline sc_fix_fast::sc_fix_fast(tp a, sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, a.type_params(), SC_TC_, sc_fxcast_switch(), \
observer_ ) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(a.type_params(), wl_, iwl_), \
SC_TC_, sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, sc_q_mode qm, sc_o_mode om, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(a.type_params(), qm, om), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, sc_q_mode qm, sc_o_mode om, int nb, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(a.type_params(), qm, om, nb), \
SC_TC_, sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, sc_q_mode qm, \
sc_o_mode om, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, sc_q_mode qm, \
sc_o_mode om, int nb, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, \
sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, a.type_params(), SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(a.type_params(), wl_, iwl_), \
SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, sc_q_mode qm, sc_o_mode om, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(a.type_params(), qm, om), SC_TC_, \
cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, sc_q_mode qm, sc_o_mode om, int nb, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(a.type_params(), qm, om, nb), \
SC_TC_, cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, sc_q_mode qm, \
sc_o_mode om, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_, qm, om), SC_TC_, \
cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, int wl_, int iwl_, sc_q_mode qm, \
sc_o_mode om, int nb, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, sc_fxtype_params(wl_, iwl_, qm, om, nb), SC_TC_, \
cast_sw, observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, const sc_fxtype_params &type_params_, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, type_params_, SC_TC_, sc_fxcast_switch(), observer_) \
{} \
\
inline sc_fix_fast::sc_fix_fast(tp a, const sc_fxtype_params &type_params_, \
const sc_fxcast_switch &cast_sw, \
sc_fxnum_fast_observer *observer_) : \
sc_fxnum_fast(a, type_params_, SC_TC_, cast_sw, observer_ ) \
{}
DEFN_CTORS_T_A(int)
DEFN_CTORS_T_A(unsigned int)
DEFN_CTORS_T_A(long)
DEFN_CTORS_T_A(unsigned long)
DEFN_CTORS_T_A(float)
DEFN_CTORS_T_A(double)
DEFN_CTORS_T_A(const char *)
DEFN_CTORS_T_A(const sc_fxval &)
DEFN_CTORS_T_A(const sc_fxval_fast &)
DEFN_CTORS_T_B(const sc_fxnum &)
DEFN_CTORS_T_B(const sc_fxnum_fast &)
DEFN_CTORS_T_A(int64)
DEFN_CTORS_T_A(uint64)
DEFN_CTORS_T_A(const sc_int_base &)
DEFN_CTORS_T_A(const sc_uint_base &)
DEFN_CTORS_T_A(const sc_signed &)
DEFN_CTORS_T_A(const sc_unsigned &)
#undef DEFN_CTORS_T_A
#undef DEFN_CTORS_T_B
// copy constructor
inline sc_fix_fast::sc_fix_fast(const sc_fix_fast &a) :
sc_fxnum_fast(a, a.type_params(), SC_TC_, sc_fxcast_switch(), 0)
{}
// unary bitwise operators
inline const sc_fix_fast
sc_fix_fast::operator ~ () const
{
SC_FXNUM_FAST_OBSERVER_READ_(*this)
int iwl_c = iwl();
int wl_c = wl();
sc_fix_fast c(wl_c, iwl_c);
for (int i = iwl_c - wl_c; i < iwl_c; ++i)
c.set_bit(i, !get_bit(i));
return sc_fix_fast(c, wl_c, iwl_c);
}
// unary bitwise functions
inline void
b_not(sc_fix_fast &c, const sc_fix_fast &a)
{
SC_FXNUM_FAST_OBSERVER_READ_(a)
int iwl_c = c.iwl();
for (int i = iwl_c - c.wl(); i < iwl_c; ++i)
c.set_bit(i, !a.get_bit(i));
c.cast();
SC_FXNUM_FAST_OBSERVER_WRITE_(c)
}
// binary bitwise operators
#define DEFN_BIN_OP_T(op, op2, tp1, tp2) \
inline const sc_fix_fast \
operator op (const tp1 &a, const tp2 &b) \
{ \
a.observer_read(); \
b.observer_read(); \
int iwl_a = a.iwl(); \
int iwl_b = b.iwl(); \
int iwl_c = sc_max(iwl_a, iwl_b); \
int fwl_c = sc_max(a.wl() - iwl_a, b.wl() - iwl_b); \
sc_fix_fast c(iwl_c + fwl_c, iwl_c); \
for (int i = -fwl_c; i < iwl_c; ++i) \
c.set_bit(i, a.get_bit(i) op2 b.get_bit(i)); \
return sc_fix_fast(c, iwl_c + fwl_c, iwl_c); \
}
DEFN_BIN_OP_T(&, &&, sc_fix_fast, sc_fix_fast)
DEFN_BIN_OP_T(|, ||, sc_fix_fast, sc_fix_fast)
DEFN_BIN_OP_T(^, !=, sc_fix_fast, sc_fix_fast)
#undef DEFN_BIN_OP_T
// binary bitwise functions
#define DEFN_BIN_FNC_T(fnc, op2, tp1, tp2) \
inline void \
fnc(sc_fix_fast &c, const tp1 &a, const tp2 &b) \
{ \
a.observer_read(); \
b.observer_read(); \
int iwl_c = c.iwl(); \
for (int i = iwl_c - c.wl(); i < iwl_c; ++i) \
c.set_bit(i, a.get_bit(i) op2 b.get_bit(i)); \
c.cast(); \
SC_FXNUM_FAST_OBSERVER_WRITE_(c) \
}
DEFN_BIN_FNC_T(b_and, &&, sc_fix_fast, sc_fix_fast)
DEFN_BIN_FNC_T(b_or, ||, sc_fix_fast, sc_fix_fast)
DEFN_BIN_FNC_T(b_xor, !=, sc_fix_fast, sc_fix_fast)
#undef DEFN_BIN_FNC_T
// assignment operators
inline sc_fix_fast &
sc_fix_fast::operator = (const sc_fix_fast &a)
{
sc_fxnum_fast::operator = (a);
return *this;
}
#define DEFN_ASN_OP_T(op, tp) \
inline sc_fix_fast & \
sc_fix_fast::operator op (tp a) \
{ \
sc_fxnum_fast::operator op(a); \
return *this; \
}
#define DEFN_ASN_OP_OTHER(op) \
DEFN_ASN_OP_T(op, int64) \
DEFN_ASN_OP_T(op, uint64) \
DEFN_ASN_OP_T(op, const sc_int_base &) \
DEFN_ASN_OP_T(op, const sc_uint_base &) \
DEFN_ASN_OP_T(op, const sc_signed &) \
DEFN_ASN_OP_T(op, const sc_unsigned &)
#define DEFN_ASN_OP(op) \
DEFN_ASN_OP_T(op, int) \
DEFN_ASN_OP_T(op, unsigned int) \
DEFN_ASN_OP_T(op, long) \
DEFN_ASN_OP_T(op, unsigned long) \
DEFN_ASN_OP_T(op, float) \
DEFN_ASN_OP_T(op, double) \
DEFN_ASN_OP_T(op, const char *) \
DEFN_ASN_OP_T(op, const sc_fxval &) \
DEFN_ASN_OP_T(op, const sc_fxval_fast &) \
DEFN_ASN_OP_T(op, const sc_fxnum &) \
DEFN_ASN_OP_T(op, const sc_fxnum_fast &) \
DEFN_ASN_OP_OTHER(op)
DEFN_ASN_OP(=)
DEFN_ASN_OP(*=)
DEFN_ASN_OP(/=)
DEFN_ASN_OP(+=)
DEFN_ASN_OP(-=)
DEFN_ASN_OP_T(<<=, int)
DEFN_ASN_OP_T(>>=, int)
#undef DEFN_ASN_OP_T
#undef DEFN_ASN_OP_OTHER
#undef DEFN_ASN_OP
#define DEFN_ASN_OP_T(op, op2, tp) \
inline sc_fix_fast & \
sc_fix_fast::operator op (const tp &b) \
{ \
SC_FXNUM_FAST_OBSERVER_READ_(*this) \
b.observer_read(); \
int iwl_c = iwl(); \
for (int i = iwl_c - wl(); i < iwl_c; ++i) \
set_bit(i, get_bit(i) op2 b.get_bit(i)); \
cast(); \
SC_FXNUM_FAST_OBSERVER_WRITE_(*this) \
return *this; \
}
DEFN_ASN_OP_T(&=, &&, sc_fix)
DEFN_ASN_OP_T(&=, &&, sc_fix_fast)
DEFN_ASN_OP_T(|=, ||, sc_fix)
DEFN_ASN_OP_T(|=, ||, sc_fix_fast)
DEFN_ASN_OP_T(^=, !=, sc_fix)
DEFN_ASN_OP_T(^=, !=, sc_fix_fast)
#undef DEFN_ASN_OP_T
// auto-increment and auto-decrement
inline const sc_fxval_fast
sc_fix_fast::operator ++ (int)
{
return sc_fxval_fast(sc_fxnum_fast::operator ++ (0));
}
inline const sc_fxval_fast
sc_fix_fast::operator -- (int)
{
return sc_fxval_fast(sc_fxnum_fast::operator -- (0));
}
inline sc_fix_fast &
sc_fix_fast::operator ++ ()
{
sc_fxnum_fast::operator ++ ();
return *this;
}
inline sc_fix_fast &
sc_fix_fast::operator -- ()
{
sc_fxnum_fast::operator -- ();
return *this;
}
} // namespace sc_dt
#endif // __SYSTEMC_EXT_DT_FX_SC_FIX_HH__