Matrix.st
author Claus Gittinger <cg@exept.de>
Tue, 20 Aug 2019 15:00:25 +0200
changeset 5082 dd1fa34053ea
child 5091 5dee87e2266e
permissions -rw-r--r--
initial checkin
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5082
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"{ Package: 'stx:libbasic2' }"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"{ NameSpace: Smalltalk }"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
AbstractMultidimensionalArray variableSubclass:#Matrix
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
	instanceVariableNames:'dimensions'
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
	classVariableNames:''
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	poolDictionaries:''
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
	category:'Collections-MultiDimensional'
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
!Matrix class methodsFor:'documentation'!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
documentation
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
    Generic Matrix with arbitrary number of dimensions.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
    Especially useful with the ArrayIndexing-Parser extension.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
    [author:]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
        Claus Gittinger (cg@sinir)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
    [instance variables:]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
    [class variables:]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
    [see also:]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
        MultiDimensionalArrayAccessor
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
examples
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
  You have to enable the Parsers arrayIndexingExtension support
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
  in order to be able to execute the examples below.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
  Parser allowArrayIndexSyntaxExtension:true
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
                                                                [exBegin]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
    |m|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    m := Matrix[3,3].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
    m[2,1] := 11.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
    m[2,2] := 12.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
    m[2,3] := 13.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
    m     
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
                                                                [exEnd]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
                                                                [exBegin]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
    |m|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
    m := Matrix3_3 new.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
    m[2,1] := 11.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
    m[2,2] := 12.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
    m[2,3] := 13.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
    m       
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
                                                                [exEnd]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
                                                                [exBegin]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
    |m1 m2|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
    m1 := Matrix3_3 new.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
    m1 atAllPut:1.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
    m2 := Matrix3_3 new.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
    m2 atAllPut:2.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
    m1 - m2    
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
                                                                [exEnd]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
                                                                [exBegin]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
    |m1 m2|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
    m1 := Matrix3_3 new.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    m1 atAllPut:1.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
    m2 := Matrix3_3 new.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
    m2 atAllPut:2.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
    m1 + m2    
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
                                                                [exEnd]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
! !
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
!Matrix class methodsFor:'instance creation'!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
_at:nIndices
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
     if a construct of the form expr[idx...] is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
        Matrix[n]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
        Matrix _at: n
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
    ^ Array new:nIndices
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
_at:dim1 at:dim2
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
     if a construct of the form expr[idx...] is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
        Matrix[n,m]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
        Matrix _at:n at:m
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
    ^ self newForRows:dim1 cols:dim2
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
_at:dim1 at:dim2 at:dim3
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
     if a construct of the form expr[idx...] is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
        Matrix[n,m,o]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
        Matrix _at:n at:m at:o
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
    ^ (self basicNew:(dim1 * dim2 * dim3))
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
        dimensions:(Array with:dim1 with:dim2 with:dim3)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
