從一開始,反向交易者就可以做空任何東西,包括類似股票和類似期貨的工具。當做空時,現金減少,被賣空資產的價值用於總淨清算價值。
從一側移除並添加到另一側可以保持平衡。
人們似乎更喜歡增加現金,這可能會增加支出。
在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()