hikyuu2/hikyuu_pywrap/trade_sys/_Portfolio.cpp

80 lines
3.2 KiB
C++
Raw Normal View History

2016-04-03 00:08:31 +08:00
/*
* _Portfolio.cpp
*
* Created on: 2016329
2016-04-14 01:36:53 +08:00
* Author: fasiondog
2016-04-03 00:08:31 +08:00
*/
#include <hikyuu/trade_sys/portfolio/build_in.h>
2020-07-15 22:50:22 +08:00
#include <hikyuu/trade_sys/selector/crt/SE_Fixed.h>
#include <hikyuu/trade_sys/allocatefunds/crt/AF_EqualWeight.h>
2023-12-27 17:02:11 +08:00
#include "../pybind_utils.h"
2016-04-03 00:08:31 +08:00
2023-12-27 17:02:11 +08:00
namespace py = pybind11;
2016-04-03 00:08:31 +08:00
using namespace hku;
2023-12-27 17:02:11 +08:00
void export_Portfolio(py::module& m) {
py::class_<Portfolio, PortfolioPtr>(m, "Portfolio", R"(实现多标的、多策略的投资组合)")
.def(py::init<>())
.def(py::init<const string&>())
.def(py::init<const TradeManagerPtr&, const SelectorPtr&, const AFPtr&>())
.def("__str__", to_py_str<Portfolio>)
.def("__repr__", to_py_str<Portfolio>)
.def_property("name", py::overload_cast<>(&Portfolio::name, py::const_),
2023-12-27 17:02:11 +08:00
py::overload_cast<const string&>(&Portfolio::name),
py::return_value_policy::copy, "名称")
.def_property("query", &Portfolio::getQuery, &Portfolio::setQuery,
py::return_value_policy::copy, "查询条件")
.def_property("tm", &Portfolio::getTM, &Portfolio::setTM, "设置或获取交易管理对象")
.def_property("se", &Portfolio::getSE, &Portfolio::setSE, "设置或获取交易对象选择算法")
.def_property("af", &Portfolio::getAF, &Portfolio::setAF, "设置或获取资产分配算法")
.def_property_readonly("proto_sys_list", &Portfolio::getProtoSystemList,
py::return_value_policy::copy, "获取原型系统列")
.def_property_readonly("real_sys_list", &Portfolio::getRealSystemList,
py::return_value_policy::copy, "由 PF 运行时设定的实际运行系统列表")
2022-02-26 17:54:15 +08:00
.def("get_param", &Portfolio::getParam<boost::any>, R"(get_param(self, name)
:param str name:
:return:
:raises out_of_range: )")
2023-12-27 17:02:11 +08:00
.def("set_param", &Portfolio::setParam<boost::any>, R"(set_param(self, name, value)
2022-02-26 17:54:15 +08:00
2020-07-15 22:50:22 +08:00
2022-02-26 17:54:15 +08:00
:param str name:
:param value:
:raises logic_error: Unsupported type! )")
2020-08-13 00:35:19 +08:00
2022-02-26 17:54:15 +08:00
.def("have_param", &Portfolio::haveParam, "是否存在指定参数")
.def("reset", &Portfolio::reset, "复位操作")
.def("clone", &Portfolio::clone, "克隆操作")
2020-08-13 00:35:19 +08:00
2023-12-27 17:02:11 +08:00
.def("run", &Portfolio::run, py::arg("query"), py::arg("force") = false, R"(run(self, query)
2020-07-15 22:50:22 +08:00
2022-02-22 01:45:28 +08:00
PF在第二次执行时
2020-07-15 22:50:22 +08:00
2022-02-22 01:45:28 +08:00
:param Query query:
:param bool force: )")
2023-12-27 17:02:11 +08:00
DEF_PICKLE(Portfolio);
2023-12-27 17:02:11 +08:00
m.def("PF_Simple", PF_Simple, py::arg("tm") = TradeManagerPtr(), py::arg("se") = SE_Fixed(),
py::arg("af") = AF_EqualWeight(),
R"(PF_Simple([tm, se, af])
2020-07-15 22:50:22 +08:00
:param TradeManager tm:
2022-02-02 17:02:07 +08:00
:param SelectorBase se:
:param AllocateFundsBase af: )");
2016-04-03 00:08:31 +08:00
}