identity: anInteger
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
    "Answer an identity matrix of order 'anInteger@anInteger'."
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
    | mat |
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
    mat := self newForRows:anInteger cols:anInteger.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    mat atAllPut:0.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
    1 to: anInteger do: [ :i | mat _at: i at: i put: 1 ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
    ^ mat
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
     self identity:3
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
     self identity:2
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
     self identity:5
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
newForRows:nRows cols:nCols
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    |mClass|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
    nRows == nCols ifTrue:[
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
        nCols == 2 ifTrue:[
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
            ^ Matrix2_2 new dimensions:#(2 2)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
        ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
        nCols == 3 ifTrue:[
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
            ^ Matrix3_3 new dimensions:#(3 3)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
        ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
        mClass := SquareMatrix
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
    ] ifFalse:[
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
        mClass := self
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
    ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
    ^ (mClass basicNew:(nRows * nCols))
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
        dimensions:(Array with:nRows with:nCols)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
ones: aPoint
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
    "Answer a matrix of order 'aPoint' filled with ones"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
    |mat|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
    mat := self newForRows:aPoint y cols:aPoint x.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
    mat atAllPut: 1.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
    ^ mat
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
     self ones:(3 @ 3)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
     self ones:(3 @ 2)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
     self ones:(5 @ 5)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
zero: aPoint
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
    "Answer a matrix of order 'aPoint' filled with zeros"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
    |mat|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
    mat := self newForRows:aPoint y cols:aPoint x.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
    mat atAllPut: 0.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
    ^ mat
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
     self zero:(3 @ 3)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
     self zero:(3 @ 2)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
     self zero:(5 @ 5)
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
! !
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
!Matrix methodsFor:'accessing'!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
_at:index
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
     if a construct of the form expr[idx...] is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
        foo[n]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
        foo _at: n
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
    dimensions size ~~ 1 ifTrue:[self dimensionError].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
    ^ self basicAt:index.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
_at:index1 at:index2
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
     if a construct of the form expr[idx...] is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
        foo[n,m]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
        foo _at:n at:m
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
    |idx|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
    dimensions size ~~ 2 ifTrue:[self dimensionError].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
    (index1 between:1 and:(dimensions at:1)) ifFalse:[self subscriptBoundsError:index1].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
    (index2 between:1 and:(dimensions at:2)) ifFalse:[self subscriptBoundsError:index2].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
    idx := ((index1-1) * (dimensions at:2)).
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
    idx := idx + index2.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
    ^ self basicAt:idx.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
     |m|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
     m := MultiDimensionalArrayAccessor new
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   227
              collection:
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   228
                #(
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   229
                   11 12 13 14
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
                   21 22 23 24
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
                   31 32 33 34
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
                 )
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   233
              dimensions:
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   234
                #(3 4).
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   235
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
     m[1,4]          
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   237
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   240
_at:index1 at:index2 at:index3
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   242
     if a construct of the form expr[idx...] is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
        foo[n,m,o]
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
        foo _at:n at:m at:o
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   247
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
    |idx|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   249
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   250
    dimensions size ~~ 3 ifTrue:[self dimensionError].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   251
    (index1 between:1 and:(dimensions at:1)) ifFalse:[self subscriptBoundsError:index1].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   252
    (index2 between:1 and:(dimensions at:2)) ifFalse:[self subscriptBoundsError:index2].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   253
    (index3 between:1 and:(dimensions at:3)) ifFalse:[self subscriptBoundsError:index3].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   254
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   255
    idx := ((((index1-1) * (dimensions at:2)) + (index2-1)) * (dimensions at:3)).
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   256
    idx := idx + index3.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
    ^ self basicAt:idx.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
     |m|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
     m := MultiDimensionalArrayAccessor new
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
              collection:
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
                #(
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
                   111 112 113 114
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   265
                   121 122 123 124
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   266
                   131 132 133 134
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
                   211 212 213 214
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
                   221 222 223 224
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
                   231 232 233 234 )
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
              dimensions:
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
                #(2 3 4).
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   273
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   274
     m[2,1,4]          
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   275
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   276
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   277
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
_at:index1 at:index2 at:index3 put:val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   280
     if a construct of the form expr[idx...] := val is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   281
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   282
        foo[n,m,o] := val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   283
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   284
        foo _at:n at:m at:o put:val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   285
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   286
    |idx|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   287
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   288
    dimensions size ~~ 3 ifTrue:[self dimensionError].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   289
    (index1 between:1 and:(dimensions at:1)) ifFalse:[self subscriptBoundsError:index1].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   290
    (index2 between:1 and:(dimensions at:2)) ifFalse:[self subscriptBoundsError:index2].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   291
    (index3 between:1 and:(dimensions at:3)) ifFalse:[self subscriptBoundsError:index3].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   292
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   293
    idx := ((((index1-1) * (dimensions at:2)) + (index2-1)) * (dimensions at:3)).
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
    idx := idx + index3.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   295
    ^ self basicAt:idx put:val.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   296
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   297
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   298
_at:index1 at:index2 put:val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   299
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   300
     if a construct of the form expr[idx...] := val is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   301
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   302
        foo[n,m] := val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   303
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   304
        foo _at:n at:m put:val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   305
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   306
    |idx|
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
    dimensions size ~~ 2 ifTrue:[self dimensionError].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   309
    (index1 between:1 and:(dimensions at:1)) ifFalse:[self subscriptBoundsError:index1].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   310
    (index2 between:1 and:(dimensions at:2)) ifFalse:[self subscriptBoundsError:index2].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   311
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   312
    idx := ((index1-1) * (dimensions at:2)).
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   313
    idx := idx + index2.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   314
    ^ self basicAt:idx put:val.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   315
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   316
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   317
_at:index put:val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   318
    "this is a synthetic selector, generated by the compiler,
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   319
     if a construct of the form expr[idx...] := val is parsed.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   320
     I.e. 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   321
        foo[n] := val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   322
     generates
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   323
        foo _at:n put:val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   324
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   325
    dimensions size ~~ 1 ifTrue:[self dimensionError].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   326
    ^ self basicAt:index put:val.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   327
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   328
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   329
at:index
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   330
    "/ dimensions size ~~ 1 ifTrue:[self dimensionError].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   331
    ^ self basicAt:index.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   332
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   333
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   334
at:index put:val
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   335
    "/ dimensions size ~~ 1 ifTrue:[self dimensionError].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
    ^ self basicAt:index put:val.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   337
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   338
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   339
dimensions
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   340
    ^ dimensions
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   341
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   342
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   343
size
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   344
    ^ self basicSize
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   345
! !
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   346
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
!Matrix methodsFor:'arithmetic'!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   348
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
+ aMatrix
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   350
    "Answer the result of adding 'aMatrix' to this matrix."
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
    ^ aMatrix sumFromMatrix:self
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   353
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   354
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   355
- aMatrix
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   356
    "Answer the result of subtracting 'aMatrix' from this matrix."
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   357
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   358
    ^ aMatrix differenceFromMatrix:self
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   359
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   360
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   361
= aMatrix
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   362
    "Answer true, if the argument represents the same matrix"
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   363
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   364
    self species == aMatrix species ifFalse: [ ^ false ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   365
    dimensions = aMatrix dimensions ifFalse: [ ^ false ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   366
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   367
    1 to: self basicSize do:[ :idx | 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   368
        (aMatrix basicAt: idx) == (self basicAt: idx) ifFalse:[^ false].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   369
    ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   370
    ^ true
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   371
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   372
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   373
differenceFromMatrix: aMatrix
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   374
    "Answer the result of subtracting the receiver from 'aMatrix'."
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   375
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   376
    | result |
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   377
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   378
    dimensions = aMatrix dimensions ifFalse: [ IncompatibleMatrixError signal ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   379
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   380
    result := (self class new:(self basicSize)) dimensions:dimensions.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   381
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   382
    1 to: self basicSize do:[ :idx | 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   383
        result basicAt: idx put: (aMatrix basicAt: idx) - (self basicAt: idx).
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   384
    ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   385
    ^ result
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   386
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   387
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   388
sumFromMatrix: aMatrix
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   389
    "Answer the result of adding 'aMatrix' to this matrix."
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   390
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   391
    | result |
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   392
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   393
    dimensions = aMatrix dimensions ifFalse: [ IncompatibleMatrixError signal ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   394
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   395
    result := (self class new:(self basicSize)) dimensions:dimensions.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   396
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   397
    1 to: self basicSize do:[ :idx | 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   398
        result basicAt: idx put: (self basicAt: idx) + (aMatrix basicAt: idx).
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   399
    ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   400
    ^ result
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   401
! !
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   402
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   403
!Matrix methodsFor:'matrix operations'!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   404
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   405
determinant
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   406
    MatrixError signal: 'Matrix must be square'
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   407
! !
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   408
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   409
!Matrix methodsFor:'private'!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   410
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   411
dimensions:dimensionsArg
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   412
    dimensionsArg isArray ifFalse:[
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   413
        dimensions := Array with:dimensionsArg y with:dimensionsArg x.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   414
    ] ifTrue:[
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   415
        dimensions := dimensionsArg.
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   416
    ].
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   417
! !
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   418
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   419
!Matrix methodsFor:'queries'!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   420
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   421
columns
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   422
    ^ dimensions at:2
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   423
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   424
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   425
isSquare
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   426
    ^ false
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   427
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   429
     (self zero:(3 @ 3)) isSquare
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   430
     (self zero:(2 @ 2)) isSquare
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   431
     (self zero:(3 @ 2)) isSquare 
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   432
    "
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   433
!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   434
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   435
rows
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   436
    ^ dimensions at:1
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   437
! !
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   438
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   439
!Matrix class methodsFor:'documentation'!
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   440
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   441
version_CVS
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   442
    ^ '$Header$'
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   443
! !
dd1fa34053ea initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   444