]> gitweb.factorcode.org Git - factor.git/blob - extra/math/finance/finance.factor
math.finance: adding dema, gdema, and tema.
[factor.git] / extra / math / finance / finance.factor
1 ! Copyright (C) 2008 John Benediktsson, Doug Coleman.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: arrays assocs kernel grouping sequences shuffle
4 math math.functions math.statistics math.vectors ;
5 IN: math.finance
6
7 <PRIVATE
8
9 : weighted ( x y a -- z )
10     [ * ] [ 1 - neg * ] bi-curry bi* + ;
11
12 : a ( n -- a )
13     1 + 2 swap / ;
14
15 PRIVATE>
16
17 : ema ( seq n -- newseq )
18     a swap unclip [ swap pick weighted ] accumulate 2nip ;
19
20 : sma ( seq n -- newseq )
21     clump [ mean ] map ;
22
23 : dema ( seq n -- newseq )
24     [ ema ] keep [ drop 2 v*n ] [ ema ] 2bi v- ;
25
26 : gdema ( seq n v -- newseq )
27     [ [ ema ] keep dupd ema ] dip
28     [ 1 + v*n ] [ v*n ] bi-curry bi* v- ;
29
30 : tema ( seq n -- newseq )
31     [ ema ] keep dupd [ ema ] keep
32     [ drop [ 3 v*n ] bi@ v- ] [ ema nip ] 3bi v+ ;
33
34 : macd ( seq n1 n2 -- newseq )
35     rot dup ema [ swap ema ] dip v- ;
36
37 : momentum ( seq n -- newseq )
38     [ tail-slice ] 2keep [ dup length ] dip - head-slice v- ;
39
40 : monthly ( x -- y ) 12 / ; inline
41
42 : semimonthly ( x -- y ) 24 / ; inline
43
44 : biweekly ( x -- y ) 26 / ; inline
45
46 : weekly ( x -- y ) 52 / ; inline
47
48 : daily-360 ( x -- y ) 360 / ; inline
49
50 : daily-365 ( x -- y ) 365 / ; inline