我想模拟消息上的错误(例如:1000010011 => 1010000011)。有没有办法在Python中实现这个?我尝试了以下,它的作品:如何使用高斯分布对列表进行混洗
import random
a = "1011101101"
b = [el for el in a] # b = ['1', '0', '1', '1', '1', '0', '1', '1', '0', '1']
random.shuffle(b)
print b # b = ['0', '1', '1', '1', '0', '1', '1', '1', '1', '0']
random.shuffle(b, random.random)
print b # b = ['1', '1', '0', '1', '1', '0', '1', '0', '1', '1']
我想我的重新排序是正常/高斯分布。 如:
import random
a = "1011101101"
b = [el for el in a] # b = ['1', '0', '1', '1', '1', '0', '1', '1', '0', '1']
random.shuffle(b,random.gauss(0.5,0.1))
print b # b = ['1', '0', '1', '1', '0', '0', '1', '1', '1', '1'] <= assume this is Gaussian distributed...
# OR
c = random.gauss(0.5,0.1)
random.shuffle(b,c)
print b # b = ['0', '0', '1', '1', '1', '0', '1', '1', '1', '1'] <= assume this is also Gaussian distributed...
但是,这并不工作,我得到的消息:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "C:\Python27\lib\random.py", line 287, in shuffle
j = int(random() * (i+1))
TypeError: 'float' object is not callable
任何建议/意见将不胜感激。
感谢
注:我只要求重新排序错误位置(例如:1000010011 => 1010000011)。但是,我还计划在模拟突发错误(例如:1000010011 => 1011111011),单一事件(例如:1000010011 => 1000010011)等
其他相关的问题:Python: binary string error simulation
你可以用一个简单的'b = list(a)'来代替'b'的列表理解。 – Droogans