如果您不介意由于四舍五入而略有不同的值,我可以为您很好地压缩它。
from math import pi, sin
interval=2*pi/1024
sinval=lambda i:int(round(sin(i*interval)*36))+50
这是实际执行您想要的操作的代码;它适用于
vals = sorted((sinval(i), i) for i in range(1024))
作为测试数据。如果您在第一列中有索引,则需要在此处切换循环val
的index
顺序。for
ranges, oldval, oldidx = [[0, 0]], 0, 0
for val, index in vals:
if not (val == oldval and index == oldidx + 1):
ranges[-1].append(oldidx)
ranges.append([val, index])
oldval, oldidx = val, index
ranges[-1].append(oldidx)
ranges.pop(0)
ifs = ('if((index >= {1}) and (index <= {2})) return {0};\n'.format(val, start, end)
for val, start, end in ranges)
print ''.join(ifs)
编辑:哎呀,我错过了一条线。固定的。另外,您的乘数实际上是 36 而不是 35,我必须在我的脑海中将 (14, 86) 舍入到 (15, 85)。
编辑2:向您展示如何仅存储表格的四分之一。
from math import pi, sin
full = 1024
half = 512
quarter = 256
mag = 72
offset = 50
interval = 2 * pi / full
def sinval(i):
return int(round(sin(i * interval) * (mag // 2))) + offset
vals = [sinval(i) for i in range(quarter)]
def sintable(i):
if i >= half + quarter:
return 2 * offset - vals[full - i - 1]
elif i >= half:
return 2 * offset - vals[i - half]
elif i >= quarter:
return vals[half - i - 1]
else:
return vals[i]
for i in range(full):
assert -1 <= sinval(i) - sintable(i) <= 1
如果您从表中减去偏移量,只需制作前两个即可-vals[...]
。
此外,底部的比较是模糊的,因为我得到了 72 个错误。这仅仅是因为您的值被四舍五入为整数;它们都是您介于两个值之间的地方,因此准确性几乎没有下降。