Can generating permutations be done in parallel?
up vote
6
down vote
favorite
I'm trying to figure out if I can speed up the generation of permutations. Specifically I'm using 8 out of [a-z] and I'd like to use 8 out of [a-zA-Z] and 8 out of [a-zA-Z0-9]. Which I know will quickly take a great deal of time and space.
Even just a permutation of length 8 from the lowercase ASCII characters takes a while and generates gigabytes. My problem is that I don't understand the underlying algorithm and so I can't begin to figure out if I can split the problem up into smaller tasks than I can join together later.
A python script I was using to generate a list of permutations:
import string
import itertools
from itertools import permutations
comb = itertools.permutations(string.ascii_lowercase, 8)
f = open('8letters.txt', 'w')
for x in comb:
y = ''.join(x)
f.write(y + 'n')
f.close()
Does anyone know how to partition this up into subtasks and put them together later? Is it possible at all?
I might just try a (possibly) faster way of doing it, but I'm having trouble with C++ and its std::next_permutation(), so I can't verify that it could speed things up even a little just yet.
If I can partition it up into 16 tasks, and run on 16 Xeon CPUs, then join the results, that would be great.
python parallel-processing permutation combinatorics
add a comment |
up vote
6
down vote
favorite
I'm trying to figure out if I can speed up the generation of permutations. Specifically I'm using 8 out of [a-z] and I'd like to use 8 out of [a-zA-Z] and 8 out of [a-zA-Z0-9]. Which I know will quickly take a great deal of time and space.
Even just a permutation of length 8 from the lowercase ASCII characters takes a while and generates gigabytes. My problem is that I don't understand the underlying algorithm and so I can't begin to figure out if I can split the problem up into smaller tasks than I can join together later.
A python script I was using to generate a list of permutations:
import string
import itertools
from itertools import permutations
comb = itertools.permutations(string.ascii_lowercase, 8)
f = open('8letters.txt', 'w')
for x in comb:
y = ''.join(x)
f.write(y + 'n')
f.close()
Does anyone know how to partition this up into subtasks and put them together later? Is it possible at all?
I might just try a (possibly) faster way of doing it, but I'm having trouble with C++ and its std::next_permutation(), so I can't verify that it could speed things up even a little just yet.
If I can partition it up into 16 tasks, and run on 16 Xeon CPUs, then join the results, that would be great.
python parallel-processing permutation combinatorics
add a comment |
up vote
6
down vote
favorite
up vote
6
down vote
favorite
I'm trying to figure out if I can speed up the generation of permutations. Specifically I'm using 8 out of [a-z] and I'd like to use 8 out of [a-zA-Z] and 8 out of [a-zA-Z0-9]. Which I know will quickly take a great deal of time and space.
Even just a permutation of length 8 from the lowercase ASCII characters takes a while and generates gigabytes. My problem is that I don't understand the underlying algorithm and so I can't begin to figure out if I can split the problem up into smaller tasks than I can join together later.
A python script I was using to generate a list of permutations:
import string
import itertools
from itertools import permutations
comb = itertools.permutations(string.ascii_lowercase, 8)
f = open('8letters.txt', 'w')
for x in comb:
y = ''.join(x)
f.write(y + 'n')
f.close()
Does anyone know how to partition this up into subtasks and put them together later? Is it possible at all?
I might just try a (possibly) faster way of doing it, but I'm having trouble with C++ and its std::next_permutation(), so I can't verify that it could speed things up even a little just yet.
If I can partition it up into 16 tasks, and run on 16 Xeon CPUs, then join the results, that would be great.
python parallel-processing permutation combinatorics
I'm trying to figure out if I can speed up the generation of permutations. Specifically I'm using 8 out of [a-z] and I'd like to use 8 out of [a-zA-Z] and 8 out of [a-zA-Z0-9]. Which I know will quickly take a great deal of time and space.
Even just a permutation of length 8 from the lowercase ASCII characters takes a while and generates gigabytes. My problem is that I don't understand the underlying algorithm and so I can't begin to figure out if I can split the problem up into smaller tasks than I can join together later.
A python script I was using to generate a list of permutations:
import string
import itertools
from itertools import permutations
comb = itertools.permutations(string.ascii_lowercase, 8)
f = open('8letters.txt', 'w')
for x in comb:
y = ''.join(x)
f.write(y + 'n')
f.close()
Does anyone know how to partition this up into subtasks and put them together later? Is it possible at all?
I might just try a (possibly) faster way of doing it, but I'm having trouble with C++ and its std::next_permutation(), so I can't verify that it could speed things up even a little just yet.
If I can partition it up into 16 tasks, and run on 16 Xeon CPUs, then join the results, that would be great.
python parallel-processing permutation combinatorics
python parallel-processing permutation combinatorics
asked Nov 11 at 15:03
James Young
333
333
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
up vote
5
down vote
accepted
If it were just permutations with replacement, it would be very easy: Just parallelize on the first letter of the string and then let each thread add the tail of the string. This would give you 26 independent tasks. If that is not enough, you could parallelize on the first two letters.
You want to have a permutation without replacement, so the problem does not trivially factorize. If one only wants to pick 8 letters from a set of 26, 52 and 62, one could do a naive brute thing: Parallelize on the first letter, let the thread just create the tail with replacement and discard the generated strings that contain duplicates. But when you want to pick 25 from 26 letters, this becomes really wasteful.
With that idea in mind, we can do better! We parallelize on the first letter of the string and then generate all permutations with seven elements from the set excluding the letter that we started with. This way we can have 26 tasks (or 52 or 62) and still use the algorithm. This could look like this:
# Use whatever chars you want as the set.
chars = set(string.ascii_lowercase)
# We iterate through all the possible heads. This exact loop will be
# parallelized in the end.
for head in chars:
# Exclude the head from the set.
remaining_chars = chars - set(head)
for tail in itertools.permutations(remaining_chars, 7):
string = head + ''.join(tail)
# Store the string in your list/file.
In order to make use of multiple cores, we use a pool. For this we first need a function to map over. This is just the above a bit refactored:
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 7)]
return strings
Now somewhere else we can create a pool and let it map over heads:
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
The pool only got the needed __enter__
and __exit__
properties with Python 3, so I assume that we use that.
Once that is finished the flatten the list of lists into a plain list of strings:
strings = [
string
for sub_list in all_strings
for string in sub_list]
Since 26 is an odd number for 16 cores, we could think about creating the heads with itertools.permutation(remaining_chars, 2)
and then using the set subtraction to generate the last 6 digits.
This is a complete working script for Python 3 that summarizes everything:
import itertools
import multiprocessing
import string
chars = set(string.ascii_lowercase)
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 3)]
return strings
def main():
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
strings = [
string
for sub_list in all_strings
for string in sub_list]
print(strings[:100])
if __name__ == '__main__':
main()
Thank you! So I can use the first part of the code, replace for head in chars: ... with the make_strings function, then add with multiprocessing.ProcessPool ... letit finish then print out the strings in [ string for sub_list in all_strings for string in sub_list ] ? Why is 26 an odd number for 16 cores? I just plucked that number out; I have 24 cores and I can adjust that for the task :) Thank you!!!
– James Young
Nov 11 at 15:41
I have added a complete program at the end such that you do not have to assemble the bits and pieces. This will only print out the first 100 elements, and I have tested it with a length of 4 strings. — Depending on what you do, it might not be the best idea to store them all in a file but rather do what you need to do with each string and not store them at all.
– Martin Ueding
Nov 11 at 15:45
Thank you Martin again. Fantastic. I have been looking up an error though: File "permutations8.py", line 21, in main with multiprocessing.Pool() as pool: AttributeError: exit Apparently it means multiprocessing.Pool() has no enter and exit methods: stackoverflow.com/questions/7447284/…
– James Young
Nov 11 at 16:11
Oh. Just switched to Python 3 and it worked. Thanks again Martin, absolutely fantastic.
– James Young
Nov 11 at 16:43
@JamesYoung: I have now explicitly stated that it is Python 3. I had assumed that everything newly developed these days uses Python 3.
– Martin Ueding
Nov 12 at 12:21
|
show 5 more comments
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
5
down vote
accepted
If it were just permutations with replacement, it would be very easy: Just parallelize on the first letter of the string and then let each thread add the tail of the string. This would give you 26 independent tasks. If that is not enough, you could parallelize on the first two letters.
You want to have a permutation without replacement, so the problem does not trivially factorize. If one only wants to pick 8 letters from a set of 26, 52 and 62, one could do a naive brute thing: Parallelize on the first letter, let the thread just create the tail with replacement and discard the generated strings that contain duplicates. But when you want to pick 25 from 26 letters, this becomes really wasteful.
With that idea in mind, we can do better! We parallelize on the first letter of the string and then generate all permutations with seven elements from the set excluding the letter that we started with. This way we can have 26 tasks (or 52 or 62) and still use the algorithm. This could look like this:
# Use whatever chars you want as the set.
chars = set(string.ascii_lowercase)
# We iterate through all the possible heads. This exact loop will be
# parallelized in the end.
for head in chars:
# Exclude the head from the set.
remaining_chars = chars - set(head)
for tail in itertools.permutations(remaining_chars, 7):
string = head + ''.join(tail)
# Store the string in your list/file.
In order to make use of multiple cores, we use a pool. For this we first need a function to map over. This is just the above a bit refactored:
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 7)]
return strings
Now somewhere else we can create a pool and let it map over heads:
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
The pool only got the needed __enter__
and __exit__
properties with Python 3, so I assume that we use that.
Once that is finished the flatten the list of lists into a plain list of strings:
strings = [
string
for sub_list in all_strings
for string in sub_list]
Since 26 is an odd number for 16 cores, we could think about creating the heads with itertools.permutation(remaining_chars, 2)
and then using the set subtraction to generate the last 6 digits.
This is a complete working script for Python 3 that summarizes everything:
import itertools
import multiprocessing
import string
chars = set(string.ascii_lowercase)
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 3)]
return strings
def main():
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
strings = [
string
for sub_list in all_strings
for string in sub_list]
print(strings[:100])
if __name__ == '__main__':
main()
Thank you! So I can use the first part of the code, replace for head in chars: ... with the make_strings function, then add with multiprocessing.ProcessPool ... letit finish then print out the strings in [ string for sub_list in all_strings for string in sub_list ] ? Why is 26 an odd number for 16 cores? I just plucked that number out; I have 24 cores and I can adjust that for the task :) Thank you!!!
– James Young
Nov 11 at 15:41
I have added a complete program at the end such that you do not have to assemble the bits and pieces. This will only print out the first 100 elements, and I have tested it with a length of 4 strings. — Depending on what you do, it might not be the best idea to store them all in a file but rather do what you need to do with each string and not store them at all.
– Martin Ueding
Nov 11 at 15:45
Thank you Martin again. Fantastic. I have been looking up an error though: File "permutations8.py", line 21, in main with multiprocessing.Pool() as pool: AttributeError: exit Apparently it means multiprocessing.Pool() has no enter and exit methods: stackoverflow.com/questions/7447284/…
– James Young
Nov 11 at 16:11
Oh. Just switched to Python 3 and it worked. Thanks again Martin, absolutely fantastic.
– James Young
Nov 11 at 16:43
@JamesYoung: I have now explicitly stated that it is Python 3. I had assumed that everything newly developed these days uses Python 3.
– Martin Ueding
Nov 12 at 12:21
|
show 5 more comments
up vote
5
down vote
accepted
If it were just permutations with replacement, it would be very easy: Just parallelize on the first letter of the string and then let each thread add the tail of the string. This would give you 26 independent tasks. If that is not enough, you could parallelize on the first two letters.
You want to have a permutation without replacement, so the problem does not trivially factorize. If one only wants to pick 8 letters from a set of 26, 52 and 62, one could do a naive brute thing: Parallelize on the first letter, let the thread just create the tail with replacement and discard the generated strings that contain duplicates. But when you want to pick 25 from 26 letters, this becomes really wasteful.
With that idea in mind, we can do better! We parallelize on the first letter of the string and then generate all permutations with seven elements from the set excluding the letter that we started with. This way we can have 26 tasks (or 52 or 62) and still use the algorithm. This could look like this:
# Use whatever chars you want as the set.
chars = set(string.ascii_lowercase)
# We iterate through all the possible heads. This exact loop will be
# parallelized in the end.
for head in chars:
# Exclude the head from the set.
remaining_chars = chars - set(head)
for tail in itertools.permutations(remaining_chars, 7):
string = head + ''.join(tail)
# Store the string in your list/file.
In order to make use of multiple cores, we use a pool. For this we first need a function to map over. This is just the above a bit refactored:
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 7)]
return strings
Now somewhere else we can create a pool and let it map over heads:
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
The pool only got the needed __enter__
and __exit__
properties with Python 3, so I assume that we use that.
Once that is finished the flatten the list of lists into a plain list of strings:
strings = [
string
for sub_list in all_strings
for string in sub_list]
Since 26 is an odd number for 16 cores, we could think about creating the heads with itertools.permutation(remaining_chars, 2)
and then using the set subtraction to generate the last 6 digits.
This is a complete working script for Python 3 that summarizes everything:
import itertools
import multiprocessing
import string
chars = set(string.ascii_lowercase)
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 3)]
return strings
def main():
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
strings = [
string
for sub_list in all_strings
for string in sub_list]
print(strings[:100])
if __name__ == '__main__':
main()
Thank you! So I can use the first part of the code, replace for head in chars: ... with the make_strings function, then add with multiprocessing.ProcessPool ... letit finish then print out the strings in [ string for sub_list in all_strings for string in sub_list ] ? Why is 26 an odd number for 16 cores? I just plucked that number out; I have 24 cores and I can adjust that for the task :) Thank you!!!
– James Young
Nov 11 at 15:41
I have added a complete program at the end such that you do not have to assemble the bits and pieces. This will only print out the first 100 elements, and I have tested it with a length of 4 strings. — Depending on what you do, it might not be the best idea to store them all in a file but rather do what you need to do with each string and not store them at all.
– Martin Ueding
Nov 11 at 15:45
Thank you Martin again. Fantastic. I have been looking up an error though: File "permutations8.py", line 21, in main with multiprocessing.Pool() as pool: AttributeError: exit Apparently it means multiprocessing.Pool() has no enter and exit methods: stackoverflow.com/questions/7447284/…
– James Young
Nov 11 at 16:11
Oh. Just switched to Python 3 and it worked. Thanks again Martin, absolutely fantastic.
– James Young
Nov 11 at 16:43
@JamesYoung: I have now explicitly stated that it is Python 3. I had assumed that everything newly developed these days uses Python 3.
– Martin Ueding
Nov 12 at 12:21
|
show 5 more comments
up vote
5
down vote
accepted
up vote
5
down vote
accepted
If it were just permutations with replacement, it would be very easy: Just parallelize on the first letter of the string and then let each thread add the tail of the string. This would give you 26 independent tasks. If that is not enough, you could parallelize on the first two letters.
You want to have a permutation without replacement, so the problem does not trivially factorize. If one only wants to pick 8 letters from a set of 26, 52 and 62, one could do a naive brute thing: Parallelize on the first letter, let the thread just create the tail with replacement and discard the generated strings that contain duplicates. But when you want to pick 25 from 26 letters, this becomes really wasteful.
With that idea in mind, we can do better! We parallelize on the first letter of the string and then generate all permutations with seven elements from the set excluding the letter that we started with. This way we can have 26 tasks (or 52 or 62) and still use the algorithm. This could look like this:
# Use whatever chars you want as the set.
chars = set(string.ascii_lowercase)
# We iterate through all the possible heads. This exact loop will be
# parallelized in the end.
for head in chars:
# Exclude the head from the set.
remaining_chars = chars - set(head)
for tail in itertools.permutations(remaining_chars, 7):
string = head + ''.join(tail)
# Store the string in your list/file.
In order to make use of multiple cores, we use a pool. For this we first need a function to map over. This is just the above a bit refactored:
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 7)]
return strings
Now somewhere else we can create a pool and let it map over heads:
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
The pool only got the needed __enter__
and __exit__
properties with Python 3, so I assume that we use that.
Once that is finished the flatten the list of lists into a plain list of strings:
strings = [
string
for sub_list in all_strings
for string in sub_list]
Since 26 is an odd number for 16 cores, we could think about creating the heads with itertools.permutation(remaining_chars, 2)
and then using the set subtraction to generate the last 6 digits.
This is a complete working script for Python 3 that summarizes everything:
import itertools
import multiprocessing
import string
chars = set(string.ascii_lowercase)
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 3)]
return strings
def main():
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
strings = [
string
for sub_list in all_strings
for string in sub_list]
print(strings[:100])
if __name__ == '__main__':
main()
If it were just permutations with replacement, it would be very easy: Just parallelize on the first letter of the string and then let each thread add the tail of the string. This would give you 26 independent tasks. If that is not enough, you could parallelize on the first two letters.
You want to have a permutation without replacement, so the problem does not trivially factorize. If one only wants to pick 8 letters from a set of 26, 52 and 62, one could do a naive brute thing: Parallelize on the first letter, let the thread just create the tail with replacement and discard the generated strings that contain duplicates. But when you want to pick 25 from 26 letters, this becomes really wasteful.
With that idea in mind, we can do better! We parallelize on the first letter of the string and then generate all permutations with seven elements from the set excluding the letter that we started with. This way we can have 26 tasks (or 52 or 62) and still use the algorithm. This could look like this:
# Use whatever chars you want as the set.
chars = set(string.ascii_lowercase)
# We iterate through all the possible heads. This exact loop will be
# parallelized in the end.
for head in chars:
# Exclude the head from the set.
remaining_chars = chars - set(head)
for tail in itertools.permutations(remaining_chars, 7):
string = head + ''.join(tail)
# Store the string in your list/file.
In order to make use of multiple cores, we use a pool. For this we first need a function to map over. This is just the above a bit refactored:
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 7)]
return strings
Now somewhere else we can create a pool and let it map over heads:
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
The pool only got the needed __enter__
and __exit__
properties with Python 3, so I assume that we use that.
Once that is finished the flatten the list of lists into a plain list of strings:
strings = [
string
for sub_list in all_strings
for string in sub_list]
Since 26 is an odd number for 16 cores, we could think about creating the heads with itertools.permutation(remaining_chars, 2)
and then using the set subtraction to generate the last 6 digits.
This is a complete working script for Python 3 that summarizes everything:
import itertools
import multiprocessing
import string
chars = set(string.ascii_lowercase)
def make_strings(head):
remaining_chars = chars - set(head)
strings = [
head + ''.join(tail)
for tail in itertools.permutations(remaining_chars, 3)]
return strings
def main():
with multiprocessing.Pool() as pool:
all_strings = pool.map(make_strings, chars)
strings = [
string
for sub_list in all_strings
for string in sub_list]
print(strings[:100])
if __name__ == '__main__':
main()
edited Nov 12 at 12:20
answered Nov 11 at 15:24
Martin Ueding
3,47032952
3,47032952
Thank you! So I can use the first part of the code, replace for head in chars: ... with the make_strings function, then add with multiprocessing.ProcessPool ... letit finish then print out the strings in [ string for sub_list in all_strings for string in sub_list ] ? Why is 26 an odd number for 16 cores? I just plucked that number out; I have 24 cores and I can adjust that for the task :) Thank you!!!
– James Young
Nov 11 at 15:41
I have added a complete program at the end such that you do not have to assemble the bits and pieces. This will only print out the first 100 elements, and I have tested it with a length of 4 strings. — Depending on what you do, it might not be the best idea to store them all in a file but rather do what you need to do with each string and not store them at all.
– Martin Ueding
Nov 11 at 15:45
Thank you Martin again. Fantastic. I have been looking up an error though: File "permutations8.py", line 21, in main with multiprocessing.Pool() as pool: AttributeError: exit Apparently it means multiprocessing.Pool() has no enter and exit methods: stackoverflow.com/questions/7447284/…
– James Young
Nov 11 at 16:11
Oh. Just switched to Python 3 and it worked. Thanks again Martin, absolutely fantastic.
– James Young
Nov 11 at 16:43
@JamesYoung: I have now explicitly stated that it is Python 3. I had assumed that everything newly developed these days uses Python 3.
– Martin Ueding
Nov 12 at 12:21
|
show 5 more comments
Thank you! So I can use the first part of the code, replace for head in chars: ... with the make_strings function, then add with multiprocessing.ProcessPool ... letit finish then print out the strings in [ string for sub_list in all_strings for string in sub_list ] ? Why is 26 an odd number for 16 cores? I just plucked that number out; I have 24 cores and I can adjust that for the task :) Thank you!!!
– James Young
Nov 11 at 15:41
I have added a complete program at the end such that you do not have to assemble the bits and pieces. This will only print out the first 100 elements, and I have tested it with a length of 4 strings. — Depending on what you do, it might not be the best idea to store them all in a file but rather do what you need to do with each string and not store them at all.
– Martin Ueding
Nov 11 at 15:45
Thank you Martin again. Fantastic. I have been looking up an error though: File "permutations8.py", line 21, in main with multiprocessing.Pool() as pool: AttributeError: exit Apparently it means multiprocessing.Pool() has no enter and exit methods: stackoverflow.com/questions/7447284/…
– James Young
Nov 11 at 16:11
Oh. Just switched to Python 3 and it worked. Thanks again Martin, absolutely fantastic.
– James Young
Nov 11 at 16:43
@JamesYoung: I have now explicitly stated that it is Python 3. I had assumed that everything newly developed these days uses Python 3.
– Martin Ueding
Nov 12 at 12:21
Thank you! So I can use the first part of the code, replace for head in chars: ... with the make_strings function, then add with multiprocessing.ProcessPool ... letit finish then print out the strings in [ string for sub_list in all_strings for string in sub_list ] ? Why is 26 an odd number for 16 cores? I just plucked that number out; I have 24 cores and I can adjust that for the task :) Thank you!!!
– James Young
Nov 11 at 15:41
Thank you! So I can use the first part of the code, replace for head in chars: ... with the make_strings function, then add with multiprocessing.ProcessPool ... letit finish then print out the strings in [ string for sub_list in all_strings for string in sub_list ] ? Why is 26 an odd number for 16 cores? I just plucked that number out; I have 24 cores and I can adjust that for the task :) Thank you!!!
– James Young
Nov 11 at 15:41
I have added a complete program at the end such that you do not have to assemble the bits and pieces. This will only print out the first 100 elements, and I have tested it with a length of 4 strings. — Depending on what you do, it might not be the best idea to store them all in a file but rather do what you need to do with each string and not store them at all.
– Martin Ueding
Nov 11 at 15:45
I have added a complete program at the end such that you do not have to assemble the bits and pieces. This will only print out the first 100 elements, and I have tested it with a length of 4 strings. — Depending on what you do, it might not be the best idea to store them all in a file but rather do what you need to do with each string and not store them at all.
– Martin Ueding
Nov 11 at 15:45
Thank you Martin again. Fantastic. I have been looking up an error though: File "permutations8.py", line 21, in main with multiprocessing.Pool() as pool: AttributeError: exit Apparently it means multiprocessing.Pool() has no enter and exit methods: stackoverflow.com/questions/7447284/…
– James Young
Nov 11 at 16:11
Thank you Martin again. Fantastic. I have been looking up an error though: File "permutations8.py", line 21, in main with multiprocessing.Pool() as pool: AttributeError: exit Apparently it means multiprocessing.Pool() has no enter and exit methods: stackoverflow.com/questions/7447284/…
– James Young
Nov 11 at 16:11
Oh. Just switched to Python 3 and it worked. Thanks again Martin, absolutely fantastic.
– James Young
Nov 11 at 16:43
Oh. Just switched to Python 3 and it worked. Thanks again Martin, absolutely fantastic.
– James Young
Nov 11 at 16:43
@JamesYoung: I have now explicitly stated that it is Python 3. I had assumed that everything newly developed these days uses Python 3.
– Martin Ueding
Nov 12 at 12:21
@JamesYoung: I have now explicitly stated that it is Python 3. I had assumed that everything newly developed these days uses Python 3.
– Martin Ueding
Nov 12 at 12:21
|
show 5 more comments
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53250001%2fcan-generating-permutations-be-done-in-parallel%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown