blob: 44f62f0c7a92b95d9da4eac18808cb214919b1dd (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
#!/usr/bin/env python
#
# Copyright 2020 Free Software Foundation, Inc.
#
# This file is part of GNU Radio
#
# SPDX-License-Identifier: GPL-3.0-or-later
#
#
def lfsr_args(seed, *exp):
"""
Produce arguments to create scrambler objects from exponent polynomial expressions.
seed: start-value of register
*exp: exponents of desired polynomial.
Example:
>>> l = digital.lfsr(*lfrs_args(0b11001,7,1,0))
Creates an lfsr object with seed 0b11001, mask 0b1000011, K=6
"""
from functools import reduce
return reduce(int.__xor__, map(lambda x: 2**x, exp)), seed, max(exp) - 1
|