@quantform/core 0.3.222 → 0.3.230

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.
Files changed (271) hide show
  1. package/dist/adapter/adapter-aggregate.js +3 -3
  2. package/dist/adapter/adapter-aggregate.js.map +1 -1
  3. package/dist/adapter/adapter.d.ts +4 -4
  4. package/dist/adapter/adapter.event.d.ts +1 -1
  5. package/dist/adapter/adapter.event.js +3 -2
  6. package/dist/adapter/adapter.event.js.map +1 -1
  7. package/dist/adapter/adapter.js +3 -3
  8. package/dist/adapter/backtester/backtester-adapter.d.ts +2 -2
  9. package/dist/adapter/backtester/backtester-adapter.js +3 -5
  10. package/dist/adapter/backtester/backtester-adapter.js.map +1 -1
  11. package/dist/adapter/backtester/backtester-cursor.d.ts +2 -2
  12. package/dist/adapter/backtester/backtester-cursor.js +5 -1
  13. package/dist/adapter/backtester/backtester-cursor.js.map +1 -1
  14. package/dist/adapter/backtester/backtester-cursor.spec.js +5 -5
  15. package/dist/adapter/backtester/backtester-cursor.spec.js.map +1 -1
  16. package/dist/adapter/backtester/backtester-streamer.d.ts +1 -1
  17. package/dist/{common/decimals.spec.d.ts → adapter/backtester/backtester-streamer.spec.d.ts} +0 -0
  18. package/dist/adapter/backtester/backtester-streamer.spec.js +45 -0
  19. package/dist/adapter/backtester/backtester-streamer.spec.js.map +1 -0
  20. package/dist/adapter/paper/{model/paper-model.d.ts → executor/paper-executor.d.ts} +1 -1
  21. package/dist/adapter/paper/{model/paper-model.js → executor/paper-executor.js} +4 -4
  22. package/dist/adapter/paper/executor/paper-executor.js.map +1 -0
  23. package/dist/adapter/paper/{model/paper-margin-model.d.ts → executor/paper-margin-executor.d.ts} +2 -2
  24. package/dist/adapter/paper/{model/paper-margin-model.js → executor/paper-margin-executor.js} +11 -11
  25. package/dist/adapter/paper/executor/paper-margin-executor.js.map +1 -0
  26. package/dist/adapter/paper/{model/paper-spot-model.d.ts → executor/paper-spot-executor.d.ts} +3 -3
  27. package/dist/adapter/paper/{model/paper-spot-model.js → executor/paper-spot-executor.js} +7 -7
  28. package/dist/adapter/paper/executor/paper-spot-executor.js.map +1 -0
  29. package/dist/adapter/paper/index.d.ts +2 -2
  30. package/dist/adapter/paper/index.js +2 -2
  31. package/dist/adapter/paper/index.js.map +1 -1
  32. package/dist/adapter/paper/paper-adapter.d.ts +3 -3
  33. package/dist/adapter/paper/paper-adapter.js +6 -6
  34. package/dist/adapter/paper/paper-adapter.js.map +1 -1
  35. package/dist/adapter/paper/paper-adapter.spec.js +2 -2
  36. package/dist/adapter/paper/paper-adapter.spec.js.map +1 -1
  37. package/dist/bin.d.ts +2 -2
  38. package/dist/bin.js +6 -4
  39. package/dist/bin.js.map +1 -1
  40. package/dist/domain/asset.js +1 -1
  41. package/dist/domain/balance.d.ts +1 -1
  42. package/dist/domain/balance.js +1 -3
  43. package/dist/domain/balance.js.map +1 -1
  44. package/dist/domain/candle-builder.d.ts +1 -1
  45. package/dist/domain/candle.d.ts +1 -1
  46. package/dist/domain/candle.spec.js +2 -2
  47. package/dist/domain/{commision.d.ts → commission.d.ts} +2 -2
  48. package/dist/domain/{commision.js → commission.js} +7 -7
  49. package/dist/domain/commission.js.map +1 -0
  50. package/dist/domain/component.d.ts +1 -1
  51. package/dist/domain/index.d.ts +1 -1
  52. package/dist/domain/index.js +1 -1
  53. package/dist/domain/index.js.map +1 -1
  54. package/dist/domain/instrument.d.ts +3 -3
  55. package/dist/domain/order.d.ts +1 -1
  56. package/dist/domain/orderbook.d.ts +1 -1
  57. package/dist/domain/position.d.ts +1 -1
  58. package/dist/domain/position.js +3 -3
  59. package/dist/domain/trade.d.ts +1 -1
  60. package/dist/index.d.ts +1 -2
  61. package/dist/index.js +1 -2
  62. package/dist/index.js.map +1 -1
  63. package/dist/indicator/truerange.spec.js +6 -6
  64. package/dist/session/index.d.ts +1 -0
  65. package/dist/session/index.js +1 -0
  66. package/dist/session/index.js.map +1 -1
  67. package/dist/session/session-descriptor.d.ts +2 -3
  68. package/dist/session/session-statement.d.ts +5 -0
  69. package/dist/session/session-statement.js +87 -0
  70. package/dist/session/session-statement.js.map +1 -0
  71. package/dist/session/session.d.ts +3 -3
  72. package/dist/session/session.js +14 -27
  73. package/dist/session/session.js.map +1 -1
  74. package/dist/session/session.spec.js +3 -3
  75. package/dist/session/session.spec.js.map +1 -1
  76. package/dist/{common → shared}/datetime.d.ts +0 -0
  77. package/dist/{common → shared}/datetime.js +0 -0
  78. package/dist/{common → shared}/datetime.js.map +1 -1
  79. package/dist/{common → shared}/decimals.d.ts +0 -0
  80. package/dist/{common → shared}/decimals.js +0 -0
  81. package/dist/{common → shared}/decimals.js.map +1 -1
  82. package/dist/{common/policy.spec.d.ts → shared/decimals.spec.d.ts} +0 -0
  83. package/dist/{common → shared}/decimals.spec.js +0 -0
  84. package/dist/{common → shared}/decimals.spec.js.map +1 -1
  85. package/dist/{common → shared}/index.d.ts +0 -0
  86. package/dist/{common → shared}/index.js +0 -0
  87. package/dist/{common → shared}/index.js.map +1 -1
  88. package/dist/{common → shared}/io.d.ts +0 -0
  89. package/dist/{common → shared}/io.js +0 -0
  90. package/dist/shared/io.js.map +1 -0
  91. package/dist/{common → shared}/logger.d.ts +0 -0
  92. package/dist/{common → shared}/logger.js +0 -0
  93. package/dist/{common → shared}/logger.js.map +1 -1
  94. package/dist/{common → shared}/policy.d.ts +0 -0
  95. package/dist/{common → shared}/policy.js +0 -0
  96. package/dist/{common → shared}/policy.js.map +1 -1
  97. package/dist/{common/topic.spec.d.ts → shared/policy.spec.d.ts} +0 -0
  98. package/dist/{common → shared}/policy.spec.js +0 -0
  99. package/dist/{common → shared}/policy.spec.js.map +1 -1
  100. package/dist/{common → shared}/topic.d.ts +0 -0
  101. package/dist/{common → shared}/topic.js +0 -0
  102. package/dist/{common → shared}/topic.js.map +1 -1
  103. package/dist/{common/worker.spec.d.ts → shared/topic.spec.d.ts} +0 -0
  104. package/dist/{common → shared}/topic.spec.js +0 -0
  105. package/dist/{common → shared}/topic.spec.js.map +1 -1
  106. package/dist/{common → shared}/worker.d.ts +0 -0
  107. package/dist/{common → shared}/worker.js +0 -0
  108. package/dist/{common → shared}/worker.js.map +1 -1
  109. package/dist/shared/worker.spec.d.ts +1 -0
  110. package/dist/{common → shared}/worker.spec.js +0 -0
  111. package/dist/{common → shared}/worker.spec.js.map +1 -1
  112. package/dist/storage/feed.d.ts +7 -4
  113. package/dist/storage/feed.js +21 -0
  114. package/dist/storage/feed.js.map +1 -1
  115. package/dist/storage/index.d.ts +1 -2
  116. package/dist/storage/index.js +1 -2
  117. package/dist/storage/index.js.map +1 -1
  118. package/dist/storage/measurement.d.ts +7 -9
  119. package/dist/storage/measurement.js +25 -0
  120. package/dist/storage/measurement.js.map +1 -1
  121. package/dist/storage/storage.d.ts +23 -0
  122. package/dist/storage/storage.js +48 -0
  123. package/dist/storage/storage.js.map +1 -0
  124. package/dist/store/event/store-balance.event.d.ts +1 -1
  125. package/dist/store/event/store-balance.event.js +1 -1
  126. package/dist/store/event/store-balance.event.spec.js +3 -3
  127. package/dist/store/event/store-balance.event.spec.js.map +1 -1
  128. package/dist/store/event/store-candle.event.d.ts +2 -2
  129. package/dist/store/event/store-candle.event.js +31 -3
  130. package/dist/store/event/store-candle.event.js.map +1 -1
  131. package/dist/store/event/store-candle.event.spec.d.ts +1 -0
  132. package/dist/store/event/store-candle.event.spec.js +24 -0
  133. package/dist/store/event/store-candle.event.spec.js.map +1 -0
  134. package/dist/store/event/store-instrument.event.d.ts +4 -4
  135. package/dist/store/event/store-instrument.event.js +3 -3
  136. package/dist/store/event/store-instrument.event.js.map +1 -1
  137. package/dist/store/event/store-instrument.event.spec.js +3 -3
  138. package/dist/store/event/store-instrument.event.spec.js.map +1 -1
  139. package/dist/store/event/store-order.event.d.ts +1 -1
  140. package/dist/store/event/store-order.event.js +1 -1
  141. package/dist/store/event/store-order.event.spec.js +2 -2
  142. package/dist/store/event/store-orderbook.event.d.ts +1 -1
  143. package/dist/store/event/store-orderbook.event.js +1 -1
  144. package/dist/store/event/store-position.event.d.ts +1 -1
  145. package/dist/store/event/store-position.event.js +1 -1
  146. package/dist/store/event/store-trade.event.d.ts +1 -1
  147. package/dist/store/event/store-trade.event.js +1 -1
  148. package/dist/store/event/store-trade.event.spec.js +6 -6
  149. package/dist/store/event/store-trade.event.spec.js.map +1 -1
  150. package/dist/store/event/store.event.d.ts +1 -1
  151. package/dist/store/store.d.ts +2 -2
  152. package/dist/store/store.js +1 -1
  153. package/dist/store/store.state.d.ts +1 -1
  154. package/dist/store/store.state.js.map +1 -1
  155. package/dist/tests/backtester-adapter.spec.js +7 -7
  156. package/dist/tests/backtester-adapter.spec.js.map +1 -1
  157. package/dist/tsconfig.tsbuildinfo +1 -1
  158. package/jestconfig.unit.json +2 -1
  159. package/package.json +1 -1
  160. package/src/adapter/adapter-aggregate.ts +4 -2
  161. package/src/adapter/adapter.event.ts +2 -2
  162. package/src/adapter/adapter.ts +4 -4
  163. package/src/adapter/backtester/backtester-adapter.ts +4 -6
  164. package/src/adapter/backtester/backtester-cursor.spec.ts +8 -8
  165. package/src/adapter/backtester/backtester-cursor.ts +7 -3
  166. package/src/adapter/backtester/backtester-streamer.spec.ts +53 -0
  167. package/src/adapter/backtester/backtester-streamer.ts +1 -1
  168. package/src/adapter/paper/{model/paper-model.ts → executor/paper-executor.ts} +1 -1
  169. package/src/adapter/paper/{model/paper-margin-model.ts → executor/paper-margin-executor.ts} +4 -4
  170. package/src/adapter/paper/{model/paper-spot-model.ts → executor/paper-spot-executor.ts} +5 -5
  171. package/src/adapter/paper/index.ts +2 -2
  172. package/src/adapter/paper/paper-adapter.spec.ts +4 -4
  173. package/src/adapter/paper/paper-adapter.ts +8 -8
  174. package/src/bin.ts +8 -6
  175. package/src/domain/asset.ts +2 -2
  176. package/src/domain/balance.ts +3 -5
  177. package/src/domain/candle-builder.ts +1 -1
  178. package/src/domain/candle.spec.ts +1 -1
  179. package/src/domain/candle.ts +1 -1
  180. package/src/domain/{commision.ts → commission.ts} +3 -3
  181. package/src/domain/component.ts +1 -1
  182. package/src/domain/index.ts +1 -1
  183. package/src/domain/instrument.ts +3 -3
  184. package/src/domain/order.ts +1 -1
  185. package/src/domain/orderbook.ts +1 -1
  186. package/src/domain/position.ts +2 -2
  187. package/src/domain/trade.ts +1 -1
  188. package/src/index.ts +1 -7
  189. package/src/indicator/truerange.spec.ts +1 -1
  190. package/src/session/index.ts +1 -0
  191. package/src/session/session-descriptor.ts +29 -7
  192. package/src/session/session-statement.ts +119 -0
  193. package/src/session/session.spec.ts +6 -4
  194. package/src/session/session.ts +67 -33
  195. package/src/{common → shared}/datetime.ts +0 -0
  196. package/src/{common → shared}/decimals.spec.ts +0 -0
  197. package/src/{common → shared}/decimals.ts +0 -0
  198. package/src/{common → shared}/index.ts +0 -0
  199. package/src/{common → shared}/io.ts +0 -0
  200. package/src/{common → shared}/logger.ts +0 -0
  201. package/src/{common → shared}/policy.spec.ts +0 -0
  202. package/src/{common → shared}/policy.ts +0 -0
  203. package/src/{common → shared}/topic.spec.ts +0 -0
  204. package/src/{common → shared}/topic.ts +0 -0
  205. package/src/{common → shared}/worker.spec.ts +0 -0
  206. package/src/{common → shared}/worker.ts +0 -0
  207. package/src/storage/feed.ts +32 -7
  208. package/src/storage/index.ts +1 -2
  209. package/src/storage/measurement.ts +28 -14
  210. package/src/storage/storage.ts +76 -0
  211. package/src/store/event/store-balance.event.spec.ts +3 -3
  212. package/src/store/event/store-balance.event.ts +2 -2
  213. package/src/store/event/store-candle.event.spec.ts +32 -0
  214. package/src/store/event/store-candle.event.ts +26 -2
  215. package/src/store/event/store-instrument.event.spec.ts +3 -3
  216. package/src/store/event/store-instrument.event.ts +5 -5
  217. package/src/store/event/store-order.event.spec.ts +1 -1
  218. package/src/store/event/store-order.event.ts +2 -2
  219. package/src/store/event/store-orderbook.event.ts +2 -2
  220. package/src/store/event/store-position.event.ts +2 -2
  221. package/src/store/event/store-trade.event.spec.ts +2 -2
  222. package/src/store/event/store-trade.event.ts +2 -2
  223. package/src/store/event/store.event.ts +1 -1
  224. package/src/store/store.state.ts +2 -1
  225. package/src/store/store.ts +1 -1
  226. package/src/tests/backtester-adapter.spec.ts +10 -10
  227. package/dist/adapter/paper/model/paper-margin-model.js.map +0 -1
  228. package/dist/adapter/paper/model/paper-model.js.map +0 -1
  229. package/dist/adapter/paper/model/paper-spot-model.js.map +0 -1
  230. package/dist/behaviour/behaviour.d.ts +0 -6
  231. package/dist/behaviour/behaviour.js +0 -3
  232. package/dist/behaviour/behaviour.js.map +0 -1
  233. package/dist/behaviour/combined-behaviour.d.ts +0 -14
  234. package/dist/behaviour/combined-behaviour.js +0 -26
  235. package/dist/behaviour/combined-behaviour.js.map +0 -1
  236. package/dist/behaviour/index.d.ts +0 -3
  237. package/dist/behaviour/index.js +0 -16
  238. package/dist/behaviour/index.js.map +0 -1
  239. package/dist/behaviour/statement/benchmark-statement.behaviour.d.ts +0 -15
  240. package/dist/behaviour/statement/benchmark-statement.behaviour.js +0 -41
  241. package/dist/behaviour/statement/benchmark-statement.behaviour.js.map +0 -1
  242. package/dist/behaviour/statement/equity-statement.behaviour.d.ts +0 -15
  243. package/dist/behaviour/statement/equity-statement.behaviour.js +0 -54
  244. package/dist/behaviour/statement/equity-statement.behaviour.js.map +0 -1
  245. package/dist/behaviour/statement/index.d.ts +0 -1
  246. package/dist/behaviour/statement/index.js +0 -14
  247. package/dist/behaviour/statement/index.js.map +0 -1
  248. package/dist/behaviour/statement/period-statement.behaviour.d.ts +0 -9
  249. package/dist/behaviour/statement/period-statement.behaviour.js +0 -20
  250. package/dist/behaviour/statement/period-statement.behaviour.js.map +0 -1
  251. package/dist/behaviour/statement/statement.behaviour.d.ts +0 -7
  252. package/dist/behaviour/statement/statement.behaviour.js +0 -19
  253. package/dist/behaviour/statement/statement.behaviour.js.map +0 -1
  254. package/dist/common/io.js.map +0 -1
  255. package/dist/domain/commision.js.map +0 -1
  256. package/dist/storage/feed.interceptor.d.ts +0 -14
  257. package/dist/storage/feed.interceptor.js +0 -52
  258. package/dist/storage/feed.interceptor.js.map +0 -1
  259. package/dist/storage/in-memory.feed.d.ts +0 -10
  260. package/dist/storage/in-memory.feed.js +0 -30
  261. package/dist/storage/in-memory.feed.js.map +0 -1
  262. package/src/behaviour/behaviour.ts +0 -7
  263. package/src/behaviour/combined-behaviour.ts +0 -23
  264. package/src/behaviour/index.ts +0 -3
  265. package/src/behaviour/statement/benchmark-statement.behaviour.ts +0 -53
  266. package/src/behaviour/statement/equity-statement.behaviour.ts +0 -71
  267. package/src/behaviour/statement/index.ts +0 -1
  268. package/src/behaviour/statement/period-statement.behaviour.ts +0 -26
  269. package/src/behaviour/statement/statement.behaviour.ts +0 -19
  270. package/src/storage/feed.interceptor.ts +0 -92
  271. package/src/storage/in-memory.feed.ts +0 -38
@@ -1,52 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.fromCandle = exports.FeedInterceptor = void 0;
4
- const event_1 = require("../store/event");
5
- class FeedInterceptor {
6
- constructor(feed) {
7
- this.feed = feed;
8
- }
9
- async read(instrument, from, to) {
10
- const output = new Array();
11
- for (const event of await this.feed.read(instrument, from, to)) {
12
- const intercepted = this.intercept(instrument, event);
13
- if (!intercepted) {
14
- continue;
15
- }
16
- if (Array.isArray(intercepted)) {
17
- output.push(...intercepted);
18
- }
19
- else {
20
- output.push(intercepted);
21
- }
22
- }
23
- return output;
24
- }
25
- write(instrument, events) {
26
- return this.feed.write(instrument, events);
27
- }
28
- }
29
- exports.FeedInterceptor = FeedInterceptor;
30
- class FeedCandleInterceptor extends FeedInterceptor {
31
- constructor(feed, options) {
32
- super(feed);
33
- this.options = options;
34
- }
35
- intercept(instrument, event) {
36
- const output = [];
37
- if (event.type == 'candle') {
38
- if (this.options.orderbook) {
39
- output.push(new event_1.OrderbookPatchEvent(instrument, event.close, 0, event.close, 0, event.timestamp));
40
- }
41
- if (this.options.trade) {
42
- output.push(new event_1.TradePatchEvent(event.instrument, event.close, 0, event.timestamp));
43
- }
44
- return output;
45
- }
46
- }
47
- }
48
- function fromCandle(feed, options) {
49
- return new FeedCandleInterceptor(feed, options);
50
- }
51
- exports.fromCandle = fromCandle;
52
- //# sourceMappingURL=feed.interceptor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"feed.interceptor.js","sourceRoot":"","sources":["../../src/storage/feed.interceptor.ts"],"names":[],"mappings":";;;AACA,0CAAkF;AAGlF,MAAsB,eAAe;IACnC,YAA6B,IAAU;QAAV,SAAI,GAAJ,IAAI,CAAM;IAAG,CAAC;IAO3C,KAAK,CAAC,IAAI,CACR,UAA8B,EAC9B,IAAY,EACZ,EAAU;QAEV,MAAM,MAAM,GAAG,IAAI,KAAK,EAAc,CAAC;QAEvC,KAAK,MAAM,KAAK,IAAI,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,EAAE,CAAC,EAAE;YAC9D,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;YAEtD,IAAI,CAAC,WAAW,EAAE;gBAChB,SAAS;aACV;YAED,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;gBAC9B,MAAM,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,CAAC;aAC7B;iBAAM;gBACL,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC1B;SACF;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,UAA8B,EAAE,MAAoB;QACxD,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;IAC7C,CAAC;CACF;AAnCD,0CAmCC;AAED,MAAM,qBAAsB,SAAQ,eAAe;IACjD,YACE,IAAU,EACO,OAGhB;QAED,KAAK,CAAC,IAAI,CAAC,CAAC;QALK,YAAO,GAAP,OAAO,CAGvB;IAGH,CAAC;IAED,SAAS,CACP,UAA8B,EAC9B,KAAuB;QAEvB,MAAM,MAAM,GAAG,EAAE,CAAC;QAElB,IAAI,KAAK,CAAC,IAAI,IAAI,QAAQ,EAAE;YAC1B,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;gBAC1B,MAAM,CAAC,IAAI,CACT,IAAI,2BAAmB,CACrB,UAAU,EACV,KAAK,CAAC,KAAK,EACX,CAAC,EACD,KAAK,CAAC,KAAK,EACX,CAAC,EACD,KAAK,CAAC,SAAS,CAChB,CACF,CAAC;aACH;YAED,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;gBACtB,MAAM,CAAC,IAAI,CACT,IAAI,uBAAe,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CACvE,CAAC;aACH;YAED,OAAO,MAAM,CAAC;SACf;IACH,CAAC;CACF;AAED,SAAgB,UAAU,CACxB,IAAU,EACV,OAGC;IAED,OAAO,IAAI,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AAClD,CAAC;AARD,gCAQC"}
@@ -1,10 +0,0 @@
1
- import { timestamp } from '../common';
2
- import { InstrumentSelector } from '../domain';
3
- import { StoreEvent } from '../store/event';
4
- import { Feed } from '.';
5
- export declare class InMemoryFeed implements Feed {
6
- private data;
7
- read(instrument: InstrumentSelector, from: timestamp, to: timestamp): Promise<StoreEvent[]>;
8
- write(instrument: InstrumentSelector, events: StoreEvent[]): Promise<void>;
9
- clear(): void;
10
- }
@@ -1,30 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryFeed = void 0;
4
- class InMemoryFeed {
5
- constructor() {
6
- this.data = {};
7
- }
8
- async read(instrument, from, to) {
9
- if (!this.data[instrument.toString()]) {
10
- return [];
11
- }
12
- return this.data[instrument.toString()]
13
- .filter(it => it.timestamp > from && it.timestamp <= to)
14
- .sort((lhs, rhs) => lhs.timestamp - rhs.timestamp);
15
- }
16
- async write(instrument, events) {
17
- if (!this.data[instrument.toString()]) {
18
- this.data[instrument.toString()] = [];
19
- }
20
- const buffer = this.data[instrument.toString()];
21
- for (const event of events) {
22
- buffer.push(event);
23
- }
24
- }
25
- clear() {
26
- this.data = {};
27
- }
28
- }
29
- exports.InMemoryFeed = InMemoryFeed;
30
- //# sourceMappingURL=in-memory.feed.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.feed.js","sourceRoot":"","sources":["../../src/storage/in-memory.feed.ts"],"names":[],"mappings":";;;AAKA,MAAa,YAAY;IAAzB;QACU,SAAI,GAAiC,EAAE,CAAC;IA+BlD,CAAC;IA7BC,KAAK,CAAC,IAAI,CACR,UAA8B,EAC9B,IAAe,EACf,EAAa;QAEb,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,EAAE;YACrC,OAAO,EAAE,CAAC;SACX;QAED,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;aACpC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,SAAS,IAAI,EAAE,CAAC;aACvD,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC;IACvD,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,UAA8B,EAAE,MAAoB;QAC9D,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC;SACvC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEhD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;YAC1B,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACpB;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;IACjB,CAAC;CACF;AAhCD,oCAgCC"}
@@ -1,7 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- import { Session } from '../session';
3
-
4
- export interface Behaviour {
5
- describe(session: Session): Observable<any>;
6
- statement?(output: Record<string, any>): void;
7
- }
@@ -1,23 +0,0 @@
1
- import { forkJoin, Observable } from 'rxjs';
2
- import { Session } from '../session';
3
- import { Behaviour } from './behaviour';
4
-
5
- export class CombinedBehaviour implements Behaviour {
6
- constructor(private readonly behaviours: Behaviour[]) {}
7
-
8
- describe(session: Session): Observable<any> {
9
- return forkJoin(this.behaviours.map(b => b.describe(session)));
10
- }
11
-
12
- statement?(output: Record<string, any>): void {
13
- this.behaviours.forEach(it => it.statement && it.statement(output));
14
- }
15
- }
16
-
17
- export class FunctionBehaviour implements Behaviour {
18
- constructor(private readonly func: (session: Session) => Observable<any>) {}
19
-
20
- describe(session: Session): Observable<any> {
21
- return this.func(session);
22
- }
23
- }
@@ -1,3 +0,0 @@
1
- export * from './behaviour';
2
- export * from './combined-behaviour';
3
- export * from './statement/index';
@@ -1,53 +0,0 @@
1
- import { combineLatest, Observable } from 'rxjs';
2
- import { Balance, InstrumentSelector, Orderbook } from '../../domain';
3
- import { Behaviour } from '..';
4
- import { Session } from '../../session';
5
- import { floor, precision } from '../../common';
6
- import { map, tap } from 'rxjs/operators';
7
- import { drawdown } from '../../indicator';
8
-
9
- export class BenchmarkStatementBehaviour implements Behaviour {
10
- private balance: number;
11
- private entry: number;
12
- private exit: number;
13
-
14
- private drawdown = 0;
15
-
16
- constructor(private readonly instrument: InstrumentSelector) {}
17
-
18
- describe(session: Session): Observable<any> {
19
- return combineLatest([
20
- session.orderbook(this.instrument),
21
- session.balance(this.instrument.quote),
22
- session.orderbook(this.instrument).pipe(
23
- drawdown(it => it.midRate),
24
- tap(it => (this.drawdown = it))
25
- )
26
- ]).pipe(map(it => this.update(it[0], it[1])));
27
- }
28
-
29
- private update(orderbook: Orderbook, quote: Balance): void {
30
- const price = orderbook.midRate;
31
-
32
- if (!this.balance) {
33
- this.balance = quote.total;
34
- }
35
-
36
- if (!this.entry) {
37
- this.entry = price;
38
- }
39
-
40
- this.exit = price;
41
- }
42
-
43
- statement?(output: Record<string, any>): void {
44
- const pnl = this.exit / this.entry - 1;
45
- const scale = precision(this.entry);
46
-
47
- output['benchmark_entry'] = this.entry;
48
- output['benchmark_exit'] = this.exit;
49
- output['benchmark_pnl'] = floor(this.balance * pnl, scale);
50
- output['benchmark_pnl_pp'] = floor(pnl * 100, 2);
51
- output['benchmark_drawdown_pp'] = floor(this.drawdown * 100, 2);
52
- }
53
- }
@@ -1,71 +0,0 @@
1
- import { InstrumentSelector } from '../../domain';
2
- import { Behaviour } from '..';
3
- import { Session } from '../../session';
4
- import { drawdown } from '../../indicator';
5
- import { floor, precision } from '../../common';
6
- import { combineLatest, Observable } from 'rxjs';
7
- import { map, tap } from 'rxjs/operators';
8
-
9
- export class EquityStatementBehaviour implements Behaviour {
10
- private balance: number;
11
- private drawdown = 0;
12
- private equity = 0;
13
- private min: number;
14
- private max: number;
15
-
16
- constructor(private readonly instrument: InstrumentSelector) {}
17
-
18
- describe(session: Session): Observable<any> {
19
- return combineLatest([
20
- session.orderbook(this.instrument),
21
- session.balance(this.instrument.base),
22
- session.balance(this.instrument.quote),
23
- session.positions(this.instrument)
24
- ]).pipe(
25
- tap(([, , quote]) => {
26
- if (!this.balance) {
27
- this.balance = quote.total;
28
- }
29
- }),
30
- map(([orderbook, base, quote, positions]) =>
31
- orderbook.instrument.quote.fixed(
32
- quote.total +
33
- base.total * orderbook.bestBidRate +
34
- positions.reduce(
35
- (agg, position) => agg + position.calculatePnL(orderbook.bestBidRate),
36
- 0
37
- )
38
- )
39
- ),
40
- tap(it => {
41
- if (!this.min) {
42
- this.min = it;
43
- } else {
44
- this.min = Math.min(this.min, it);
45
- }
46
-
47
- if (!this.max) {
48
- this.max = it;
49
- } else {
50
- this.max = Math.max(this.max, it);
51
- }
52
-
53
- this.equity = it;
54
- }),
55
- drawdown(it => it),
56
- tap(it => (this.drawdown = it))
57
- );
58
- }
59
-
60
- statement?(output: Record<string, any>): void {
61
- const pnl = this.equity / this.balance - 1;
62
- const scale = precision(this.equity);
63
-
64
- output['equity'] = this.equity;
65
- output['equity_min'] = this.min;
66
- output['equity_max'] = this.max;
67
- output['equity_pnl'] = floor(this.balance * pnl, scale);
68
- output['equity_pnl_pp'] = floor(pnl * 100, 2);
69
- output['equity_drawdown_pp'] = floor(this.drawdown * 100, 2);
70
- }
71
- }
@@ -1 +0,0 @@
1
- export * from './statement.behaviour';
@@ -1,26 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- import { Session } from '../../session';
3
- import { Behaviour } from '..';
4
- import { map } from 'rxjs/operators';
5
-
6
- export class PeriodStatementBehaviour implements Behaviour {
7
- private from: number;
8
- private to: number;
9
-
10
- describe(session: Session): Observable<any> {
11
- return session.store.changes$.pipe(
12
- map(it => {
13
- if (!this.from) {
14
- this.from = it.timestamp;
15
- }
16
-
17
- this.to = it.timestamp;
18
- })
19
- );
20
- }
21
-
22
- statement?(statement: Record<string, any>): void {
23
- statement['period_from'] = new Date(this.from).toISOString();
24
- statement['period_to'] = new Date(this.to).toISOString();
25
- }
26
- }
@@ -1,19 +0,0 @@
1
- import { InstrumentSelector } from '../../domain';
2
- import { Behaviour } from '../behaviour';
3
- import { BenchmarkStatementBehaviour } from './benchmark-statement.behaviour';
4
- import { EquityStatementBehaviour } from './equity-statement.behaviour';
5
- import { PeriodStatementBehaviour } from './period-statement.behaviour';
6
-
7
- export class Statement {
8
- static period(): Behaviour {
9
- return new PeriodStatementBehaviour();
10
- }
11
-
12
- static benchmark(instrument: InstrumentSelector): Behaviour {
13
- return new BenchmarkStatementBehaviour(instrument);
14
- }
15
-
16
- static equity(instrument: InstrumentSelector): Behaviour {
17
- return new EquityStatementBehaviour(instrument);
18
- }
19
- }
@@ -1,92 +0,0 @@
1
- import { InstrumentSelector } from '../domain';
2
- import { StoreEvent, OrderbookPatchEvent, TradePatchEvent } from '../store/event';
3
- import { Feed } from './feed';
4
-
5
- export abstract class FeedInterceptor implements Feed {
6
- constructor(private readonly feed: Feed) {}
7
-
8
- abstract intercept(
9
- instrument: InstrumentSelector,
10
- event: StoreEvent
11
- ): StoreEvent | StoreEvent[];
12
-
13
- async read(
14
- instrument: InstrumentSelector,
15
- from: number,
16
- to: number
17
- ): Promise<StoreEvent[]> {
18
- const output = new Array<StoreEvent>();
19
-
20
- for (const event of await this.feed.read(instrument, from, to)) {
21
- const intercepted = this.intercept(instrument, event);
22
-
23
- if (!intercepted) {
24
- continue;
25
- }
26
-
27
- if (Array.isArray(intercepted)) {
28
- output.push(...intercepted);
29
- } else {
30
- output.push(intercepted);
31
- }
32
- }
33
-
34
- return output;
35
- }
36
-
37
- write(instrument: InstrumentSelector, events: StoreEvent[]): Promise<void> {
38
- return this.feed.write(instrument, events);
39
- }
40
- }
41
-
42
- class FeedCandleInterceptor extends FeedInterceptor {
43
- constructor(
44
- feed: Feed,
45
- private readonly options: {
46
- orderbook: boolean;
47
- trade: boolean;
48
- }
49
- ) {
50
- super(feed);
51
- }
52
-
53
- intercept(
54
- instrument: InstrumentSelector,
55
- event: StoreEvent & any
56
- ): StoreEvent | StoreEvent[] {
57
- const output = [];
58
-
59
- if (event.type == 'candle') {
60
- if (this.options.orderbook) {
61
- output.push(
62
- new OrderbookPatchEvent(
63
- instrument,
64
- event.close, // + instrument.quote.tickSize,
65
- 0,
66
- event.close, // - instrument.quote.tickSize,
67
- 0,
68
- event.timestamp
69
- )
70
- );
71
- }
72
-
73
- if (this.options.trade) {
74
- output.push(
75
- new TradePatchEvent(event.instrument, event.close, 0, event.timestamp)
76
- );
77
- }
78
-
79
- return output;
80
- }
81
- }
82
- }
83
-
84
- export function fromCandle(
85
- feed: Feed,
86
- options: {
87
- orderbook: boolean;
88
- trade: boolean;
89
- }
90
- ): Feed {
91
- return new FeedCandleInterceptor(feed, options);
92
- }
@@ -1,38 +0,0 @@
1
- import { timestamp } from '../common';
2
- import { InstrumentSelector } from '../domain';
3
- import { StoreEvent } from '../store/event';
4
- import { Feed } from '.';
5
-
6
- export class InMemoryFeed implements Feed {
7
- private data: Record<string, StoreEvent[]> = {};
8
-
9
- async read(
10
- instrument: InstrumentSelector,
11
- from: timestamp,
12
- to: timestamp
13
- ): Promise<StoreEvent[]> {
14
- if (!this.data[instrument.toString()]) {
15
- return [];
16
- }
17
-
18
- return this.data[instrument.toString()]
19
- .filter(it => it.timestamp > from && it.timestamp <= to)
20
- .sort((lhs, rhs) => lhs.timestamp - rhs.timestamp);
21
- }
22
-
23
- async write(instrument: InstrumentSelector, events: StoreEvent[]): Promise<void> {
24
- if (!this.data[instrument.toString()]) {
25
- this.data[instrument.toString()] = [];
26
- }
27
-
28
- const buffer = this.data[instrument.toString()];
29
-
30
- for (const event of events) {
31
- buffer.push(event);
32
- }
33
- }
34
-
35
- clear() {
36
- this.data = {};
37
- }
38
- }