質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

1771閲覧

Pythonで複数の関数を『同時に』実行させたい

insecticide

総合スコア315

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

1クリップ

投稿2022/05/17 04:54

Pythonで複数の関数を物理的に(本当に)『同時に』実行させたいですけれども、
可能であれば、もっとも一般的なやり方を教えてください。

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Logarithm

2022/05/17 05:10

完全な同時は無理だと思います。どうしてもやるなら並列処理で調べればいいと思います。 処理時間を測定したいだけならdatetimeをそれぞれの関数の間に挟んであげればいいだけです。
y_waiwai

2022/05/17 05:21

どういうことがしたくてその質問をしたのか、ってのを説明しよう。 同時に、というのがどういう解釈かによって答えは変わろうかとおもいます
insecticide

2022/05/17 13:41 編集

> どういうことがしたくてその質問をしたのか 一つの部品の上に同じパーツが幾つかあります。 各パーツの検査時間が同じなので、これらのパーツ検査は厳密に同時に行われれば、検査時間が短縮でき、検査ラインの稼働能率が数倍アップできますね。 『CPUタイムシェアリング』的な『同時』であれば、検査全体時間が短縮できないので意味がありません。
Zuishin

2022/05/17 13:43

関数が仮に同時に動いてもハードやドライバの制限があるでしょう。
insecticide

2022/05/17 14:02 編集

場合によっても問題になりますね。 純粋な計算ソフトなので、ハードディスクアクセスの衝突以外考えなくても大丈夫です。 《もっとも一般的なやり方》ありがとうございます。
Zuishin

2022/05/17 14:00

Python にスレッド以上のリアルタイム性を求めるのは無理があります。複数の CPU や GPU を同時に動かせるよう、アセンブラを使ってください。全部アセンブラで書かなくても、クリティカルな部分だけ書いて Python から呼び出せばいいでしょう。 自分で作るのが難しければ、プロに有料で頼むのが良いと思います。
jbpb0

2022/05/18 04:23

python側でどんなにガンバって並列化しても、どのCPUコアにどのスレッドをいつ割り当てるのかはOS次第なので、 > 物理的に(本当に)『同時に』実行 を「確実に」行うのは、Windowsとかの汎用OSでは無理だと思います https://monoist.itmedia.co.jp/mn/spv/1105/23/news003.html とかで解説されてるマルチコア対応リアルタイムOSを使って、  コア数≧タスク数 の場合に各コアに一つずつタスクを割り当てたら、「本当に同時に実行」が「確実に」できるかもしれませんが、そういう開発をやった経験が無いので、タスク起動のタイミングのバラツキが無視できるくらい小さいのか、とかよく分かりません
guest

回答2

0

ベストアンサー

複数プロセスや複数スレッドで実行すれば実現可能です。

ただし、厳密に「同時」とするのは難しいですけどね。

マルチスレッド
マルチプロセス
joblibは両方サポート

投稿2022/05/17 05:52

TakaiY

総合スコア12763

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

insecticide

2022/05/18 05:36

貴重な情報ありがとうございます。 マルチプロセスに馴染みが薄いで、もしかして マルチプロセスのほうは各プロセスが独立していて、CPUタイムシェアリングという事はしないでしょうか。或いはできるだけ物理的なマルチコアに均等にタスクを分配してくれるのでしょうか。
TakaiY

2022/05/18 13:53 編集

コアに実際のプロセスを割り当てるのはOSの仕事です。 特にWindowsやLinuxのような汎用のOSでは、そのプロセスがどのように コアに割り当てられて実行されるのかをこちらから指定することはできません。2つのプロセスを生成しても、それらが1うのCPUで交互に実行されてしまうかもしれません。 って、読んでみると、他の方も同じことを書いてますね。
TakaiY

2022/05/18 13:59

> 各パーツの検査時間が同じなので、これらのパーツ検査は厳密に同時に行われれば、検査時間が短縮でき、検査ラインの稼働能率が数倍アップできますね。 『CPUタイムシェアリング』的な『同時』であれば、検査全体時間が短縮できないので意味がありません。 この程度の話であれば、マルチスレッド/マルチプロセスで充分に速度の向上が望めると思います。 どれくらい向上させられるかについては、プロセス(コア)数よりも、それ以外の要因の方が問題になるだろおうと思います。たとえば、PCと検査をするパーツの間の通信とか。
insecticide

2022/05/18 21:04 編集

