あなたが「バッチ」コマンドを(私はあなたが並列コンピューティングツールボックスを持っている必要があります考えて)使用する必要がありますMathWorks社のMATLABでのマルチスレッド化を行うには、ここに
は一例です:
私はMathWorks社のMATLABでスクリプトを実行したいです長い時間
スクリプトの例を取る:
for i=1:1e8
A(i)=sin(i*2*pi/1e8);
end
iが "ダ" として、このスクリプトを保存!その後、バッチモードでそれを実行するための
私はMathWorks社のMATLABでこのコードを書いた:
job=batch("da")
をジョブはバッチモードで実行し、tはあなたができた仕事を終えた後、結果を取得すると同時に をあなたのMATLABを使用することができます単に書く:
load(job,'A')
をし、その結果、配列Aは、ワークスペースになります
あなたが開くから「ジョブGUIを監視する」ことができホーム>環境>パラレル>モニターの仕事 、最終的には、単純なコードの下でジョブを削除できます。
delete(job)
をバッチ処理のための機能をロードするためには、単にこのステートメントを使用することができます
j=batch(fcn, N, {x1,x2,...,xn})
場所fcnは関数名、Nは出力配列の数、x1、... xnは関数入力配列です。
いいえ、AFAIK Parallel Processing Toolboxをお持ちで、parfeval関数を使用している場合を除き、AFAIKはありません。あなたがParallel Processing Toolboxを手に入れておらず、非同期の処理をしたい場合は、間違った言語を使用しています。あなたの唯一の希望は、 'foo()'がJavaをいくつか呼び出し、いくつかのスレッドや他のコードからJaveコードを生成させることです。あるいは、Python(numpyとscipyは非常にMatLab-esqueに見えるようになります)を考えてから、適切な(!)プログラミング言語機能にアクセスできます。 – bazza
@bazza私はそれが確かに答えだと信じています。そのように投稿することを検討してください。 –
Parallel Computing Toolboxの@bazza 'parfeval'は' foo() 'の後にコールバック関数が完了していないことを除いて、私の要求を満たしています。 –