Use the Smith Decomposition to Analyze a Lattice
Consider the lattice generated by integer multiples of the vectors
and
.
In[1]:=
data:image/s3,"s3://crabby-images/26e4c/26e4c51891211238e14b3a0966476e1e66277c6b" alt="Click for copyable input"
b1 = {3, -3};
b2 = {2, 1};
In[2]:=
data:image/s3,"s3://crabby-images/ed4af/ed4af423187451539b3cee9d75cfe6d2f2f6eb98" alt="Click for copyable input"
ptsb = Flatten[Table[j b1 + k b2, {j, -12, 12}, {k, -12, 12}], 1];
In[3]:=
data:image/s3,"s3://crabby-images/67296/67296046016018f2a8c0735be4d4e250e44320b6" alt="Click for copyable input"
graphicsb =
Graphics[{Blue, PointSize[Large], Point@ptsb}, PlotRange -> 10,
Axes -> True]
Out[3]=
data:image/s3,"s3://crabby-images/0642a/0642a0df8e65df8b2562b9d7b956bd2529c1feef" alt=""
Let be the matrix whose rows are
and
.
In[4]:=
data:image/s3,"s3://crabby-images/3c0fa/3c0fa1882b4ac49c74e72aa7e09f7df096e3b429" alt="Click for copyable input"
m = {b1, b2};
The Smith decomposition gives three matrices that satisfy the identity .
In[5]:=
data:image/s3,"s3://crabby-images/ce238/ce238f36c6010136beaf354b03d1494f7a6c51d4" alt="Click for copyable input"
{u, r, v} = SmithDecomposition[m];
In[6]:=
data:image/s3,"s3://crabby-images/b9f49/b9f49a1bcd21f8067da5ecb9b0439fcaa6df23e4" alt="Click for copyable input"
u.m.v == r
Out[6]=
data:image/s3,"s3://crabby-images/2fa5b/2fa5bb0330771ce9e7c30eca4fc1813110d2fa24" alt=""
The matrices and
have integer entries and determinant one.
In[7]:=
data:image/s3,"s3://crabby-images/eb6d5/eb6d5581b3b0ed0d34a01a9fa42591e656f3351a" alt="Click for copyable input"
{u // MatrixForm, v // MatrixForm, Det[u], Det[v]}
Out[7]=
data:image/s3,"s3://crabby-images/9b54c/9b54cd1501a1c06649af97414823763327a77a36" alt=""
The matrix is integer and diagonal. From its entries it can be seen that the structure of the group
is
or simply
, as
is the trivial group.
In[8]:=
data:image/s3,"s3://crabby-images/6dd30/6dd302391ffc4453fc48969de24b43fe4bcac016" alt="Click for copyable input"
r // MatrixForm
Out[8]//MatrixForm=
data:image/s3,"s3://crabby-images/4ffac/4ffac9ac4c751dbb6d1845681f81f1d191d19c06" alt=""
Multiplying the identity on the right by
gives
. Because
is integer and determinant
,
generates the same lattice as
but is simpler.
In[9]:=
data:image/s3,"s3://crabby-images/e14e7/e14e79845387d8e14412c67a7bcef0156de7476b" alt="Click for copyable input"
g = r.Inverse[v];
g // MatrixForm
Out[9]//MatrixForm=
data:image/s3,"s3://crabby-images/9f321/9f321cc71e64ce554a6f61376ce433ac5da55949" alt=""
Visualize the lattice generated by the rows of .
In[10]:=
data:image/s3,"s3://crabby-images/3a31f/3a31fbfb7783cfc16f5114843095e2fe022eb9f9" alt="Click for copyable input"
ptsg = Flatten[
Table[j First[g] + k Last[g], {j, -12, 12}, {k, -12, 12}], 1];
In[11]:=
data:image/s3,"s3://crabby-images/c2fb4/c2fb438ae4cc5feb92f85d5b31a0e27baaf22691" alt="Click for copyable input"
graphicsg =
Graphics[{Red, PointSize[Medium], Point@ptsg}, PlotRange -> 10,
Axes -> True]
Out[11]=
data:image/s3,"s3://crabby-images/ba9b8/ba9b8f1660217e05597246cad982790f775ad4a6" alt=""
Superimposing the new lattice on the original confirms that they are the same.
In[12]:=
data:image/s3,"s3://crabby-images/ca379/ca379d99183da5ebabd3c6c2df126cee312a5fab" alt="Click for copyable input"
Show[{graphicsb, graphicsg}]
Out[12]=
data:image/s3,"s3://crabby-images/afb5d/afb5da08652a63c4f2634bfba21c755fb7748218" alt=""