9 #ifndef TRGSignal_FLAG_
10 #define TRGSignal_FLAG_
13 #include "trg/trg/Clock.h"
14 #include "trg/trg/Time.h"
42 const TRGClock& = Belle2_GDL::GDLSystemClock);
59 const std::string&
name(
void)
const;
68 unsigned nEdges(
void)
const;
71 unsigned width(
unsigned i = 0)
const;
77 bool active(
int clk0,
int clk1)
const;
80 bool state(
int clockPosition)
const;
84 bool riseEdge(
int clockPosition)
const;
91 void dump(
const std::string& message =
"",
92 const std::string& pre =
"")
const;
97 const std::string&
name(
const std::string& newName);
164 static std::vector<TRGTime>
orOperation(
const std::vector<TRGTime>&);
197 return _name = newName;
219 return (*
this) &= left;
246 return (*
this) |= left;
290 for (
unsigned i = 0; i <
_history.size(); i++) {
308 for (
unsigned i = 0; i <
_history.size(); i++) {
311 }
else if (
_history[i].time() == a) {
313 }
else if (
_history[i].time() > a) {
340 return (!
operator==(a));
347 for (
unsigned i = 0; i <
_history.size(); i++) {
349 const int t0 =
_history[i - 1].time();
352 if ((c1 > t0) && (c0 < t1))
354 if ((c1 < t0) && (c1 < t1))
A class to represent a digitized signal. Unit is nano second.
A class to represent a digitized signal. Unit is nano second.
TRGSignal & operator=(const TRGSignal &)=default
Default assignment operator.
const TRGClock * _clock
Clock.
std::vector< TRGTime > _history
Timing history.
const TRGSignal & set(double t0, double t1)
makes a pulse with leading edge at t0 and with trailing edge at t1.
A class to represent a signal timing in the trigger system.
TRGSignal & operator|=(const TRGSignal &)
returns OR result.
unsigned nEdges(void) const
returns # of edges.
static std::vector< TRGTime > orOperation(const std::vector< TRGTime > &)
Or operation.
TRGSignal & operator&=(const TRGSignal &)
returns AND result.
const TRGTime * operator[](unsigned i) const
returns timing of i'th edge.
TRGSignal operator&(const TRGSignal &) const
returns AND result.
const TRGClock & clock(void) const
returns clock.
bool operator!=(const TRGSignal &) const
returns true if two are the same.
TRGSignal & widen(unsigned width)
returns widen signals. Signals wider than "width" will be untouched.
bool riseEdge(int clockPosition) const
returns true if signal is active and rising edge in give clock position.
const std::string & name(void) const
returns name.
std::vector< int > stateChanges(void) const
returns a list of clock position of state change.
const TRGSignal & unset(int t0, int t1)
clear(or unset) with leading edge at clock t0 and with trailing edge at clock t1.
unsigned width(unsigned i=0) const
returns width of i'th signal (i=0,1,2,...).
unsigned nSignals(void) const
returns # of signals.
TRGSignal(const TRGClock &=Belle2_GDL::GDLSystemClock)
Constructor.
bool state(int clockPosition) const
returns true if signal is active in given clock position.
virtual ~TRGSignal()
Destructor.
bool active(void) const
returns true if there is a signal.
bool operator==(const TRGSignal &) const
returns true if two are the same.
void sort(void)
Sort operation.
TRGSignal operator|(const TRGSignal &) const
returns OR result.
void clear(void)
clears contents.
bool consistencyCheck(void) const
Self-consitency check. True is return if something wrong.
const TRGSignal & invert(void)
makes signal inverted.
void dump(const std::string &message="", const std::string &pre="") const
dumps contents.
Abstract base class for different kinds of events.