ArithmeticValue.st
author claus
Thu, 10 Aug 1995 14:32:31 +0200
changeset 379 5b5a130ccd09
parent 345 cf2301210c47
child 384 cc3d110ea879
permissions -rw-r--r--
revision added
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Magnitude subclass:#ArithmeticValue
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:'DivisionByZeroSignal DomainErrorSignal
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    16
			   OverflowSignal UnderflowSignal
345
claus
parents: 326
diff changeset
    17
			   ArithmeticSignal AnyArithmeticSignal
claus
parents: 326
diff changeset
    18
			   UnorderedSignal'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
       category:'Magnitude-Numbers'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    22
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
ArithmeticValue comment:'
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    24
COPYRIGHT (c) 1993 by Claus Gittinger
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    25
	      All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
    26
379
5b5a130ccd09 revision added
claus
parents: 345
diff changeset
    27
$Header: /cvs/stx/stx/libbasic/ArithmeticValue.st,v 1.14 1995-08-10 12:25:41 claus Exp $
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    28
'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    30
!ArithmeticValue class methodsFor:'documentation' !
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    31
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    32
copyright
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    33
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    34
 COPYRIGHT (c) 1993 by Claus Gittinger
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    35
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    36
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    37
 This software is furnished under a license and may be used
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    38
 only in accordance with the terms of that license and with the
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    39
 inclusion of the above copyright notice.   This software may not
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    40
 be provided or otherwise made available to, or used by, any
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    41
 other person.  No title to or ownership of the software is
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    42
 hereby transferred.
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    43
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    44
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    45
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    46
version
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    47
"
379
5b5a130ccd09 revision added
claus
parents: 345
diff changeset
    48
$Header: /cvs/stx/stx/libbasic/ArithmeticValue.st,v 1.14 1995-08-10 12:25:41 claus Exp $
5b5a130ccd09 revision added
claus
parents: 345
diff changeset
    49
$Revision: 1.14 $
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    50
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    51
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    52
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    53
documentation
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    54
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    55
    ArithmeticValue is an abstract superclass for all things responding to
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    56
    arithmetic messages. It was inserted into the hierarchy, to allow objects
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    57
    like matrices, functions etc. to share the arithmetic methods defined here.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    58
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    59
    class variables:
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    60
	ArithmeticSignal        <Signal>        parent of all arithmetic signals
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    61
						(never raised itself)
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    62
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    63
	DomainErrorSignal       <Signal>        raised upon float errors
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    64
						(for example range in trigonometric)
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    65
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    66
	DivisionByZeroSignal    <Signal>        raised when division by 0 is attempted
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    67
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    68
	OverflowSignal          <Signal>        raised on overflow/underflow conditions
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    69
	UnderflowSignal                         in float arithmetic. 
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    70
						Notice: some OperatingSystems do not 
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    71
						provide enough information for ST/X to 
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    72
						extract the real reason for the floatException
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    73
						thus raising DomainErrorSignal in these cases.
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    74
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    75
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
!ArithmeticValue class methodsFor:'initialization' !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
initialize
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
    "setup the signals"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 3
