2 * Introduction to Miscellaneous Options::
4 * Functions and Variables for Miscellaneous Options::
7 @c -----------------------------------------------------------------------------
8 @node Introduction to Miscellaneous Options, Share, Miscellaneous Options, Miscellaneous Options
9 @section Introduction to Miscellaneous Options
10 @c -----------------------------------------------------------------------------
12 この節では、Maximaの操作上、グローバルな効果を持つ様々なオプションが論じられます。
13 すべてのユーザー定義関数のリストのような様々なリストも論じられます。
15 @c -----------------------------------------------------------------------------
16 @node Share, Functions and Variables for Miscellaneous Options, Introduction to Miscellaneous Options, Miscellaneous Options
18 @c -----------------------------------------------------------------------------
20 Maximaの「共有」ディレクトリは、Maximaユーザーのためのものですが、
21 Maximaのコア実装の部分ではない、プログラムと他のファイルを含みます。
22 これらのプログラムは、通常、 @code{load}や @code{setup_autoload}によってロードされます。
24 @code{:lisp *maxima-sharedir*}は、
25 ユーザーのファイルシステム内の共有ディレクトリの位置を表示します。
27 @c FIXME FIXME FIXME -- WE REALLY NEED AN UP-TO-DATE LIST OF SHARE PACKAGES !!
28 @code{printfile ("share.usg")}は、
29 共有パッケージの期限切れリストを印字します。
31 ファイルシステムブラウザを使って共有ディレクトリをブラウズすることがもっと情報が得られることを知るでしょう。
33 @c -----------------------------------------------------------------------------
34 @node Functions and Variables for Miscellaneous Options, , Share, Miscellaneous Options
35 @section Functions and Variables for Miscellaneous Options
36 @c -----------------------------------------------------------------------------
38 @c -----------------------------------------------------------------------------
40 @defvr {宣言} alphabetic
42 @code{alphabetic}は、 @code{declare}が認識する宣言タイプです。
43 式 @code{declare(@var{s}, alphabetic)}は、Maximaに
44 @var{s}―は文字列でなければいけません―の中の文字のすべてをalphabeticとして認識するように
47 @ref{Identifiers}も参照してください。
53 @c declare ("~`@", alphabetic);
54 @c xx~yy`@ + @yy`xx + `xx@@yy~;
58 (%i1) xx\~yy\`\@@ : 1729;
60 (%i2) declare ("~`@@", alphabetic);
62 (%i3) xx~yy`@@ + @@yy`xx + `xx@@@@yy~;
63 (%o3) `xx@@@@yy~ + @@yy`xx + 1729
65 (%o4) [@@yy`xx, `xx@@@@yy~]
69 @category{Declarations and inferences}
73 @c -----------------------------------------------------------------------------
75 @defvr {オプション変数} genindex
79 必要な時、和の次の変数を生成するために使われる
83 @category{Sums and products}
88 @defvr {オプション変数} gensumnum
94 もし@code{false}に設定されているなら、
95 インデックスは数値接尾辞なしで@code{genindex}だけから成ります。
98 @category{Sums and products}
102 @c -----------------------------------------------------------------------------
104 @deffn {関数} gensym ()
105 @deffnx {関数} gensym (@var{x})
107 @code{gensym()}は新鮮なシンボルを生成し、返します。
111 Lisp内部カウンタの値がデフォルトの数の十進表現である接尾辞の連結です。
113 もし@var{x}が供給されて、それが文字列なら、
115 その文字列は"g"の代わりに接頭辞として使われます。
117 もし@var{x}が供給されて、それが整数なら、
119 内部Lisp整数の値の代わりに接尾辞として使われます。
121 もし陽な接尾辞が供給されないなら、また、その時だけ、
122 Lisp内部整数は、使われた後1だけ増分されます。
142 @c CROSS REF TO WHICH FUNCTION OR FUNCTIONS ESTABLISH PROPERTIES !! (VERY IMPORTANT)
143 @c NEEDS EXPANSION, CLARIFICATION, AND EXAMPLES
145 @c -----------------------------------------------------------------------------
147 @deffn {関数} properties (@var{a})
149 アトム@var{a}に関連づけられたプロパティすべての名前のリストを返します。
152 @category{Declarations and inferences}
156 @c CROSS REF TO WHICH FUNCTION OR FUNCTIONS ESTABLISH PROPERTIES !! (VERY IMPORTANT)
157 @c NEEDS EXPANSION, CLARIFICATION, AND EXAMPLES
158 @c WHAT IS HIDDEN IN THE "etc" HERE ??
160 @c -----------------------------------------------------------------------------
162 @defvr {特殊シンボル} props
165 @code{declare}関数で指定されたプロパティはもちろん、
166 @code{atvalue}, @code{matchdeclare}, などが指定したような、
167 @code{infolists}で陽に言及されたもの以外の任意のプロパティ、を持つアトムです。
170 @category{Declarations and inferences} @category{Global variables}
174 @c CROSS REF TO WHICH FUNCTION OR FUNCTIONS ESTABLISH PROPERTIES !! (VERY IMPORTANT)
175 @c NEEDS EXPANSION, CLARIFICATION, AND EXAMPLES
177 @c -----------------------------------------------------------------------------
179 @deffn {関数} propvars (@var{prop})
182 @var{prop}が示すプロパティを持つアトムのリストを返します。
184 @code{propvars (atvalue)}は、atvalueを持つアトムのリストを返します。
187 @category{Declarations and inferences}
192 @c CROSS REF TO OTHER FUNCTIONS WHICH PUT/GET PROPERTIES !! (VERY IMPORTANT)
193 @c NEEDS EXPANSION, CLARIFICATION, AND EXAMPLES
194 @c ARE PROPERTIES ESTABLISHED BY put THE SAME AS PROPERTIES ESTABLISHED BY declare OR OTHER FUNCTIONS ??
195 @c IS put (foo, true, integer) EQUIVALENT TO declare (foo, integer) FOR EXAMPLE ??
197 @c -----------------------------------------------------------------------------
199 @deffn {関数} put (@var{atom}, @var{value}, @var{indicator})
201 @var{value}を@var{atom}の(@var{indicator}が指定する)プロパティに割り当てます。
202 @var{indicator}は、任意のプロパティの名前を取り得ますが、
205 @code{rem}は@code{put}の効果をひっくり返します。
208 @code{put}は@var{value}を返します。
213 (%i1) put (foo, (a+b)^5, expr);
216 (%i2) put (foo, "Hello", str);
218 (%i3) properties (foo);
219 (%o3) [[user properties, str, expr]]
220 (%i4) get (foo, expr);
223 (%i5) get (foo, str);
228 @category{Declarations and inferences}
233 @c -----------------------------------------------------------------------------
235 @deffn {関数} qput (@var{atom}, @var{value}, @var{indicator})
237 @var{value}を@var{atom}の(@var{indicator}が指定する)プロパティに割り当てます。
238 これは、引数がクォートされることを除いて、@code{put}と同じです。
246 (%i4) put (foo, bar, baz);
248 (%i5) properties (aa);
249 (%o5) [[user properties, cc]]
252 (%i7) qput (foo, bar, baz);
254 (%i8) properties (foo);
255 (%o8) [value, [user properties, baz]]
256 (%i9) get ('foo, 'baz);
261 @category{Declarations and inferences}
265 @c CROSS REF TO OTHER FUNCTIONS WHICH PUT/GET PROPERTIES !! (VERY IMPORTANT)
266 @c NEEDS EXPANSION, CLARIFICATION, AND EXAMPLES
267 @c HOW DOES THIS INTERACT WITH declare OR OTHER PROPERTY-ESTABLISHING FUNCTIONS ??
268 @c HOW IS THIS DIFFERENT FROM remove ??
270 @c -----------------------------------------------------------------------------
272 @deffn {関数} rem (@var{atom}, @var{indicator})
274 @var{atom}から、@var{indicator}が示すプロパティを取り除きます。
275 @code{rem}は@code{put}の効果をひっくり返します。
277 @code{rem}が呼び出された時、もし@var{atom}が@var{indicator}プロパティを持っていたなら、@code{rem}は@code{done}を返します。もしそんなプロパティを持っていなかったら@code{false}を返します。
280 @category{Declarations and inferences}
284 @c CROSS REF TO OTHER FUNCTIONS WHICH PUT/GET PROPERTIES !! (VERY IMPORTANT)
285 @c NEEDS EXPANSION, CLARIFICATION, AND EXAMPLES
286 @c HOW DOES THIS INTERACT WITH declare OR OTHER PROPERTY-ESTABLISHING FUNCTIONS ??
287 @c HOW IS THIS DIFFERENT FROM rem ??
289 @c -----------------------------------------------------------------------------
291 @deffn {関数} remove (@var{a_1}, @var{p_1}, ..., @var{a_n}, @var{p_n})
292 @deffnx {関数} remove ([@var{a_1}, @dots{}, @var{a_m}], [@var{p_1}, @dots{}, @var{p_n}], ...)
293 @deffnx {関数} remove ("@var{a}", operator)
294 @deffnx {関数} remove (@var{a}, transfun)
295 @deffnx {関数} remove (all, @var{p})
296 アトムに関連づけられたプロパティを取り除きます。
298 @code{remove (@var{a_1}, @var{p_1}, ..., @var{a_n}, @var{p_n})}
299 は、アトム@code{a_k}からプロパティ@code{p_k}を取り除きます。
301 @code{remove ([@var{a_1}, ..., @var{a_m}], [@var{p_1}, ..., @var{p_n}], ...)}
303 アトム@var{a_1}, @dots{}, @var{a_m}から
304 プロパティ@code{@var{p_1}, ..., @var{p_n}}を
308 @c VERIFY THAT THIS WORKS AS ADVERTISED
309 @code{remove (all, @var{p})}は、
310 プロパティ@var{p}を、それを持つアトムすべてから取り除きます。
312 @c SHOULD REFER TO A LIST OF ALL SYSTEM-DEFINED PROPERTIES HERE.
314 @code{function}, @code{macro}, @code{mode_declare}のようなシステム定義のプロパティ
316 @code{remove}は@code{put}で定義されたプロパティを取り除きません。
318 @c VERIFY THAT THIS WORKS AS ADVERTISED
319 @c IS transfun PECULIAR TO remove ?? IF SO, SHOW SPECIAL CASE AS @defunx
320 翻訳されたLispバージョンの関数を取り除くために
321 プロパティは、@code{transfun}を取ることができます。
322 これを実行した後は、翻訳バージョンでなく、Maximaバージョンの関数が実行されます。
324 @code{remove ("@var{a}", operator)}または、同値な, @code{remove ("@var{a}", op)}
327 @code{prefix}, @code{infix}, @code{nary}, @code{postfix}, @code{matchfix}, @code{nofix}が宣言した演算子プロパティを取り除きます。
328 演算子名はクォートされた文字列として書かれなければいけないことに注意してください。
330 アトムが指定されたプロパティを持とうが持ちまいが、
331 @code{remove}は、いつも@code{done}を返します。
332 この振る舞いは、もっと具体的な削除関数@code{remvalue}, @code{remarray}, @code{remfunction}, @code{remrule}と似ていません。
334 @code{remove}は引数をクォートします。
336 @c IN SERIOUS NEED OF EXAMPLES HERE
338 @category{Declarations and inferences}
344 @c -----------------------------------------------------------------------------
346 @deffn {関数} remvalue (@var{name_1}, ..., @var{name_n})
347 @deffnx {関数} remvalue (all)
349 (添字付きもありえる)ユーザー変数@var{name_1}, ..., @var{name_n}の値をシステムから
352 @code{remvalue (all)}は、
353 removes the values of all variables in
354 @code{values}―(Maximaが自動的に割り当てたものと対照的に)
355 ユーザーが名前を与えた変数すべてのリスト―
358 @code{values}も参照してください。
361 @category{Evaluation}
367 @c -----------------------------------------------------------------------------
369 @deffn {関数} rncombine (@var{expr})
371 同一の分母や、たがいに数値因子だけことなる分母を持つ
372 @var{expr}のすべての項を結合することで、
374 これは、@code{combine}の振る舞いとわずかに違います。
375 @code{combine}は、同一分母を持つ項を集めます。
377 @code{pfeformat: true}を設定し、@code{combine}を使うことは、
378 @code{rncombine}を使って得られるものと似た結果をもたらしますが、
380 クロス積の数値的分母因子のおまけのステップを実行します。
381 これは、きれいな形式と、いくつかの相殺を認識する可能性を生みます。
383 @code{load(rncomb)}はこの関数をロードします。
386 @category{Expressions}
391 @c NEEDS CLARIFICATION AND EXAMPLES
393 @c -----------------------------------------------------------------------------
395 @deffn {関数} scalarp (@var{expr})
398 @code{declare}で@code{scalar}と宣言された変数、
399 数と定数とそんな変数から完全に構成され、行列やリストを含まない変数なら、
403 @category{Predicate functions} @category{Vectors} @category{Matrices}
407 @c -----------------------------------------------------------------------------
408 @anchor{setup_autoload}
409 @deffn {関数} setup_autoload (@var{filename}, @var{function_1}, ..., @var{function_n})
411 もし@var{function_1}, ..., @var{function_n}のいずれかが、
413 @code{load}を通じて@var{filename}がロードされるように指定します。
415 強制はされませんが、普通、指定された関数の定義を含みます。
417 @code{setup_autoload}は配列関数については機能しません。
419 @code{setup_autoload}は引数をクォートします。
423 @c EXAMPLE GENERATED FROM FOLLOWING INPUT
424 @c legendre_p (1, %pi);
425 @c setup_autoload ("specfun.mac", legendre_p, ultraspherical);
426 @c ultraspherical (2, 1/2, %pi);
427 @c legendre_p (1, %pi);
428 @c legendre_q (1, %pi);
430 (%i1) legendre_p (1, %pi);
431 (%o1) legendre_p(1, %pi)
432 (%i2) setup_autoload ("specfun.mac", legendre_p, ultraspherical);
434 (%i3) ultraspherical (2, 1/2, %pi);
435 Warning - you are redefining the Macsyma function ultraspherical
436 Warning - you are redefining the Macsyma function legendre_p
439 (%o3) ------------ + 3 (%pi - 1) + 1
441 (%i4) legendre_p (1, %pi);
443 (%i5) legendre_q (1, %pi);
447 (%o5) ---------------- - 1
452 @category{Function definition} @category{File input}