Rumah > pembangunan bahagian belakang > Tutorial Python > Mengapa Pemprosesan Berbilang Terhenti pada Teras Tunggal Apabila NumPy Diimport?

Mengapa Pemprosesan Berbilang Terhenti pada Teras Tunggal Apabila NumPy Diimport?

Patricia Arquette
Lepaskan: 2024-10-29 18:19:57
asal
274 orang telah melayarinya

Why Does Multiprocessing Stall on a Single Core When NumPy Is Imported?

Mengapa Gerai Berbilang Pemprosesan pada Teras Tunggal Apabila NumPy Diimport

Apabila cuba menyelaraskan gelung intensif CPU menggunakan joblib, anda mungkin menghadapi isu di mana semua proses pekerja diperuntukkan kepada teras yang sama, yang membawa kepada tiada peningkatan prestasi. Ini berlaku disebabkan oleh modul Python tertentu, termasuk NumPy, memanipulasi pertalian teras pada import.

Punca Punca:

Pautan NumPy terhadap perpustakaan OpenBLAS berbilang benang, yang mengganggu pertalian teras tetapan.

Penyelesaian:

Untuk menyelesaikan isu ini, tetapkan semula perkaitan tugas menggunakan arahan berikut:

<code class="python">os.system("taskset -p 0xff %d" % os.getpid())</code>
Salin selepas log masuk

Letakkan baris ini selepas mengimport modul di mana isu itu timbul. Ini memaksa proses berjalan pada semua teras yang tersedia.

Penyelesaian Alternatif:

  • Pembolehubah Persekitaran: Tetapkan OPENBLAS_MAIN_FREE (atau GOTOBLAS_MAIN_ ) pembolehubah persekitaran kepada 1 pada masa jalan untuk melumpuhkan gelagat penetapan semula afiniti CPU OpenBLAS.
  • Pengubahsuaian Masa Binaan: Lumpuhkan tetapan semula pertalian CPU secara kekal dengan mengubah suai Makefile.rule untuk disertakan baris NO_AFFINITY=1 apabila menyusun OpenBLAS daripada sumber.

Atas ialah kandungan terperinci Mengapa Pemprosesan Berbilang Terhenti pada Teras Tunggal Apabila NumPy Diimport?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan