@quantform/core 0.5.13 → 0.5.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/adapter/adapter-aggregate.d.ts +8 -5
- package/dist/adapter/adapter-aggregate.js +18 -20
- package/dist/adapter/adapter-aggregate.js.map +1 -1
- package/dist/adapter/adapter.d.ts +20 -32
- package/dist/adapter/adapter.js +8 -43
- package/dist/adapter/adapter.js.map +1 -1
- package/dist/adapter/backtester/backtester-adapter.d.ts +11 -9
- package/dist/adapter/backtester/backtester-adapter.js +17 -16
- package/dist/adapter/backtester/backtester-adapter.js.map +1 -1
- package/dist/{tests → adapter/backtester}/backtester-adapter.spec.d.ts +0 -0
- package/dist/adapter/backtester/backtester-adapter.spec.js +83 -0
- package/dist/adapter/backtester/backtester-adapter.spec.js.map +1 -0
- package/dist/adapter/backtester/backtester-cursor.d.ts +3 -4
- package/dist/adapter/backtester/backtester-cursor.js +2 -1
- package/dist/adapter/backtester/backtester-cursor.js.map +1 -1
- package/dist/adapter/backtester/backtester-cursor.spec.js +19 -18
- package/dist/adapter/backtester/backtester-cursor.spec.js.map +1 -1
- package/dist/adapter/backtester/backtester-streamer.d.ts +3 -1
- package/dist/adapter/backtester/backtester-streamer.js +25 -14
- package/dist/adapter/backtester/backtester-streamer.js.map +1 -1
- package/dist/adapter/backtester/backtester-streamer.spec.js +17 -16
- package/dist/adapter/backtester/backtester-streamer.spec.js.map +1 -1
- package/dist/adapter/error.d.ts +2 -0
- package/dist/adapter/error.js +12 -0
- package/dist/adapter/error.js.map +1 -0
- package/dist/adapter/paper/engine/paper-engine.d.ts +11 -0
- package/dist/adapter/paper/engine/paper-engine.js +104 -0
- package/dist/adapter/paper/engine/paper-engine.js.map +1 -0
- package/dist/adapter/paper/{simulator/paper-spot-simulator.spec.d.ts → engine/paper-engine.spec.d.ts} +0 -0
- package/dist/adapter/paper/engine/paper-engine.spec.js +54 -0
- package/dist/adapter/paper/engine/paper-engine.spec.js.map +1 -0
- package/dist/adapter/paper/index.d.ts +1 -2
- package/dist/adapter/paper/index.js +1 -2
- package/dist/adapter/paper/index.js.map +1 -1
- package/dist/adapter/paper/paper-adapter.d.ts +10 -9
- package/dist/adapter/paper/paper-adapter.js +26 -23
- package/dist/adapter/paper/paper-adapter.js.map +1 -1
- package/dist/adapter/paper/paper-adapter.spec.js +36 -17
- package/dist/adapter/paper/paper-adapter.spec.js.map +1 -1
- package/dist/bootstrap.js +11 -10
- package/dist/bootstrap.js.map +1 -1
- package/dist/cli/pull.js +8 -11
- package/dist/cli/pull.js.map +1 -1
- package/dist/cli/test.js +5 -1
- package/dist/cli/test.js.map +1 -1
- package/dist/domain/asset.d.ts +10 -9
- package/dist/domain/asset.js +26 -23
- package/dist/domain/asset.js.map +1 -1
- package/dist/domain/asset.spec.js +36 -36
- package/dist/domain/asset.spec.js.map +1 -1
- package/dist/domain/balance.d.ts +13 -13
- package/dist/domain/balance.js +38 -32
- package/dist/domain/balance.js.map +1 -1
- package/dist/domain/balance.operator.d.ts +6 -0
- package/dist/domain/balance.operator.js +10 -0
- package/dist/domain/balance.operator.js.map +1 -0
- package/dist/{indicator/truerange.spec.d.ts → domain/balance.operator.spec.d.ts} +0 -0
- package/dist/domain/balance.operator.spec.js +23 -0
- package/dist/domain/balance.operator.spec.js.map +1 -0
- package/dist/domain/balance.spec.js +73 -12
- package/dist/domain/balance.spec.js.map +1 -1
- package/dist/domain/candle.d.ts +8 -23
- package/dist/domain/candle.js +6 -72
- package/dist/domain/candle.js.map +1 -1
- package/dist/domain/candle.operator.d.ts +10 -0
- package/dist/domain/candle.operator.js +64 -0
- package/dist/domain/candle.operator.js.map +1 -0
- package/dist/{shared/policy.spec.d.ts → domain/candle.operator.spec.d.ts} +0 -0
- package/dist/domain/candle.operator.spec.js +112 -0
- package/dist/domain/candle.operator.spec.js.map +1 -0
- package/dist/domain/candle.spec.js +16 -58
- package/dist/domain/candle.spec.js.map +1 -1
- package/dist/domain/commission.d.ts +12 -8
- package/dist/domain/commission.js +6 -6
- package/dist/domain/commission.js.map +1 -1
- package/dist/{shared/topic.spec.d.ts → domain/commission.spec.d.ts} +0 -0
- package/dist/domain/commission.spec.js +31 -0
- package/dist/domain/commission.spec.js.map +1 -0
- package/dist/domain/component.d.ts +1 -0
- package/dist/domain/error.d.ts +6 -0
- package/dist/domain/error.js +24 -0
- package/dist/domain/error.js.map +1 -0
- package/dist/domain/index.d.ts +8 -1
- package/dist/domain/index.js +8 -1
- package/dist/domain/index.js.map +1 -1
- package/dist/domain/instrument.d.ts +3 -2
- package/dist/domain/instrument.js +17 -9
- package/dist/domain/instrument.js.map +1 -1
- package/dist/domain/instrument.operator.d.ts +6 -0
- package/dist/domain/instrument.operator.js +14 -0
- package/dist/domain/instrument.operator.js.map +1 -0
- package/dist/{store/event/store-balance.event.spec.d.ts → domain/instrument.operator.spec.d.ts} +0 -0
- package/dist/domain/instrument.operator.spec.js +24 -0
- package/dist/domain/instrument.operator.spec.js.map +1 -0
- package/dist/domain/instrument.spec.js +22 -30
- package/dist/domain/instrument.spec.js.map +1 -1
- package/dist/domain/order.d.ts +16 -18
- package/dist/domain/order.js +39 -27
- package/dist/domain/order.js.map +1 -1
- package/dist/domain/order.operator.d.ts +7 -0
- package/dist/domain/order.operator.js +14 -0
- package/dist/domain/order.operator.js.map +1 -0
- package/dist/{store/event/store-candle.event.spec.d.ts → domain/order.operator.spec.d.ts} +0 -0
- package/dist/domain/order.operator.spec.js +65 -0
- package/dist/domain/order.operator.spec.js.map +1 -0
- package/dist/{store/event/store-instrument.event.spec.d.ts → domain/order.spec.d.ts} +0 -0
- package/dist/domain/order.spec.js +34 -0
- package/dist/domain/order.spec.js.map +1 -0
- package/dist/domain/orderbook.d.ts +19 -6
- package/dist/domain/orderbook.js +6 -4
- package/dist/domain/orderbook.js.map +1 -1
- package/dist/domain/orderbook.operator.d.ts +6 -0
- package/dist/domain/orderbook.operator.js +10 -0
- package/dist/domain/orderbook.operator.js.map +1 -0
- package/dist/{store/event/store-order.event.spec.d.ts → domain/orderbook.operator.spec.d.ts} +0 -0
- package/dist/domain/orderbook.operator.spec.js +22 -0
- package/dist/domain/orderbook.operator.spec.js.map +1 -0
- package/dist/{store/event/store-trade.event.spec.d.ts → domain/orderbook.spec.d.ts} +0 -0
- package/dist/domain/orderbook.spec.js +13 -0
- package/dist/domain/orderbook.spec.js.map +1 -0
- package/dist/domain/position.d.ts +9 -14
- package/dist/domain/position.js +9 -31
- package/dist/domain/position.js.map +1 -1
- package/dist/domain/position.operator.d.ts +11 -0
- package/dist/domain/position.operator.js +38 -0
- package/dist/domain/position.operator.js.map +1 -0
- package/dist/domain/position.operator.spec.d.ts +1 -0
- package/dist/domain/position.operator.spec.js +49 -0
- package/dist/domain/position.operator.spec.js.map +1 -0
- package/dist/domain/position.spec.js +22 -17
- package/dist/domain/position.spec.js.map +1 -1
- package/dist/domain/session.d.ts +15 -18
- package/dist/domain/session.js +21 -31
- package/dist/domain/session.js.map +1 -1
- package/dist/domain/session.spec.js +2 -2
- package/dist/domain/session.spec.js.map +1 -1
- package/dist/domain/trade.d.ts +4 -3
- package/dist/domain/trade.js +1 -0
- package/dist/domain/trade.js.map +1 -1
- package/dist/domain/trade.operator.d.ts +6 -0
- package/dist/domain/trade.operator.js +10 -0
- package/dist/domain/trade.operator.js.map +1 -0
- package/dist/domain/trade.operator.spec.d.ts +1 -0
- package/dist/domain/trade.operator.spec.js +24 -0
- package/dist/domain/trade.operator.spec.js.map +1 -0
- package/dist/domain/trade.spec.d.ts +1 -0
- package/dist/domain/trade.spec.js +13 -0
- package/dist/domain/trade.spec.js.map +1 -0
- package/dist/indicator/atr.d.ts +2 -1
- package/dist/indicator/atr.js +3 -3
- package/dist/indicator/atr.js.map +1 -1
- package/dist/indicator/cross.d.ts +3 -2
- package/dist/indicator/cross.js +13 -13
- package/dist/indicator/cross.js.map +1 -1
- package/dist/indicator/cross.spec.js +23 -22
- package/dist/indicator/cross.spec.js.map +1 -1
- package/dist/indicator/donchian.d.ts +3 -2
- package/dist/indicator/donchian.js.map +1 -1
- package/dist/indicator/drawdown.d.ts +2 -1
- package/dist/indicator/drawdown.js +3 -2
- package/dist/indicator/drawdown.js.map +1 -1
- package/dist/indicator/ema.d.ts +2 -1
- package/dist/indicator/ema.js +3 -2
- package/dist/indicator/ema.js.map +1 -1
- package/dist/indicator/ema.spec.js +4 -3
- package/dist/indicator/ema.spec.js.map +1 -1
- package/dist/indicator/envelope.d.ts +4 -3
- package/dist/indicator/envelope.js +4 -4
- package/dist/indicator/envelope.js.map +1 -1
- package/dist/indicator/index.d.ts +1 -1
- package/dist/indicator/index.js +1 -1
- package/dist/indicator/index.js.map +1 -1
- package/dist/indicator/macd.d.ts +2 -1
- package/dist/indicator/macd.js +1 -1
- package/dist/indicator/macd.js.map +1 -1
- package/dist/indicator/min-max.d.ts +4 -3
- package/dist/indicator/min-max.js +5 -4
- package/dist/indicator/min-max.js.map +1 -1
- package/dist/indicator/rma.d.ts +2 -1
- package/dist/indicator/rma.js +3 -2
- package/dist/indicator/rma.js.map +1 -1
- package/dist/indicator/sma.d.ts +2 -1
- package/dist/indicator/sma.js +4 -6
- package/dist/indicator/sma.js.map +1 -1
- package/dist/indicator/sma.spec.js +4 -3
- package/dist/indicator/sma.spec.js.map +1 -1
- package/dist/indicator/swma.d.ts +2 -1
- package/dist/indicator/swma.js +5 -1
- package/dist/indicator/swma.js.map +1 -1
- package/dist/indicator/tma.d.ts +2 -1
- package/dist/indicator/tma.js.map +1 -1
- package/dist/indicator/tma.spec.js +4 -3
- package/dist/indicator/tma.spec.js.map +1 -1
- package/dist/indicator/trailing.d.ts +8 -7
- package/dist/indicator/trailing.js +12 -11
- package/dist/indicator/trailing.js.map +1 -1
- package/dist/indicator/trailing.spec.js +15 -14
- package/dist/indicator/trailing.spec.js.map +1 -1
- package/dist/indicator/true-range.d.ts +4 -0
- package/dist/indicator/true-range.js +20 -0
- package/dist/indicator/true-range.js.map +1 -0
- package/dist/indicator/true-range.spec.d.ts +1 -0
- package/dist/indicator/true-range.spec.js +28 -0
- package/dist/indicator/true-range.spec.js.map +1 -0
- package/dist/indicator/window.d.ts +1 -1
- package/dist/indicator/window.js +1 -1
- package/dist/indicator/window.js.map +1 -1
- package/dist/indicator/wma.d.ts +2 -1
- package/dist/indicator/wma.js +6 -5
- package/dist/indicator/wma.js.map +1 -1
- package/dist/indicator/wma.spec.js +4 -3
- package/dist/indicator/wma.spec.js.map +1 -1
- package/dist/shared/collections.d.ts +26 -0
- package/dist/shared/collections.js +115 -0
- package/dist/shared/collections.js.map +1 -0
- package/dist/shared/collections.spec.d.ts +1 -0
- package/dist/shared/collections.spec.js +28 -0
- package/dist/shared/collections.spec.js.map +1 -0
- package/dist/shared/datetime.d.ts +0 -1
- package/dist/shared/datetime.js +1 -12
- package/dist/shared/datetime.js.map +1 -1
- package/dist/shared/decimals.d.ts +15 -6
- package/dist/shared/decimals.js +22 -36
- package/dist/shared/decimals.js.map +1 -1
- package/dist/shared/decimals.spec.js +18 -22
- package/dist/shared/decimals.spec.js.map +1 -1
- package/dist/shared/index.d.ts +2 -1
- package/dist/shared/index.js +2 -1
- package/dist/shared/index.js.map +1 -1
- package/dist/shared/io.js.map +1 -1
- package/dist/shared/pipe.d.ts +4 -0
- package/dist/shared/pipe.js +9 -0
- package/dist/shared/pipe.js.map +1 -0
- package/dist/shared/policy.d.ts +0 -1
- package/dist/shared/policy.js +1 -11
- package/dist/shared/policy.js.map +1 -1
- package/dist/storage/cache.js +1 -1
- package/dist/storage/cache.js.map +1 -1
- package/dist/storage/cache.spec.d.ts +1 -0
- package/dist/storage/cache.spec.js +18 -0
- package/dist/storage/cache.spec.js.map +1 -0
- package/dist/storage/feed.d.ts +7 -4
- package/dist/storage/feed.js +55 -8
- package/dist/storage/feed.js.map +1 -1
- package/dist/storage/storage.d.ts +2 -7
- package/dist/storage/storage.js +6 -11
- package/dist/storage/storage.js.map +1 -1
- package/dist/store/index.d.ts +8 -2
- package/dist/store/index.js +8 -2
- package/dist/store/index.js.map +1 -1
- package/dist/store/store-balance.event.d.ts +33 -0
- package/dist/store/store-balance.event.js +90 -0
- package/dist/store/store-balance.event.js.map +1 -0
- package/dist/store/store-balance.event.spec.d.ts +1 -0
- package/dist/store/{event/store-balance.event.spec.js → store-balance.event.spec.js} +10 -10
- package/dist/store/store-balance.event.spec.js.map +1 -0
- package/dist/store/{event/store-instrument.event.d.ts → store-instrument.event.d.ts} +5 -8
- package/dist/store/store-instrument.event.js +52 -0
- package/dist/store/store-instrument.event.js.map +1 -0
- package/dist/store/store-instrument.event.spec.d.ts +1 -0
- package/dist/store/store-instrument.event.spec.js +22 -0
- package/dist/store/store-instrument.event.spec.js.map +1 -0
- package/dist/store/store-order.event.d.ts +59 -0
- package/dist/store/store-order.event.js +181 -0
- package/dist/store/store-order.event.js.map +1 -0
- package/dist/store/store-order.event.spec.d.ts +1 -0
- package/dist/store/{event/store-order.event.spec.js → store-order.event.spec.js} +8 -8
- package/dist/store/store-order.event.spec.js.map +1 -0
- package/dist/store/store-orderbook.event.d.ts +12 -0
- package/dist/store/store-orderbook.event.js +42 -0
- package/dist/store/store-orderbook.event.js.map +1 -0
- package/dist/store/store-orderbook.event.spec.d.ts +1 -0
- package/dist/store/store-orderbook.event.spec.js +28 -0
- package/dist/store/store-orderbook.event.spec.js.map +1 -0
- package/dist/store/store-position.event.d.ts +21 -0
- package/dist/store/store-position.event.js +89 -0
- package/dist/store/store-position.event.js.map +1 -0
- package/dist/store/store-state.d.ts +27 -0
- package/dist/store/store-state.js +29 -0
- package/dist/store/store-state.js.map +1 -0
- package/dist/store/store-trade.event.d.ts +12 -0
- package/dist/store/store-trade.event.js +25 -0
- package/dist/store/store-trade.event.js.map +1 -0
- package/dist/store/store-trade.event.spec.d.ts +1 -0
- package/dist/store/store-trade.event.spec.js +44 -0
- package/dist/store/store-trade.event.spec.js.map +1 -0
- package/dist/store/store.d.ts +4 -25
- package/dist/store/store.event.d.ts +6 -0
- package/dist/store/{event/store.event.js → store.event.js} +0 -0
- package/dist/store/store.event.js.map +1 -0
- package/dist/store/store.js +7 -195
- package/dist/store/store.js.map +1 -1
- package/dist/store/store.spec.d.ts +1 -0
- package/dist/store/store.spec.js +119 -0
- package/dist/store/store.spec.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/{jestconfig.unit.json → jestconfig.json} +2 -2
- package/package.json +4 -6
- package/src/adapter/adapter-aggregate.ts +39 -38
- package/src/adapter/adapter.ts +39 -71
- package/src/adapter/backtester/backtester-adapter.spec.ts +133 -0
- package/src/adapter/backtester/backtester-adapter.ts +41 -21
- package/src/adapter/backtester/backtester-cursor.spec.ts +19 -18
- package/src/adapter/backtester/backtester-cursor.ts +7 -7
- package/src/adapter/backtester/backtester-streamer.spec.ts +23 -22
- package/src/adapter/backtester/backtester-streamer.ts +28 -15
- package/src/adapter/error.ts +9 -0
- package/src/adapter/paper/engine/paper-engine.spec.ts +99 -0
- package/src/adapter/paper/engine/paper-engine.ts +142 -0
- package/src/adapter/paper/index.ts +1 -2
- package/src/adapter/paper/paper-adapter.spec.ts +65 -20
- package/src/adapter/paper/paper-adapter.ts +42 -27
- package/src/bootstrap.ts +26 -19
- package/src/cli/pull.ts +11 -6
- package/src/cli/test.ts +5 -2
- package/src/domain/asset.spec.ts +37 -33
- package/src/domain/asset.ts +33 -34
- package/src/domain/balance.operator.spec.ts +25 -0
- package/src/domain/balance.operator.ts +15 -0
- package/src/domain/balance.spec.ts +101 -12
- package/src/domain/balance.ts +57 -51
- package/src/domain/candle.operator.spec.ts +126 -0
- package/src/domain/candle.operator.ts +107 -0
- package/src/domain/candle.spec.ts +18 -73
- package/src/domain/candle.ts +9 -121
- package/src/domain/commission.spec.ts +34 -0
- package/src/domain/commission.ts +13 -11
- package/src/domain/component.ts +1 -0
- package/src/domain/error.ts +27 -0
- package/src/domain/index.ts +8 -1
- package/src/domain/instrument.operator.spec.ts +28 -0
- package/src/domain/instrument.operator.ts +25 -0
- package/src/domain/instrument.spec.ts +22 -30
- package/src/domain/instrument.ts +20 -11
- package/src/domain/order.operator.spec.ts +82 -0
- package/src/domain/order.operator.ts +23 -0
- package/src/domain/order.spec.ts +44 -0
- package/src/domain/order.ts +55 -55
- package/src/domain/orderbook.operator.spec.ts +28 -0
- package/src/domain/orderbook.operator.ts +15 -0
- package/src/domain/orderbook.spec.ts +17 -0
- package/src/domain/orderbook.ts +18 -9
- package/src/domain/position.operator.spec.ts +59 -0
- package/src/domain/position.operator.ts +64 -0
- package/src/domain/position.spec.ts +28 -23
- package/src/domain/position.ts +17 -49
- package/src/domain/session.spec.ts +4 -4
- package/src/domain/session.ts +42 -134
- package/src/domain/trade.operator.spec.ts +31 -0
- package/src/domain/trade.operator.ts +15 -0
- package/src/domain/trade.spec.ts +17 -0
- package/src/domain/trade.ts +7 -4
- package/src/indicator/atr.ts +6 -5
- package/src/indicator/cross.spec.ts +33 -48
- package/src/indicator/cross.ts +18 -10
- package/src/indicator/donchian.ts +5 -4
- package/src/indicator/drawdown.ts +7 -5
- package/src/indicator/ema.spec.ts +5 -4
- package/src/indicator/ema.ts +7 -6
- package/src/indicator/envelope.ts +11 -6
- package/src/indicator/index.ts +1 -1
- package/src/indicator/macd.ts +5 -4
- package/src/indicator/min-max.ts +10 -7
- package/src/indicator/rma.ts +7 -6
- package/src/indicator/sma.spec.ts +5 -4
- package/src/indicator/sma.ts +9 -8
- package/src/indicator/swma.ts +8 -4
- package/src/indicator/tma.spec.ts +5 -4
- package/src/indicator/tma.ts +4 -3
- package/src/indicator/trailing.spec.ts +29 -16
- package/src/indicator/trailing.ts +22 -16
- package/src/indicator/true-range.spec.ts +32 -0
- package/src/indicator/true-range.ts +32 -0
- package/src/indicator/window.ts +3 -3
- package/src/indicator/wma.spec.ts +5 -4
- package/src/indicator/wma.ts +8 -7
- package/src/shared/collections.spec.ts +30 -0
- package/src/shared/collections.ts +141 -0
- package/src/shared/datetime.ts +0 -12
- package/src/shared/decimals.spec.ts +19 -24
- package/src/shared/decimals.ts +22 -55
- package/src/shared/index.ts +2 -1
- package/src/shared/io.ts +0 -2
- package/src/shared/pipe.ts +12 -0
- package/src/shared/policy.ts +0 -13
- package/src/storage/cache.spec.ts +18 -0
- package/src/storage/cache.ts +1 -1
- package/src/storage/feed.ts +88 -23
- package/src/storage/storage.ts +9 -13
- package/src/store/index.ts +8 -2
- package/src/store/{event/store-balance.event.spec.ts → store-balance.event.spec.ts} +10 -10
- package/src/store/store-balance.event.ts +124 -0
- package/src/store/store-instrument.event.spec.ts +25 -0
- package/src/store/store-instrument.event.ts +72 -0
- package/src/store/store-order.event.spec.ts +28 -0
- package/src/store/store-order.event.ts +214 -0
- package/src/store/store-orderbook.event.spec.ts +37 -0
- package/src/store/store-orderbook.event.ts +54 -0
- package/src/store/store-position.event.ts +114 -0
- package/src/store/store-state.ts +48 -0
- package/src/store/store-trade.event.spec.ts +60 -0
- package/src/store/store-trade.event.ts +36 -0
- package/src/store/store.event.ts +8 -0
- package/src/store/store.spec.ts +180 -0
- package/src/store/store.ts +10 -208
- package/dist/adapter/paper/simulator/paper-margin-simulator.d.ts +0 -10
- package/dist/adapter/paper/simulator/paper-margin-simulator.js +0 -69
- package/dist/adapter/paper/simulator/paper-margin-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-simulator.d.ts +0 -16
- package/dist/adapter/paper/simulator/paper-simulator.js +0 -93
- package/dist/adapter/paper/simulator/paper-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-spot-simulator.d.ts +0 -13
- package/dist/adapter/paper/simulator/paper-spot-simulator.js +0 -81
- package/dist/adapter/paper/simulator/paper-spot-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-spot-simulator.spec.js +0 -49
- package/dist/adapter/paper/simulator/paper-spot-simulator.spec.js.map +0 -1
- package/dist/domain/statement.d.ts +0 -4
- package/dist/domain/statement.js +0 -87
- package/dist/domain/statement.js.map +0 -1
- package/dist/indicator/truerange.d.ts +0 -3
- package/dist/indicator/truerange.js +0 -19
- package/dist/indicator/truerange.js.map +0 -1
- package/dist/indicator/truerange.spec.js +0 -28
- package/dist/indicator/truerange.spec.js.map +0 -1
- package/dist/shared/policy.spec.js +0 -22
- package/dist/shared/policy.spec.js.map +0 -1
- package/dist/shared/topic.d.ts +0 -14
- package/dist/shared/topic.js +0 -40
- package/dist/shared/topic.js.map +0 -1
- package/dist/shared/topic.spec.js +0 -43
- package/dist/shared/topic.spec.js.map +0 -1
- package/dist/store/event/index.d.ts +0 -8
- package/dist/store/event/index.js +0 -25
- package/dist/store/event/index.js.map +0 -1
- package/dist/store/event/store-balance.event.d.ts +0 -37
- package/dist/store/event/store-balance.event.js +0 -119
- package/dist/store/event/store-balance.event.js.map +0 -1
- package/dist/store/event/store-balance.event.spec.js.map +0 -1
- package/dist/store/event/store-candle.event.d.ts +0 -18
- package/dist/store/event/store-candle.event.js +0 -63
- package/dist/store/event/store-candle.event.js.map +0 -1
- package/dist/store/event/store-candle.event.spec.js +0 -23
- package/dist/store/event/store-candle.event.spec.js.map +0 -1
- package/dist/store/event/store-instrument.event.js +0 -78
- package/dist/store/event/store-instrument.event.js.map +0 -1
- package/dist/store/event/store-instrument.event.spec.js +0 -21
- package/dist/store/event/store-instrument.event.spec.js.map +0 -1
- package/dist/store/event/store-order.event.d.ts +0 -61
- package/dist/store/event/store-order.event.js +0 -205
- package/dist/store/event/store-order.event.js.map +0 -1
- package/dist/store/event/store-order.event.spec.js.map +0 -1
- package/dist/store/event/store-orderbook.event.d.ts +0 -15
- package/dist/store/event/store-orderbook.event.js +0 -65
- package/dist/store/event/store-orderbook.event.js.map +0 -1
- package/dist/store/event/store-position.event.d.ts +0 -23
- package/dist/store/event/store-position.event.js +0 -97
- package/dist/store/event/store-position.event.js.map +0 -1
- package/dist/store/event/store-trade.event.d.ts +0 -13
- package/dist/store/event/store-trade.event.js +0 -47
- package/dist/store/event/store-trade.event.js.map +0 -1
- package/dist/store/event/store-trade.event.spec.js +0 -44
- package/dist/store/event/store-trade.event.spec.js.map +0 -1
- package/dist/store/event/store.event.d.ts +0 -5
- package/dist/store/event/store.event.js.map +0 -1
- package/dist/store/store.state.d.ts +0 -21
- package/dist/store/store.state.js +0 -21
- package/dist/store/store.state.js.map +0 -1
- package/dist/tests/backtester-adapter.spec.js +0 -61
- package/dist/tests/backtester-adapter.spec.js.map +0 -1
- package/dist/tests/session.spec.d.ts +0 -0
- package/dist/tests/session.spec.js +0 -1
- package/dist/tests/session.spec.js.map +0 -1
- package/jestconfig.integration.json +0 -12
- package/src/adapter/paper/simulator/paper-margin-simulator.ts +0 -108
- package/src/adapter/paper/simulator/paper-simulator.ts +0 -121
- package/src/adapter/paper/simulator/paper-spot-simulator.spec.ts +0 -87
- package/src/adapter/paper/simulator/paper-spot-simulator.ts +0 -134
- package/src/domain/statement.ts +0 -119
- package/src/indicator/truerange.spec.ts +0 -32
- package/src/indicator/truerange.ts +0 -31
- package/src/shared/policy.spec.ts +0 -25
- package/src/shared/topic.spec.ts +0 -34
- package/src/shared/topic.ts +0 -43
- package/src/store/event/index.ts +0 -8
- package/src/store/event/store-balance.event.ts +0 -161
- package/src/store/event/store-candle.event.spec.ts +0 -30
- package/src/store/event/store-candle.event.ts +0 -71
- package/src/store/event/store-instrument.event.spec.ts +0 -25
- package/src/store/event/store-instrument.event.ts +0 -84
- package/src/store/event/store-order.event.spec.ts +0 -28
- package/src/store/event/store-order.event.ts +0 -218
- package/src/store/event/store-orderbook.event.ts +0 -70
- package/src/store/event/store-position.event.ts +0 -109
- package/src/store/event/store-trade.event.spec.ts +0 -60
- package/src/store/event/store-trade.event.ts +0 -52
- package/src/store/event/store.event.ts +0 -6
- package/src/store/store.state.ts +0 -43
- package/src/tests/backtester-adapter.spec.ts +0 -88
- package/src/tests/session.spec.ts +0 -121
package/dist/indicator/ema.js
CHANGED
|
@@ -2,17 +2,18 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ema = void 0;
|
|
4
4
|
const rxjs_1 = require("rxjs");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
5
6
|
const sma_1 = require("./sma");
|
|
6
7
|
function ema(length, fn) {
|
|
7
8
|
return function (source) {
|
|
8
|
-
const alpha = 2.0
|
|
9
|
+
const alpha = (0, shared_1.d)(2.0).div((0, shared_1.d)(length + 1));
|
|
9
10
|
let value = null;
|
|
10
11
|
return source.pipe((0, sma_1.sma)(length, fn), (0, rxjs_1.map)(([it, sma]) => {
|
|
11
12
|
if (!value) {
|
|
12
13
|
value = sma;
|
|
13
14
|
}
|
|
14
15
|
else {
|
|
15
|
-
value = alpha
|
|
16
|
+
value = alpha.mul(fn(it)).plus((0, shared_1.d)(1.0).minus(alpha).mul(value));
|
|
16
17
|
}
|
|
17
18
|
const tuple = [it, value];
|
|
18
19
|
return tuple;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ema.js","sourceRoot":"","sources":["../../src/indicator/ema.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;AAE9C,+BAA4B;AAE5B,SAAgB,GAAG,CAAI,MAAc,EAAE,
|
|
1
|
+
{"version":3,"file":"ema.js","sourceRoot":"","sources":["../../src/indicator/ema.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;AAE9C,sCAAuC;AACvC,+BAA4B;AAE5B,SAAgB,GAAG,CAAI,MAAc,EAAE,EAAsB;IAC3D,OAAO,UAAU,MAAqB;QACpC,MAAM,KAAK,GAAG,IAAA,UAAC,EAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAA,UAAC,EAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;QACxC,IAAI,KAAK,GAAY,IAAI,CAAC;QAE1B,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,SAAG,EAAC,MAAM,EAAE,EAAE,CAAC,EACf,IAAA,UAAG,EAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE;YAChB,IAAI,CAAC,KAAK,EAAE;gBACV,KAAK,GAAG,GAAG,CAAC;aACb;iBAAM;gBACL,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAA,UAAC,EAAC,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;aAChE;YAED,MAAM,KAAK,GAAiB,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;YAExC,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,EACF,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AArBD,kBAqBC"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const rxjs_1 = require("rxjs");
|
|
4
|
+
const shared_1 = require("../shared");
|
|
4
5
|
const ema_1 = require("./ema");
|
|
5
|
-
describe('ema
|
|
6
|
+
describe('ema', () => {
|
|
6
7
|
test('should return expected value', done => {
|
|
7
8
|
let value;
|
|
8
9
|
(0, rxjs_1.from)([
|
|
@@ -10,11 +11,11 @@ describe('ema tests', () => {
|
|
|
10
11
|
214.22, 213.43, 214.21, 213.66, 215.03, 216.89, 216.66, 216.32, 214.98, 214.96,
|
|
11
12
|
215.05, 215.19
|
|
12
13
|
])
|
|
13
|
-
.pipe((0, ema_1.ema)(20, it => it))
|
|
14
|
+
.pipe((0, ema_1.ema)(20, it => (0, shared_1.d)(it)))
|
|
14
15
|
.subscribe({
|
|
15
16
|
next: ([, it]) => (value = it),
|
|
16
17
|
complete: () => {
|
|
17
|
-
expect(
|
|
18
|
+
expect(value.toDecimalPlaces(4)).toEqual((0, shared_1.d)(214.6336));
|
|
18
19
|
done();
|
|
19
20
|
}
|
|
20
21
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ema.spec.js","sourceRoot":"","sources":["../../src/indicator/ema.spec.ts"],"names":[],"mappings":";;AAAA,+BAA4B;AAE5B,+BAA4B;AAE5B,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"ema.spec.js","sourceRoot":"","sources":["../../src/indicator/ema.spec.ts"],"names":[],"mappings":";;AAAA,+BAA4B;AAE5B,sCAAuC;AACvC,+BAA4B;AAE5B,QAAQ,CAAC,KAAK,EAAE,GAAG,EAAE;IACnB,IAAI,CAAC,8BAA8B,EAAE,IAAI,CAAC,EAAE;QAC1C,IAAI,KAAc,CAAC;QAEnB,IAAA,WAAI,EAAC;YACH,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;YAC7E,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;YAC9E,MAAM,EAAE,MAAM;SACf,CAAC;aACC,IAAI,CAAC,IAAA,SAAG,EAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAA,UAAC,EAAC,EAAE,CAAC,CAAC,CAAC;aAC1B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;YAC9B,QAAQ,EAAE,GAAG,EAAE;gBACb,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,QAAQ,CAAC,CAAC,CAAC;gBACtD,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AAgBL,CAAC,CAAC,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
import { decimal } from '../shared';
|
|
3
|
+
export declare function envelope<T>(length: number, percent: number, valueFn: (it: T) => decimal): (source: Observable<T>) => Observable<{
|
|
4
|
+
min: decimal;
|
|
5
|
+
max: decimal;
|
|
5
6
|
}>;
|
|
@@ -5,11 +5,11 @@ const rxjs_1 = require("rxjs");
|
|
|
5
5
|
const sma_1 = require("./sma");
|
|
6
6
|
function envelope(length, percent, valueFn) {
|
|
7
7
|
return function (source) {
|
|
8
|
-
return source.pipe((0, sma_1.sma)(length, valueFn), (0, rxjs_1.map)(([
|
|
9
|
-
const offset = (
|
|
8
|
+
return source.pipe((0, sma_1.sma)(length, valueFn), (0, rxjs_1.map)(([, sma]) => {
|
|
9
|
+
const offset = sma.mul(percent).div(100);
|
|
10
10
|
return {
|
|
11
|
-
min: sma
|
|
12
|
-
max: sma
|
|
11
|
+
min: sma.minus(offset),
|
|
12
|
+
max: sma.add(offset)
|
|
13
13
|
};
|
|
14
14
|
}), (0, rxjs_1.share)());
|
|
15
15
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"envelope.js","sourceRoot":"","sources":["../../src/indicator/envelope.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;
|
|
1
|
+
{"version":3,"file":"envelope.js","sourceRoot":"","sources":["../../src/indicator/envelope.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;AAG9C,+BAA4B;AAE5B,SAAgB,QAAQ,CACtB,MAAc,EACd,OAAe,EACf,OAA2B;IAE3B,OAAO,UAAU,MAAqB;QACpC,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,SAAG,EAAC,MAAM,EAAE,OAAO,CAAC,EACpB,IAAA,UAAG,EAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,EAAE;YACd,MAAM,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAEzC,OAAO;gBACL,GAAG,EAAE,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC;gBACtB,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC;aACrB,CAAC;QACJ,CAAC,CAAC,EACF,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAnBD,4BAmBC"}
|
package/dist/indicator/index.js
CHANGED
|
@@ -28,7 +28,7 @@ __exportStar(require("./sma"), exports);
|
|
|
28
28
|
__exportStar(require("./swma"), exports);
|
|
29
29
|
__exportStar(require("./tma"), exports);
|
|
30
30
|
__exportStar(require("./trailing"), exports);
|
|
31
|
-
__exportStar(require("./
|
|
31
|
+
__exportStar(require("./true-range"), exports);
|
|
32
32
|
__exportStar(require("./window"), exports);
|
|
33
33
|
__exportStar(require("./wma"), exports);
|
|
34
34
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/indicator/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wCAAsB;AACtB,0CAAwB;AACxB,6CAA2B;AAC3B,6CAA2B;AAC3B,wCAAsB;AACtB,6CAA2B;AAC3B,yCAAuB;AACvB,4CAA0B;AAC1B,gDAA8B;AAC9B,wCAAsB;AACtB,wCAAsB;AACtB,yCAAuB;AACvB,wCAAsB;AACtB,6CAA2B;AAC3B
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/indicator/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wCAAsB;AACtB,0CAAwB;AACxB,6CAA2B;AAC3B,6CAA2B;AAC3B,wCAAsB;AACtB,6CAA2B;AAC3B,yCAAuB;AACvB,4CAA0B;AAC1B,gDAA8B;AAC9B,wCAAsB;AACtB,wCAAsB;AACtB,yCAAuB;AACvB,wCAAsB;AACtB,6CAA2B;AAC3B,+CAA6B;AAC7B,2CAAyB;AACzB,wCAAsB"}
|
package/dist/indicator/macd.d.ts
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
|
|
2
|
+
import { decimal } from '../shared';
|
|
3
|
+
export declare function macd<T>(fast: number, slow: number, length: number, fn: (it: T) => decimal): (source: Observable<T>) => Observable<decimal>;
|
package/dist/indicator/macd.js
CHANGED
|
@@ -6,7 +6,7 @@ const ema_1 = require("./ema");
|
|
|
6
6
|
function macd(fast, slow, length, fn) {
|
|
7
7
|
return function (source) {
|
|
8
8
|
source = source.pipe((0, rxjs_1.share)());
|
|
9
|
-
return source.pipe((0, rxjs_1.withLatestFrom)(source.pipe((0, ema_1.ema)(fast, fn)), source.pipe((0, ema_1.ema)(slow, fn))), (0, ema_1.ema)(length, it => it[1][1]
|
|
9
|
+
return source.pipe((0, rxjs_1.withLatestFrom)(source.pipe((0, ema_1.ema)(fast, fn)), source.pipe((0, ema_1.ema)(slow, fn))), (0, ema_1.ema)(length, it => it[1][1].minus(it[2][1])), (0, rxjs_1.map)(([, macd]) => macd), (0, rxjs_1.share)());
|
|
10
10
|
};
|
|
11
11
|
}
|
|
12
12
|
exports.macd = macd;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"macd.js","sourceRoot":"","sources":["../../src/indicator/macd.ts"],"names":[],"mappings":";;;AAAA,+BAA8D;
|
|
1
|
+
{"version":3,"file":"macd.js","sourceRoot":"","sources":["../../src/indicator/macd.ts"],"names":[],"mappings":";;;AAAA,+BAA8D;AAG9D,+BAA4B;AAE5B,SAAgB,IAAI,CAClB,IAAY,EACZ,IAAY,EACZ,MAAc,EACd,EAAsB;IAEtB,OAAO,UAAU,MAAqB;QACpC,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAA,YAAK,GAAE,CAAC,CAAC;QAE9B,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,qBAAc,EAAC,MAAM,CAAC,IAAI,CAAC,IAAA,SAAG,EAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,IAAA,SAAG,EAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,EACtE,IAAA,SAAG,EAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAC3C,IAAA,UAAG,EAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,EACvB,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAhBD,oBAgBC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
import { decimal } from '../shared';
|
|
3
|
+
export declare function minMax<T>(length: number, fn: (it: T) => decimal): (source: Observable<T>) => Observable<[T, {
|
|
4
|
+
min: decimal;
|
|
5
|
+
max: decimal;
|
|
5
6
|
}]>;
|
|
@@ -2,15 +2,16 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.minMax = void 0;
|
|
4
4
|
const rxjs_1 = require("rxjs");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
5
6
|
const window_1 = require("./window");
|
|
6
7
|
function minMax(length, fn) {
|
|
7
8
|
return function (source) {
|
|
8
9
|
return source.pipe((0, window_1.window)(length, fn), (0, rxjs_1.filter)(([, buffer]) => buffer.isFull), (0, rxjs_1.map)(([it, buffer]) => {
|
|
9
|
-
let min =
|
|
10
|
-
let max =
|
|
10
|
+
let min = shared_1.d.Zero;
|
|
11
|
+
let max = shared_1.d.Zero;
|
|
11
12
|
buffer.forEach(it => {
|
|
12
|
-
min =
|
|
13
|
-
max =
|
|
13
|
+
min = shared_1.decimal.min(it, min);
|
|
14
|
+
max = shared_1.decimal.max(it, max);
|
|
14
15
|
});
|
|
15
16
|
const tuple = [it, { min, max }];
|
|
16
17
|
return tuple;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"min-max.js","sourceRoot":"","sources":["../../src/indicator/min-max.ts"],"names":[],"mappings":";;;AAAA,+BAAsD;AAEtD,qCAAkC;AAElC,SAAgB,MAAM,CAAI,MAAc,EAAE,
|
|
1
|
+
{"version":3,"file":"min-max.js","sourceRoot":"","sources":["../../src/indicator/min-max.ts"],"names":[],"mappings":";;;AAAA,+BAAsD;AAEtD,sCAAuC;AACvC,qCAAkC;AAElC,SAAgB,MAAM,CAAI,MAAc,EAAE,EAAsB;IAC9D,OAAO,UACL,MAAqB;QAErB,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,eAAM,EAAC,MAAM,EAAE,EAAE,CAAC,EAClB,IAAA,aAAM,EAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EACrC,IAAA,UAAG,EAAC,CAAC,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE;YACnB,IAAI,GAAG,GAAG,UAAC,CAAC,IAAI,CAAC;YACjB,IAAI,GAAG,GAAG,UAAC,CAAC,IAAI,CAAC;YAEjB,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;gBAClB,GAAG,GAAG,gBAAO,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC;gBAC3B,GAAG,GAAG,gBAAO,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;YACH,MAAM,KAAK,GAAwC,CAAC,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;YAEtE,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,EACF,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAtBD,wBAsBC"}
|
package/dist/indicator/rma.d.ts
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
|
|
2
|
+
import { decimal } from '../shared';
|
|
3
|
+
export declare function rma<T>(length: number, fn: (it: T) => decimal): (source: Observable<T>) => Observable<[T, decimal]>;
|
package/dist/indicator/rma.js
CHANGED
|
@@ -2,17 +2,18 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.rma = void 0;
|
|
4
4
|
const rxjs_1 = require("rxjs");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
5
6
|
const _1 = require(".");
|
|
6
7
|
function rma(length, fn) {
|
|
7
8
|
return function (source) {
|
|
8
|
-
const alpha = 1.0
|
|
9
|
+
const alpha = (0, shared_1.d)(1.0).div(length);
|
|
9
10
|
let value = null;
|
|
10
11
|
return source.pipe((0, _1.sma)(length, fn), (0, rxjs_1.map)(([it, sma]) => {
|
|
11
12
|
if (!value) {
|
|
12
13
|
value = sma;
|
|
13
14
|
}
|
|
14
15
|
else {
|
|
15
|
-
value = alpha
|
|
16
|
+
value = alpha.mul(fn(it)).plus((0, shared_1.d)(1.0).minus(alpha).mul(value));
|
|
16
17
|
}
|
|
17
18
|
const tuple = [it, value];
|
|
18
19
|
return tuple;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rma.js","sourceRoot":"","sources":["../../src/indicator/rma.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;AAE9C,wBAAwB;AAExB,SAAgB,GAAG,CAAI,MAAc,EAAE,
|
|
1
|
+
{"version":3,"file":"rma.js","sourceRoot":"","sources":["../../src/indicator/rma.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;AAE9C,sCAAuC;AACvC,wBAAwB;AAExB,SAAgB,GAAG,CAAI,MAAc,EAAE,EAAsB;IAC3D,OAAO,UAAU,MAAqB;QACpC,MAAM,KAAK,GAAG,IAAA,UAAC,EAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACjC,IAAI,KAAK,GAAY,IAAI,CAAC;QAE1B,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,MAAG,EAAC,MAAM,EAAE,EAAE,CAAC,EACf,IAAA,UAAG,EAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE;YAChB,IAAI,CAAC,KAAK,EAAE;gBACV,KAAK,GAAG,GAAG,CAAC;aACb;iBAAM;gBACL,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAA,UAAC,EAAC,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;aAChE;YAED,MAAM,KAAK,GAAiB,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;YACxC,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,EACF,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AApBD,kBAoBC"}
|
package/dist/indicator/sma.d.ts
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
|
|
2
|
+
import { decimal } from '../shared';
|
|
3
|
+
export declare function sma<T>(length: number, fn: (it: T) => decimal): (source: Observable<T>) => Observable<[T, decimal]>;
|
package/dist/indicator/sma.js
CHANGED
|
@@ -2,15 +2,13 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.sma = void 0;
|
|
4
4
|
const rxjs_1 = require("rxjs");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
5
6
|
const window_1 = require("./window");
|
|
6
7
|
function sma(length, fn) {
|
|
7
8
|
return function (source) {
|
|
8
|
-
let accumulated =
|
|
9
|
-
return source.pipe((0, window_1.window)(length, fn), (0, rxjs_1.tap)(([, , added, removed]) => {
|
|
10
|
-
|
|
11
|
-
accumulated -= removed;
|
|
12
|
-
}), (0, rxjs_1.filter)(([, buffer]) => buffer.isFull), (0, rxjs_1.map)(([it, buffer]) => {
|
|
13
|
-
const tuple = [it, accumulated / buffer.size];
|
|
9
|
+
let accumulated = shared_1.d.Zero;
|
|
10
|
+
return source.pipe((0, window_1.window)(length, fn), (0, rxjs_1.tap)(([, , added, removed]) => (accumulated = accumulated.add(added).minus(removed !== null && removed !== void 0 ? removed : 0))), (0, rxjs_1.filter)(([, buffer]) => buffer.isFull), (0, rxjs_1.map)(([it, buffer]) => {
|
|
11
|
+
const tuple = [it, accumulated.div(buffer.size)];
|
|
14
12
|
return tuple;
|
|
15
13
|
}), (0, rxjs_1.share)());
|
|
16
14
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sma.js","sourceRoot":"","sources":["../../src/indicator/sma.ts"],"names":[],"mappings":";;;AAAA,+BAA2D;AAE3D,qCAAkC;AAElC,SAAgB,GAAG,CAAI,MAAc,EAAE,
|
|
1
|
+
{"version":3,"file":"sma.js","sourceRoot":"","sources":["../../src/indicator/sma.ts"],"names":[],"mappings":";;;AAAA,+BAA2D;AAE3D,sCAAuC;AACvC,qCAAkC;AAElC,SAAgB,GAAG,CAAI,MAAc,EAAE,EAAsB;IAC3D,OAAO,UAAU,MAAqB;QACpC,IAAI,WAAW,GAAG,UAAC,CAAC,IAAI,CAAC;QAEzB,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,eAAM,EAAC,MAAM,EAAE,EAAE,CAAC,EAClB,IAAA,UAAG,EACD,CAAC,CAAC,EAAE,AAAD,EAAG,KAAK,EAAE,OAAO,CAAC,EAAE,EAAE,CACvB,CAAC,WAAW,GAAG,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,CAAC,CAAC,CAAC,CAC7D,EACD,IAAA,aAAM,EAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EACrC,IAAA,UAAG,EAAC,CAAC,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE;YACnB,MAAM,KAAK,GAAiB,CAAC,EAAE,EAAE,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;YAE/D,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,EACF,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAnBD,kBAmBC"}
|
|
@@ -1,16 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const rxjs_1 = require("rxjs");
|
|
4
|
+
const shared_1 = require("../shared");
|
|
4
5
|
const sma_1 = require("./sma");
|
|
5
|
-
describe('sma
|
|
6
|
+
describe('sma', () => {
|
|
6
7
|
test('should return expected value', done => {
|
|
7
8
|
let value;
|
|
8
9
|
(0, rxjs_1.from)([18136.17, 18092.15, 18082.39, 18065.4, 18046.47])
|
|
9
|
-
.pipe((0, sma_1.sma)(5, it => it))
|
|
10
|
+
.pipe((0, sma_1.sma)(5, it => (0, shared_1.d)(it)))
|
|
10
11
|
.subscribe({
|
|
11
12
|
next: ([, it]) => (value = it),
|
|
12
13
|
complete: () => {
|
|
13
|
-
expect(
|
|
14
|
+
expect(value.toDecimalPlaces(2)).toEqual((0, shared_1.d)(18084.52));
|
|
14
15
|
done();
|
|
15
16
|
}
|
|
16
17
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sma.spec.js","sourceRoot":"","sources":["../../src/indicator/sma.spec.ts"],"names":[],"mappings":";;AAAA,+BAA4B;AAE5B,+BAA4B;AAE5B,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"sma.spec.js","sourceRoot":"","sources":["../../src/indicator/sma.spec.ts"],"names":[],"mappings":";;AAAA,+BAA4B;AAE5B,sCAAuC;AACvC,+BAA4B;AAE5B,QAAQ,CAAC,KAAK,EAAE,GAAG,EAAE;IACnB,IAAI,CAAC,8BAA8B,EAAE,IAAI,CAAC,EAAE;QAC1C,IAAI,KAAc,CAAC;QAGnB,IAAA,WAAI,EAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;aACpD,IAAI,CAAC,IAAA,SAAG,EAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,IAAA,UAAC,EAAC,EAAE,CAAC,CAAC,CAAC;aACzB,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;YAC9B,QAAQ,EAAE,GAAG,EAAE;gBACb,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,QAAQ,CAAC,CAAC,CAAC;gBACtD,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/dist/indicator/swma.d.ts
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
|
|
2
|
+
import { decimal } from '../shared';
|
|
3
|
+
export declare function swma<T>(fn: (it: T) => decimal): (source: Observable<T>) => Observable<[T, decimal]>;
|
package/dist/indicator/swma.js
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.swma = void 0;
|
|
4
4
|
const rxjs_1 = require("rxjs");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
5
6
|
const window_1 = require("./window");
|
|
6
7
|
function swma(fn) {
|
|
7
8
|
return function (source) {
|
|
@@ -10,7 +11,10 @@ function swma(fn) {
|
|
|
10
11
|
const x2 = buffer.at(buffer.capacity - (2 + 1));
|
|
11
12
|
const x1 = buffer.at(buffer.capacity - (1 + 1));
|
|
12
13
|
const x0 = buffer.at(buffer.capacity - (0 + 1));
|
|
13
|
-
const value = (x3
|
|
14
|
+
const value = shared_1.d.Zero.plus(x3.mul(1).div(6))
|
|
15
|
+
.plus(x2.mul(2).div(6))
|
|
16
|
+
.plus(x1.mul(2).div(6))
|
|
17
|
+
.plus(x0.mul(1).div(6));
|
|
14
18
|
const tuple = [it, value];
|
|
15
19
|
return tuple;
|
|
16
20
|
}), (0, rxjs_1.share)());
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"swma.js","sourceRoot":"","sources":["../../src/indicator/swma.ts"],"names":[],"mappings":";;;AAAA,+BAAsD;AAEtD,qCAAkC;AAElC,SAAgB,IAAI,CAAI,
|
|
1
|
+
{"version":3,"file":"swma.js","sourceRoot":"","sources":["../../src/indicator/swma.ts"],"names":[],"mappings":";;;AAAA,+BAAsD;AAEtD,sCAAuC;AACvC,qCAAkC;AAElC,SAAgB,IAAI,CAAI,EAAsB;IAC5C,OAAO,UAAU,MAAqB;QACpC,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,eAAM,EAAC,CAAC,EAAE,EAAE,CAAC,EACb,IAAA,aAAM,EAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EACrC,IAAA,UAAG,EAAC,CAAC,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE;YACnB,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAChD,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAChD,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAChD,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAEhD,MAAM,KAAK,GAAG,UAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;iBACxC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;iBACtB,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;iBACtB,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YAE1B,MAAM,KAAK,GAAiB,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;YACxC,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,EACF,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAtBD,oBAsBC"}
|
package/dist/indicator/tma.d.ts
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
|
|
2
|
+
import { decimal } from '../shared';
|
|
3
|
+
export declare function tma<T>(length: number, fn: (it: T) => decimal): (source: Observable<T>) => Observable<[T, decimal]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tma.js","sourceRoot":"","sources":["../../src/indicator/tma.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;
|
|
1
|
+
{"version":3,"file":"tma.js","sourceRoot":"","sources":["../../src/indicator/tma.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;AAG9C,iCAA8B;AAC9B,+BAA4B;AAE5B,SAAgB,GAAG,CAAI,MAAc,EAAE,EAAsB;IAC3D,OAAO,UAAU,MAAqB;QACpC,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,SAAG,EAAC,MAAM,EAAE,EAAE,CAAC,EACf,IAAA,WAAI,EAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EACpB,IAAA,UAAG,EAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,EAAE;YACnB,MAAM,KAAK,GAAiB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;YAEvC,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,EACF,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAbD,kBAaC"}
|
|
@@ -1,16 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const rxjs_1 = require("rxjs");
|
|
4
|
+
const shared_1 = require("../shared");
|
|
4
5
|
const tma_1 = require("./tma");
|
|
5
|
-
describe('tma
|
|
6
|
+
describe('tma', () => {
|
|
6
7
|
test('should return expected value', done => {
|
|
7
8
|
let value;
|
|
8
9
|
(0, rxjs_1.from)([18086.36, 18116.15, 18127.81, 18136.17, 18092.15, 18082.39, 18065.4, 18046.47])
|
|
9
|
-
.pipe((0, tma_1.tma)(4, it => it))
|
|
10
|
+
.pipe((0, tma_1.tma)(4, it => (0, shared_1.d)(it)))
|
|
10
11
|
.subscribe({
|
|
11
12
|
next: ([, it]) => (value = it),
|
|
12
13
|
complete: () => {
|
|
13
|
-
expect(
|
|
14
|
+
expect(value.toDecimalPlaces(2)).toEqual((0, shared_1.d)(18090.98));
|
|
14
15
|
done();
|
|
15
16
|
}
|
|
16
17
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tma.spec.js","sourceRoot":"","sources":["../../src/indicator/tma.spec.ts"],"names":[],"mappings":";;AAAA,+BAA4B;AAE5B,+BAA4B;AAE5B,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"tma.spec.js","sourceRoot":"","sources":["../../src/indicator/tma.spec.ts"],"names":[],"mappings":";;AAAA,+BAA4B;AAE5B,sCAAuC;AACvC,+BAA4B;AAE5B,QAAQ,CAAC,KAAK,EAAE,GAAG,EAAE;IACnB,IAAI,CAAC,8BAA8B,EAAE,IAAI,CAAC,EAAE;QAC1C,IAAI,KAAc,CAAC;QAGnB,IAAA,WAAI,EAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;aAClF,IAAI,CAAC,IAAA,SAAG,EAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,IAAA,UAAC,EAAC,EAAE,CAAC,CAAC,CAAC;aACzB,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;YAC9B,QAAQ,EAAE,GAAG,EAAE;gBACb,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,QAAQ,CAAC,CAAC,CAAC;gBACtD,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
+
import { decimal } from '../shared';
|
|
2
3
|
export declare class Trailing {
|
|
3
|
-
readonly trigger:
|
|
4
|
-
readonly buffer:
|
|
4
|
+
readonly trigger: decimal;
|
|
5
|
+
readonly buffer: decimal;
|
|
5
6
|
private triggered;
|
|
6
7
|
private max;
|
|
7
8
|
private min;
|
|
8
|
-
constructor(trigger:
|
|
9
|
-
up(value:
|
|
10
|
-
down(value:
|
|
9
|
+
constructor(trigger: decimal, buffer: decimal);
|
|
10
|
+
up(value: decimal): boolean;
|
|
11
|
+
down(value: decimal): boolean;
|
|
11
12
|
}
|
|
12
|
-
export declare function
|
|
13
|
-
export declare function
|
|
13
|
+
export declare function trailingUp<T>(trigger: decimal, buffer: decimal, value: (it: T) => decimal): (source: Observable<T>) => Observable<T>;
|
|
14
|
+
export declare function trailingDown<T>(trigger: decimal, buffer: decimal, value: (it: T) => decimal): (source: Observable<T>) => Observable<T>;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.trailingDown = exports.trailingUp = exports.Trailing = void 0;
|
|
4
4
|
const rxjs_1 = require("rxjs");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
5
6
|
class Trailing {
|
|
6
7
|
constructor(trigger, buffer) {
|
|
7
8
|
this.trigger = trigger;
|
|
@@ -11,7 +12,7 @@ class Trailing {
|
|
|
11
12
|
this.min = null;
|
|
12
13
|
}
|
|
13
14
|
up(value) {
|
|
14
|
-
if (value
|
|
15
|
+
if (value.greaterThanOrEqualTo(this.trigger)) {
|
|
15
16
|
this.triggered = true;
|
|
16
17
|
}
|
|
17
18
|
if (this.triggered) {
|
|
@@ -19,10 +20,10 @@ class Trailing {
|
|
|
19
20
|
this.max = value;
|
|
20
21
|
}
|
|
21
22
|
else {
|
|
22
|
-
this.max =
|
|
23
|
+
this.max = shared_1.decimal.max(this.max, value);
|
|
23
24
|
}
|
|
24
25
|
}
|
|
25
|
-
if (this.triggered && value
|
|
26
|
+
if (this.triggered && value.lessThanOrEqualTo(this.max.minus(this.buffer))) {
|
|
26
27
|
this.triggered = false;
|
|
27
28
|
this.max = null;
|
|
28
29
|
return true;
|
|
@@ -30,7 +31,7 @@ class Trailing {
|
|
|
30
31
|
return false;
|
|
31
32
|
}
|
|
32
33
|
down(value) {
|
|
33
|
-
if (value
|
|
34
|
+
if (value.lessThanOrEqualTo(this.trigger)) {
|
|
34
35
|
this.triggered = true;
|
|
35
36
|
}
|
|
36
37
|
if (this.triggered) {
|
|
@@ -38,10 +39,10 @@ class Trailing {
|
|
|
38
39
|
this.min = value;
|
|
39
40
|
}
|
|
40
41
|
else {
|
|
41
|
-
this.min =
|
|
42
|
+
this.min = shared_1.decimal.min(this.min, value);
|
|
42
43
|
}
|
|
43
44
|
}
|
|
44
|
-
if (this.triggered && value
|
|
45
|
+
if (this.triggered && value.greaterThanOrEqualTo(this.min.plus(this.buffer))) {
|
|
45
46
|
this.triggered = false;
|
|
46
47
|
this.min = null;
|
|
47
48
|
return true;
|
|
@@ -50,18 +51,18 @@ class Trailing {
|
|
|
50
51
|
}
|
|
51
52
|
}
|
|
52
53
|
exports.Trailing = Trailing;
|
|
53
|
-
function
|
|
54
|
+
function trailingUp(trigger, buffer, value) {
|
|
54
55
|
return function (source) {
|
|
55
56
|
const trailing = new Trailing(trigger, buffer);
|
|
56
57
|
return source.pipe((0, rxjs_1.filter)(it => trailing.up(value(it))));
|
|
57
58
|
};
|
|
58
59
|
}
|
|
59
|
-
exports.
|
|
60
|
-
function
|
|
60
|
+
exports.trailingUp = trailingUp;
|
|
61
|
+
function trailingDown(trigger, buffer, value) {
|
|
61
62
|
return function (source) {
|
|
62
63
|
const trailing = new Trailing(trigger, buffer);
|
|
63
64
|
return source.pipe((0, rxjs_1.filter)(it => trailing.down(value(it))));
|
|
64
65
|
};
|
|
65
66
|
}
|
|
66
|
-
exports.
|
|
67
|
+
exports.trailingDown = trailingDown;
|
|
67
68
|
//# sourceMappingURL=trailing.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"trailing.js","sourceRoot":"","sources":["../../src/indicator/trailing.ts"],"names":[],"mappings":";;;AAAA,+BAA0C;AAE1C,MAAa,QAAQ;IAKnB,YAAqB,
|
|
1
|
+
{"version":3,"file":"trailing.js","sourceRoot":"","sources":["../../src/indicator/trailing.ts"],"names":[],"mappings":";;;AAAA,+BAA0C;AAE1C,sCAAuC;AAEvC,MAAa,QAAQ;IAKnB,YAAqB,OAAgB,EAAW,MAAe;QAA1C,YAAO,GAAP,OAAO,CAAS;QAAW,WAAM,GAAN,MAAM,CAAS;QAJvD,cAAS,GAAG,KAAK,CAAC;QAClB,QAAG,GAAY,IAAI,CAAC;QACpB,QAAG,GAAY,IAAI,CAAC;IAEsC,CAAC;IAEnE,EAAE,CAAC,KAAc;QACf,IAAI,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;QAED,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;gBACb,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC;aAClB;iBAAM;gBACL,IAAI,CAAC,GAAG,GAAG,gBAAO,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;aACzC;SACF;QAED,IAAI,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE;YAC1E,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC;YAEhB,OAAO,IAAI,CAAC;SACb;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,CAAC,KAAc;QACjB,IAAI,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;QAED,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;gBACb,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC;aAClB;iBAAM;gBACL,IAAI,CAAC,GAAG,GAAG,gBAAO,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;aACzC;SACF;QAED,IAAI,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE;YAC5E,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC;YAEhB,OAAO,IAAI,CAAC;SACb;QAED,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AApDD,4BAoDC;AAED,SAAgB,UAAU,CACxB,OAAgB,EAChB,MAAe,EACf,KAAyB;IAEzB,OAAO,UAAU,MAAqB;QACpC,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAE/C,OAAO,MAAM,CAAC,IAAI,CAAC,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3D,CAAC,CAAC;AACJ,CAAC;AAVD,gCAUC;AAED,SAAgB,YAAY,CAC1B,OAAgB,EAChB,MAAe,EACf,KAAyB;IAEzB,OAAO,UAAU,MAAqB;QACpC,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAE/C,OAAO,MAAM,CAAC,IAAI,CAAC,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC;AACJ,CAAC;AAVD,oCAUC"}
|
|
@@ -1,19 +1,20 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const rxjs_1 = require("rxjs");
|
|
4
|
+
const shared_1 = require("../shared");
|
|
4
5
|
const trailing_1 = require("./trailing");
|
|
5
|
-
describe('
|
|
6
|
+
describe('trailingUp', () => {
|
|
6
7
|
test('should trigger uptrend once', done => {
|
|
7
8
|
let triggered = false;
|
|
8
9
|
(0, rxjs_1.from)([1, 2, 3, 2, 3])
|
|
9
|
-
.pipe((0, trailing_1.
|
|
10
|
+
.pipe((0, rxjs_1.map)(it => (0, shared_1.d)(it)), (0, trailing_1.trailingUp)((0, shared_1.d)(3), (0, shared_1.d)(1), it => it))
|
|
10
11
|
.subscribe({
|
|
11
12
|
next: it => {
|
|
12
|
-
expect(it).
|
|
13
|
+
expect(it).toEqual((0, shared_1.d)(2));
|
|
13
14
|
triggered = true;
|
|
14
15
|
},
|
|
15
16
|
complete: () => {
|
|
16
|
-
expect(triggered).
|
|
17
|
+
expect(triggered).toEqual(true);
|
|
17
18
|
done();
|
|
18
19
|
}
|
|
19
20
|
});
|
|
@@ -21,31 +22,31 @@ describe('trailing up tests', () => {
|
|
|
21
22
|
test('should trigger uptrend twice', done => {
|
|
22
23
|
let triggered = 0;
|
|
23
24
|
(0, rxjs_1.from)([1, 2, 3, 2, 3, 2, 3])
|
|
24
|
-
.pipe((0, trailing_1.
|
|
25
|
+
.pipe((0, rxjs_1.map)(it => (0, shared_1.d)(it)), (0, trailing_1.trailingUp)((0, shared_1.d)(3), (0, shared_1.d)(1), it => it))
|
|
25
26
|
.subscribe({
|
|
26
27
|
next: it => {
|
|
27
|
-
expect(it).
|
|
28
|
+
expect((0, shared_1.d)(it)).toEqual((0, shared_1.d)(2));
|
|
28
29
|
triggered++;
|
|
29
30
|
},
|
|
30
31
|
complete: () => {
|
|
31
|
-
expect(triggered).
|
|
32
|
+
expect(triggered).toEqual(2);
|
|
32
33
|
done();
|
|
33
34
|
}
|
|
34
35
|
});
|
|
35
36
|
});
|
|
36
37
|
});
|
|
37
|
-
describe('
|
|
38
|
+
describe('trailingDown', () => {
|
|
38
39
|
test('should trigger downtrend once', done => {
|
|
39
40
|
let triggered = false;
|
|
40
41
|
(0, rxjs_1.from)([3, 2, 1, 2, 1])
|
|
41
|
-
.pipe((0, trailing_1.
|
|
42
|
+
.pipe((0, rxjs_1.map)(it => (0, shared_1.d)(it)), (0, trailing_1.trailingDown)((0, shared_1.d)(3), (0, shared_1.d)(1), it => it))
|
|
42
43
|
.subscribe({
|
|
43
44
|
next: it => {
|
|
44
|
-
expect(it).
|
|
45
|
+
expect(it).toEqual((0, shared_1.d)(2));
|
|
45
46
|
triggered = true;
|
|
46
47
|
},
|
|
47
48
|
complete: () => {
|
|
48
|
-
expect(triggered).
|
|
49
|
+
expect(triggered).toEqual(true);
|
|
49
50
|
done();
|
|
50
51
|
}
|
|
51
52
|
});
|
|
@@ -53,14 +54,14 @@ describe('trailingdown tests', () => {
|
|
|
53
54
|
test('should trigger downtrend twice', done => {
|
|
54
55
|
let triggered = 0;
|
|
55
56
|
(0, rxjs_1.from)([3, 2, 1, 2, 1, 2, 1])
|
|
56
|
-
.pipe((0, trailing_1.
|
|
57
|
+
.pipe((0, rxjs_1.map)(it => (0, shared_1.d)(it)), (0, trailing_1.trailingDown)((0, shared_1.d)(3), (0, shared_1.d)(1), it => it))
|
|
57
58
|
.subscribe({
|
|
58
59
|
next: it => {
|
|
59
|
-
expect(it).
|
|
60
|
+
expect(it).toEqual((0, shared_1.d)(2));
|
|
60
61
|
triggered++;
|
|
61
62
|
},
|
|
62
63
|
complete: () => {
|
|
63
|
-
expect(triggered).
|
|
64
|
+
expect(triggered).toEqual(2);
|
|
64
65
|
done();
|
|
65
66
|
}
|
|
66
67
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"trailing.spec.js","sourceRoot":"","sources":["../../src/indicator/trailing.spec.ts"],"names":[],"mappings":";;AAAA,+
|
|
1
|
+
{"version":3,"file":"trailing.spec.js","sourceRoot":"","sources":["../../src/indicator/trailing.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.trueRange = void 0;
|
|
4
|
+
const rxjs_1 = require("rxjs");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
6
|
+
function trueRange(fn) {
|
|
7
|
+
return function (source) {
|
|
8
|
+
let previous;
|
|
9
|
+
return source.pipe((0, rxjs_1.map)(it => {
|
|
10
|
+
const current = fn(it);
|
|
11
|
+
const value = previous == null
|
|
12
|
+
? current.high.minus(current.low)
|
|
13
|
+
: shared_1.decimal.max(shared_1.decimal.max(current.high.minus(current.low), shared_1.decimal.abs(current.high.minus(previous.close))), shared_1.decimal.abs(current.low.minus(previous.close)));
|
|
14
|
+
const tuple = [it, value];
|
|
15
|
+
return tuple;
|
|
16
|
+
}), (0, rxjs_1.share)());
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
exports.trueRange = trueRange;
|
|
20
|
+
//# sourceMappingURL=true-range.js.map
|