コード例 #1
0
ファイル: TEST_ME_spot_times.py プロジェクト: ajmal017/IB-7
# Backtest with hist from local files https://youtu.be/UR_7_F8wPL0
# Speed up backtest by designating spot times https://youtu.be/bVE59nZ02ig
# Convert hist data format https://youtu.be/hYL6SYgy7wE
fileName = 'demo_buy_low_sell_high.py'

accountCode = 'dummyAccountCode'  # IBridgePy needs a dummyAccountCode to simulate transactions when dataProviderName = 'LOCAL_FILE'
dataProviderName = 'LOCAL_FILE'  # RANDOM, IB, LOCAL_FILE, TD, ROBINHOOD, IBRIDGEPY

# "histIngestionPlan" is a reserved word in IBridgePy to store the historical data ingestion plan that describes what historical data
# are needed during backtesting and IBridgePy backtester will fetch these data before backtesting to speed up the whole backtesting process.
# "histIngestionPlan" is not required for backtesting but it will make backtest much faster.
# "histIngestionPlan" is an instance of HistIngestionPlan.
histIngestionPlan = HistIngestionPlan()
histIngestionPlan.add(
    Plan(security=symbol('SPY'),
         barSize='1 min',
         fileName='STK,SPY,USD_1 min_40 D.csv')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans
histIngestionPlan.add(
    Plan(security=symbol('SPY'),
         barSize='1 day',
         fileName='STK,SPY,USD_1 day_55 D.csv')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans

# In CUSTOM mode, user can specify each spot time to backtest with any data provider.
# customSpotTimeList is an IBridgePy reserved key word. Its type is List.
# User can append each spot time into customSpotTimeList to backtest at these spot times.
timeGeneratorType = 'CUSTOM'
customSpotTimeList = []
import pandas as pd
# The goal is to backtest from 2020-10-30 to 2020-12-24 and only allow the datetime of 15:59:00 Eastern go through the to-be-tested strategy
コード例 #2
0
####
# The backtesting time period is defined by two variables: endTime and startTime, default timezone = 'US/Eastern'
####

# As a demo, endTime is Dec 24th 2020 because the ingested historical data ends on that date.
# IBridgePy automatically sets endTime.second to 0 because the default mode of IBridgePy backtester is designed to
# backtest strategies minutely and the second must be zero.
endTime = dt.datetime(2020, 12, 24)

# As a demo, startTime is 50 days ago from the current time.
startTime = endTime - dt.timedelta(days=50)

# "histIngestionPlan" is a reserved word in IBridgePy to store the historical data ingestion plan that describes what historical data
# are needed during backtesting and IBridgePy backtester will fetch these data before backtesting to speed up the whole backtesting process.
# "histIngestionPlan" is not required for backtesting but it will make backtest much faster.
# "histIngestionPlan" is an instance of HistIngestionPlan.
histIngestionPlan = HistIngestionPlan()

# dataSourceName='simulatedByDailyBars' means to simulate minute bar data by daily bar data when it is needed.
# The default is to use "close" price of the daily bar to simulate minute price. It can be configured in settings.py --> PROJECT --> useColumnNameWhenSimulatedByDailyBar
histIngestionPlan.add(
    Plan(security=symbol('SPY'),
         barSize='1 min',
         dataSourceName='simulatedByDailyBars')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans
histIngestionPlan.add(
    Plan(security=symbol('SPY'), barSize='1 day', fileName='SPY_1day_55D.csv')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans

test_me(fileName, globals())
コード例 #3
0
# Backtest with hist ingestion https://youtu.be/XnpxAVU4ogY
# Backtest with hist from local files https://youtu.be/UR_7_F8wPL0
# Speed up backtest by designating spot times https://youtu.be/bVE59nZ02ig
# Convert hist data format https://youtu.be/hYL6SYgy7wE
# Backtest using IBridgePy data center https://youtu.be/0FPgtmUpTI0
fileName = 'demo_buy_low_sell_high.py'

accountCode = 'dummyAccountCode'  # IBridgePy needs a dummyAccountCode to simulate transactions when dataProviderName = 'LOCAL_FILE'
dataProviderName = 'LOCAL_FILE'  # RANDOM, IB, LOCAL_FILE, TD, ROBINHOOD, IBRIDGEPY

# "histIngestionPlan" is a reserved word in IBridgePy to store the historical data ingestion plan that describes what historical data
# are needed during backtesting and IBridgePy backtester will fetch these data before backtesting to speed up the whole backtesting process.
# "histIngestionPlan" is not required for backtesting but it will make backtest much faster.
# "histIngestionPlan" is an instance of HistIngestionPlan.
histIngestionPlan = HistIngestionPlan()
histIngestionPlan.add(Plan(security=symbol('SPY'), barSize='1 min', fileName='SPY_1min_40D.csv'))  # "histIngestionPlan.add" is used to add more Ingestion Plans
histIngestionPlan.add(Plan(security=symbol('SPY'), barSize='1 day', fileName='SPY_1day_55D.csv'))  # "histIngestionPlan.add" is used to add more Ingestion Plans

# In CUSTOM mode, user can specify each spot time to backtest with any data provider.
# customSpotTimeList is an IBridgePy reserved key word. Its type is List.
# User can append each spot time into customSpotTimeList to backtest at these spot times.
timeGeneratorType = 'CUSTOM'
customSpotTimeList = []
# The goal is to backtest from 2020-10-30 to 2020-12-24 and only allow the datetime of 15:59:00 Eastern go through the to-be-tested strategy
# because "demo_close_price_reversion.py" only makes trading decisions at 15:59:00 Eastern on every trading day.
# pd.date_range is used to create a list of dates that have hour=0 and minute=0.
dateRange = pd.date_range(dt.datetime(2020, 10, 30), dt.datetime(2020, 12, 24), freq='1D', tz=pytz.timezone('US/Eastern'))
for aDate in dateRange:
    a = aDate.replace(hour=15, minute=59)  # datetime(2020, 10, 30, 0, 0) --> datetime(2020, 10, 30, 15, 59)
    customSpotTimeList.append(a)
コード例 #4
0
fileName = 'demo_buy_low_sell_high.py'

accountCode = 'DU1868499'  # IB accountCode is needed to retrieve historical data from IB server.
dataProviderName = 'IB'  # RANDOM, IB, LOCAL_FILE, TD, ROBINHOOD, IBRIDGEPY

####
# The backtesting time period is defined by two variables: endTime and startTime, default timezone = 'US/Eastern'
####

# As a demo, endTime is the current time.
# IBridgePy automatically sets endTime.second to 0 because the default mode of IBridgePy backtester is designed to
# backtest strategies minutely and the second must be zero.
endTime = dt.datetime.now()

# As a demo, startTime is 50 days ago from the current time.
startTime = endTime - dt.timedelta(days=50)

# "histIngestionPlan" is a reserved word in IBridgePy to store the historical data ingestion plan that describes what historical data
# are needed during backtesting and IBridgePy backtester will fetch these data before backtesting to speed up the whole backtesting process.
# "histIngestionPlan" is not required for backtesting but it will make backtest much faster.
# "histIngestionPlan" is an instance of HistIngestionPlan.
histIngestionPlan = HistIngestionPlan()
histIngestionPlan.add(
    Plan(security=symbol('SPY'), barSize='1 min', goBack='40 D')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans
histIngestionPlan.add(
    Plan(security=symbol('SPY'), barSize='1 day', goBack='55 D')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans

test_me(fileName, globals())
コード例 #5
0
####
# The backtesting time period is defined by two variables: endTime and startTime, default timezone = 'US/Eastern'
####

# As a demo, endTime is Dec 24th 2020 because the ingested historical data ends on that date.
# Set second to 0 because the default mode of IBridgePy backtester is designed to backtest strategies minutely and the second must be zero.
endTime = dt.datetime(2020, 12, 24).replace(second=0)

# As a demo, startTime is 50 days ago from the current time.
startTime = endTime - dt.timedelta(days=50)

# "histIngestionPlan" is a reserved word in IBridgePy to store the historical data ingestion plan that describes what historical data
# are needed during backtesting and IBridgePy backtester will fetch these data before backtesting to speed up the whole backtesting process.
# "histIngestionPlan" is not required for backtesting but it will make backtest much faster.
# "histIngestionPlan" is an instance of HistIngestionPlan.
histIngestionPlan = HistIngestionPlan()

# dataSourceName='simulatedByDailyBars' means to simulate minute bar data by daily bar data when it is needed.
# The default is to use "close" price of the daily bar to simulate minute price. It can be configured in settings.py --> PROJECT --> useColumnNameWhenSimulatedByDailyBar
histIngestionPlan.add(
    Plan(security=symbol('SPY'),
         barSize='1 min',
         dataSourceName='simulatedByDailyBars')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans
histIngestionPlan.add(
    Plan(security=symbol('SPY'),
         barSize='1 day',
         fileName='STK,SPY,USD_1 day_55 D_indexOfDatetime.csv')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans

test_me(fileName, globals())
コード例 #6
0
####
# The backtesting time period is defined by two variables: endTime and startTime, default timezone = 'US/Eastern'
####

# As a demo, endTime is Dec 24th 2020 because the ingested historical data ends on that date.
# IBridgePy automatically sets endTime.second to 0 because the default mode of IBridgePy backtester is designed to
# backtest strategies minutely and the second must be zero.
endTime = dt.datetime(2020, 12, 24)

# As a demo, startTime is 50 days ago from the current time.
startTime = endTime - dt.timedelta(days=50)

# "histIngestionPlan" is a reserved word in IBridgePy to store the historical data ingestion plan that describes what historical data
# are needed during backtesting and IBridgePy backtester will fetch these data before backtesting to speed up the whole backtesting process.
# "histIngestionPlan" is not required for backtesting but it will make backtest much faster.
# "histIngestionPlan" is an instance of HistIngestionPlan.
histIngestionPlan = HistIngestionPlan()

# Default folder to load hist files is ibridgepyRoot/Input
# User can designate the loading folder by "histIngestionPlan = HistIngestionPlan(defaultFolderName=xxx)"
# "histIngestionPlan.add" is used to add more Ingestion Plans
# The full path of the file is ibridgepyRoot/Input/SPY_1min_40D.csv
histIngestionPlan.add(
    Plan(security=symbol('SPY'), barSize='1 min', fileName='SPY_1min_40D.csv'))
histIngestionPlan.add(
    Plan(security=symbol('SPY'), barSize='1 day',
         fileName='SPY_1day_55D.csv'))  # Add more plans as needed.

test_me(fileName, globals())
コード例 #7
0
accountCode = 'dummyAccountCode'  # IBridgePy needs a dummyAccountCode to simulate transactions when dataProviderName = 'LOCAL_FILE'
dataProviderName = 'LOCAL_FILE'  # RANDOM, IB, LOCAL_FILE, TD, ROBINHOOD, IBRIDGEPY

####
# The backtesting time period is defined by two variables: endTime and startTime, default timezone = 'US/Eastern'
####

# As a demo, endTime is Dec 24th 2020 because the ingested historical data ends on that date.
# Set second to 0 because the default mode of IBridgePy backtester is designed to backtest strategies minutely and the second must be zero.
endTime = dt.datetime(2020, 12, 24).replace(second=0)

# As a demo, startTime is 50 days ago from the current time.
startTime = endTime - dt.timedelta(days=50)

# "histIngestionPlan" is a reserved word in IBridgePy to store the historical data ingestion plan that describes what historical data
# are needed during backtesting and IBridgePy backtester will fetch these data before backtesting to speed up the whole backtesting process.
# "histIngestionPlan" is not required for backtesting but it will make backtest much faster.
# "histIngestionPlan" is an instance of HistIngestionPlan.
histIngestionPlan = HistIngestionPlan()
histIngestionPlan.add(
    Plan(security=symbol('SPY'),
         barSize='1 min',
         fileName='STK,SPY,USD_1 min_40 D_indexOfDatetime.csv')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans
histIngestionPlan.add(
    Plan(security=symbol('SPY'),
         barSize='1 day',
         fileName='STK,SPY,USD_1 day_55 D_indexOfDatetime.csv')
)  # "histIngestionPlan.add" is used to add more Ingestion Plans

test_me(fileName, globals())