AbstractNumberVector.st
author Stefan Vogel <sv@exept.de>
Sun, 14 Feb 2016 17:08:04 +0100
changeset 19220 b2b3ad682045
parent 19029 0b7682f30ead
child 19228 f2f3abaadcb4
child 19921 a8c0dde1075e
permissions -rw-r--r--
#FEATURE class: AbstractNumberVector comment/format in: #primAddScalar: changed: #length #squaredLength mark as aobsolete
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
19029
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
    14
"{ NameSpace: Smalltalk }"
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
    15
14026
d72d69757a61 class definition
Claus Gittinger <cg@exept.de>
parents: 13824
diff changeset
    16
UninterpretedBytes subclass:#AbstractNumberVector
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
	instanceVariableNames:''
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
	classVariableNames:''
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	poolDictionaries:''
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	category:'Collections-Arrayed'
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
!AbstractNumberVector class methodsFor:'documentation'!
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
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
 COPYRIGHT (c) 2011 by Claus Gittinger
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
              All Rights Reserved
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
 This software is furnished under a license and may be used
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
 only in accordance with the terms of that license and with the
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 inclusion of the above copyright notice.   This software may not
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
 be provided or otherwise made available to, or used by, any
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
 other person.  No title to or ownership of the software is
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
 hereby transferred.
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
documentation
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
    abstract superclass for all direct storing number vector classes
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    (float, double, integer arrays)
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
    Mostly to share double dispatch code.
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
"
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
! !
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
17197
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    48
!AbstractNumberVector methodsFor:'arithmetic'!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    49
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    50
* anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    51
    "return the product of the receiver and the argument.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    52
     The argument may either be a scalar or another vector"
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
    ^ self clone *= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    55
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    56
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    57
     #(1 2 3 4) asFloatArray * 3
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    58
     #(1 2 3 4) asFloatArray * #(1 2 3 4) asFloatArray
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    61
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    62
+ anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    63
    "return the sum of the receiver and the argument.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    64
     The argument may either be a scalar or another vector"
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
    ^ self clone += anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    67
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    68
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    69
     #(1 2 3 4) asFloatArray + 3
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    70
     #(1 2 3 4) asFloatArray + #(1 2 3 4) asFloatArray
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    73
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    74
- anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    75
    "return the difference of the receiver and the argument.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    76
     The argument may either be a scalar or another vector"
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
    ^ self clone -= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    79
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    80
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    81
     #(1 2 3 4) asFloatArray - 3
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    82
     #(1 2 3 4) asFloatArray - #(1 2 3 4) asFloatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    83
    "
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
    "Created: / 30-05-2007 / 17:41:46 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    86
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    87
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    88
/ anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    89
    "return the division of the receiver and the argument.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    90
     The argument may either be a scalar or another vector"
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
    ^ self clone /= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    93
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    94
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    95
     #(1 2 3 4) asFloatArray / 3
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    96
     #(1 2 3 4) asFloatArray / #(1 2 3 4) asFloatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
    97
    "
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
    "Created: / 30-05-2007 / 17:46:05 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   100
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   101
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   102
abs
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   103
    "return a new vector containing absolute values.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   104
     The receiver is unchanged"
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
    ^ self clone primAbs
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   107
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   108
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   109
     #( -1 2 -3 4 -5 6 -7 8) abs.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   110
     #( -1 2 -3 4 -5 6 -7 8) asFloatArray abs. 
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   113
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   114
negated
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   115
    "return a new vector containing negated values. 
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   116
     The receiver is unchanged"
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
    ^ self clone primNegated
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   119
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   120
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   121
     #( -1 2 -3 4 -5 6 -7 8) negated.     
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   122
     #( -1 2 -3 4 -5 6 -7 8) asFloatArray negated. 
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   123
    "
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
    "Modified: / 30-05-2007 / 17:51:47 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   126
