Я сталкиваюсь с проблемами на projecteuler.net, чтобы узнать, как программировать в Erlang, и у меня сложнее всего создать генератор простых чисел, который может создавать все простые числа ниже 2 миллионов, меньше минута. Используя последовательный стиль, я уже написал три типа генераторов, в том числе сито Эратосфена, и никто из них не работает достаточно хорошо.Параллельный первичный генератор
Я решил, что параллельное сито будет работать отлично, но я получаю сообщения о плохом образе, и я не уверен, почему. Любые предложения о том, почему у меня есть проблема, или как правильно ее закодировать?
Вот мой код, Закомментированный из секции, где я пытался сделать вещи одновременно:
-module(primeserver). -compile(export_all). start() -> register(primes, spawn(fun() -> loop() end)). is_prime(N) -> rpc({is_prime,N}). rpc(Request) -> primes ! {self(), Request}, receive {primes, Response} -> Response end. loop() -> receive {From, {is_prime, N}} -> if N From ! {primes, false}; N =:= 2 -> From ! {primes, true}; N rem 2 =:= 0 -> From ! {primes, false}; true -> Values = is_not_prime(N), Val = not(lists:member(true, Values)), From ! {primes, Val} end, loop() end. for(N,N,_,F) -> [F(N)]; for(I,N,S,F) when I + S [F(I)|for(I+S, N, S, F)]; for(I,N,S,F) when I + S =:= N -> [F(I)|for(I+S, N, S, F)]; for(I,N,S,F) when I + S > N -> [F(I)]. get_list(I, Limit) -> if I [I*A || A [] end. is_not_prime(N) -> for(3, N, 2, fun(I) -> List = get_list(I,trunc(N/I)), lists:member(N,lists:flatten(List)) end ). %%L = for(1,N, fun() -> spawn(fun(I) -> wait(I,N) end) end), %%SeedList = [A || A %% lists:foreach(fun(X) -> %% Pid ! {in_list, X} %% end, SeedList) %% end, L). %%wait(I,N) -> %% List = [I*A || A lists:member(X,List) %% end.
Как вы подавили неподходящую синтаксическую окраску Markdown? – 2008-09-30 15:58:26