##// END OF EJS Templates
Fixing minor bugs in IPython.kernel....
Fixing minor bugs in IPython.kernel. * Regular expressions now using raw strings in launcher.py * Directory permissions on cluster directory handled properly. * A raw ipcluster start will now create cluster default and add the default config files. * Config files updated to use raw strings where appropriate.

File last commit:

r1338:72652d65
r2342:9e3db2d3
Show More
pwordfreq_skel.py
35 lines | 982 B | text/x-python | PythonLexer
#!/usr/bin/env python
"""Parallel word frequency counter."""
from itertools import repeat
from wordfreq import print_wordfreq, wordfreq
def pwordfreq(rc, text):
"""Parallel word frequency counter.
rc - An IPython RemoteController
text - The name of a string on the engines to do the freq count on.
"""
if __name__ == '__main__':
# Create a MultiEngineClient
from IPython.kernel import client
ipc = client.MultiEngineClient()
# Run the wordfreq script on the engines.
ipc.run('wordfreq.py')
# Run the serial version
print "Serial word frequency count:"
text = open('davinci.txt').read()
freqs = wordfreq(text)
print_wordfreq(freqs, 10)
# The parallel version
print "\nParallel word frequency count:"
files = ['davinci%i.txt' % i for i in range(4)]
ipc.scatter('textfile', files)
ipc.execute('text = open(textfile[0]).read()')
pfreqs = pwordfreq(ipc,'text')
print_wordfreq(freqs)