Если вы не возражаете, слегка различные значения из-за округления, я могу сжать это действительно хорошо для вас.
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ошибки за это.Это просто потому, что ваши значения округлены до целых чисел;это все места, где вы находитесь на полпути между двумя значениями, поэтому точность уменьшается очень незначительно.