Pattern¶
-
class
decida.Pattern.
Pattern
(**kwargs)¶ Bases:
decida.ItclObjectx.ItclObjectx
synopsis:
Pattern generator.
Pattern generates one of various bit-sequences and outputs the sequence as either a string of 1’s and 0’s, a piece-wise linear set of time, voltage pairs, or a set of time, binary pairs.
The Tckt class uses Pattern to generate piece-wise linear voltage specifications for procedural simulation scripts.
constructor arguments:
**kwargs (dict)
keyword=value specifications: configuration-optionsconfiguration options:
v0 (float, default=0.0)
low value of the signal.v1 (float, default=1.0)
high value of the signal.delay (float, default=0.0)
delay before first bit.edge (float, default=50ps)
rise and fall times in s.period (float, default=1ns)
bit period in s.pre (str, default=””)
specify preamble to bit-pattern (bit-sequence)post (str, default=””)
specify suffix to bit-pattern (bit-sequence)start_at_first_bit (bool, default=False)
Normally a pwl sequence starts at the common-mode. If start_at_first_bit=True, start at first bit value.format (str, default=”pwl”)
Format of return list:
“binary”: return pattern only
“time-binary”: return list of time binary pairs
“pwl”: return piecewise linear waveform
example (from test_Pattern):
from decida.Pattern import Pattern p = Pattern(delay=4e-9, start_at_first_bit=True, edge=0.1e-9) pwl = p.prbs(length=50) print("t v") for t,v in zip(pwl[0::2], pwl[1::2]) : print(t, v)
public methods:
- public methods from ItclObjectx
-
clock
(length, startbit=0, bits_level=1)¶ generate clock pattern (0, 1, 0, 1, 0, ...).
arguments:
length (int)
The number of bits in the sequencestartbit (int, default=0)
The starting bit of the bit sequencebits_level (int, default=1)
Number of bits in each clock level.results:
- The Pattern pattern is set to a clock pattern, with the start bit set to the specified value.
- Returns pattern in format specified by the format configuration option.
-
format
(pattern)¶ format the bit-sequence.
arguments:
pattern (string)
a string of “1“‘s and “0“‘sresults:
Returns Pattern pattern in format specified by the format configuration option.
format is one of:
- “binary”: string sequence of “1“‘s and “0“‘s
- “time-binary”: pairs of time, and integer value 1 or 0.
- “pwl”: pairs of time, value to account for signal edge, period, and voltage low and high values.
-
long_short
(longs, shorts, startbit=0, length=0)¶ - generate a bit pattern with several repeated bits, followed by
- a phase where each bit is inverted.
arguments:
longs (int)
number of bits in the long phase, where each bit is repeated.shorts (int)
number of bits in the short phase, where each bit is inverted.startbit (int, default=0)
The starting bit of the bit sequencelength (int, default=0)
The number of bits in the sequence. If not specified, or less than 1, set to long+shortresults:
- The Pattern pattern is set to the bit pattern.
- Returns pattern in format specified by the format configuration option.
-
pattern
(pattern)¶ specify and generate a bit pattern directly.
arguments:
pattern (str)
a string of “1“‘s and “0“‘sresults:
- The Pattern pattern is set to the bit pattern.
- Returns pattern in format specified by the format configuration option.
-
prbs
(size=7, length=0)¶ generate a pseudo-random bit pattern.
arguments:
size (int, default=7)
The PRBS specification: size=7 generates a pseudo-random bit-sequence of length 2^7-1.length (int, default=0)
The length of the bit-sequence. If length=0, generates a sequence of 2^size - 1.results:
- The Pattern pattern is set to the PRBS bit pattern.
- Returns pattern in format specified by the format configuration option.
-
rand
(length, seed=None)¶ generate a random bit sequence.
arguments:
length (int)
the length of the bit sequence.seed (str, default=None)
random seed to initialize random number generator.results:
- The Pattern pattern is set to a random bit pattern.
- Returns pattern in format specified by the format configuration option.