# QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.# Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.## Licensed under the Apache License, Version 2.0 (the "License");# you may not use this file except in compliance with the License.# You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0## Unless required by applicable law or agreed to in writing, software# distributed under the License is distributed on an "AS IS" BASIS,# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.# See the License for the specific language governing permissions and# limitations under the License.from AlgorithmImports import *### <summary>### Example demonstrating how to access to options history for a given underlying equity security.### </summary>### <meta name="tag" content="using data" />### <meta name="tag" content="options" />### <meta name="tag" content="filter selection" />### <meta name="tag" content="history" />class BasicTemplateOptionsHistoryAlgorithm(QCAlgorithm):''' This example demonstrates how to get access to options history for a given underlying equity security.'''def initialize(self):# this test opens position in the first day of trading, lives through stock split (7 for 1), and closes adjusted position on the second dayself.set_start_date(2015, 12, 24)self.set_end_date(2015, 12, 24)self.set_cash(1000000)option = self.add_option("GOOG")# add the initial contract filter# SetFilter method accepts timedelta objects or integer for days.# The following statements yield the same filtering criteriaoption.set_filter(-2, +2, 0, 180)# option.set_filter(-2,2, timedelta(0), timedelta(180))# set the pricing model for Greeks and volatility# find more pricing models https://www.quantconnect.com/lean/documentation/topic27704.htmloption.price_model = OptionPriceModels.black_scholes()# set the warm-up period for the pricing modelself.set_warm_up(TimeSpan.from_days(4))# set the benchmark to be the initial cashself.set_benchmark(lambda x: 1000000)def on_data(self,slice):if self.is_warming_up: returnif not self.portfolio.invested:for chain in slice.option_chains:volatility = self.securities[chain.key.underlying].volatility_model.volatilityfor contract in chain.value:self.log("{0},Bid={1} Ask={2} Last={3} OI={4} sigma={5:.3f} NPV={6:.3f} \delta={7:.3f} gamma={8:.3f} vega={9:.3f} beta={10:.2f} theta={11:.2f} IV={12:.2f}".format(contract.symbol.value,contract.bid_price,contract.ask_price,contract.last_price,contract.open_interest,volatility,contract.theoretical_price,contract.greeks.delta,contract.greeks.gamma,contract.greeks.vega,contract.greeks.rho,contract.greeks.theta / 365,contract.implied_volatility))def on_securities_changed(self, changes):for change in changes.added_securities:# only print options priceif change.symbol.value == "GOOG": returnhistory = self.history(change.symbol, 10, Resolution.MINUTE).sort_index(level='time', ascending=False)[:3]for index, row in history.iterrows():self.log("History: " + str(index[3])+ ": " + index[4].strftime("%m/%d/%Y %I:%M:%S %p")+ " > " + str(row.close))
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。