从一开始,反向交易者就可以做空任何东西,包括类似股票和类似期货的工具。当做空时,现金减少,被卖空资产的价值用于总净清算价值。
从一侧移除并添加到另一侧可以保持平衡。
人们似乎更喜欢增加现金,这可能会增加支出。
在1.9.7.105
版本中,经纪人已将默认行为更改为添加现金和移除价值。这可以通过默认为True
的参数shortcash
来控制。改变它是这样的:
cerebro.broker.set_shortcash(False)
或者:
cerebro.broker = bt.brokers.BackBroker(shortcash=False, **other_kwargs)
在行动
下面的示例使用标准移动平均交叉,可用于查看差异。在没有参数和新行为的情况下运行它:
$ ./shortcash.py --plot
它可以与禁用的行为进行比较:
$ ./shortcash.py --plot --broker shortcash=False
保持不变的事情:
最后结果
交易
净清算价值演变
为了看到这一点,添加了一个额外的Observer以确保缩放允许详细查看演变
有什么变化:
当
shortcash
设置为False
cash 永远不会超过初始水平,因为操作总是要花钱但是通过新的默认行为,我们已经可以看到第 1次空头操作(恰好是第 1次)向系统添加现金,然后多头如何从系统中扣除现金(很明显,空头是第一次关闭的)
示例使用
$ ./shortcash.py --help usage: shortcash.py [-h] [--data DATA] [--cerebro CEREBRO] [--broker BROKER] [--sizer SIZER] [--strat STRAT] [--plot [kwargs]] shortcash testing ... optional arguments: -h, --help show this help message and exit --data DATA Data to read in (default: ../../datas/2005-2006-day-001.txt) --cerebro CEREBRO kwargs in key=value format (default: ) --broker BROKER kwargs in key=value format (default: ) --sizer SIZER kwargs in key=value format (default: ) --strat STRAT kwargs in key=value format (default: ) --plot [kwargs], -p [kwargs] Plot the read data applying any kwargs passed For example: --plot style="candle" (to plot candles) (default: None)
示例代码
from __future__ import (absolute_import, division, print_function, unicode_literals) import argparse import backtrader as bt class MACrossOver(bt.SignalStrategy): params = (('ma', bt.ind.MovAv.SMA), ('p1', 10), ('p2', 30),) def __init__(self): ma1, ma2 = self.p.ma(period=self.p.p1), self.p.ma(period=self.p.p2) self.signal_add(bt.SIGNAL_LONGSHORT, bt.ind.CrossOver(ma1, ma2)) def runstrat(args=None): args = parse_args(args) cerebro = bt.Cerebro() # Data feed data0 = bt.feeds.BacktraderCSVData(dataname=args.data) cerebro.adddata(data0) # Broker kwargs = eval('dict(' + args.broker + ')') cerebro.broker = bt.brokers.BackBroker(**kwargs) # Sizer kwargs = eval('dict(' + args.sizer + ')') cerebro.addsizer(bt.sizers.FixedSize, **kwargs) # Strategy kwargs = eval('dict(' + args.strat + ')') cerebro.addstrategy(MACrossOver, **kwargs) # better net liquidation value view cerebro.addobserver(bt.observers.Value) # Execute cerebro.run(**(eval('dict(' + args.cerebro + ')'))) if args.plot: # Plot if requested to cerebro.plot(**(eval('dict(' + args.plot + ')'))) def parse_args(pargs=None): parser = argparse.ArgumentParser( formatter_class=argparse.ArgumentDefaultsHelpFormatter, description='shortcash testing ...') parser.add_argument('--data', default='../../datas/2005-2006-day-001.txt', required=False, help='Data to read in') parser.add_argument('--cerebro', required=False, action='store', default='', help='kwargs in key=value format') parser.add_argument('--broker', required=False, action='store', default='', help='kwargs in key=value format') parser.add_argument('--sizer', required=False, action='store', default='', help='kwargs in key=value format') parser.add_argument('--strat', required=False, action='store', default='', help='kwargs in key=value format') parser.add_argument('--plot', '-p', nargs='?', required=False, metavar='kwargs', const='{}', help=('Plot the read data applying any kwargs passed\n' '\n' 'For example:\n' '\n' ' --plot style="candle" (to plot candles)\n')) return parser.parse_args(pargs) if __name__ == '__main__': runstrat()