clash-prelude
Copyright(C) 2021 QBayLogic B.V.
LicenseBSD2 (see the file LICENSE)
MaintainerQBayLogic B.V. <devops@qbaylogic.com>
Safe HaskellNone
LanguageHaskell2010

Clash.Class.Counter

Description

Utilities for wrapping counters consisting of multiple individual counters

Synopsis

Documentation

class Counter a where Source #

Counter is a class that composes multiple counters into a single one. It is similar to odometers found in olds cars, once all counters reach their maximum they reset to zero - i.e. odometer rollover. See countSucc and countPred for API usage examples.

Example use case: when driving a monitor through VGA you would like to keep track at least two counters: one counting a horizontal position, and one vertical. Perhaps a fancy VGA driver would also like to keep track of the number of drawn frames. To do so, the three counters are setup with different types. On each round of the horizontal counter the vertical counter should be increased. On each round of the vertical counter the frame counter should be increased. With this class you could simply use the type:

(FrameCount, VerticalCount, HorizontalCount)

and have countSucc work as described.

Minimal complete definition

Nothing

Methods

countMin :: a Source #

Value counter wraps around to on a countSuccOverflow overflow

default countMin :: Bounded a => a Source #

countMax :: a Source #

Value counter wraps around to on a countPredOverflow overflow

default countMax :: Bounded a => a Source #

countSuccOverflow :: a -> (Bool, a) Source #

Gets the successor of a. If it overflows, the first part of the tuple will be set to True and the second part wraps around to countMin.

default countSuccOverflow :: (Eq a, Enum a, Bounded a) => a -> (Bool, a) Source #

countPredOverflow :: a -> (Bool, a) Source #

Gets the predecessor of a. If it underflows, the first part of the tuple will be set to True and the second part wraps around to countMax.

default countPredOverflow :: (Eq a, Enum a, Bounded a) => a -> (Bool, a) Source #

Instances

Instances details
Counter Bool Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Int Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Int8 Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Int16 Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Int32 Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Int64 Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Word Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Word8 Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Word16 Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Word32 Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Word64 Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter Bit Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter a => Counter (Maybe a) Source #

Nothing is considered the minimum value, while Just countMax is considered the maximum value.

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

Counter a => Counter (Identity a) Source #

Since: 1.8.2

Instance details

Defined in Clash.Class.Counter.Internal

KnownNat n => Counter (BitVector n) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

(1 <= n, KnownNat n) => Counter (Index n) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

KnownNat n => Counter (Unsigned n) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

KnownNat n => Counter (Signed n) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

(Counter a, Counter b) => Counter (Either a b) Source #

Counter instance that flip-flops between Left and Right. Examples:

>>> type T = Either (Index 2) (Unsigned 2)
>>> countSucc @T (Left 0)
Left 1
>>> countSucc @T (Left 1)
Right 0
>>> countSucc @T (Right 0)
Right 1
Instance details

Defined in Clash.Class.Counter.Internal

(Counter a0, Counter a1) => Counter (a0, a1) Source #

Counters on tuples increment from right-to-left. This makes sense from the perspective of LSB/MSB; MSB is on the left-hand-side and LSB is on the right-hand-side in other Clash types.

>>> type T = (Unsigned 2, Index 2, Index 2)
>>> countSucc @T (0, 0, 0)
(0,0,1)
>>> countSucc @T (0, 0, 1)
(0,1,0)
>>> countSucc @T (0, 1, 0)
(0,1,1)
>>> countSucc @T (0, 1, 1)
(1,0,0)

NB: The documentation only shows the instances up to 3-tuples. By default, instances up to and including 12-tuples will exist. If the flag large-tuples is set instances up to the GHC imposed limit will exist. The GHC imposed limit is either 62 or 64 depending on the GHC version.

Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1) Source #

countMax :: (a0, a1) Source #

countSuccOverflow :: (a0, a1) -> (Bool, (a0, a1)) Source #

countPredOverflow :: (a0, a1) -> (Bool, (a0, a1)) Source #

(Counter a0, Counter a1, Counter a2) => Counter (a0, a1, a2) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2) Source #

countMax :: (a0, a1, a2) Source #

countSuccOverflow :: (a0, a1, a2) -> (Bool, (a0, a1, a2)) Source #

countPredOverflow :: (a0, a1, a2) -> (Bool, (a0, a1, a2)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3) => Counter (a0, a1, a2, a3) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3) Source #

