從一開始,反向交易者就可以做空任何東西,包括類似股票和類似期貨的工具。當做空時,現金減少,被賣空資產的價值用於總淨清算價值。
從一側移除並添加到另一側可以保持平衡。
人們似乎更喜歡增加現金,這可能會增加支出。
在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設置為Falsecash 永遠不會超過初始水平,因為操作總是要花錢但是通過新的默認行為,我們已經可以看到第 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()