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