Skip to content

Commit 107e40f

Browse files
committed
Add TRA Model
1 parent 4837ba8 commit 107e40f

13 files changed

+2180
-0
lines changed

examples/benchmarks/TRA/README.md

+81
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,81 @@
1+
# Learning Multiple Stock Trading Patterns with Temporal Routing Adaptor and Optimal Transport
2+
3+
This code provides a PyTorch implementation for TRA (Temporal Routing Adaptor), as described in the paper [Learning Multiple Stock Trading Patterns with Temporal Routing Adaptor and Optimal Transport](http://arxiv.org/abs/2106.12950).
4+
5+
* TRA (Temporal Routing Adaptor) is a lightweight module that consists of a set of independent predictors for learning multiple patterns as well as a router to dispatch samples to different predictors.
6+
* We also design a learning algorithm based on Optimal Transport (OT) to obtain the optimal sample to predictor assignment and effectively optimize the router with such assignment through an auxiliary loss term.
7+
8+
9+
# Running TRA
10+
11+
## Requirements
12+
- Install `Qlib` main branch
13+
14+
## Running
15+
16+
We attach our running scripts for the paper in `run.sh`.
17+
18+
And here are two ways to run the model:
19+
20+
* Running from scripts with default parameters
21+
You can directly run from Qlib command `qrun`:
22+
```
23+
qrun configs/config_alstm.yaml
24+
```
25+
26+
* Running from code with self-defined parameters
27+
Setting different parameters is also allowed. See codes in `example.py`:
28+
```
29+
python example.py --config_file configs/config_alstm.yaml
30+
```
31+
32+
Here we trained TRA on a pretrained backbone model. Therefore we run `*_init.yaml` before TRA's scipts.
33+
34+
# Results
35+
36+
## Outputs
37+
38+
After running the scripts, you can find result files in path `./output`:
39+
40+
`info.json` - config settings and result metrics.
41+
42+
`log.csv` - running logs.
43+
44+
`model.bin` - the model parameter dictionary.
45+
46+
`pred.pkl` - the prediction scores and output for inference.
47+
48+
## Our Results
49+
| Methods | MSE| MAE| IC | ICIR | AR | AV | SR | MDD |
50+
|-------------------|-------------------|---------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|
51+
|Linear|0.163|0.327|0.020|0.132|-3.2%|16.8%|-0.191|32.1%|
52+
|LightGBM|0.160(0.000)|0.323(0.000)|0.041|0.292|7.8%|15.5%|0.503|25.7%|
53+
|MLP|0.160(0.002)|0.323(0.003)|0.037|0.273|3.7%|15.3%|0.264|26.2%|
54+
|SFM|0.159(0.001) |0.321(0.001) |0.047 |0.381 |7.1% |14.3% |0.497 |22.9%|
55+
|ALSTM|0.158(0.001) |0.320(0.001) |0.053 |0.419 |12.3% |13.7% |0.897 |20.2%|
56+
|Trans.|0.158(0.001) |0.322(0.001) |0.051 |0.400 |14.5% |14.2% |1.028 |22.5%|
57+
|ALSTM+TS|0.160(0.002) |0.321(0.002) |0.039 |0.291 |6.7% |14.6% |0.480|22.3%|
58+
|Trans.+TS|0.160(0.004) |0.324(0.005) |0.037 |0.278 |10.4% |14.7% |0.722 |23.7%|
59+
|ALSTM+TRA(Ours)|0.157(0.000) |0.318(0.000) |0.059 |0.460 |12.4% |14.0% |0.885 |20.4%|
60+
|Trans.+TRA(Ours)|0.157(0.000) |0.320(0.000) |0.056 |0.442 |16.1% |14.2% |1.133 |23.1%|
61+
62+
A more detailed demo for our experiment results in the paper can be found in `Report.ipynb`.
63+
64+
# Common Issues
65+
66+
For help or issues using TRA, please submit a GitHub issue.
67+
68+
Sometimes we might encounter situation where the loss is `NaN`, please check the `epsilon` parameter in the sinkhorn algorithm, adjusting the `epsilon` according to input's scale is important.
69+
70+
# Citation
71+
If you find this repository useful in your research, please cite:
72+
```
73+
@inproceedings{HengxuKDD2021,
74+
author = {Hengxu Lin and Dong Zhou and Weiqing Liu and Jiang Bian},
75+
title = {Learning Multiple Stock Trading Patterns with Temporal Routing Adaptor and Optimal Transport},
76+
booktitle = {Proceedings of the 27th ACM SIGKDD Conference on Knowledge Discovery \& Data Mining},
77+
series = {KDD '21},
78+
year = {2021},
79+
publisher = {ACM},
80+
}
81+
```

0 commit comments

Comments
 (0)