Mathematica 9 is now available

Documentation / Mathematica / Mathematicaブック / Mathematicaの仕組み / Mathematicaセッションの グローバルな面 /

2.14.4 メモリ管理

メモリ使用状況の参照

特にメモリ容量が記号計算における計算規模を決定する主要な要因になっている.計算が遅いと,そのまま長く計算させておくことができる.しかし,計算過程においてメモリに入り切らないほどの大きな中間結果が生成されると,計算を続けることは不可能になってしまう.

Mathematicaはメモリをなるべく効率的に使うようにプログラムされている.計算で生成された中間結果が必要なくなったなら,その保管に使われていたメモリ領域はすぐに解放されるようになっている.つまり,セッションのどの時点においても実際に必要な式しか保管されない.後で「ゴミ収拾」しなければならないような,いらなくなったオブジェクトは手元にはおかない.

Mathematicaが使用中のメモリ量を調 べる.

In[1]:= MemoryInUse[ ]

Out[1]=

10000個の要素からなるリストを作る.

In[2]:= Range[10000] // Short

Out[2]//Short=

リストのため使用量が増えている.

In[3]:= MemoryInUse[ ]

Out[3]=

リストはOut[2]に割り当てられた値として保管されている.したがって,Out[2]を消去するともとのリストが消える.

In[4]:= Unprotect[Out]; Out[2]=.

メモリ使用量が減った.

In[5]:= MemoryInUse[ ]

Out[5]=

セッションで使える最大メモリ量を調べる.

In[6]:= MaxMemoryUsed[ ]

Out[6]=

特定のコンピュータにおいて,Mathematicaで使用可能なメモリ量はどう決まるのだろうか.コン ピュータの実行している処理の数や量によらず,使えるメモリ量には限りがある.また,メモリの上限はオペレーティングシステムの種類や設定条件により変わる.設定によっては物理的に搭載してあるメモリ量に相当する.また,大容量記憶装置の空間の一部を仮想メモリとして使っている場合は,物理メモリ量より大きくなる.

Mathematicaの実行にはデータとプログラムの両方を保持する空間が必要である.プログラムだけで数メガバイトの大きさなので,要求のあった計算に応じて必要なコード部だけが,通常,メモリに読み込まれる.あるデータを保管するのにメモリ量がどのくらい必要かを計算するなら,プログラム部の使う量も勘定に入れることを忘れないようにする.さらに,他のプログラムも同時に動作している場合は,使える容量はさらに減るだろう.別に実行しているプログラムが少なければ少ないほど計算に使える容量は普通増える.

計算にかかる時間も物理メモリ量に大きく依存する.つまり,搭載メモリが大きいほど時間が短くてすむようになる.仮想メモリを使うよう設定しておけば使えるメモリ量は増えるが,アクセスに要する時間が物理メモリの数百から数千倍かかってしまう.計算の規模が大きいため,どうしても仮想メモリを使わなければできない場合もあるが,そのようなときは余計に時間がかかってしまう.

メモリ使用量の制限

MemoryConstrainedを使ったメモリの制限設定は計算時間の制限で使うTimeConstrainedの設定に似ている.指定した上限より大きなメモリの要求があると,評価処理が強制的に中止する.ただし,TimeConstrainedでそうであるように,MemoryConstrainedでも実際に中止する前に指定した上限量以上のメモリが使われてしまうこともある.

式の大きさ情報

ByteCountを使うと計算したい式がどの程度の大きさかが分かり便利である.ただし,式が同じでも,違うMathematicaバージョンではメモリの使用量が変わるときもあるので,普遍的な値ではないということに注意が必要である.

また,ByteCountの返してくる使用量は上限の目安なので,実際の式の保管では,通常,それより少ないメモリで間にあう.これは式の成分によっては共通なものがあり,全成分を保管する必要がなくなるからである.

f[1 + x, 1 + x]の式には成分が2つあるが,どちらも1 + xで同じである.実際には片方だけしか保管されないかもしれないし,両方とも保管されるかもしれない.ByteCountのだす値は成分の共有がないことを前提とした使用量である.関連事項として,式成分の共有は/.による置換操作等が行われると即座に無効になるので注意すること.

式の成分を強制的に共有するようにすることも可能である.それを行うには関数Shareを使う.共有することで実際に使うメモリ量を低く押さえることができる.

メモリ使用量の最適化

多くのコンピュータシステムでは,実行中のプログラムは2つの部分から構成されている.プログラムが取得したメモリ空間,そして,スタック空間である.内部ルーチンが呼び出されるたびにスタック空間の一部が使われ,呼出しに関連した引数等のパラメータが一時保管される.多くのコンピュータシステムではプログラムの使うスタック量をあらかじめ指定しておかなければいけない.もし,実行時にスタック空間を使い切ってしまうと,プログラムは通常,強制的に終了してしまう.

Mathematicaでは,スタック空間は主に関数呼出し時に発生する各種の処理を行うために使われる.Mathematicaのスタック(Stackで参照)にはすべてのレベルにおける関数の呼出しが記録される(詳細は2.6.12を参照のこと).スタックの大きさを変えるには大域変数$RecursionLimitの値を変更する.設定値をあまり大きくしすぎると,使用しているコンピュータシステムの許容量を超えてしまい,ス タック空間を確保できなくなってしまうので注意が必要である.



Any questions about topics on this page? Click here to get an individual response.Buy NowMore Information
THIS IS DOCUMENTATION FOR AN OBSOLETE PRODUCT.
SEE THE DOCUMENTATION CENTER FOR THE LATEST INFORMATION.