AbstractNumberVector.st
author Stefan Vogel <sv@exept.de>
Mon, 22 Jun 2015 11:24:02 +0200
changeset 18494 41f8a86105f0
parent 17197 ef67b8f2437e
child 18120 e3a375d5f6a8
child 19029 0b7682f30ead
permissions -rw-r--r--
class: UnixOperatingSystem changed: #syncFileSystem: disable - defined only in glibc 2.14, but we need to support glibc 2.12
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
 COPYRIGHT (c) 2011 by Claus Gittinger
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
              All Rights Reserved
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
 This software is furnished under a license and may be used
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 hereby transferred.
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
"{ Package: 'stx:libbasic' }"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
14026
d72d69757a61 class definition
Claus Gittinger <cg@exept.de>
parents: 13824
diff changeset
    14
UninterpretedBytes subclass:#AbstractNumberVector
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
	instanceVariableNames:''
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
	classVariableNames:''
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
	poolDictionaries:''
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
	category:'Collections-Arrayed'
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
!AbstractNumberVector class methodsFor:'documentation'!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
copyright
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
 COPYRIGHT (c) 2011 by Claus Gittinger
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
              All Rights Reserved
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
 This software is furnished under a license and may be used
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
 only in accordance with the terms of that license and with the
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
 be provided or otherwise made available to, or used by, any
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 other person.  No title to or ownership of the software is
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
 hereby transferred.
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
documentation
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
    abstract superclass for all direct storing number vector classes
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
    (float, double, integer arrays)
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    Mostly to share double dispatch code.
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
! !
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
17197
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    46
!AbstractNumberVector methodsFor:'arithmetic'!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    47
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    48
* anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    49
    "return the product of the receiver and the argument.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    50
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    51
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    52
    ^ self clone *= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    53
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    54
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    55
     #(1 2 3 4) asFloatArray * 3
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    56
     #(1 2 3 4) asFloatArray * #(1 2 3 4) asFloatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    57
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    58
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    59
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    60
+ anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    61
    "return the sum of the receiver and the argument.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    62
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    63
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    64
    ^ self clone += anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    65
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    66
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    67
     #(1 2 3 4) asFloatArray + 3
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    68
     #(1 2 3 4) asFloatArray + #(1 2 3 4) asFloatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    69
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    70
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    71
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    72
- anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    73
    "return the difference of the receiver and the argument.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    74
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    75
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    76
    ^ self clone -= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    77
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    78
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    79
     #(1 2 3 4) asFloatArray - 3
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    80
     #(1 2 3 4) asFloatArray - #(1 2 3 4) asFloatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    81
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    82
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    83
    "Created: / 30-05-2007 / 17:41:46 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    84
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    85
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    86
/ anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    87
    "return the division of the receiver and the argument.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    88
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    89
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    90
    ^ self clone /= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    91
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    92
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    93
     #(1 2 3 4) asFloatArray / 3
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    94
     #(1 2 3 4) asFloatArray / #(1 2 3 4) asFloatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    95
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    96
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    97
    "Created: / 30-05-2007 / 17:46:05 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    98
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    99
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   100
abs
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   101
    "return a new vector containing absolute values.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   102
     The receiver is unchanged"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   103
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   104
    ^ self clone primAbs
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   105
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   106
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   107
     #( -1 2 -3 4 -5 6 -7 8) abs.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   108
     #( -1 2 -3 4 -5 6 -7 8) asFloatArray abs. 
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   109
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   110
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   111
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   112
negated
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   113
    "return a new vector containing negated values. 
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   114
     The receiver is unchanged"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   115
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   116
    ^ self clone primNegated
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   117
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   118
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   119
     #( -1 2 -3 4 -5 6 -7 8) negated.     
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   120
     #( -1 2 -3 4 -5 6 -7 8) asFloatArray negated. 
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   121
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   122
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   123
    "Modified: / 30-05-2007 / 17:51:47 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   124