! !
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
!AbstractNumberVector methodsFor:'arithmetic destructive'!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   129
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   130
*= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   131
    "multiply the argument into the receiver (destructive).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   132
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   133
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   134
    ^ anObject isNumber
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   135
	    ifTrue:[self primMulScalar: anObject asFloat]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   136
	    ifFalse:[self primMulArray: anObject]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   137
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|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   140
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   141
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   142
     f *= 3.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   143
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   144
    "
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|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   147
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   148
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   149
     f *= #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   150
     f
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   153
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   154
+= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   155
    "add the argument into the receiver (destructive).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   156
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   157
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   158
    ^ anObject isNumber
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   159
	    ifTrue:[self primAddScalar: anObject asFloat]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   160
	    ifFalse:[self primAddArray: anObject]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   161
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|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   164
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   165
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   166
     f += 3.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   167
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   168
    "
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|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   171
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   172
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   173
     f += #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   174
     f
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   177
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   178
-= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   179
    "subtract the argument from the receiver (destructive).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   180
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   181
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   182
    ^ anObject isNumber
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   183
	    ifTrue:[self primSubtractScalar: anObject asFloat]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   184
	    ifFalse:[self primSubtractArray: anObject]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   185
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|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   188
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   189
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   190
     f -= 3.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   191
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   192
    "
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|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   195
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   196
     f := #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   197
     f += #(1 2 3 4) asFloatArray.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   198
     f
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   199
    "
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
    "Created: / 30-05-2007 / 17:42:13 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   202
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   203
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   204
/= anObject
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   205
    "divide the argument into the receiver (destructive).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   206
     The argument may either be a scalar or another vector"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   207
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   208
    ^ anObject isNumber
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   209
	    ifTrue:[self primDivScalar: anObject asFloat]
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   210
	    ifFalse:[self primDivArray: anObject]
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
    "Modified: / 30-05-2007 / 17:45:46 / cg"
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   213
! !
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
!AbstractNumberVector methodsFor:'destructive arithmetic support'!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   216
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   217
primAbs
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   218
    "low performance fall back: destructive replace each element by its absolute value"
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
    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
   221
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   222
    "
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   223
     |f|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   224
     f := FloatArray withAll:#(-1 2 -3 4 -5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   225
     Transcript showCR:f.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   226
     Transcript showCR:f abs.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   227
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   228
     |i|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   229
     i := SignedIntegerArray withAll:#(-1 2 -3 4 -5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   230
     Transcript showCR:i.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   231
     Transcript showCR:i abs.
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   234
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   235
primAddArray: floatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   236
    "low performance fallback: destructively add the vector argument into the receiver.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   237
     The argument must be another vector"
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
    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
   240
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 f2|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   243
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   244
     f1 := FloatArray withAll:#(1 2 3 4 5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   245
     f2 := FloatArray withAll:#(2 2 2 3 3).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   246
     f1 += f2.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   247
     f1
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   250
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   251
primAddScalar: aScalar
19220
b2b3ad682045 #FEATURE
Stefan Vogel <sv@exept.de>
parents: 19029
diff changeset
   252
    "low performance fallback: destructively add the scalar argument into the receiver."
17197
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
    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
   255
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   256
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   257
primDivArray: floatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   258
    "low performance fallback: destructively divide the vector argument into the receiver.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   259
     The argument must be another vector"
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
    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
   262
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 f2|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   265
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   266
     f1 := FloatArray withAll:#(1 2 3 4 5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   267
     f2 := FloatArray withAll:#(2 2 2 3 3).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   268
     f1 /= f2.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   269
     f1
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   272
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   273
primDivScalar: aScalar
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   274
    "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
   275
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   276
    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
   277
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   278
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   279
primMulArray: floatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   280
    "low performance fallback: destructively multiply the vector argument into the receiver.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   281
     The argument must be another vector"
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
    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
   284
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 f2|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   287
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   288
     f1 := FloatArray withAll:#(1 2 3 4 5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   289
     f2 := FloatArray withAll:#(2 2 2 3 3).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   290
     f1 *= f2.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   291
     f1
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   294
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   295
primMulScalar: aScalar
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   296
    "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
   297
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   298
    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
   299
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   300
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   301
primNegated
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   302
    "low performance fallback: destructively negative value of each element"
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
    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
   305
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|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   308
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   309
     f := FloatArray withAll:#(-1 2 -3 4 -5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   310
     f negated.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   311
     f
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   314
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   315
primSubtractArray: floatArray
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   316
    "low performance fallback: destructively subtract the vector argument into the receiver.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   317
     The argument must be another vector"
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
    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
   320
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 f2|
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   323
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   324
     f1 := FloatArray withAll:#(1 2 3 4 5).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   325
     f2 := FloatArray withAll:#(2 2 2 3 3).
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   326
     f1 -= f2.
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   327
     f1
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
!
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   330
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   331
primSubtractScalar: aScalar
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   332
    "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
   333
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   334
    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
   335
