コンテンツにスキップ

空積

出典: フリー百科事典『ウィキペディア(Wikipedia)』
零項積から転送)

数学における空積(くうせき、: empty product)あるいは零項積 (nullary product) は、0 個の因子を掛けた結果である。(考えている乗法演算に単位元が存在する場合に限り)「空積の値は単位元 1 に等しい」という規約を設ける[1][2][3][4]。このことは、空和(すなわち0個の数を足した結果)が零元 0 に等しいと約束することと同様である。

用語 "空積" は算術的演算を議論するときに上の意味で使われることが多い。しかしながら、この用語は集合論の共通部分、圏論の積、コンピュータプログラミングにおける積に対しても使われる。これらは以下で議論される。

零項算術積

[編集]

正当化

[編集]

a1, a2, a3, …数の列とし、

をこの列の最初の m-項の積とする。このとき

がすべての m = 1, 2, … に対して成り立つというためには、P1 = a1 および P0 = 1 とするという規約が必要である。これはつまり、ただ一つの因子からなる "積" P1 の値はその因子自身であり、全く因子を持たない "積" P0 の値は 1 とするということである。一つだけあるいは零個の因子の "積" を許すことで、多くの数学的な公式において考慮すべき場合の数を減らすことができるようになる。そのような "積" は数学的帰納法やアルゴリズムにおける起点として自然に現れる。これらの理由のため「空積の値は 1 であるものと約束する」ことは数学やコンピュータプログラミングにおいて常識である。

空積を定義することの妥当性

[編集]

空積の概念は、数 0空集合が有用なのと同じ理由で有用である。全く面白くない概念を表しているように見えるが、その存在によって多くの主題のはるかに短い数学的表示が可能になるのである。

例えば、0! = 1x0 = 1 といった空積は、テイラー級数表記を短くする(x = 0 のときの議論は0の0乗を参照)。同様に、Mn × n 行列であれば、M0n × n 単位行列である。これは線型写像を零回適用することは恒等写像を適用することと同じ効果を持っているという事実を反映している。

別の例として、算術の基本定理は、すべての正の整数は素数の積として一意的に書けることを言っている。しかしながら、もし 0 個や 1 個の因子の積を許さなかったら、定理(と証明)は長くなる[5][6]

数学で空積を使用しているさらなる例は、二項定理(これは任意の x に対して x0 = 1 であることを仮定し、かつそれを導く)、スターリング数ケーニッヒの定理二項型多項式列二項級数有限差分ポッホハマー記号において見つかるだろう。

対数

[編集]

対数は積を和に変えるから、空積を空和に写すべきである。そして空積を 1 と定義するならば、空和は log 1 = 0 であるべきである。逆に、指数関数は和を積に変えるから、空和を 0 と定義するならば、空積は e0 = 1 であるべきである。

零項デカルト積

[編集]

デカルト積の一般の定義を考えよう:

添字集合 I が空ならば、そのような g空写像 f ただ一つである。これは ∅ × ∅ の部分集合で写像 ∅ → ∅ を定める唯一のものであり、(∅ × ∅ が持つ唯一の部分集合としての)空部分集合 である:

したがって、零個の集合のデカルト積の濃度は 1 である。

より馴染みのあるであろう順序組の解釈の下では、

つまり、空リストを含む一元集合である。両方の表現において空積は濃度 1 を持つことに注意しよう。

写像の零項デカルト積

[編集]

写像の空デカルト積は再び空写像である。

圏論における空積

[編集]

任意のにおいて、空の族のはその圏の終対象である。これは積の極限による定義を用いて証明できる。n 重の圏論的積は n 個の対象からなる離散圏によって与えられる図式に関する極限として定義できる。すると空積は空圏に関する極限によって与えられ、これは圏の終対象(存在すれば)である。この定義を特殊化すれば上記の結果が与えられる。例えば、集合の圏において、圏論的積は通常のデカルト積であり、終対象は単元集合である。群の圏において、圏論的積は群のデカルト積であり、終対象は1つの元からなる自明群である。空積の通常の算術的定義を得るためには、有限集合の圏において空積の脱圏化英語版を取らなければならない(今の場合これはすなわち、各集合に対してその濃度を考えるということに他ならない)。

双対的に、空な族の余積始対象である。零項の圏論的積や余積は与えられた圏において存在しないかもしれない。例えば、体の圏においては、どちらも存在しない。

論理学における空積

[編集]

