私は、エラトステネスのふるいを使用してPythonで素数生成を行っています。そして、人々が比較的高速なオプションとして指摘する解決策は、the answers to a question on optimising prime number generation in pythonのいくつかのもののように簡単で単純ではありませんここで私が実装している実装は効率的にそれらに匹敵します。私の実装は、実行タイミングPythonの高速素数篩
def sieve_for_primes_to(n):
size = n//2
sieve = [1]*size
limit = int(n**0.5)
for i in range(1,limit):
if sieve[i]:
val = 2*i+1
tmp = ((size-1) - i)//val
sieve[i+val::val] = [0]*tmp
return sieve
print [2] + [i*2+1 for i, v in enumerate(sieve_for_primes_to(10000000)) if v and i>0]
の下に与えられているのpython料理から最速のものとして上記のリンクの質問への答えに記載された方法が
import itertools
def erat2():
D = { }
yield 2
for q in itertools.islice(itertools.count(3), 0, None, 2):
p = D.pop(q, None)
if p is None:
D[q*q] = q
yield q
else:
x = p + q
while x in D or not (x&1):
x += p
D[x] = p
def get_primes_erat(n):
return list(itertools.takewhile(lambda p: p<n, erat2()))
の下に与えられている間に
python -m timeit -n10 -s "import euler" "euler.sieve_for_primes_to(1000000)"
10 loops, best of 3: 19.5 msec per loop
を返します。
実行時
python -m timeit -n10 -s "import euler" "euler.get_primes_erat(1000000)"
10 loops, best of 3: 697 msec per loop
私の質問は、なぜ理想的なプライムジェネレータとして比較的複雑な調理本から上記を説いているのですか?
「erat2」を理想的なプライムジェネレータとして宣伝するのは誰とどこですか?あなたの質問を引き起こした文脈をよりよく理解できるように、参考文献を提供してください。 – NPE
あなたは['rwh_primes2'](http://stackoverflow.com/a/3035188)アルゴリズムと比較しましたか? –
'erat2'はそのページのOPのコードとしか比較されておらず、Alex Martelliは* CookbookのソリューションはOPのソリューション*に比べて2倍以上速いと述べています。 あなたのソリューションは 'rwh_primes2'に比べて2倍遅いです。 –