Comments (5)
Are you using multiprocessing? And what version of Python? We've seen issues where parallel FFTW calculations don't play well with multiple instances invoked in parallel at a higher level. There are also issues in general with multi processing on macOS on python 2.7, but the code should be raising an error if you even try that.
First thing to try is just disabling FFTW in the poppy configuration settings, so you just use the regular python FFT. Let me know if that makes the problem go away, and if so it's diagnostic that it is definitely FFTW.
from poppy.
I am indeed using multiprocessing on Python 2.7.13, on Mac OS X 10.12 Sierra.
from poppy.
Disabling FFTW fixed the halting problem.
from poppy.
See #23 and numpy/numpy#5752
The short version: The way that multiprocessing is implemented in Python 2.7 has fundamental incompatibilities with Apple's Accelerate framework, so if you're using anything compiled against that library you may (will) see random hangs like this. The best solution we found is to move to Python ≥ 3.4, which provides an different method for forking off processes that works reliably.
We've also seen issues with using FFTW inside multiprocessing. I don't know if that's because FFTW is invoking multiprocessing, or if it's somehow just not thread-safe itself. That said, if you're using FFTW, you can just ask FFTW itself to parallelize calculations across all your CPU cores, in which case there is no performance gain from wrapping that in another layer of parallelization.
from poppy.
Ok, that makes sense. I'm ready to consider this ticket resolved.
from poppy.
Related Issues (20)
- need to update minimum version of astropy in setup.py HOT 1
- python3 Integer division in poppy/utils.py HOT 2
- zernike.arbitrary_basis still sometimes clips the edges of apertures HOT 1
- Fresnel propagation detector and setting pixel pitch HOT 1
- poppy travis builds failing silently HOT 1
- OpticalSystem.input_wavefront default sampling should look to OpticalSystem attributes first
- API inconsistency in specifying shifts between FITS and Analytic optics
- test function `test_fresnel_FITS_Optical_element` misses the point
- Bug in QuadraticPhase? HOT 14
- Implement ThermalBloomingWFE HOT 1
- loading FFTW wisdom from disk is unreliable?
- re-importing modules breaks fresnel propagation HOT 3
- Clone / copy repo to https://github.com/spacetelescope/poppy HOT 6
- Adding user-defined Fresnel wavefront error HOT 3
- Remove all Python 2.x items HOT 2
- Phase and ampliude modulation HOT 2
- Missing dependence on pysynphot HOT 2
- Support for intermediate planes? HOT 1
- poppy.display_profiles() Output Plot Inquiry
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from poppy.