countMax :: (a0, a1, a2, a3) Source #

countSuccOverflow :: (a0, a1, a2, a3) -> (Bool, (a0, a1, a2, a3)) Source #

countPredOverflow :: (a0, a1, a2, a3) -> (Bool, (a0, a1, a2, a3)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3, Counter a4) => Counter (a0, a1, a2, a3, a4) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3, a4) Source #

countMax :: (a0, a1, a2, a3, a4) Source #

countSuccOverflow :: (a0, a1, a2, a3, a4) -> (Bool, (a0, a1, a2, a3, a4)) Source #

countPredOverflow :: (a0, a1, a2, a3, a4) -> (Bool, (a0, a1, a2, a3, a4)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3, Counter a4, Counter a5) => Counter (a0, a1, a2, a3, a4, a5) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3, a4, a5) Source #

countMax :: (a0, a1, a2, a3, a4, a5) Source #

countSuccOverflow :: (a0, a1, a2, a3, a4, a5) -> (Bool, (a0, a1, a2, a3, a4, a5)) Source #

countPredOverflow :: (a0, a1, a2, a3, a4, a5) -> (Bool, (a0, a1, a2, a3, a4, a5)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3, Counter a4, Counter a5, Counter a6) => Counter (a0, a1, a2, a3, a4, a5, a6) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3, a4, a5, a6) Source #

countMax :: (a0, a1, a2, a3, a4, a5, a6) Source #

countSuccOverflow :: (a0, a1, a2, a3, a4, a5, a6) -> (Bool, (a0, a1, a2, a3, a4, a5, a6)) Source #

countPredOverflow :: (a0, a1, a2, a3, a4, a5, a6) -> (Bool, (a0, a1, a2, a3, a4, a5, a6)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3, Counter a4, Counter a5, Counter a6, Counter a7) => Counter (a0, a1, a2, a3, a4, a5, a6, a7) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3, a4, a5, a6, a7) Source #

countMax :: (a0, a1, a2, a3, a4, a5, a6, a7) Source #

countSuccOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7)) Source #

countPredOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3, Counter a4, Counter a5, Counter a6, Counter a7, Counter a8) => Counter (a0, a1, a2, a3, a4, a5, a6, a7, a8) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3, a4, a5, a6, a7, a8) Source #

countMax :: (a0, a1, a2, a3, a4, a5, a6, a7, a8) Source #

countSuccOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7, a8) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7, a8)) Source #

countPredOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7, a8) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7, a8)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3, Counter a4, Counter a5, Counter a6, Counter a7, Counter a8, Counter a9) => Counter (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) Source #

countMax :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) Source #

countSuccOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9)) Source #

countPredOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3, Counter a4, Counter a5, Counter a6, Counter a7, Counter a8, Counter a9, Counter a10) => Counter (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10) Source #

countMax :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10) Source #

countSuccOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10)) Source #

countPredOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10)) Source #

(Counter a0, Counter a1, Counter a2, Counter a3, Counter a4, Counter a5, Counter a6, Counter a7, Counter a8, Counter a9, Counter a10, Counter a11) => Counter (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11) Source # 
Instance details

Defined in Clash.Class.Counter.Internal

Methods

countMin :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11) Source #

countMax :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11) Source #

countSuccOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11)) Source #

countPredOverflow :: (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11) -> (Bool, (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11)) Source #

countSucc :: Counter a => a -> a Source #

Successor of a counter.

Examples:

>>> type T = (Unsigned 2, Unsigned 2)
>>> countSucc @T (1, 1)
(1,2)
>>> countSucc @T (1, 2)
(1,3)
>>> countSucc @T (1, 3)
(2,0)
>>> countSucc @T (3, 3)
(0,0)
>>> countSucc @(Index 9, Index 2) (0, 1)
(1,0)
>>> countSucc @(Either (Index 9) (Index 9)) (Left 8)
Right 0

countPred :: Counter a => a -> a Source #

Predecessor of a counter

Examples:

>>> type T = (Unsigned 2, Unsigned 2)
>>> countPred @T (1, 2)
(1,1)
>>> countPred @T (1, 3)
(1,2)
>>> countPred @T (2, 0)
(1,3)
>>> countPred @T (0, 0)
(3,3)
>>> countPred @(Index 9, Index 2) (1, 0)
(0,1)
>>> countPred @(Either (Index 9) (Index 9)) (Right 0)
Left 8