! !
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   125
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   126
!AbstractNumberVector methodsFor:'arithmetic destructive'!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   127
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   128
*= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   129
    "multiply the argument into the receiver (destructive).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   130
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   131
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   132
    ^ anObject isNumber
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   133
	    ifTrue:[self primMulScalar: anObject asFloat]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   134
	    ifFalse:[self primMulArray: anObject]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   135
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   136
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   137
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   138
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   139
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   140
     f *= 3.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   141
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   142
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   143
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   144
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   145
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   146
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   147
     f *= #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   148
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   149
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   150
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   151
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   152
+= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   153
    "add the argument into the receiver (destructive).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   154
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   155
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   156
    ^ anObject isNumber
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   157
	    ifTrue:[self primAddScalar: anObject asFloat]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   158
	    ifFalse:[self primAddArray: anObject]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   159
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   160
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   161
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   162
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   163
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   164
     f += 3.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   165
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   166
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   167
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   168
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   169
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   170
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   171
     f += #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   172
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   173
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   174
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   175
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   176
-= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   177
    "subtract the argument from the receiver (destructive).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   178
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   179
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   180
    ^ anObject isNumber
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   181
	    ifTrue:[self primSubtractScalar: anObject asFloat]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   182
	    ifFalse:[self primSubtractArray: anObject]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   183
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   184
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   185
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   186
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   187
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   188
     f -= 3.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   189
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   190
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   191
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   192
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   193
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   194
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   195
     f += #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   196
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   197
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   198
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   199
    "Created: / 30-05-2007 / 17:42:13 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   200
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   201
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   202
/= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   203
    "divide the argument into the receiver (destructive).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   204
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   205
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   206
    ^ anObject isNumber
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   207
	    ifTrue:[self primDivScalar: anObject asFloat]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   208
	    ifFalse:[self primDivArray: anObject]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   209
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   210
    "Modified: / 30-05-2007 / 17:45:46 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   211
