當前位置: 首頁>>代碼示例>>Python>>正文


Python BatchTransformAlgorithm.run方法代碼示例

本文整理匯總了Python中zipline.test_algorithms.BatchTransformAlgorithm.run方法的典型用法代碼示例。如果您正苦於以下問題:Python BatchTransformAlgorithm.run方法的具體用法?Python BatchTransformAlgorithm.run怎麽用?Python BatchTransformAlgorithm.run使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在zipline.test_algorithms.BatchTransformAlgorithm的用法示例。


在下文中一共展示了BatchTransformAlgorithm.run方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_event_window

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
    def test_event_window(self):
        algo = BatchTransformAlgorithm()
        algo.run(self.source)
        wl = algo.window_length
        # The following assertion depend on window length of 3
        self.assertEqual(wl, 3)
        self.assertEqual(
            algo.history_return_price_class[:wl],
            [None] * wl,
            "First three iterations should return None."
            + "\n"
            + "i.e. no returned values until window is full'"
            + "%s" % (algo.history_return_price_class,),
        )
        self.assertEqual(
            algo.history_return_price_decorator[:wl],
            [None] * wl,
            "First three iterations should return None."
            + "\n"
            + "i.e. no returned values until window is full'"
            + "%s" % (algo.history_return_price_decorator,),
        )
        # After three Nones, the next value should be a data frame
        self.assertTrue(isinstance(algo.history_return_price_class[wl], pd.DataFrame))

        # Test whether arbitrary fields can be added to datapanel
        field = algo.history_return_arbitrary_fields[-1]
        self.assertTrue("arbitrary" in field.items, "datapanel should contain column arbitrary")

        self.assertTrue(
            all(field["arbitrary"].values.flatten() == [123] * algo.window_length),
            'arbitrary dataframe should contain only "test"',
        )

        for data in algo.history_return_sid_filter[wl:]:
            self.assertIn(0, data.columns)
            self.assertNotIn(1, data.columns)

        for data in algo.history_return_field_filter[wl:]:
            self.assertIn("price", data.items)
            self.assertNotIn("ignore", data.items)

        for data in algo.history_return_field_no_filter[wl:]:
            self.assertIn("price", data.items)
            self.assertIn("ignore", data.items)

        for data in algo.history_return_ticks[wl:]:
            self.assertTrue(isinstance(data, deque))

        for data in algo.history_return_not_full:
            self.assertIsNot(data, None)

        # test overloaded class
        for test_history in [algo.history_return_price_class, algo.history_return_price_decorator]:
            # starting at window length, the window should contain
            # consecutive (of window length) numbers up till the end.
            for i in range(algo.window_length, len(test_history)):
                np.testing.assert_array_equal(
                    range(i - algo.window_length + 1, i + 1), test_history[i].values.flatten()
                )
開發者ID:gawecoti,項目名稱:zipline,代碼行數:62,代碼來源:test_transforms.py

示例2: test_event_window

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
    def test_event_window(self):
        algo = BatchTransformAlgorithm()
        algo.run(self.source)

        self.assertEqual(algo.history_return_price_class[:2],
                         [None, None],
                         "First two iterations should return None")
        self.assertEqual(algo.history_return_price_decorator[:2],
                         [None, None],
                         "First two iterations should return None")
        self.assertEqual(algo.history_return_price_market_aware[:2],
                         [None, None],
                         "First two iterations should return None")

        # test overloaded class
        for test_history in [algo.history_return_price_class,
                             algo.history_return_price_decorator]:
            np.testing.assert_array_equal(
                    range(2, 8),
                    test_history[2].values.flatten()
            )

            np.testing.assert_array_equal(
                    range(2, 8),
                    test_history[3].values.flatten()
            )

            np.testing.assert_array_equal(
                    range(4, 12),
                    test_history[4].values.flatten()
            )
開發者ID:snth,項目名稱:zipline,代碼行數:33,代碼來源:test_transforms.py

