]> gitweb.factorcode.org Git - factor.git/blob - library/math/pow.factor
0f73783d9db2412a26e220be27f75faa8003dc0b
[factor.git] / library / math / pow.factor
1 !:folding=indent:collapseFolds=0:
2
3 ! $Id$
4 !
5 ! Copyright (C) 2004 Slava Pestov.
6
7 ! Redistribution and use in source and binary forms, with or without
8 ! modification, are permitted provided that the following conditions are met:
9
10 ! 1. Redistributions of source code must retain the above copyright notice,
11 !    this list of conditions and the following disclaimer.
12
13 ! 2. Redistributions in binary form must reproduce the above copyright notice,
14 !    this list of conditions and the following disclaimer in the documentation
15 !    and/or other materials provided with the distribution.
16
17 ! THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
18 ! INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
19 ! FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
20 ! DEVELOPERS AND CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 ! SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
22 ! PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
23 ! OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
24 ! WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
25 ! OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
26 ! ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28 IN: math
29 USE: arithmetic
30 USE: combinators
31 USE: real-math
32 USE: kernel
33 USE: stack
34
35 !!! Power-related functions:
36 !!!     exp log sqrt pow
37
38 : exp >rect swap fexp swap polar> ;
39 : log >polar swap flog swap rect> ;
40
41 : sqrt ( z -- sqrt )
42     >polar dup pi = [
43         drop fsqrt 0 swap rect>
44     ] [
45         swap fsqrt swap 2 / polar>
46     ] ifte ;
47
48 : ^mag ( w abs arg -- magnitude )
49     [ [ >rect swap ] dip swap fpow ] dip rot * fexp / ;
50
51 : ^theta ( w abs arg -- theta )
52     [ [ >rect ] dip flog * swap ] dip * + ;
53
54 : ^ ( z w -- z^w )
55     swap >polar 3dup ^theta [ ^mag ] dip polar> ;