MLGetReal128Array (C 関数)

MLGetReal128ArrayWSGetReal128Arrayに置き換えられた.

int MLGetReal128Array(MLINK link, mlextended_double **a,int **dims,char ***heads,int *d)

link で指定されたMathLink接続から拡張精度浮動小数点数の配列を得て,配列を a に,その次元を dims に,そしてその深さを d に保持しておく.

詳細

  • 配列 a は,mlextended_double a[m][n] と宣言されたC言語の配列のようにメモリにレイアウトされる.
  • heads は,配列の各レベルに頭部として現れる記号名に対応する文字列のリストを返す.
  • MLGetReal128Array()は,MLReleaseReal128Array()を呼び出して解放しなければならないメモリを割り当てる.MLGetReal128Array()が不成功で関数の返す値がエラーを示す場合には,a のコンテンツについてMLReleaseReal128Array()を呼び出してはならない.
  • MLGetReal128Array()は不変のデータを返す.
  • MLGetReal128Array()はエラーがあると0を返し,関数が成功すると0以外の値を返す.
  • MLError()を使うと,MLGetReal128Array()が不成功の場合にエラーコードを引き出すことができる.
  • MLGetReal128Array()は,MathLinkヘッダファイルmathlink.hの中で宣言される.

例題

  (1)

#include "mathlink.h"

/* read an array of extended-precision floating-point numbers from a link */

void f(MLINK lp)
{
    mlextended_double *data;
    int *dims;
    char **heads;
    int d;

    if(! MLGetReal128Array(lp, &data, &dims, &heads, &d))
        {
            /* unable to read the array of numbers from lp */
            return;
        }

    /* ... */

    MLReleaseReal128Array(lp, data, dims, heads, d);
}