保型形式 という数学用語を聞いたことはあるでしょうか?
数学好きの方の中には、フェルマーの最終定理の証明で楕円曲線と保型形式が役に立った、という話を聞いたことがある方もいるでしょう。
私が保型形式に出会ったのは、数学ガール「フェルマーの最終定理」という本でした。
この本の最終章では、保型形式の具体例を計算して、楕円曲線と保型形式の深い関係について、その入口の部分を体感できます。この本を読んで「なんだか面白そう」と思った方も多いのではないかと思います。私もその一人です。
一方で、さわりの部分だけでは物足りない、もっと保型形式のその先を勉強してみたい、と思う方も多いのではないかと思います。
今回の記事は、そんな「あなた」のための記事です。
この記事を通して詳しく解説しますが、保型形式とはたとえばこんな感じの関数です(現時点でこれが分からなくても大丈夫です):
保型形式は端的に言うと「きわめて多くの対称性を持った特殊な関数」です。対称性からさまざまな良い性質が導かれ、これにより数学の多様な分野と関わることができます。
また保型形式は(上にあげたものだけには留まらない)多様な関数が集まった、とても広いクラスを表す概念です。そのため、全容を学ぼうとするととても大変ですし、私自身もよくわかっていません。
そこで今回は、保型形式のあくまで一部分である モジュラー形式 を紹介したいと思います。保型形式とモジュラー形式は、以下のベン図に示すような包含関係にあります:
真面目にモジュラー形式を勉強しようとすると難しいですが、今回の記事の目的はあくまでその魅力を伝えることです。言いかえると モジュラー形式を勉強するとこんなにも楽しい ということを紹介したいと思います。
記事の構成ですが、前半の「導入編」と後半の「応用編」に分けたいと思います。別記事にして、後半の応用編は明日投稿したいと思います。
前半の「導入編」では、魅力をお伝えするのに必要な 最低限の知識だけを紹介 します。
後半の「応用編」では、導入編で得た知識を活用して、モジュラー形式の魅力的な応用事例を「これでもか」というぐらい紹介したいと思います。応用編が特におすすめです!
導入編の目次(この記事です!)
応用編の目次(次回の記事)
- 応用①:「関数」の間の非自明な関係式が得られる(難易度:★★)
- 応用②:「数列」の間の非自明な関係式が得られる(難易度:★★)
- 応用③:ヘッケ作用素と2次のゼータ(難易度:★★★)
- 応用④:素数を表現する2次形式(難易度:★★★★★)
- 応用⑤:楕円曲線とフェルマーの最終定理(難易度:★★★★)
導入①:三角関数のおさらい
モジュラー形式に段階的に進んでいくために、まずは高校数学で習った 三角関数 から話を始めようと思います。
三角関数とは、たとえば
のような関数でした。
みなさんよくご存知の通り、これらの関数には 周期 があります。波打つ曲線が、一定間隔で無限に繰り返すような構造を持っているわけですね。
と は、周期 を持つ関数となっています。そのため、位相を ずらすと同じ関数になります:
周期 だと分かりにくいので、 軸をぐーっと縮小させて周期を にしてみましょう。つまり、 の代わりに
を考えることにするのです。
このようにすると
が成り立つことがわかります。(このような修正を加えても、本質的な部分は何もかわりません。)
言い換えると、三角関数 は
に対して値が変わらない(不変な)関数であるというわけです。この変換は以降も使うので、 という名前をつけておきましょう。
単なる言い換えに見えるかもしれませんが、これがモジュラー形式を理解する上でも、とても重要な考え方の変化です。一種のパラダイムシフトですね。
三角関数についてもう一つ思い出したいのは オイラーの公式 です。ここから大学数学に入りますが、三角関数は指数関数を使って
のように表せるのでした。
この関数も、右辺が三角関数なので周期を持ちます。同じように、変数 を に置き換えておいて
としておきます。
ここで、 に対して「変換 : を に置き換える」を適用すると
が成り立ちます。つまり、 が成り立つわけです。
も広い意味で見れば三角関数の仲間です。このように考えると
のような三角関数の特徴は
ということができそうですね。
導入②:モジュラー形式とは?
さて、いよいよモジュラー形式を導入したいと思います。
三角関数では
という変換を考えました。この変換によって不変な関数を三角関数と言うのでした。
以下では、変換 を含むような、より一般的な変換を考えます。
まず、2×2の行列
を考えます。行列 の係数 は整数 であって、行列式が であるとします。
行列 に対して次のような
を考えたいと思います。
毎回
というのは大変なので、このような行列全体のなす集合を フルモジュラー群 といい、(あるいは )と書く表す約束にしましょう。この記事の中では一貫して を使います。
行列として特に
を考えると、 の係数は整数で、行列式は を満たします。
一方、行列 に対応する変換は
となり、これは変換 とまったく同じですね。したがって、フルモジュラー群 は、変換 に対応する行列を含んでいるとわかります。
モジュラー形式とは、「不正確さを承知の上でいえば」フルモジュラー群 に属する任意の行列 に対する変換で不変な関数 のことです。フルモジュラー群 は変換 に対応する行列を含んでいるので、三角関数よりずっと対称性が高い関数を考えたいということですね。
「不正確さを承知の上でいえば」と書いたのは、より正確には以下のように修正が必要だからです。
①まず、 としては を複素数とする 複素関数 を考える必要があります。慣習に従って、 の代わりに複素数の変数 を用いて と表すことにします。
また、 は 正則関数 でなければいけません。正則な領域としては、複素数平面の中で特に虚部が正の領域()であればよいです。
このような領域のことを上半平面といいます。 は上半平面で正則、すなわち微分可能な関数でなければなりません。直感的には、無限大に発散するポイントが存在しない(極を持たない)ということです。複素関数の正則性というのはとても強い制約であり、これにより条件を満たす関数がかなり限られてきます。
②さらに、 を に対して極限を取ります。あまりなじみがないかもしれませんが、変数の虚軸方向に大きくしたときの極限ということです。
このような極限を考えたときに が において正則 であるという条件がつきます。 が無限大に発散せず、ちゃんとした値を持つということですね。
これで一通りの条件が出揃いました。以上をまとめるとこうなります:
② は で正則
③ フルモジュラー群 に属する任意の行列 に対する変換で は不変
以上①〜③を満たす関数がモジュラー形式の定義です・・・、といいたいですが、違います。
実は、①〜③をすべて満たす関数は定数関数しかありません。(だめじゃん!!)
というわけで、このままでは定数だけしか扱えない、という非常に残念なことになります。
条件が厳しすぎたので、もう少し条件を緩めたいですね。
①、②の条件はできれば変えたくありません。そこで、③を修正したいと思います。
新しい条件③'は次の通りです:
とするのではなく、 と 倍が余計についた形にするのですね。
ここで は非負の整数で、 の重さ(ウェイト) といいます。
「変換に対して不変」としていたところを「 倍のずれ」を許容することで、定義した関数が定数だけになってしまうのを回避するわけです。いやー、絶妙ですね。
これでようやく モジュラー形式 が次のように定義できます:
① は上半平面で正則な複素関数
② は で正則
③' フルモジュラー群 に属する任意の行列 に対して は以下の等式を満たす:
このモジュラー形式の重さという概念はきわめて重要で、応用編で大変役に立つので覚えておいてください。
なお、①②の性質を「正則性」といい、③'の性質を「保型性」といいます。
Wikipediaで「モジュラー形式」を調べると、同じページに「モジュラー関数」というのが出てきて混乱するかと思います。
モジュラー形式では、最初の条件①〜③のうち③を③'に置き換えることで定義されたのでした。実はもう一つ拡張の方向性はあって、それは①②の正則性を諦めてしまうことです。正則関数ではなく、有理型関数 という条件にしてしまうわけですね。有理型関数とは「極」という無限大に発散する点を許容するような関数です。詳しいことは複素関数論を読んでください。
①' は上半平面で有理型な複素関数。
②' は でも有理型。
③ フルモジュラー群 に属する任意の行列 に対して は以下の等式を満たす:
モジュラー関数も大変面白い対象ではあるし、言いたいことはたくさんあります。一つだけ言っておくと、私のブログの一番上にある画像の数式が、モジュラー関数の代表例です。それぐらいお気に入りの関数です。
フルモジュラー群 は
と表される行列全体でした。実は、これは次の3つの行列(および逆行列)を繰り返し掛け合わせることによって表すことができます:
の重さを としたとき、 に対応する保型性は次のようになります:
- 変換 に対する保型性:
- 変換 に対する保型性:
- 変換 に対する保型性:
奇数だと にしかならない件は、応用編①でまた言及することになります。
の組み合わせからフルモジュラー群 のすべての行列を表すことができるので、この3つの保型性だけチェックすればすべての保型性が示されることになります。この事実は保型性のチェックをするのに大変便利なので、後ほど積極的に使っていきます。
さて、これにてモジュラー形式を定義することに成功したわけですが、上で定義したものは実は「フルモジュラーな」モジュラー形式というタイプのもので、モジュラー形式すべてを定義できたわけではありません。
もう少し変換のための行列を減らしたものも「モジュラー形式の仲間」として認めてあげようというわけです。
具体的には、ある固定した正の整数 に対して
で表される行列全体を考えます。下線部がフルモジュラー群のときと異なる箇所で「 が で割り切れるもの」だけ考えるということですね。つまり、フルモジュラー群の一部分だけを考えるということです。(群論の言葉を使うと、フルモジュラー群 の部分群を考えることになります。)
このような任意の行列に対して保型性
を持つ関数 を考えます。これを レベル のモジュラー形式と言います。
こんな風に拡張していくことで、どんどんモジュラー形式のバリエーションを増やすことができるわけです。
他にも、「重さ 」として半整数のものを考えることもあります。これは半整数ウェイトのモジュラー形式といいます。
上記のような拡張したものもひっくるめて モジュラー形式 といいます。さらに、これをもっと拡張したような、とても一般化した概念が保型形式ということですね。
今回は、基本的にはフルモジュラーなモジュラー形式を扱うことになります。なので、特に断りがなければフルモジュラーだと思ってください。
応用④と応用⑤のところだけ、例外的にレベル のモジュラー形式が登場します。
導入③:これだけは覚えて欲しい2つのモジュラー形式
モジュラー形式が定義できたので、モジュラー形式の具体例を紹介したいと思います。
今回は、2種類の代表的なモジュラー形式を紹介します。一つはアイゼンシュタイン級数で、もう一つはラマヌジャンのデルタです。実はこれらは記事の冒頭で既に紹介しているものです。
教科書だと「私、ただの具体例ですけど」みたいにしれっと出てくるのですが、よーく注意してください。この2種類は極めて重要な具体例 です。
まずは、アイゼンシュタイン級数です。 を 以上の整数として、重さ のアイゼンシュタイン級数 は次のように定義されます:
パラメータとして が入っているので、アイゼンシュタイン級数は一個だけではありません。たとえば、 のときは 、同様に
のすべてがアイゼンシュタイン級数です。
(導入④では、これを単に定数倍しただけの「正規化されたアイゼンシュタイン級数」が登場します。)
定義式 を観察すると、右辺が無限個の項を足す級数の形になっています。
和の取り方としては「 以外の整数 の組み合わせ全部」についての和を考えています。 のときは になりますし、 のときは になります。これらの無限の組み合わせを全部足し合わせるわけですね。これで一個の に対する値が決まるのです。
が抜けているのはなぜかわかるでしょうか。もし を足し合わせるとなると、その項は になってしまいます。このままでは値が定義できないので、この項を除いておく必要があるのですね。
アイゼンシュタイン級数 は、重さが のモジュラー形式 となっています。
導入②で議論したように、行列 と行列 に対する保型性を確認すれば十分です。
行列 を適用すると、次のようになります:
最後はちょっとトリッキーな変形に見えるかもしれません。以下の2つを使っています:
- と を入れ替えても和の取り方は変わらない
- と を記号的に入れ替えても和の取り方は変わらない
行列 に対する保型性( )は簡単に確認できるので、ぜひ考えてみてください。
アイゼンシュタイン級数の和の取り方の「対称性」によって、モジュラー形式の性質を満たされているわけですね。
続いて、重さ のモジュラー形式の例として、ラマヌジャンのデルタ を紹介します。アイゼンシュタイン級数と違って、こちらは1つの関数です:
一見ごちゃごちゃした形に見えますね。しかしながら、よくよく観察すると、これが を基本パーツとして構成されていることがわかります。
これに着目して
と置いてあげると、少し見やすくなるかもしれません。
右辺は、無限積 と呼ばれるもので、シグマ記号の「積」バージョンです。 の各 に対して を計算して、これらをすべて掛け合わせるというものです。
実際、次のような式を考えているということですね:
このラマヌジャンのデルタのパーツは なのでした。そして、三角関数のときにやったように、 は行列 に対する保型性(不変性)が成り立つ なのでした:
よって、ラマヌジャンのデルタ全体としても、行列 による変換に対して不変になるのです。面白いですね!!
あとは、行列 に対しての保型性を言えばいいのですが、この証明は簡単ではありません。
ここでは結果を述べるだけに留めますが、ラマヌジャンのデルタは行列 に対して次のような「保型性」を満たします:
よって、ラマヌジャンのデルタは重さ のモジュラー形式というわけですね。
導入④:q-展開とカスプ形式
モジュラー形式の表現形式として -展開 というものがあります。これはぜひ知っておくべきことです。
先ほどのラマヌジャンのデルタは、 というパーツで構成されていたことを思い出しましょう。見やすくするために
という新しい変数を用意して、ラマヌジャンのデルタを書き直しましょう:
これでラマヌジャンのデルタが に依存して値が決まることが分かりやすくなりました。
さて、右辺は無限積の形になっていますが、これを和の形に変えてみましょう。
まで掛け合わせると、右辺は
となります。
(思い切り省略していますが、全部の項を展開するのはとても大変な作業です。)
まで掛け合わせると
となります。
以降、繰り返すと
のように係数が確定していきます。
ラマヌジャンのデルタが のべき級数の形で展開できたわけですが、これを -展開 といいます。
一般に、(フルモジュラーな)モジュラー形式は行列 による変換に対して不変です。ということは、三角関数と同じ周期性を持っているわけですね。
ここで、フーリエ級数展開 を思い出すと、周期 の周期性を持つ関数 は
のように表すことができます。
と置き換えると
となります。あとは、負のべきの項が消えれば、-展開の形になりますね。
ここで、モジュラー形式の定義にあった条件②「 は において正則」を思い出しましょう。 のとき、 なので
となります。
負べきの項は という形になっているので、 のとき になってしまいます。よって、モジュラー形式であるためには、負べきの項に関する係数はすべて でなければなりません。
以上によって、任意の(フルモジュラーな)モジュラー形式は
と表せるわけですね。これをモジュラー形式 の -展開といいます。また、 を の -係数といいます。
関連して、カスプ形式 という概念を紹介します。今定義した -展開を明示的に表すと
と書けます。このとき、特に定数項が であるものをカスプ形式といいます。つまり
のように の 次以降から始まるものをカスプ形式というわけですね。
なお、 の極限を考えると は に収束するので
をカスプ形式の条件であると言い換えることもできます。
カスプ形式かどうかというのは「ささいな違い」に見えるかもしれませんが、応用編で度々活用されるように極めて重要な条件となっています。
例:ラマヌジャンのデルタの -展開:
ラマヌジャンのデルタは
のように の 次から始まっていますので、カスプ形式の一例です。
応用編その③で使うので、ラマヌジャンのデルタの -係数を、特別に と置いておくことにしましょう。これをラマヌジャンのタウ関数といいます。
のように続いてきます。
例:アイゼンシュタイン級数の -展開:
アイゼンシュタイン級数 はカスプ形式ではありません。この -展開は次のように表されます:
ここで、 はリーマン・ゼータ関数の における値、 はベルヌーイ数の 番目の値です。これは に対して決まってしまう定数の値なので、特に気にする必要はありません。(リーマン・ゼータやベルヌーイ数が出てくるのは大変興味深いですが!)
定数項 が非零なので、カスプ形式ではないと言う分けですね。
の係数についている は( 乗の)約数関数と呼ばれるもので、 の正の約数をすべて 乗してから足し合わせるという関数です。数論的にはしばしば見かける関数ですね。
上の式 を見ると、アイゼンシュタイン級数 を最初から 倍してあげたほうがよさそうに思えます。
つまり
ということです。この を正規化されたアイゼンシュタイン級数といいます。-展開の定数項が に正規化されるというわけですね。
こうしておけば、正規化されたアイゼンシュタイン級数が「約数関数の母関数」だと思うことができて、いっそう綺麗に思えます。
正規化されたアイゼンシュタイン級数の -展開を計算すると、次のようになります:
次回予告!
以上で、モジュラー形式に関する最低限の事項はすべて説明し終わりました。キリが良いところなので、導入編はこの辺で終わりたいと思います。
今回はモジュラー形式の定義を紹介し、重さ のモジュラー形式としてアイゼンシュタイン級数 を、重さ のカスプ形式としてラマヌジャンのデルタ を紹介しました。これらの具体例は次回も出てくるので、ぜひ親しんでおいてください。
また、-展開を導入して、(あるいは正規化されたアイゼンシュタイン級数 )と の -展開を紹介しました。
これにて準備ができたということで、明日公開の記事では 「モジュラー形式を勉強するとこんなにも楽しい」 という話をしていきたいと思います。
具体的には 5つ の話を紹介したいと思います。
- 応用①:「関数」の間の非自明な関係式が得られる(難易度:★★)
- 応用②:「数列」の間の非自明な関係式が得られる(難易度:★★)
- 応用③:ヘッケ作用素と2次のゼータ(難易度:★★★)
- 応用④:素数を表現する2次形式(難易度:★★★★★)
- 応用⑤:楕円曲線とフェルマーの最終定理(難易度:★★★★)
上記のリストは、私が保型形式を勉強する中で 本当に感動したものだけを厳選したもの となっています。明日の記事をお楽しみに!
それでは、今日はこの辺で!
今回の分の参考文献
数学ガール「フェルマーの最終定理」は今回挙げた本の中で一番おすすめしたい本です。気軽に読める本でありながら、楕円曲線と保型形式の関係を紹介する最終章はたいへん深くて数学好きにも満足できる内容になっているかと思います。ぜひご一読ください。
また、保型形式についての議論はこちらが基本的な文献となっています。第3章が「保型形式」についての章となっていて、他の章とは独立して読むことができるのがありがたいです。
私自身は、ざっと目を通した程度なのですが、ちゃんと読んでいるわけではありませんので、よろしければこちらを合わせて参照されるとより良いかと思います。
まったく目を通せていないのですが、セールによる下記の本の第7章がおすすめだと聞きます。
最近出た「数理科学2021年2月号」では「保型形式」の特集が組まれました。その中で金子先生が執筆された「1変数保型形式の数論入門」という記事が大変わかりやすく参考になるかと思います。