古典論理学で定義される演算としての連言は、普遍量化英語版をすることとして、そして述語計算により任意個数の連言へ一般化することができる。真を 1, 偽を 0 と同一視すれば連言を取ることは単に算術的な掛け算をしているだけと直観できるから、連言のことは論理積といった方が通りがよかろう。論理積の因子としては任意個数の入力を受けることができるから、入力が零個の場合として空論理積 (empty conjunction) が考えられ、これは恒等的に真である。

論理学においてこれと関連する概念として、空虚な真は対象からなる空集合は任意の性質を持ち得ることを主張する。これを(論理学の一般論の一部として)論理積が 1 以下の値をとるということを用いて説明することができる。つまり、因子の数の多い論理積を考える場合、それが長くなれば長くなるほどその値が 0(つまり偽)となる確率は高くなる(特に、論理積を取る命題のうちの一つでも 0であることが分かれば、その論理積全体は 0 と確定するから、残り全ての命題について値が 0 かどうかを調べる必要が無くなる)ということであり、裏を返せば論理積の因子となる命題の数を減らせば、0 でないことのチェックを通過してその論理積の値が 1 になる確率はより増加するということである。従って特に、命題の数が零個なら、調べる回数も零回で、何もしなくてもチェックに引っかかることなどあり得ないから、どのような命題あるいは対象の性質を調べているかということとは無関係に、このチェックは必ず通過することになる。

コンピュータプログラミングにおいて

[編集]

多くのプログラミング言語、例えばPython、は数のリストの直接的表現を許しており、任意個のパラメーターを許す関数すら許している。そのような言語がリストに入っているすべての数の積を返す関数を持っていれば、通常以下のように動く:

   listprod( [2,3,5] ) --> 30
   listprod( [2,3] )   --> 6
   listprod( [2] )     --> 2
   listprod( [] )      --> 1

この慣習によって「リストの長さが1ならば」とか「リストの長さが0ならば」のような特別な場合を特別な場合としてコードしなくてもよくなる。

乗法は中置オペレータであり、したがって二項演算であり、空積の表記をややこしくしている。いくつかのプログラミング言語はこれを可変長引数関数を使うことによって扱っている。例えば、LISP十分にかっこをつけた前置記法から0項の英語版関数の自然な表記が生じる:

(* 2 2 2)   ; evaluates to 8
(* 2 2)     ; evaluates to 4
(* 2)       ; evaluates to 2
(*)         ; evaluates to 1

関連項目

[編集]

参考文献

[編集]
  1. ^ Jaroslav Nešetřil, Jiří Matoušek (1998). Invitation to Discrete Mathematics. Oxford University Press. pp. 12. ISBN 0-19-850207-9 
  2. ^ A.E. Ingham and R C Vaughan (1990). The Distribution of Prime Numbers. Cambridge University Press. pp. 1. ISBN 0-521-39789-8 
  3. ^ Page 9 of Lang, Serge (2002), Algebra, Graduate Texts in Mathematics, 211 (Revised third ed.), New York: Springer-Verlag, ISBN 978-0-387-95385-4, Zbl 0984.00001, MR1878556 
  4. ^ Grillet, Pierre A (1995). Semigroups: An Introduction to the Structure Theory. ISBN 978-0824796624 
  5. ^ Edsger Wybe Dijkstra (1990年3月4日). “How Computing Science created a new mathematical style”. EWD. 2010年1月20日閲覧。 “Hardy and Wright: “Every positive integer, except 1, is a product of primes”, Harold M. Stark: “If n is an integer greater than 1, then either n is prime or n is a finite product of primes.”. These examples —which I owe to A.J.M. van Gasteren— both reject the empty product, the last one also rejects the product with a single factor. 訳:ハーディ・ライト:「1 を除いてすべての正の整数は素数の積である」、ハロルド・M・スターク:「n が 1 よりも大きい整数であれば、n は素数であるかまたは素数の有限個の積である。」これらの例は、私は A.J.M. van Gasteren に聞いたものであるが、どちらも空積を拒否しており、後者は因子がただ1つの積も拒んでいる。”
  6. ^ Edsger Wybe Dijkstra (1986年11月14日). “The nature of my research and why I do it”. EWD. 2010年7月3日閲覧。 “But also 0 is certainly finite and by defining the product of 0 factors —how else?— to be equal to 1 we can do away with the exception: "If n is a positive integer, then n is a finite product of primes." 訳:しかし 0 もまた確かに有限であり、0 個の因子の積を 1 に等しいと定義することによって―他にどうやって?―例外を排除することができる:「n が正の整数であれば、n は素数の有限個の積である。」”

外部リンク

[編集]