diff changeset
    82
    DomainErrorSignal isNil ifTrue:[
302
1f76060d58a4 *** empty log message ***
claus
parents: 213
diff changeset
    83
	ArithmeticSignal := ErrorSignal newSignalMayProceed:false.
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    84
	ArithmeticSignal nameClass:self message:#arithmeticSignal.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    85
	ArithmeticSignal notifierString:'arithmetic error'.
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    86
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    87
	DomainErrorSignal := ArithmeticSignal newSignalMayProceed:false.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    88
	DomainErrorSignal nameClass:self message:#domainErrorSignal.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    89
	DomainErrorSignal notifierString:'domain error'.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    91
	DivisionByZeroSignal := ArithmeticSignal newSignalMayProceed:false.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    92
	DivisionByZeroSignal nameClass:self message:#divisionByZeroSignal.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    93
	DivisionByZeroSignal notifierString:'division by zero'.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    95
	OverflowSignal := ArithmeticSignal newSignalMayProceed:false.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    96
	OverflowSignal nameClass:self message:#overflowSignal.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    97
	OverflowSignal notifierString:'overflow'.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 3
diff changeset
    98
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
    99
	UnderflowSignal := ArithmeticSignal newSignalMayProceed:false.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   100
	UnderflowSignal nameClass:self message:#underflowSignal.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   101
	UnderflowSignal notifierString:'underflow'.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
345
claus
parents: 326
diff changeset
   103
	UnorderedSignal := ArithmeticSignal newSignalMayProceed:false.
claus
parents: 326
diff changeset
   104
	UnorderedSignal nameClass:self message:#unorderedSignal.
claus
parents: 326
diff changeset
   105
	UnorderedSignal notifierString:'unordered'.
claus
parents: 326
diff changeset
   106
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   107
	AnyArithmeticSignal := SignalSet with:DomainErrorSignal
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   108
					 with:DivisionByZeroSignal
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   109
					 with:OverflowSignal
345
claus
parents: 326
diff changeset
   110
					 with:UnderflowSignal
claus
parents: 326
diff changeset
   111
					 with:UnorderedSignal.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 3
diff changeset
   112
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
345
claus
parents: 326
diff changeset
   115
!ArithmeticValue class methodsFor:'Signal constants' !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
domainErrorSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
    "return the signal which is raised on math errors
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
     (such as log of 0 etc.)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
    ^ DomainErrorSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
divisionByZeroSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
    "return the signal which is raised on division by zero"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
    ^ DivisionByZeroSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
overflowSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
    "return the signal which is raised on overflow conditions (in floats)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
    ^ OverflowSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
underflowSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
    "return the signal which is raised on underflow conditions (in floats)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
a27a279701f8 Initial revision
claus
parents:
diff changeset
   139
    ^ UnderflowSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
345
claus
parents: 326
diff changeset
   142
unorderedSignal
claus
parents: 326
diff changeset
   143
    "return the signal which is raised when numbers are compared, 
claus
parents: 326
diff changeset
   144
     for which no ordering is defined (for example: complex numbers)"
claus
parents: 326
diff changeset
   145
claus
parents: 326
diff changeset
   146
    ^ UnderflowSignal
claus
parents: 326
diff changeset
   147
!
claus
parents: 326
diff changeset
   148
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   149
arithmeticSignal
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   150
    "return the parent of all arithmetic signals"
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   151
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   152
    ^ ArithmeticSignal
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   153
!
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   154
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   155
anyArithmeticSignal
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   156
    "return a signalSet with all possible arithmetic signals.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   157
     OBSOLETE: this will vanish, since starting with 2.10.3, signal parents
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   158
	       have been added."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   159
a27a279701f8 Initial revision
claus
parents:
diff changeset
   160
    ^ AnyArithmeticSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   161
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   162
a27a279701f8 Initial revision
claus
parents:
diff changeset
   163
!ArithmeticValue methodsFor:'converting' !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
degreesToRadians
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
    "interpreting the receiver as radians, return the degrees"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
a27a279701f8 Initial revision
claus
parents:
diff changeset
   168
    ^ self asFloat degreesToRadians
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
a27a279701f8 Initial revision
claus
parents:
diff changeset
   171
radiansToDegrees
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
    "interpreting the receiver as degrees, return the radians"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   173
a27a279701f8 Initial revision
claus
parents:
diff changeset
   174
    ^ self asFloat radiansToDegrees
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   176
a27a279701f8 Initial revision
claus
parents:
diff changeset
   177
asInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   178
    "return an integer with same value - might truncate"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
    ^ self truncated
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
a27a279701f8 Initial revision
claus
parents:
diff changeset
   183
asFloat
a27a279701f8 Initial revision
claus
parents:
diff changeset
   184
    "return a float with same value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   185
a27a279701f8 Initial revision
claus
parents:
diff changeset
   186
   ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   187
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
asFraction
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
    "return a fraction with same value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
   ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
coerce:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
    "convert aNumber into an instance of the receivers class and return it."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
generality
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
    "return a number giving the receivers generality, that number is
a27a279701f8 Initial revision
claus
parents:
diff changeset
   203
     used to convert one of the arguments in a mixed expression. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   204
     The generality has to be defined in subclasses,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
     such that gen(a) > gen(b) iff, conversion of b into a's class 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
     does not cut precision. For example, Integer has 40, Float has 80,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
     meaning that if we convert a Float to an Integer, some precision may
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
     be lost. The generality is used by ArithmeticValue>>retry:cuercing:"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
      
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   211
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   212
a27a279701f8 Initial revision
claus
parents:
diff changeset
   213
retry:aSymbol coercing:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   214
    "arithmetic represented by the binary operator, aSymbol,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   215
    could not be performed with the receiver and the argument, aNumber, 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
    because of the differences in representation.  
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
    Coerce either the receiver or the argument, depending on which has higher 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
    generality, and try again.  
a27a279701f8 Initial revision
claus
parents:
diff changeset
   219
    If the operation is compare for same value (=), return false if
a27a279701f8 Initial revision
claus
parents:
diff changeset
   220
    the argument is not a Number. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
    If the generalities are the same, create an error message, since this
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
    means that a subclass has not been fully implemented."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
    |myGenerality otherGenerality|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
    (aSymbol == #=) ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   227
	(aNumber respondsTo:#generality) ifFalse:[^ false]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
    ] ifFalse:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   229
	(aNumber respondsTo:#generality) ifFalse:[
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   230
	    self error:'retry:coercing: argument is not a number'.
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   231
	    ^ self
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   232
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   233
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   234
    myGenerality := self generality.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   235
    otherGenerality := aNumber generality.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   236
    (myGenerality > otherGenerality) ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   237
	^ self perform:aSymbol with:(self coerce:aNumber)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   238
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   239
    (myGenerality < otherGenerality) ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   240
	^ (aNumber coerce:self) perform:aSymbol with:aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
    self error:'retry:coercing: oops - same generality'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   244
a27a279701f8 Initial revision
claus
parents:
diff changeset
   245
!ArithmeticValue methodsFor:'queries' !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   246
a27a279701f8 Initial revision
claus
parents:
diff changeset
   247
respondsToArithmetic
a27a279701f8 Initial revision
claus
parents:
diff changeset
   248
    "return true, if the receiver responds to arithmetic messages"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   249
a27a279701f8 Initial revision
claus
parents:
diff changeset
   250
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
!ArithmeticValue methodsFor:'arithmetic' !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
+ something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   256
    "return the sum of the receiver and the argument"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   259
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   260
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
- something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
    "return the difference of the receiver and the argument"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   265
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
* something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
    "return the product of the receiver and the argument"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
/ something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
    "return the quotient of the receiver and the argument"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
a27a279701f8 Initial revision
claus
parents:
diff changeset
   279
// something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
    "return the integer quotient of the receiver and the argument"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   281
a27a279701f8 Initial revision
claus
parents:
diff changeset
   282
    ^ (self / something) floor
a27a279701f8 Initial revision
claus
parents:
diff changeset
   283
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   284
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
\\ something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   286
    "return the integer modulu of the receiver and the argument"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
    ^ self - ((self // something) * something)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
quo:something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
    "Return the integer quotient of dividing the receiver by the argument
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
     with truncation towards zero."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
a27a279701f8 Initial revision
claus
parents:
diff changeset
   295
    ^ (self / something) truncated
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
rem:something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
    "Return the integer remainder of dividing the receiver by the argument
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
     with truncation towards zero.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
     The remainder has the same sign as the receiver."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   302
a27a279701f8 Initial revision
claus
parents:
diff changeset
   303
    ^ self - ((self quo:something) * something)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   305
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
abs
a27a279701f8 Initial revision
claus
parents:
diff changeset
   307
    "return the absolute value of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   308
a27a279701f8 Initial revision
claus
parents:
diff changeset
   309
    (self negative) ifTrue:[^ self negated].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   310
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   311
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
a27a279701f8 Initial revision
claus
parents:
diff changeset
   313
negated
a27a279701f8 Initial revision
claus
parents:
diff changeset
   314
    "return the receiver negated"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   315
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
    ^ self class zero - self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
reciprocal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
    "return the receivers reciprocal"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   321
a27a279701f8 Initial revision
claus
parents:
diff changeset
   322
    ^ self class unity / self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   323
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   324
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
!ArithmeticValue methodsFor:'comparing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   326
a27a279701f8 Initial revision
claus
parents:
diff changeset
   327
>= something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   328
    "return true, if the argument is less or equal than the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   329
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
    ^ (self < something) not
a27a279701f8 Initial revision
claus
parents:
diff changeset
   331
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
> something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
    "return true, if the argument is less than the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   335
a27a279701f8 Initial revision
claus
parents:
diff changeset
   336
    ^ something < self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   337
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   338
a27a279701f8 Initial revision
claus
parents:
diff changeset
   339
<= something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
    "return true, if the argument is greater or equal than the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
    ^ (something < self) not
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
< something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
    "return true, if the argument is greater than the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
a27a279701f8 Initial revision
claus
parents:
diff changeset
   348
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   349
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   350
a27a279701f8 Initial revision
claus
parents:
diff changeset
   351
compare:arg ifLess:lessBlock ifEqual:equalBlock ifGreater:greaterBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
    "three-way compare - thanks to Self for this idea.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
     Can be redefined in subclasses to do it with a single comparison if
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
     comparison is expensive."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   355
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
    self < arg ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   357
	^ lessBlock value
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   358
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
    self = arg ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   360
	^ equalBlock value
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   361
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   362
    ^ greaterBlock value
a27a279701f8 Initial revision
claus
parents:
diff changeset
   363
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   364
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   365
!ArithmeticValue methodsFor:'truncation & rounding'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   366
a27a279701f8 Initial revision
claus
parents:
diff changeset
   367
ceiling
a27a279701f8 Initial revision
claus
parents:
diff changeset
   368
    "return the integer nearest the receiver towards positive infinity."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
    |anInteger|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
    anInteger := self // 1.       "truncates towards negative infinity"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
    anInteger = self ifTrue:[^ anInteger].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
    ^ anInteger + 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
floor
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
    "return the receiver truncated towards negative infinity"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   379
a27a279701f8 Initial revision
claus
parents:
diff changeset
   380
    ^ self // 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   381
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   382
a27a279701f8 Initial revision
claus
parents:
diff changeset
   383
truncated
a27a279701f8 Initial revision
claus
parents:
diff changeset
   384
    "return the receiver truncated towards zero"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   385
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   386
    self negative ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   387
	^ self ceiling
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   388
    ].
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   389
    ^ self floor
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   390
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   391
a27a279701f8 Initial revision
claus
parents:
diff changeset
   392
truncateTo:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   393
    "return the receiver truncated to multiples of aNumber"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
a27a279701f8 Initial revision
claus
parents:
diff changeset
   395
    ^ ((self / aNumber) floor * aNumber) asInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   396
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   397
a27a279701f8 Initial revision
claus
parents:
diff changeset
   398
rounded
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
    "return the integer nearest the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   401
    ^ (self + 0.5) floor
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   403
a27a279701f8 Initial revision
claus
parents:
diff changeset
   404
roundTo:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   405
    "return the receiver rounded to multiples of aNumber"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   406
a27a279701f8 Initial revision
claus
parents:
diff changeset
   407
    ^ (self / aNumber) rounded * aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
a27a279701f8 Initial revision
claus
parents:
diff changeset
   410
!ArithmeticValue methodsFor:'double dispatching'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
a27a279701f8 Initial revision
claus
parents:
diff changeset
   412
sumFromInteger:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   413
    "the receiver does not know how to add an integer -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
    ^ anInteger retry:#+ coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   417
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
sumFromFloat:aFloat
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
    "the receiver does not know how to add a float -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
a27a279701f8 Initial revision
claus
parents:
diff changeset
   423
    ^ aFloat retry:#+ coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   425
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
sumFromFraction:aFraction
a27a279701f8 Initial revision
claus
parents:
diff changeset
   427
    "the receiver does not know how to add a fraction -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   428
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
a27a279701f8 Initial revision
claus
parents:
diff changeset
   430
    ^ aFraction retry:#+ coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   431
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   432
a27a279701f8 Initial revision
claus
parents:
diff changeset
   433
differenceFromInteger:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   434
    "the receiver does not know how to subtract from an integer -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   435
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   436
a27a279701f8 Initial revision
claus
parents:
diff changeset
   437
    ^ anInteger retry:#- coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   438
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   439
a27a279701f8 Initial revision
claus
parents:
diff changeset
   440
differenceFromFloat:aFloat
a27a279701f8 Initial revision
claus
parents:
diff changeset
   441
    "the receiver does not know how to subtract from a float -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   442
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   443
a27a279701f8 Initial revision
claus
parents:
diff changeset
   444
    ^ aFloat retry:#- coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   446
a27a279701f8 Initial revision
claus
parents:
diff changeset
   447
differenceFromFraction:aFraction
a27a279701f8 Initial revision
claus
parents:
diff changeset
   448
    "the receiver does not know how to subtract from a fraction -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   449
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
    ^ aFraction retry:#- coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
productFromInteger:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
    "the receiver does not know how to multiply an integer -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   456
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
    ^ anInteger retry:#* coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
productFromFloat:aFloat
a27a279701f8 Initial revision
claus
parents:
diff changeset
   462
    "the receiver does not know how to multiply a float -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
a27a279701f8 Initial revision
claus
parents:
diff changeset
   465
    ^ aFloat retry:#* coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
a27a279701f8 Initial revision
claus
parents:
diff changeset
   468
productFromFraction:aFraction
a27a279701f8 Initial revision
claus
parents:
diff changeset
   469
    "the receiver does not know how to multiply a fraction -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   470
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   471
a27a279701f8 Initial revision
claus
parents:
diff changeset
   472
    ^ aFraction retry:#* coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   474
a27a279701f8 Initial revision
claus
parents:
diff changeset
   475
quotientFromInteger:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   476
    "the receiver does not know how to divide an integer -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   477
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   478
a27a279701f8 Initial revision
claus
parents:
diff changeset
   479
    ^ anInteger retry:#/ coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   480
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   481
a27a279701f8 Initial revision
claus
parents:
diff changeset
   482
quotientFromFloat:aFloat
a27a279701f8 Initial revision
claus
parents:
diff changeset
   483
    "the receiver does not know how to divide a float -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   484
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   485
a27a279701f8 Initial revision
claus
parents:
diff changeset
   486
    ^ aFloat retry:#/ coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
quotientFromFraction:aFraction
a27a279701f8 Initial revision
claus
parents:
diff changeset
   490
    "the receiver does not know how to divide a fraction -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   491
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   492
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
    ^ aFraction retry:#/ coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   495
a27a279701f8 Initial revision
claus
parents:
diff changeset
   496
lessFromInteger:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   497
    "the receiver does not know how to compare to an integer -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   498
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   499
a27a279701f8 Initial revision
claus
parents:
diff changeset
   500
    ^ anInteger retry:#< coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   501
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   502
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
lessFromFloat:aFloat
a27a279701f8 Initial revision
claus
parents:
diff changeset
   504
    "the receiver does not know how to compare to a float -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   505
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   506
a27a279701f8 Initial revision
claus
parents:
diff changeset
   507
    ^ aFloat retry:#< coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   508
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   509
a27a279701f8 Initial revision
claus
parents:
diff changeset
   510
lessFromFraction:aFraction
a27a279701f8 Initial revision
claus
parents:
diff changeset
   511
    "the receiver does not know how to compare to a fraction -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   512
     retry the operation by coercing to higher generality"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   513
a27a279701f8 Initial revision
claus
parents:
diff changeset
   514
    ^ aFraction retry:#< coercing:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   515
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   516
a27a279701f8 Initial revision
claus
parents:
diff changeset
   517
!ArithmeticValue methodsFor:'misc math'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   518
a27a279701f8 Initial revision
claus
parents:
diff changeset
   519
squared
a27a279701f8 Initial revision
claus
parents:
diff changeset
   520
    "return receiver * receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   521
a27a279701f8 Initial revision
claus
parents:
diff changeset
   522
    ^ self * self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   523
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   524
a27a279701f8 Initial revision
claus
parents:
diff changeset
   525
exp
a27a279701f8 Initial revision
claus
parents:
diff changeset
   526
    "return e ^ receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
a27a279701f8 Initial revision
claus
parents:
diff changeset
   528
    ^ self asFloat exp
a27a279701f8 Initial revision
claus
parents:
diff changeset
   529
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
ln
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
    "return the natural logarithm of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
a27a279701f8 Initial revision
claus
parents:
diff changeset
   534
    ^ self asFloat ln
a27a279701f8 Initial revision
claus
parents:
diff changeset
   535
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
log
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
    "return log base 10 of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   539
a27a279701f8 Initial revision
claus
parents:
diff changeset
   540
    ^ self log:10
a27a279701f8 Initial revision
claus
parents:
diff changeset
   541
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   542
a27a279701f8 Initial revision
claus
parents:
diff changeset
   543
log:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   544
    "return log base aNumber of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   545
a27a279701f8 Initial revision
claus
parents:
diff changeset
   546
    ^ self ln / aNumber ln
a27a279701f8 Initial revision
claus
parents:
diff changeset
   547
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   548
a27a279701f8 Initial revision
claus
parents:
diff changeset
   549
sqrt
a27a279701f8 Initial revision
claus
parents:
diff changeset
   550
    "return the square root of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   551
a27a279701f8 Initial revision
claus
parents:
diff changeset
   552
    ^ self asFloat sqrt
a27a279701f8 Initial revision
claus
parents:
diff changeset
   553
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   554
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
floorLog:radix
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
    "return the logarithm truncated as an integer"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   557
a27a279701f8 Initial revision
claus
parents:
diff changeset
   558
    ^ (self log:radix) floor
a27a279701f8 Initial revision
claus
parents:
diff changeset
   559
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   560
a27a279701f8 Initial revision
claus
parents:
diff changeset
   561
raisedTo:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   562
    "return the receiver raised to aNumber"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   563
a27a279701f8 Initial revision
claus
parents:
diff changeset
   564
    aNumber = 0 ifTrue:[^ 1].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   565
    aNumber = 1 ifTrue:[^ self].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   566
    aNumber isInteger ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   567
	^ self raisedToInteger:aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   568
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   569
    ^ self asFloat raisedTo:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   571
a27a279701f8 Initial revision
claus
parents:
diff changeset
   572
raisedToInteger:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   573
    "return the receiver raised to anInteger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   574
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
    |count result|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   576
a27a279701f8 Initial revision
claus
parents:
diff changeset
   577
    result := self coerce:1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   578
    count := anInteger abs.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   579
    count timesRepeat:[result := result * self].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   580
    (anInteger < 0) ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 155
diff changeset
   581
	^ 1 / result
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   582
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   583
    ^ result
a27a279701f8 Initial revision
claus
parents:
diff changeset
   584
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   585
a27a279701f8 Initial revision
claus
parents:
diff changeset
   586
!ArithmeticValue methodsFor:'trigonometric'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   587
a27a279701f8 Initial revision
claus
parents:
diff changeset
   588
sin
a27a279701f8 Initial revision
claus
parents:
diff changeset
   589
    "return the sine of the receiver (interpreted as radians)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   590
a27a279701f8 Initial revision
claus
parents:
diff changeset
   591
    ^ self asFloat sin
a27a279701f8 Initial revision
claus
parents:
diff changeset
   592
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   593
a27a279701f8 Initial revision
claus
parents:
diff changeset
   594
cos
a27a279701f8 Initial revision
claus
parents:
diff changeset
   595
    "return the cosine of the receiver (interpreted as radians)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   596
a27a279701f8 Initial revision
claus
parents:
diff changeset
   597
    ^ self asFloat cos
a27a279701f8 Initial revision
claus
parents:
diff changeset
   598
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   599
a27a279701f8 Initial revision
claus
parents:
diff changeset
   600
tan
a27a279701f8 Initial revision
claus
parents:
diff changeset
   601
    "return the tangens of the receiver (interpreted as radians)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   602
a27a279701f8 Initial revision
claus
parents:
diff changeset
   603
    ^ self asFloat tan
a27a279701f8 Initial revision
claus
parents:
diff changeset
   604
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   605
a27a279701f8 Initial revision
claus
parents:
diff changeset
   606
arcCos
a27a279701f8 Initial revision
claus
parents:
diff changeset
   607
    "return the arccosine of the receiver (in radians)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   608
a27a279701f8 Initial revision
claus
parents:
diff changeset
   609
    ^ self asFloat arcCos
a27a279701f8 Initial revision
claus
parents:
diff changeset
   610
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   611
a27a279701f8 Initial revision
claus
parents:
diff changeset
   612
arcSin
a27a279701f8 Initial revision
claus
parents:
diff changeset
   613
    "return the arcsine of the receiver (in radians)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   614
a27a279701f8 Initial revision
claus
parents:
diff changeset
   615
    ^ self asFloat arcSin
a27a279701f8 Initial revision
claus
parents:
diff changeset
   616
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   617
a27a279701f8 Initial revision
claus
parents:
diff changeset
   618
arcTan
a27a279701f8 Initial revision
claus
parents:
diff changeset
   619
    "return the arctangens of the receiver (in radians)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   620
a27a279701f8 Initial revision
claus
parents:
diff changeset
   621
    ^ self asFloat arcTan
a27a279701f8 Initial revision
claus
parents:
diff changeset
   622
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   623
a27a279701f8 Initial revision
claus
parents:
diff changeset
   624
!ArithmeticValue methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   625
a27a279701f8 Initial revision
claus
parents:
diff changeset
   626
negative
a27a279701f8 Initial revision
claus
parents:
diff changeset
   627
    "return true, if the receiver is < 0"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
a27a279701f8 Initial revision
claus
parents:
diff changeset
   629
    " this would lead to infinite recursion ...
a27a279701f8 Initial revision
claus
parents:
diff changeset
   630
    ^ (self < 0)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   631
    "
a27a279701f8 Initial revision
claus
parents:
diff changeset
   632
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   633
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   634
a27a279701f8 Initial revision
claus
parents:
diff changeset
   635
positive
a27a279701f8 Initial revision
claus
parents:
diff changeset
   636
    "return true, if the receiver is >= 0"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   637
a27a279701f8 Initial revision
claus
parents:
diff changeset
   638
    ^ self negative not
a27a279701f8 Initial revision
claus
parents:
diff changeset
   639
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   640
a27a279701f8 Initial revision
claus
parents:
diff changeset
   641
strictlyPositive
a27a279701f8 Initial revision
claus
parents:
diff changeset
   642
    "return true, if the receiver is > 0"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   643
a27a279701f8 Initial revision
claus
parents:
diff changeset
   644
    ^ (self > 0)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   645
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   646
a27a279701f8 Initial revision
claus
parents:
diff changeset
   647
sign
a27a279701f8 Initial revision
claus
parents:
diff changeset
   648
    "return the sign of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   649
a27a279701f8 Initial revision
claus
parents:
diff changeset
   650
    (self < 0) ifTrue:[^ -1].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   651
    (self > 0) ifTrue:[^ 1].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
    ^ 0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   653
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   654
a27a279701f8 Initial revision
claus
parents:
diff changeset
   655
even
a27a279701f8 Initial revision
claus
parents:
diff changeset
   656
    "return true if the receiver is divisible by 2"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   657
a27a279701f8 Initial revision
claus
parents:
diff changeset
   658
    ^ self truncated asInteger even
a27a279701f8 Initial revision
claus
parents:
diff changeset
   659
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   660
a27a279701f8 Initial revision
claus
parents:
diff changeset
   661
odd
a27a279701f8 Initial revision
claus
parents:
diff changeset
   662
    "return true if the receiver is not divisible by 2"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   663
a27a279701f8 Initial revision
claus
parents:
diff changeset
   664
    ^ self even not
a27a279701f8 Initial revision
claus
parents:
diff changeset
   665
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   666
a27a279701f8 Initial revision
claus
parents:
diff changeset
   667
denominator
a27a279701f8 Initial revision
claus
parents:
diff changeset
   668
    "return the denominator of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
a27a279701f8 Initial revision
claus
parents:
diff changeset
   670
    ^ 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   671
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   672
a27a279701f8 Initial revision
claus
parents:
diff changeset
   673
numerator
a27a279701f8 Initial revision
claus
parents:
diff changeset
   674
    "return the numerator of the receiver."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   675
a27a279701f8 Initial revision
claus
parents:
diff changeset
   676
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   677
! !