ごめんなさい! やはり私の説明が下手だったんで、改めて具体的な実例で説明したいと思います。 工業オンライン部品検査画像(中に異なるパーツの画像がある)をパソコンのメモリに既に取り込んだ前提で、 その画像を異なるパーツの画像別に分割して、それぞれ独立に画像検査(= 画像認識+画像処理)を行いたいのです。 【画像検査の間、共通なアクセス対象となるパソコンメモリのほか、リソースの衝突がないと考えられます。】 Q1:  その『独立な画像検査』処理を最大限に『厳密に』同時に実行したい場合、マルチスレッドよりマルチプロセスのほうは有利でしょうか。(あくまでも可能な限りの話) Q2: それに、CPUコアを指定してマルチスレッドやマルチプロセスを実行できるのでしょうか。
guest

0

『CPUタイムシェアリング』的な『同時』であれば、検査全体時間が短縮できないので意味がありません。

という用途であるなら、pythonを使うって段階で不可能です。
というより、WindowsやらLinuxやらのOS上でどーこーしようとしてるのが間違いですね。
いかにスレッドで分けようとマルチタスクにしようと、個々の処理の実行時間を厳密に規定するのは不可能です

これをするなら、多数のMCUを並列に動かせて、タイムベース信号で同期的に実行させるってテぐらいしかなかろうかと。

投稿2022/05/17 22:40

y_waiwai

総合スコア87774

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

insecticide

2022/05/18 05:27

お返答ありがとうございます。 >個々の処理の実行時間を厳密に規定する というニーズではなく、本質的に幾つかの関数(処理)を別別のCPUコアに実行させたいのです。 マルチスレッドかマルチプロセスでこのような事を実現する方法を教えていただけませんか。
y_waiwai

2022/05/18 08:10

なんか言ってることが変わってきてますが、たとえなんとかして別のコアで同時に実行させたところで、各パーツの検査のアクション(パラレルIO?シリアル通信?)のリソースは一つしか無いので、そこで必ず操作時間はずれます。 はやいはなし、不可能だ、ということになろうかと思います
insecticide

2022/05/18 21:04 編集

ごめんなさい! やはり私の説明が下手だったんで、改めて具体的な実例で説明したいと思います。 工業オンライン部品検査画像(中に異なるパーツの画像がある)をパソコンのメモリに既に取り込んだ前提で、 その画像を異なるパーツの画像別に分割して、それぞれ独立に画像検査(= 画像認識+画像処理)を行いたいのです。 【画像検査の間、共通なアクセス対象となるパソコンメモリのほか、リソースの衝突がないと考えられます。】 Q1:  その『独立な画像検査』処理を最大限に『厳密に』同時に実行したい場合、マルチスレッドよりマルチプロセスのほうは有利でしょうか。(あくまでも可能な限りの話) Q2: それに、CPUコアを指定してマルチスレッドやマルチプロセスを実行できるのでしょうか。
TakaiY

2022/05/19 02:36

Q1: 処理内容からすると、入出力を伴わないCPU boundな処理になるので、マルチスレッドでなくマルチプロセスでないこ効果が出にくいでしょう。(これについてはGlobal Interpreter Lock(GIL)を確認してみてください。) Q2: pythonに限らず、WindowsやLinux・MacでCPUコアを指定してプロセスを動作させることはできませんし、 とあるタスクがあるコア上のプロセスとして開始したとしても、そのプロセスがそのコア上で動き続ける保証もありません。(たぶん中断されて他に移されます。) 全体の構成がどうなっているかにもよりますけど、2並列にすると処理時間は半分近くになって、10並列だと10分の1にはほど遠いって感じですかね。(感じかたはそれぞれでしょうけど) 事前にはっきりした効果がわからないと動きにくいのかもしれませsが、まずはやってみるのがいいのではないかと思います。 僕はいつもそんな感じですね。
y_waiwai

2022/05/19 02:56

そういう質問の前提条件は質問文を編集してそっちの方に書こう 元質問とあまりに話が変わりすぎてます 他の方が回答されてますが、全くその通りで、本気でそういうことをしたいなら、WindowsとかLinuxを使わずに、ベアメタルでやらんとどーしよーもないんじゃないかとも思えます #そもそも別のコアで同時に実行できている、という検証をすることはできるんだろうか。。
TakaiY

2022/05/20 04:51

自分の回答の質問欄に書いたつもりでした。 よごしちゃってすみません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問