! !
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   212
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   213
!AbstractNumberVector methodsFor:'destructive arithmetic support'!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   214
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   215
primAbs
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   216
    "low performance fall back: destructive replace each element by its absolute value"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   217
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   218
    1 to: self size do:[:i| self at: i put: (self at: i) abs].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   219
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   220
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   221
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   222
     f := FloatArray withAll:#(-1 2 -3 4 -5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   223
     Transcript showCR:f.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   224
     Transcript showCR:f abs.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   225
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   226
     |i|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   227
     i := SignedIntegerArray withAll:#(-1 2 -3 4 -5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   228
     Transcript showCR:i.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   229
     Transcript showCR:i abs.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   230
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   231
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   232
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   233
primAddArray: floatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   234
    "low performance fallback: destructively add the vector argument into the receiver.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   235
     The argument must be another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   236
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   237
    1 to: self size do:[:i| self at: i put: (self at: i) + (floatArray at: i)].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   238
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   239
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   240
     |f1 f2|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   241
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   242
     f1 := FloatArray withAll:#(1 2 3 4 5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   243
     f2 := FloatArray withAll:#(2 2 2 3 3).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   244
     f1 += f2.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   245
     f1
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   246
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   247
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   248
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   249
primAddScalar: aScalar
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   250
    "low performace fallback: destructively add the scalar argument into the receiver."
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   251
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   252
    1 to: self size do:[:i| self at: i put: (self at: i) + aScalar].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   253
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   254
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   255
primDivArray: floatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   256
    "low performance fallback: destructively divide the vector argument into the receiver.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   257
     The argument must be another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   258
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   259
    1 to: self size do:[:i| self at: i put: (self at: i) / (floatArray at: i)].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   260
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   261
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   262
     |f1 f2|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   263
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   264
     f1 := FloatArray withAll:#(1 2 3 4 5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   265
     f2 := FloatArray withAll:#(2 2 2 3 3).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   266
     f1 /= f2.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   267
     f1
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   268
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   269
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   270
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   271
primDivScalar: aScalar
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   272
    "low performace fallback: destructively divide each element of the receiver by the scalar argument."
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   273
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   274
    1 to: self size do:[:i| self at: i put: (self at: i) / aScalar ].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   275
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   276
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   277
primMulArray: floatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   278
    "low performance fallback: destructively multiply the vector argument into the receiver.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   279
     The argument must be another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   280
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   281
    1 to: self size do:[:i| self at: i put: (self at: i) * (floatArray at: i)].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   282
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   283
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   284
     |f1 f2|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   285
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   286
     f1 := FloatArray withAll:#(1 2 3 4 5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   287
     f2 := FloatArray withAll:#(2 2 2 3 3).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   288
     f1 *= f2.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   289
     f1
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   290
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   291
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   292
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   293
primMulScalar: aScalar
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   294
    "low performace fallback: destructively multiply each element of the receiver by the scalar argument."
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   295
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   296
    1 to: self size do:[:i| self at: i put: (self at: i) * aScalar ].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   297
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   298
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   299
primNegated
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   300
    "low performance fallback: destructively negative value of each element"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   301
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   302
    1 to: self size do:[:i| self at: i put: (self at: i) negated].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   303
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   304
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   305
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   306
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   307
     f := FloatArray withAll:#(-1 2 -3 4 -5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   308
     f negated.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   309
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   310
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   311
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   312
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   313
primSubtractArray: floatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   314
    "low performance fallback: destructively subtract the vector argument into the receiver.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   315
     The argument must be another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   316
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   317
    1 to: self size do:[:i| self at: i put: (self at: i) - (floatArray at: i)].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   318
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   319
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   320
     |f1 f2|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   321
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   322
     f1 := FloatArray withAll:#(1 2 3 4 5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   323
     f2 := FloatArray withAll:#(2 2 2 3 3).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   324
     f1 -= f2.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   325
     f1
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   326
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   327
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   328
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   329
primSubtractScalar: aScalar
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   330
    "low performace fallback: destructively subtract the scalar argument from each element of the receiver."
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   331
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   332
    1 to: self size do:[:i| self at: i put: (self at: i) - aScalar ].
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   333
! !
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   334
15934
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   335
!AbstractNumberVector methodsFor:'queries'!
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   336
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   337
absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   338
    "return the largest absolute value"
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   339
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   340
    |minMax|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   341
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   342
    minMax := self minMax.
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   343
    ^ (minMax at:1) abs max:(minMax at:2) abs
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   344
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   345
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   346
     |f1|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   347
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   348
     f1 := (1 to:1000) asFloatArray.
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   349
     Time millisecondsToRun:[ 1000 timesRepeat:[ f1 absMax ] ]
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   350
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   351
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   352
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   353
     |f1|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   354
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   355
     f1 := FloatArray withAll:#(1 2 3 4 5).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   356
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   357
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   358
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   359
     |f1|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   360
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   361
     f1 := FloatArray withAll:#(5 4 3 2 1).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   362
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   363
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   364
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   365
     |f1|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   366
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   367
     f1 := FloatArray withAll:#(5 -4 3 2 1).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   368
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   369
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   370
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   371
     |f1|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   372
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   373
     f1 := FloatArray withAll:#(5 -5 3 2 1).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   374
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   375
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   376
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   377
     |f1|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   378
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   379
     f1 := FloatArray withAll:#(5 -6 3 2 1).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   380
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   381
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   382
! !
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   383
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   384
!AbstractNumberVector methodsFor:'vector arithmetic'!
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   385
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   386
dot:aFloatVector
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   387
    "Return the dot product of the receiver and the argument.
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   388
     Fail if the argument is not of the same size as the receiver."
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   389
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   390
    |mySize result|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   391
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   392
    mySize := self size.
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   393
    mySize = aFloatVector size ifFalse:[^self error:'Must be of equal size'].
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   394
    result := 0.0.
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   395
    1 to: mySize do:[:i|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   396
        result := result + ((self at: i) * (aFloatVector at: i)).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   397
    ].
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   398
    ^result
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   399
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   400
    "
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   401
     |v|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   402
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   403
     v := #(2.0 2.0 1.0) asDoubleArray.
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   404
     v dot:v.            
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   405
    "
17163
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   406
!
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   407
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   408
length
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   409
    "Return the length of the receiver interpreted as vector
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   410
     (that is the length of the vector from 0.0 @ 0.0 @ ... @ 0.0
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   411
      to the point in the n-dimensional space represented by the receiver)"
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   412
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   413
    ^ self squaredLength sqrt
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   414
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   415
    "
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   416
     #(10.0 10.0) asFloatArray length
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   417
     #(10.0 10.0 10.0) asFloatArray length
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   418
    "
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   419
!
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   420
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   421
squaredLength
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   422
    "Return the squared length of the receiver interpreted as vector"
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   423
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   424
    ^ self dot: self
15934
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   425
! !
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   426
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   427
!AbstractNumberVector class methodsFor:'documentation'!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   429
version
17197
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   430
    ^ '$Header: /cvs/stx/stx/libbasic/AbstractNumberVector.st,v 1.5 2014-12-08 17:29:27 cg Exp $'
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   431
!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   432
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   433
version_CVS
17197
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   434
    ^ '$Header: /cvs/stx/stx/libbasic/AbstractNumberVector.st,v 1.5 2014-12-08 17:29:27 cg Exp $'
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   435
! !
15934
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   436