Python can do parallel computing. The following is the relevant introduction:
1. Overview
Parallel Python is a python module that provides a mechanism for parallel execution of python code on SMPs (systems with multiple processors or multi-cores) and clusters (computers connected through a network). It is lightweight, easy to install and integrate with other python software. Parallel Python is an open source and cross-platform module written in pure Python. 2. Features
Execute python code in parallel on SMP and clusters
Easy to understand and implement Job-based parallelization technology (easy to convert serial applications in parallel)
Automatic detection of optimal configuration (number of worker processes is set to the number of effective processors by default)
Dynamic processor allocation (number of worker processes can be changed at runtime)
Low overhead for subsequent jobs with the same functionality (implement transparent caching to reduce overhead)
Dynamic load balancing (jobs are distributed across processors while running)
Fault tolerance (if one of Node failure, tasks are rescheduled on other nodes)
Automatic discovery of computing resources
Dynamic allocation of computing resources (the result of automatic discovery and fault tolerance)
Network connection SHA-based authentication
Cross-platform portability and interoperability (Windows, Linux, Unix, Mac OS X)
Cross-architecture portability and interoperability (x86, x86 -64 etc.)
Open source
Related recommendations: "python video tutorial"
3. Motivation
Nowadays, software written in python is used in many applications, including business logic, data analysis and scientific computing. This, together with the wide availability of SMP computers (multi-processor or multi-core) and clusters (computers connected via a network) on the market, creates a need for parallel execution of python code.
The simplest and most common way to write parallel applications for SMP computers is to use threads. Although, if the application is computationally bound using threads or the threaded python module will not allow running python bytecode in parallel. The reason is that the python interpreter uses the GIL (Global Interpreter Lock) for internal accounting. This lock allows only one python bytecode instruction to be executed at a time, even on SMP machines.
The PP module overcomes this limitation and provides an easy way to write parallel python applications. Internally ppsmp uses processes and IPC (inter-process communication) to organize parallel computations. All details and complexities of the latter are completely taken care of, the application just submits the job and retrieves its results (the simplest way to write parallel applications).
To make things even better, software written in PP works in parallel, even on many computers connected via a local network or the Internet. Cross-platform portability and dynamic load balancing allow PP to efficiently parallelize computing even on heterogeneous and multi-platform clusters.
4. Installation
Any platform: Download the module archive and extract it to a local directory. Run the installation script: python setup.py install
Windows: Download and execute the Windows installer binary.
5. Example
import math, sys, time import pp def isprime(n): """Returns True if n is prime and False otherwise""" if not isinstance(n, int): raise TypeError("argument passed to is_prime is not of 'int' type") if n < 2: return False if n == 2: return True max = int(math.ceil(math.sqrt(n))) i = 2 while i <= max: if n % i == 0: return False i += 1 return True def sum_primes(n): """Calculates sum of all primes below given integer n""" return sum([x for x in xrange(2,n) if isprime(x)]) print """Usage: python sum_primes.py [ncpus] [ncpus] - the number of workers to run in parallel, if omitted it will be set to the number of processors in the system """ # tuple of all parallel python servers to connect with ppservers = () #ppservers = ("10.0.0.1",) if len(sys.argv) > 1: ncpus = int(sys.argv[1]) # Creates jobserver with ncpus workers job_server = pp.Server(ncpus, ppservers=ppservers) else: # Creates jobserver with automatically detected number of workers job_server = pp.Server(ppservers=ppservers) print "Starting pp with", job_server.get_ncpus(), "workers" # Submit a job of calulating sum_primes(100) for execution. # sum_primes - the function # (100,) - tuple with arguments for sum_primes # (isprime,) - tuple with functions on which function sum_primes depends # ("math",) - tuple with module names which must be imported before sum_primes execution # Execution starts as soon as one of the workers will become available job1 = job_server.submit(sum_primes, (100,), (isprime,), ("math",)) # Retrieves the result calculated by job1 # The value of job1() is the same as sum_primes(100) # If the job has not been finished yet, execution will wait here until result is available result = job1() print "Sum of primes below 100 is", result start_time = time.time() # The following submits 8 jobs and then retrieves the results inputs = (100000, 100100, 100200, 100300, 100400, 100500, 100600, 100700) jobs = [(input, job_server.submit(sum_primes,(input,), (isprime,), ("math",))) for input in inputs] for input, job in jobs: print "Sum of primes below", input, "is", job() print "Time elapsed: ", time.time() - start_time, "s" job_server.print_stats()
The above is the detailed content of Can Python do parallel computing?. For more information, please follow other related articles on the PHP Chinese website!

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于Seaborn的相关问题,包括了数据可视化处理的散点图、折线图、条形图等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于进程池与进程锁的相关问题,包括进程池的创建模块,进程池函数等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于简历筛选的相关问题,包括了定义 ReadDoc 类用以读取 word 文件以及定义 search_word 函数用以筛选的相关内容,下面一起来看一下,希望对大家有帮助。

VS Code的确是一款非常热门、有强大用户基础的一款开发工具。本文给大家介绍一下10款高效、好用的插件,能够让原本单薄的VS Code如虎添翼,开发效率顿时提升到一个新的阶段。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于数据类型之字符串、数字的相关问题,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于numpy模块的相关问题,Numpy是Numerical Python extensions的缩写,字面意思是Python数值计算扩展,下面一起来看一下,希望对大家有帮助。

pythn的中文意思是巨蟒、蟒蛇。1989年圣诞节期间,Guido van Rossum在家闲的没事干,为了跟朋友庆祝圣诞节,决定发明一种全新的脚本语言。他很喜欢一个肥皂剧叫Monty Python,所以便把这门语言叫做python。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver CS6
Visual web development tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

Atom editor mac version download
The most popular open source editor

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