示例3: test_event_window

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
    def test_event_window(self):
        algo = BatchTransformAlgorithm()
        algo.run(self.source)
        wl = algo.window_length
        self.assertEqual(algo.history_return_price_class[:wl],
                         [None] * wl,
                         "First two iterations should return None")
        self.assertEqual(algo.history_return_price_decorator[:wl],
                         [None] * wl,
                         "First two iterations should return None")
        self.assertTrue(isinstance(
            algo.history_return_price_class[wl + 1],
            pd.DataFrame)
        )

        # Test whether arbitrary fields can be added to datapanel
        field = algo.history_return_arbitrary_fields[-1]
        self.assertTrue(
            'arbitrary' in field.items,
            'datapanel should contain column arbitrary'
        )

        self.assertTrue(all(
            field['arbitrary'].values.flatten() ==
            [123] * algo.window_length),
            'arbitrary dataframe should contain only "test"'
        )

        for data in algo.history_return_sid_filter[wl:]:
            self.assertIn(0, data.columns)
            self.assertNotIn(1, data.columns)

        for data in algo.history_return_field_filter[wl:]:
            self.assertIn('price', data.items)
            self.assertNotIn('ignore', data.items)

        for data in algo.history_return_field_no_filter[wl:]:
            self.assertIn('price', data.items)
            self.assertIn('ignore', data.items)

        for data in algo.history_return_ticks[wl:]:
            self.assertTrue(isinstance(data, deque))

        for data in algo.history_return_not_full:
            self.assertIsNot(data, None)

        # test overloaded class
        for test_history in [algo.history_return_price_class,
                             algo.history_return_price_decorator]:
            # starting at window length, the window should contain
            # consecutive (of window length) numbers up till the end.
            for i in range(algo.window_length, len(test_history)):
                np.testing.assert_array_equal(
                    range(i - algo.window_length + 1, i + 1),
                    test_history[i].values.flatten()
                )
開發者ID:Elektra58,項目名稱:zipline,代碼行數:58,代碼來源:test_transforms.py

示例4: test_passing_of_args

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
    def test_passing_of_args(self):
        algo = BatchTransformAlgorithm(1, kwarg='str')
        self.assertEqual(algo.args, (1,))
        self.assertEqual(algo.kwargs, {'kwarg': 'str'})

        algo.run(self.source)
        expected_item = ((1, ), {'kwarg': 'str'})
        self.assertEqual(
            algo.history_return_args,
            [None, None, expected_item, expected_item,
             expected_item, expected_item])
開發者ID:snth,項目名稱:zipline,代碼行數:13,代碼來源:test_transforms.py

示例5: test_core_functionality

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
 def test_core_functionality(self):
     algo = BatchTransformAlgorithm(sim_params=self.sim_params)
     algo.run(self.source)
     wl = algo.window_length
     # The following assertion depend on window length of 3
     self.assertEqual(wl, 3)
     # If window_length is 3, there should be 2 None events, as the
     # window fills up on the 3rd day.
     n_none_events = 2
     self.assertEqual(algo.history_return_price_class[:n_none_events],
                      [None] * n_none_events,
                      "First two iterations should return None." + "\n" +
                      "i.e. no returned values until window is full'" +
                      "%s" % (algo.history_return_price_class,))
開發者ID:CarterBain,項目名稱:AlephNull,代碼行數:16,代碼來源:test_batchtransform.py

示例6: test_passing_of_args

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
    def test_passing_of_args(self):
        algo = BatchTransformAlgorithm(1, kwarg='str')
        self.assertEqual(algo.args, (1,))
        self.assertEqual(algo.kwargs, {'kwarg': 'str'})

        algo.run(self.source)
        expected_item = ((1, ), {'kwarg': 'str'})
        self.assertEqual(
            algo.history_return_args,
            [
                # 1990-01-03 - window not full
                None,
                # 1990-01-04 - window not full
                None,
                # 1990-01-05 - window not full, 3rd event
                None,
                # 1990-01-08 - window now full
                expected_item
            ])
開發者ID:snoopying,項目名稱:zipline,代碼行數:21,代碼來源:test_transforms.py

示例7: test_event_window

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
    def test_event_window(self):
        algo = BatchTransformAlgorithm()
        algo.run(self.source)

        self.assertEqual(algo.history_return_price_class[:2],
                         [None, None],
                         "First two iterations should return None")
        self.assertEqual(algo.history_return_price_decorator[:2],
                         [None, None],
                         "First two iterations should return None")
        self.assertEqual(algo.history_return_price_market_aware[:2],
                         [None, None],
                         "First two iterations should return None")
        self.assertEqual(algo.history_return_more_days_than_refresh[:3],
                         [None, None, None],
                         "First five iterations should return None")
        self.assertTrue(isinstance(
            algo.history_return_more_days_than_refresh[4],
            pd.DataFrame),
            "Sixth iteration should not be None"
        )

        # test overloaded class
        for test_history in [algo.history_return_price_class,
                             algo.history_return_price_decorator]:
            np.testing.assert_array_equal(
                range(2, 8),
                test_history[2].values.flatten()
            )

            np.testing.assert_array_equal(
                range(2, 8),
                test_history[3].values.flatten()
            )

            np.testing.assert_array_equal(
                range(4, 12),
                test_history[4].values.flatten()
            )
