[size=150][b]このワークシートは[url=https://www.geogebra.org/m/twxxx3yq]Math by Code[/url]の一部です。[br][br]集合と集合を九九の表のように組み合わせた要素の集合を[color=#0000ff]直積(direct Product)[/color]といいます。[br][/b][size=100]たとえば、[br]A={0,1}, B={0,1,2}としたら、たてにA、よこにBをかいた表を作るとします。[br]すると、2行3列の表ができるので、AとBとのすべての要素の組み合わせを全体として[br]とらえることができます。これが直積の例です。[br]この表をA×Bとかき直積といいます。Aの成分とBの成分を順に並べただけのものです。[br]Aの成分が0のときが1行目で(0,0),(0,1),(0,2)がならびます。[br]Aの成分が1のときが2行目で(1,0),(1,1),(1,2)の3列です。[br]ぜんぶで、タプルが2行3列できますから、A×Bの要素数は2×3になりますね。[br][color=#0000ff]だから、直積そのものは何も計算しているわけではなく、座標のように成分を順序よく入れるのが基本です。[b]成分ごと操作(componts-wize operation)[/b]です。[/color][br][/size][/size][b]なぜ、直積なんて考えるのでしょうか。[br][/b]それは、直積があると、2項演算、関数、グラフを記号化、明確化がしやすいというのがあるでしょう。[br][color=#0000ff](例)[/color][br]2項演算c=a*b=a×b(mod 2)は、a∈A, b∈Bならば、A×Bの表にcの値をならべた行列で表示できますね。[br]この2項演算をfとすると、fはA×B→{0,1}という関数として表現できますね。[br][color=#0000ff](例)[/color][br]y=2xの関数fはx={0,1,2,3}に対してy={0,3,4,6}ですから,fのグラフは{(x,y)| y=2x}={(0,0),(1,2),(2,4),(3,6)}と[br]順序対、タプルのリストになります。この集合は直積R×Rの部分集合になりますね。[br]一般に、[br]・2つの集合AとBの[b]直積A×Bの要素数[/b]は|A||B|と2つの要素数の積になる。[br]・関数f:直積A×A→Aの関数fをA上の[b]2項演算[/b]と言う。[br]・関数f:R→Rに対する集合F={(x,y)|y=f(x)}は[b]関数fのグラフといい、直積R×Rの部分集合と言えるね。[br][/b]
[b][size=150]<群の直積>[/size][/b][br]n個の群の集合{G1,G2,..Gi.,Gn}があるとき、直積集合G=G1×G2×..Gi.×Gnを考えてみよう。[br]g1x,g2y∈G1, g2x,g2y∈G2, ....Gix,giy∈Gi,... Gnx,Gny∈Gnと各群からの適当に2要素をとりだして、[br]直積集合の2項演算gpx★gpyを[br](g1x,g2x,...gix,...gnx)★(g1y,g2y...giy....gny)=(g1x*g1y, g2x*g2y, .....,gix*giy....gnx*gny)[br]と定めてみる。Gの単位元Ge=(g1e, g2e,....gie...gne)としよう。[br]GはGeを単位元として、[b]各Gi成分、因子が演算*で群をなしているから[br]Gの演算★でも群をなす[/b]ことは明らかだね。[br][color=#0000ff](例)[/color][br][b]群Z2={0,1}と群Z3={0,1,2}の直積Z2×Z3=Z23とすると、[br]この集合は位数が2×3=6の巡回群になりZ6同型[/b]だ。[br]なぜなら、x2,y2∈Z2、x3,y3∈Z3とするとき、x2+y2∈Z2, x3+x3∈Z3。[br]Z2の単位元は0,Z3の単位元も0。[br]Z23=Z2×Z3の要素に対して、2項演算x23★y23を[br](x1,x2)★(y1,y2)=(x1+y1,x2+y2)と定めよう。[br][br]Z23の単位元をe=(0,0)とする。[br]Z23の★算はZ2成分、Z3成分の場所でそれぞれ演算しているだけだから、[br]閉じているしそれぞれの成分での加算が群をなすから、★算でZ23も群になる。[br]Z23={(0,0),(1,1),(0,2),(1,0),(0,1),(1,2)}がZ6の{0,1,2,3,4,5}に対応する。[br][b](1,1)=1を加算の生成元とする。1をたすごとにZ2成分は0,1を繰り返し、Z3成分は0,1,2を繰り返す。[/b][br]だから、このようにZ6にきれいに対応することがわかる。[br][br][b][size=150]<直積から成分への分解>[br][/size][/b]G1,G2が群ならG1,G2は直積G1×G2の部分群とみなせる。[br]これは、たとえば、G1×G2のうち、g1∈G1に対してG2成分だけeにした(g1,e)への対応は単射だから、[br]G1はG1×G2の部分群とみなせる。G2も同様だね。[br]しかも、G1、G2はG1×G2の正規部分群だ。(この説明は省略。)[br][br][b][size=150]<直積が巡回群になる条件>[br][/size][color=#0000ff]「直積Zm×Znが巡回群になるのはmとnが互いに素であるときにかぎる[/color]。(中国剰余定理)」[/b][br]互いに素であるときは、単位元0=(0,0), 生成元1=(1,1)として、Zm成分が0,..m-1を繰り返し、[br]Zn成分が0,...n-1を繰り返すので、最大元mnー1=(m-1,n-1)の次が0=(0,0)に戻るから位数mnの巡回群[br]になる。[br]もしmとnに公約数dがあるなら、p=m/d, q=n/dとなる整数がある。[br]Zm×Znの適当な元(x,y)に対して(1,1)をpdq回加える。(x+pdq, y+pdq)=(x+mq, y+mp)≡(x(mod m), y (mod n))となるから、(x,y)の位数はpdq=mn/d以下となり、群の位数がmnより小さくなる。[br]位数mnの元を含まないから、巡回群ではない。[br][color=#0000ff](例)[/color][br][b]Z2×Z2は巡回群ではなくクライン群[/b]になる。[br]Z2={0,1}とすると、Z2×Z2の元は(0,0),(0,1),(1,0),(1,1)の4つある。しかし2と2は互いに素ではないから巡回群にはならない。単位元を0=(0,0)として、1=(0,1)すると、1+1=(0,2)≡(0,0)となり1の位数が2になる。2=(1,0)としても、2+2=(2,0)≡(0,0)となり2の位数も2になる。3=(1,1)にしても2個たすと(0,0)になってしまうから、位数が2。1+2=(0,1)+(1,0)=(1,1)=3だから閉じてはいる。しかし、群の位数は4だが、要素の位数はどれも2以下で、位数4の元を含まないから巡回群ではない。[br][color=#0000ff](例)[br][/color][b]Z3×Z5は巡回群Z15になる。[br][/b][br][b][size=150]<2つの部分群H,Kの直積と等しくなる群G>[br][/size][/b]「H、KがGの正規部分群でHK=G、H∩K={e}なら、H×KとGは同型になる。」[br]h∈H、k∈Gに対してf(h,k)=hkとすると、fは単射でHK=Gだから、H×KからGへの単射となるから。
ラグランジュの定理というのがあったね。[br]群Gを部分群Hで剰余類に分けると、G=|H|+a|H|+b|H|+....と剰余類分解ができることから、[br][b][size=150][color=#0000ff]部分群Hの位数は群Gの約数であるというのがラグランジュの定理[/color][/size][/b]だったね。[br]さらに、元の位数はその元を生成元とする部分群の位数に等しいので、[br]群Gのどの元の位数も、Gの位数の約数だということが言えたね。[br]この逆のような内容がある。それがコーシーの定理だ。[br][br][b][size=150]<コーシーの定理>[/size][/b][br][b][color=#0000ff][size=200][size=150]pが有限群Gの位数の素因数ならGに位数pの元がある。[br][/size][/size][/color][/b][color=#0000ff](例)[br][/color][b]位数が2の倍数の群Gには位数2の元がある[/b]ことになるね。[br]位数2の群ではZ2={0,1}の1は位数が2だ。[br]位数4の群では巡回群Z4={0,1,2,3}の2は位数が2だ。クライン群Z2×Z2{(0,0),(1,0),(0,1),(1,1)}の単位元以外はみな位数が2だったね。[br]位数2nの巡回群Z2n={0,1,...n,...n-1}のnの位数は2だ。[br]位数2nの2面体群Dn={0,r^1,...r^(n-1),t, tr, tr^2,...,tr^(n-1)}のtの位数は2だ。[br]位数3!=6の対称群S3={e,r=(1 2 3),s=(1 3 2), a=(2 3), b=(1 2), c=(1 3)}のa,b,cの位数は2だ。[br]位数4!/2=12の交代群A4={e, {(a b c)| a,b,c ∈{1,2,3,4}}, {(a b)(c d)| a,b,c,d}}の(a b)(c d)型の3個の位数は2だ。[br]位数4!=24の対称群S4は互換の位数は2だ。[br]位数n!の対称群Snの互換の位数は2だ。[br][br][b][size=150]<シロ―の定理>[br][/size][/b](p群とは)[br]素数pのべきの位数をもつ|G|=qr (q=p[sup]m[/sup]、rはpの倍数でない)の群を[b]p群[/b]という。[br]素数pのべきの位数をもつ|G|=p[sup]2[/sup]なら、Gは可換群。[br][color=#0000ff](例)[/color][b]位数が4の群[br][/b]4=2[sup]2[/sup],|G|=2×1(1は2の倍数でない)の群は2群である。Z4(C4)とV4がある。巡回群Z4={0,1,2,3}の2は位数が2だ。クライン群Z2×Z2{(0,0),(1,0),(0,1),(1,1)}の単位元以外はみな位数が2だった。[br](シロ―p部分群の性質)[br]位数がq=p[sup]m[/sup]の部分群をGの[b]シロ―p部分群[/b]という。S(p)などとかいたりする。[br]1・S(p)を筆頭に、[b]qの約数位数[/b]の部分群がある。[br]2・S(p)は[b]互いに共役[/b]だから、共役作用の軌道になる。[br]3・S(p)の[b]個数は1(mod p)で、r=|G|/qの約数[/b]だ。[br] もし、S(p)が1個だけなら、自分自身と共役だから、この1個は[b]Gの正規部分群[/b]となる。[br][br][b][size=150]<有限アーベル群の構造定理>[br][/size][/b]可換群なら位数が素数のべきの巡回群の直積群と同型になる。[br]この巡回群の種類と個数は、同型の取り方と関係なく一定で、有限アーベル群の不変量と言えるね。[br][color=#0000ff](例)[/color][b]pが素数のときのp[sup]4[/sup]の可換群[/b][br]4=3+1=2+2=2+1+1=1+1+1+1の位数の和分解5個から、[br]p[sup]4[/sup]の指数4の和分解した指数乗の巡回群の直積に分解できる。[br]Cp[sup]4[/sup], Cp[sup]3[/sup]×Cp, Cp[sup]2[/sup]×Cp[sup]2[/sup],Cp[sup]2[/sup]×Cp×Cp,Cp×Cp×Cp×Cp[br][color=#0000ff](例)[/color][b]位数72のアーベル群[/b]72=2[sup]3[/sup]*2[sup]2[/sup]だから、構造定理から次の6個が代表元となるね。[br]C8×C9, C8×C3×C3,C4×C2×C9, C4×C2×C3×C3, C2×C2×C2×C9,C2×C2×C2×C3×C3[br][br][b]<分類問題の例>[br]・位数が2p(pが奇素数)の群はC2pかDpと同型[br][/b][color=#0000ff](例)[/color]位数6の群Z6かD3と同型だ。[br][color=#0000ff](例)[/color]位数10の群Z10かD5と同型だ。[br][color=#0000ff](例)[/color]位数14の群Z14かD7と同型だ。[br][b]・位数が8の群[br][/b]アーベル群ではC8,C4×C2,C2×C2×C2[br]非アーベル群ではD4,Q8[br][b]・位数が9の群[br][/b]アーベル群だけで、C9,C3×C3[br][br][color=#9900ff][b][u][size=150]質問:さらに多くの分類問題を解くためには、どうしたらよいでしょうか。[br][/size][/u][/b][/color][br]半直積、フロベニウス群などを学ぼう。[br]また、インストールの手間を惜しまなければ、[b]GAP[/b]や[b]Sage[/b]などの群論が使える言語も調べてみよう。[br]実験しながら、思考を深めたり検証することができるでしょう。[br]視覚化の必要がなければ、[b][color=#0000ff]インストールなしでwebでsage,gapが使える[/color][/b][b][color=#0000ff][url=https://sagecell.sagemath.org/]Sage Cell Server[/url]もあります[/color][/b]。[br]languageを変えて、コードを入れ、evaluateで実行できるplaygroundになっていますよ。[br]tutorialをコピペしたりしながら、いろいろ試して、学びを深めよう。
有限な位数の群はケーリーの定理によると、対称群の部分群として表すことができた。[br]だから、対称群は置換だから、辞書というデータ構造で群の2項演算を辞書の合成としてコード化することができたね。[br]可換群については、アーベルの構造定理が役立ったね。非可換群は、結構調べにくい。[br]そこで、群の置換表現だけでなく、一般線形群GLで表すことで、表現の道具を増やしてみよう。[br]たとえば、対称群S3の置換表現を辞書データで表してみよう。[br]辞書{1:x, 2:y, 3:z}を簡単のために、xyzとかくことする。すると、互換、巡回置換は数値列で表現できる。[br]S3={e=(1)=123, r=(123)=231, s=(132)=312, a=(12)=213, b=(23)=132, c=(13)=321}[br]行列で表してみよう。[br][b][color=#0000ff]e=[[1,0,0],[0,1,0],[0,0,1]], r=[[0,0,1],[1,0,0],[0,1,0]], s=[[0,1,0],[0,0,1],[1,0,0]],[br]a=[[0,1,0],[1,0,0],[0,0,1]], b=[[1,0,0],[0,0,1],[0,1,0]], c=[[0,0,1],[0,1,0],[1,0,0]][br][/color][/b][br][color=#9900ff][u][b][size=150]質問:群S3を行列で表して、2項演算をコードで作るにはどうしたらよいでしょうか。[br][/size][/b][/u][/color][br]geogebraで作れます。[br]e=Identity(3)は3次の単位行列です。[br]何度も同じ行ベクトルをかくのが手間なので、[b][color=#0000ff][br]p1={1,0,0},p2={0,1,0},p3={0,0,1}[/color][/b]とすることで、[br][b][color=#0000ff]Ags={e, r={p3,p1,p2},s={p2,p3,p1},a={p2,p1,p3},b={p1,p3,p2},c={p3,p2,p1}}[br][/color][/b]と簡単に指定できるし、p1,p2,p3の3要素の順列と考えると3!=6要素ができることにも合致するね。[br]行列の積は行列を並べてかくだけです。[br]行列の積がq=(1,2,3)のインデックスがどう入れ替わったかを知るためにapplymatrix(積行列、q)[br]をしましょう。[br]積(1,2,3)=(x,y,z)になることが、辞書{1:x, 2:y, 3:z}を表すので、置換表現と行列表現を行き来することができるね。3次元ベクトル空間Xから基底を選んだ数体K上のベクトル空間KXから、[br]G=S3の表現f:G→GL(KX);g→Agが定まる。fは準同型写像。[br]Pgの集まりをPとしている。[br][b][size=150]<基底の変換>[br]群Gの作用する線形変換fでの基底での表現がAからBに変わったとする。[br]つまり、[br][/size][/b]基底ベクトルをe1=[math]\left(\begin{matrix}1\\0\\0\end{matrix}\right)[/math],e2=[math]\left(\begin{matrix}0\\1\\0\\\end{matrix}\right)[/math],e3=[math]\left(\begin{matrix}0\\0\\1\\\end{matrix}\right)[/math]としてfの表現行列をAとする。[br]基底を変えても群を表現することはできる。[br]新基底x1=e1+e2+e3=[math]\left(\begin{matrix}1\\1\\1\end{matrix}\right)[/math], x2=e1=[math]\left(\begin{matrix}1\\0\\0\\\end{matrix}\right)[/math], x3=e1+e2=[math]\left(\begin{matrix}1\\1\\0\end{matrix}\right)[/math]のときのfの表現行列をBとする。[br][br]基底x=(e1,e2,e3)から新基底X=(x1,x2,x3)に変換する基底変換行列がPなら、[br]X=Pxだから、(x1,x2,x3)=(e1,e2,e3)P[br]([math]\left(\begin{matrix}1\\1\\1\end{matrix}\right)[/math], [math]\left(\begin{matrix}1\\0\\0\\\end{matrix}\right)[/math], [math]\left(\begin{matrix}1\\1\\0\end{matrix}\right)[/math])=([math]\left(\begin{matrix}1\\0\\0\end{matrix}\right)[/math],[math]\left(\begin{matrix}0\\1\\0\\\end{matrix}\right)[/math],[math]\left(\begin{matrix}0\\0\\1\\\end{matrix}\right)[/math]) P[br][math]\left(\begin{matrix}1,1,1\\1,0,1\\1,0,0\end{matrix}\right)=\left(\begin{matrix}1,0,0\\0,1,0\\0,0,1\end{matrix}\right)P[/math] =P[br]P=[math]\left(\begin{matrix}1,1,1\\1,0,1\\1,0,0\end{matrix}\right)[/math] [br]可換図式は次のようになるね。[br][br] A[br]x⇒⇒⇒f(x)[br]↓ ↑[br]↓P ↑P[sup]-1[/sup][br]↓ ↑[br]X⇒⇒⇒f(X)[br] B[br][color=#9900ff][b][u][size=150]質問:可換図式をコードでかくにはどうしたらよいでしょうか。[br][/size][/u][/b][/color][br][IN]Python[br]import japanize_matplotlib[br]import numpy as np [br]from matplotlib import pyplot as plt[br]import networkx as nx[br][br][br]def kakanzushiki(f,n,funcs,E):[br] # グラフの作成[br] G = nx.DiGraph()[br] G.add_nodes_from(f, bipartite=0)[br] G.add_nodes_from(n, bipartite=1)[br] G.add_edges_from(E)[br] [br] # グラフを描画[br] pos = nx.bipartite_layout(G, f)[br] colorList = ['white']*(len(f) + len(n))[br] labels = nx.get_edge_attributes(G, 'label')[br] nx.draw_networkx_edge_labels(G, pos, edge_labels=labels,[br] font_family='IPAexGothic',font_size=20,rotate = False,verticalalignment='baseline')[br] nx.draw_networkx(G,pos,node_color=colorList,edge_color ='green',font_size=20,[br] verticalalignment='baseline',arrowsize=30)[br] plt.show()[br] [br]# グラフの設定と実行==========================================================================[br]f = ["x","X"][br]n = ["f(x)","f(X)"][br]funcs=["A", "P", "B", "1/P"][br]f.reverse()[br]n.reverse()[br]E = [(f[1],n[1], {'label':funcs[0]}),(f[1],f[0], {'label': funcs[1]}),(f[0],n[0], {'label':funcs[2]}),(n[0],n[1], {'label':funcs[3]})][br]kakanzushiki(f,n,funcs,E)[br][img][/img][br][br]xからf(x)への表現Aは、表現Bを経由するとB=P[sup]-1[/sup]APになる。[br]この表現AにAgを入れて計算すると、対応する、Bgが求められる。[br]つまり、群の行列表現は基底に連動して変わるということがわかるね。[br]ということは、計算しやすいように、基底を選ぶことで表現行列が扱いやすくなるということだね。そうすると、群の2項演算が表現行列どうしの積になるので、群の計算が線形代数の計算や[br]写像の問題に置き換えて議論できるということになることがわかる。[br][br][color=#9900ff][b][size=150]質問:新旧の基底からPとinvPを求めて可換図式に反映し、AからBを求める関数を作るコードはどうしたらよいでしょう。[br][/size][/b][/color][br]pythonでは[b]行ベクトルを多列につみあげたものが行列というデータの入力方法なので、[br]Pのデータを行ベクトルのリストという形式で渡しましょう[/b]。[br]渡されたデータから、numpyで、行列Pと逆行列inv(P)を求めて、行列を返す関数[b]makePs[/b]を作ります。[br]そして、Aのデータは対称群なので、行ベクトルp1,p2,p3の順列をnumpyの行列リストとして作り出す関数[br][b]makeS3[/b]を作ります。返される行列群をAとして受け取りましょう。[br]そして、makePsからP,inv(P)を取得して、Aの各要素にinv(P)APをしてあげて、Bを作ればよいですね。[br][br]import japanize_matplotlib[br]import numpy as np [br]from matplotlib import pyplot as plt[br]import networkx as nx[br]from numpy.linalg import inv[br]from itertools import permutations[br]def makeS3():[br] p1 = np.array([1,0,0])[br] p2 = np.array([0,1,0])[br] p3 = np.array([0,0,1])[br] source = [p1,p2,p3][br] return [np.array(x) for x in permutations(source)][br]def makePs(newbase):[br] X = np.array(newbase)[br] x = np.identity(3)[br] P = np.dot(X,inv(x))[br] invP=inv(P)[br] return x,X,P,invP[br]def makeB(P,invP,A):[br] return [np.dot(invP,np.dot(x,P)) for x in A][br]def kakanzushiki(f,n,funcs,E):[br] # グラフの作成[br] G = nx.DiGraph()[br] G.add_nodes_from(f, bipartite=0)[br] G.add_nodes_from(n, bipartite=1)[br] G.add_edges_from(E)[br] # グラフを描画[br] pos = nx.bipartite_layout(G, f)[br] colorList = ['white']*(len(f) + len(n))[br] labels = nx.get_edge_attributes(G, 'label')[br] nx.draw_networkx_edge_labels(G, pos, edge_labels=labels,[br] font_family='IPAexGothic',font_size=10,rotate = False,verticalalignment='baseline')[br] nx.draw_networkx(G,pos,node_color=colorList,edge_color ='green',font_size=10,[br] verticalalignment='center',arrowsize=15)[br] plt.show()[br][br]# グラフの設定と実行===============================================================[br]x,X,P,invP=makePs([[1, 1, 1],[1, 0, 1],[1, 0, 0]])[br]Ag=makeS3()[br]Bg=makeB(P,invP,Ag)[br]print("Ag:")[br]for item in Ag:[br] print(item)[br]print("Bg:")[br]for item in Bg:[br] print(item)[br]f = [f"x{x}",f"X{X}"][br]n = ["f(x)","f(X)"][br]funcs=["A", f"P{P}", "B", f"1/P{invP}"][br]f.reverse()[br]n.reverse()[br]E = [(f[1],n[1], {'label':funcs[0]}),(f[1],f[0], {'label': funcs[1]}),(f[0],n[0], {'label':funcs[2]}),(n[0],n[1], {'label':funcs[3]})][br]kakanzushiki(f,n,funcs,E)[br]