mirror of
https://github.com/microsoft/qlib.git
synced 2026-06-06 14:01:28 +08:00
70 lines
1.9 KiB
Python
70 lines
1.9 KiB
Python
# Copyright (c) Microsoft Corporation.
|
|
# Licensed under the MIT License.
|
|
|
|
import sys
|
|
import unittest
|
|
import numpy as np
|
|
|
|
import qlib
|
|
from qlib.data import D
|
|
from qlib.data.ops import ElemOperator, PairOperator
|
|
from qlib.config import REG_CN
|
|
from qlib.utils import exists_qlib_data
|
|
from qlib.tests import TestAutoData
|
|
from qlib.tests.data import GetData
|
|
|
|
|
|
class Diff(ElemOperator):
|
|
"""Feature First Difference
|
|
Parameters
|
|
----------
|
|
feature : Expression
|
|
feature instance
|
|
Returns
|
|
----------
|
|
Expression
|
|
a feature instance with first difference
|
|
"""
|
|
|
|
def _load_internal(self, instrument, start_index, end_index, freq):
|
|
series = self.feature.load(instrument, start_index, end_index, freq)
|
|
return series.diff()
|
|
|
|
def get_extended_window_size(self):
|
|
lft_etd, rght_etd = self.feature.get_extended_window_size()
|
|
return lft_etd + 1, rght_etd
|
|
|
|
|
|
class Distance(PairOperator):
|
|
"""Feature Distance
|
|
Parameters
|
|
----------
|
|
feature : Expression
|
|
feature instance
|
|
Returns
|
|
----------
|
|
Expression
|
|
a feature instance with distance
|
|
"""
|
|
|
|
def _load_internal(self, instrument, start_index, end_index, freq):
|
|
series_left = self.feature_left.load(instrument, start_index, end_index, freq)
|
|
series_right = self.feature_right.load(instrument, start_index, end_index, freq)
|
|
return np.abs(series_left - series_right)
|
|
|
|
|
|
class TestRegiterCustomOps(TestAutoData):
|
|
@classmethod
|
|
def setUpClass(cls) -> None:
|
|
cls._setup_kwargs.update({"custom_ops": [Diff, Distance]})
|
|
super().setUpClass()
|
|
|
|
def test_regiter_custom_ops(self):
|
|
instruments = ["SH600000"]
|
|
fields = ["Diff($close)", "Distance($close, Ref($close, 1))"]
|
|
print(D.features(instruments, fields, start_time="2010-01-01", end_time="2017-12-31", freq="day"))
|
|
|
|
|
|
if __name__ == "__main__":
|
|
unittest.main()
|