開發者ID:andycwang,項目名稱:zipline,代碼行數:41,代碼來源:test_transforms.py

示例8: test_passing_of_args

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
    def test_passing_of_args(self):
        algo = BatchTransformAlgorithm(1, kwarg='str',
                                       sim_params=self.sim_params,
                                       env=self.env)
        algo.run(self.source)
        self.assertEqual(algo.args, (1,))
        self.assertEqual(algo.kwargs, {'kwarg': 'str'})

        expected_item = ((1, ), {'kwarg': 'str'})
        self.assertEqual(
            algo.history_return_args,
            [
                # 1990-01-01 - market holiday, no event
                # 1990-01-02 - window not full
                None,
                # 1990-01-03 - window not full
                None,
                # 1990-01-04 - window now full, 3rd event
                expected_item,
                # 1990-01-05 - window now full
                expected_item,
                # 1990-01-08 - window now full
                expected_item
            ])
開發者ID:HectorZarate,項目名稱:zipline,代碼行數:26,代碼來源:test_batchtransform.py

示例9: test_core_functionality

# 需要導入模塊: from zipline.test_algorithms import BatchTransformAlgorithm [as 別名]
# 或者: from zipline.test_algorithms.BatchTransformAlgorithm import run [as 別名]
    def test_core_functionality(self):
        algo = BatchTransformAlgorithm(sim_params=self.sim_params)
        algo.run(self.source)
        wl = algo.window_length
        # The following assertion depend on window length of 3
        self.assertEqual(wl, 3)
        # If window_length is 3, there should be 2 None events, as the
        # window fills up on the 3rd day.
        n_none_events = 2
        self.assertEqual(algo.history_return_price_class[:n_none_events],
                         [None] * n_none_events,
                         "First two iterations should return None." + "\n" +
                         "i.e. no returned values until window is full'" +
                         "%s" % (algo.history_return_price_class,))
        self.assertEqual(algo.history_return_price_decorator[:n_none_events],
                         [None] * n_none_events,
                         "First two iterations should return None." + "\n" +
                         "i.e. no returned values until window is full'" +
                         "%s" % (algo.history_return_price_decorator,))

        # After three Nones, the next value should be a data frame
        self.assertTrue(isinstance(
            algo.history_return_price_class[wl],
            pd.DataFrame)
        )

        # Test whether arbitrary fields can be added to datapanel
        field = algo.history_return_arbitrary_fields[-1]
        self.assertTrue(
            'arbitrary' in field.items,
            'datapanel should contain column arbitrary'
        )

        self.assertTrue(all(
            field['arbitrary'].values.flatten() ==
            [123] * algo.window_length),
            'arbitrary dataframe should contain only "test"'
        )

        for data in algo.history_return_sid_filter[wl:]:
            self.assertIn(0, data.columns)
            self.assertNotIn(1, data.columns)

        for data in algo.history_return_field_filter[wl:]:
            self.assertIn('price', data.items)
            self.assertNotIn('ignore', data.items)

        for data in algo.history_return_field_no_filter[wl:]:
            self.assertIn('price', data.items)
            self.assertIn('ignore', data.items)

        for data in algo.history_return_ticks[wl:]:
            self.assertTrue(isinstance(data, deque))

        for data in algo.history_return_not_full:
            self.assertIsNot(data, None)

        # test overloaded class
        for test_history in [algo.history_return_price_class,
                             algo.history_return_price_decorator]:
            # starting at window length, the window should contain
            # consecutive (of window length) numbers up till the end.
            for i in range(algo.window_length, len(test_history)):
                np.testing.assert_array_equal(
                    range(i - algo.window_length + 2, i + 2),
                    test_history[i].values.flatten()
                )
開發者ID:99plus2,項目名稱:zipline,代碼行數:69,代碼來源:test_batchtransform.py


注:本文中的zipline.test_algorithms.BatchTransformAlgorithm.run方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。