Matrix3_3.st
author Claus Gittinger <cg@exept.de>
Tue, 20 Aug 2019 15:10:57 +0200
changeset 5087 2d85f44acc3e
child 5111 ab3d7db395d2
permissions -rw-r--r--
initial checkin
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5087
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"{ Package: 'stx:libbasic2' }"
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"{ NameSpace: Smalltalk }"
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
SquareMatrix variableSubclass:#Matrix3_3
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
	instanceVariableNames:''
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
	classVariableNames:''
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	poolDictionaries:''
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
	category:'Collections-MultiDimensional'
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
!
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
!Matrix3_3 class methodsFor:'documentation'!
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
documentation
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
"
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
    3x3 Matrix (2 dimensions).
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
    Especially useful with the ArrayIndexing-Parser extension.
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
    [author:]
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
        Claus Gittinger (cg@sinir)
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
    [instance variables:]
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
    [class variables:]
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
    [see also:]
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
        MultiDimensionalArrayAccessor
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
"
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
! !
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
!Matrix3_3 class methodsFor:'instance creation'!
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
new
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
    ^ self basicNew:3*3
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
! !
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
!Matrix3_3 methodsFor:'accessing'!
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
_at:index1 at:index2
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
    "this is a synthetic selector, generated by the compiler,
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
     if a construct of the form expr[idx...] is parsed.
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
     I.e. 
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
        foo[n,m]
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
     generates
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
        foo _at:n at:m
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
    "
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    |idx|
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
    (index1 between:1 and:3) ifFalse:[self subscriptBoundsError:index1].
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
    (index2 between:1 and:3) ifFalse:[self subscriptBoundsError:index2].
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
    idx := index1 * 3 - 3 + index2.
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
    ^ self basicAt:idx.
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
!
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
_at:index1 at:index2 put:value
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
    "this is a synthetic selector, generated by the compiler,
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
     if a construct of the form expr[idx...] := val is parsed.
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
     I.e. 
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
        foo[n,m] := val
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
     generates
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
        foo _at:n at:m put:val
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
    "
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
    |idx|
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
    (index1 between:1 and:3) ifFalse:[self subscriptBoundsError:index1].
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
    (index2 between:1 and:3) ifFalse:[self subscriptBoundsError:index2].
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
    idx := index1 * 3 - 3 + index2.
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
    ^ self basicAt:idx put:value.
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
! !
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
!Matrix3_3 methodsFor:'matrix operations'!
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
determinantByCofactors
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    "Answer the determinant of this matrix."
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
    ^ ((self _at: 1 at: 1) * (((self _at: 2 at: 2)*(self _at: 3 at: 3)) - ((self _at: 3 at: 2)*(self _at: 2 at: 3)))) -
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
      ((self _at: 1 at: 2) * (((self _at: 2 at: 1)*(self _at: 3 at: 3)) - ((self _at: 3 at: 1)*(self _at: 2 at: 3)))) +
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
      ((self _at: 1 at: 3) * (((self _at: 2 at: 1)*(self _at: 3 at: 2)) - ((self _at: 3 at: 1)*(self _at: 2 at: 2)))).
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
! !
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
!Matrix3_3 class methodsFor:'documentation'!
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
version_CVS
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
    ^ '$Header$'
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
! !
2d85f44acc3e initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88