数学建模社区-数学中国

标题: 求助 用mathematica编一个求任意整数矩阵的smith标准形 [打印本页]

作者: firlimin    时间: 2008-4-18 22:17
标题: 求助 用mathematica编一个求任意整数矩阵的smith标准形
跪求用mathematica求任意整数矩阵A的smith标准形

算法为(1)找出A的元素中的最大公约数
(2)将它调到(1,1)位置上去
(3)使第一行和第一列的所有其他元素都为零
这可用基本行或列来变换:
交换两行(列)
一行(列)减去另一行(列)的整数倍
这样得到矩阵B,置S11=b11,对(m-1)x(n-1)的矩阵[bij]重复以上算法,重复r次就可得到smith标准形.
This topic gives a version of the Gauss elimination algorithm for a commutative principal ideal domain which is usually described only for a field.

Let be a -matrix with entries from a commutative principal ideal domain . For denotes the number of prime factors of . Start with and choose to be the smallest column index of with a non-zero entry.

(I)
If and , exchange rows 1 and .
(II)
If there is an entry at position such that , then set and choose such that
) z) {& t4 F5 \


By left-multiplication with an appropriate matrix it can be achieved that row 1 of the matrix product is the sum of row 1 multiplied by and row multiplied by . Then we get at position , where . Repeating these steps one obtains a matrix having an entry at position that divides all entries in column .
(III)
Finally, adding appropriate multiples of row , it can be achieved that all entries in column except for that at position are zero. This can be achieved by left-multiplication with an appropriate matrix.
Applying the steps described above to the remaining non-zero columns of the resulting matrix (if any), we get an -matrix with column indices where , each of which satisfies the following:
the entry at position is non-zero;
all entries below and above position as well as entries left of are zero.
Furthermore, all rows below the -th row are zero.
Now we can re-order the columns of this matrix so that elements on positions for are nonzero and for ; and all columns right of the -th column (if present) are zero. For short set for the element at position . has non-negative integer values; so is equivalent to being a unit of . can either happen if and differ by a unit factor, or if they are relatively prime. In the latter case one can add column to column (which doesn't change and then apply appropriate row manipulations to get . And for and one can apply step (II) after adding column to column . This diminishes the minimum -values for non-zero entries of the matrix, and by reordering columns etc. we end up with a matrix whose diagonal elements satisfy .

Since all row and column manipulations involved in the process are invertible, this shows that there exist invertible and -matrices so that is



This is the Smith normal form of the matrix. The elements are unique up to associates and are called elementary divisors

有没有谁能够根据上述算法,将程序编出来.............
谢谢!!!!!!!

作者: toniby1978    时间: 2008-12-15 17:43
标题: 留个脚印

& p5 r' `2 o; f9 {$ e' r; C
) a0 W1 @9 l& W! f* h5 W6 O( N
$ B% f" ~* x- `. }+ n/ e6 j+ f% v" j) M" q- f
  F$ s4 F. _. o+ W7 G7 C$ m

5 Q; t& i' C, O( D. r- B; ]! d
7 K+ U0 y* K! }2 u/ C' x( ~
& M; I( X6 {( R; G: Q. z) e% h
( m' l: t% t6 `! V7 C1 j9 G
2 U7 o+ y2 h% g/ ?" ?
! v2 {9 Y3 f* C4 w) k
5 `) J0 [4 U0 i! i# d/ q5 H  c

& }0 X6 S- C: A- E. P6 e/ Q$ N! X4 @# d2 O3 K% |, l4 r, Q) H

# k) j5 |' B% [4 ^$ Z; h8 k
8 O* M5 \: c1 r) e
3 D+ W$ \+ z  ]/ Y4 M) u( I4 k0 E/ T0 y; i, q

7 S" ~2 x, F$ z. }% u( [
  R2 C3 N3 Q0 [% Y8 ?, g% f
  F0 ]8 J0 ?6 I0 j" r1 U5 ], t1 L* Q# D! ^* M) D- _" R+ r( Y

9 M( t* _; }& j( k
; J5 C1 j. e% V2 O$ p: i
4 L. K; N1 \' s8 E天下风云出我辈, 一入江湖岁月催。 皇图霸业谈笑中, 不胜人生一场醉。  D0 H$ J+ l' _5 g! o" [4 p
专业
深圳SEO服务:百度优化,Google优化,深圳SEO优化,注册香港公司SEO优化




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5