performance - improving speed of Python module import -


the question of how speed importing of python modules has been asked (speeding python "import" loader , python -- speed imports?) without specific examples , has not yielded accepted solutions. therefore take issue again here, time specific example.

i have python script loads 3-d image stack disk, smooths it, , displays movie. call script system command prompt when want view data. i'm ok 700 ms takes smooth data comparable matlab. however, takes additional 650 ms import modules. user's perspective python code runs @ half speed.

this series of modules i'm importing:

import numpy np import matplotlib.pyplot plt import matplotlib.animation animation import scipy.ndimage import scipy.signal import sys import os 

of course, not modules equally slow import. chief culprits are:

matplotlib.pyplot   [300ms] numpy               [110ms] scipy.signal        [200ms] 

i have experimented using from, isn't faster. since matplotlib main culprit , it's got reputation slow screen updates, looked alternatives. 1 pyqtgraph, takes 550 ms import.

i aware of 1 obvious solution, call function interactive python session rather system command prompt. fine it's matlab-like, i'd prefer elegance of having function available system prompt.

i'm new python , i'm not sure how proceed @ point. since i'm new, i'd appreciate links on how implement proposed solutions. ideally, i'm looking simple solution (aren't all!) because code needs portable between multiple mac , linux machines.

you build simple server/client, server running continuously making , updating plot, , client communicating next file process.

i wrote simple server/client example based on basic example socket module docs: http://docs.python.org/2/library/socket.html#example

here server.py:

# expensive imports import numpy np import matplotlib.pyplot plt import matplotlib.animation animation import scipy.ndimage import scipy.signal import sys import os  # echo server program import socket  host = ''                 # symbolic name meaning available interfaces port = 50007              # arbitrary non-privileged port s = socket.socket(socket.af_inet, socket.sock_stream) s.bind((host, port)) s.listen(1) while 1:     conn, addr = s.accept()     print 'connected by', addr     data = conn.recv(1024)     if not data: break     conn.sendall("plotting:" + data)     # update plot     conn.close() 

and client.py:

# echo client program import socket import sys  host = ''    # remote host port = 50007              # same port used server s = socket.socket(socket.af_inet, socket.sock_stream) s.connect((host, port)) s.sendall(sys.argv[1]) data = s.recv(1024) s.close() print 'received', repr(data) 

you run server:

python server.py 

which imports, client sends via socket filename of new file plot:

python client.py mytextfile.txt 

then server updates plot.

on machine running imports take 0.6 seconds, while running client.py 0.03 seconds.


Comments

Popular posts from this blog

c++ - Function signature as a function template parameter -

algorithm - What are some ways to combine a number of (potentially incompatible) sorted sub-sets of a total set into a (partial) ordering of the total set? -

How to call a javascript function after the page loads with a chrome extension? -