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