! !
ef67b8f2437e class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 17163
diff changeset
   336
15934
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   337
!AbstractNumberVector methodsFor:'queries'!
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   338
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   339
absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   340
    "return the largest absolute value"
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|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   343
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   344
    minMax := self minMax.
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   345
    ^ (minMax at:1) abs max:(minMax at:2) abs
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   346
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|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   349
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   350
     f1 := (1 to:1000) asFloatArray.
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   351
     Time millisecondsToRun:[ 1000 timesRepeat:[ f1 absMax ] ]
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
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|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   356
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   357
     f1 := FloatArray withAll:#(1 2 3 4 5).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   358
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   359
    "
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|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   362
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   363
     f1 := FloatArray withAll:#(5 4 3 2 1).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   364
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   365
    "
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|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   368
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   369
     f1 := FloatArray withAll:#(5 -4 3 2 1).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   370
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   371
    "
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|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   374
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   375
     f1 := FloatArray withAll:#(5 -5 3 2 1).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   376
     f1 absMax
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   377
    "
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|
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   380
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   381
     f1 := FloatArray withAll:#(5 -6 3 2 1).
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   382
     f1 absMax
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
! !
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
!AbstractNumberVector methodsFor:'vector arithmetic'!
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   387
17163
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   388
length
19220
b2b3ad682045 #FEATURE
Stefan Vogel <sv@exept.de>
parents: 19029
diff changeset
   389
    <resource: #obsolete>
17163
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   390
    "Return the length of the receiver interpreted as vector
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   391
     (that is the length of the vector from 0.0 @ 0.0 @ ... @ 0.0
19029
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   392
      to the point in the n-dimensional space represented by the receiver).
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   393
     Obsolete: the name 'length' may lead to confusion.
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   394
               therefore renamed to vectorLength"
17163
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   395
19029
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   396
    self obsoleteMethodWarning:'use vectorLength'.
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   397
    ^ self squaredVectorLength sqrt
17163
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   398
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   399
    "
19029
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   400
     #(10.0 10.0) asFloatArray vectorLength
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   401
     #(10.0 10.0 10.0) asFloatArray vectorLength
17163
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   402
    "
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   403
!
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   404
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   405
squaredLength
19220
b2b3ad682045 #FEATURE
Stefan Vogel <sv@exept.de>
parents: 19029
diff changeset
   406
    <resource: #obsolete>
19029
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   407
    "Return the squared length of the receiver interpreted as vector.
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   408
     Obsolete: the name 'squaredLength' may lead to confusion.
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   409
               therefore renamed to squaredVectorLength"
17163
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   410
19029
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   411
    self obsoleteMethodWarning:'use squaredVectorLength'.
17163
506b7f2ef014 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 15934
diff changeset
   412
    ^ self dot: self
15934
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   413
! !
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   414
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   415
!AbstractNumberVector class methodsFor:'documentation'!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   416
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   417
version
19029
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   418
    ^ '$Header$'
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   419
!
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   420
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   421
version_CVS
19029
0b7682f30ead #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17197
diff changeset
   422
    ^ '$Header$'
13824
95e857e60462 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   423
! !
15934
2ac38e84aab5 class: AbstractNumberVector
Claus Gittinger <cg@exept.de>
parents: 14026
diff changeset
   424