<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
	<channel>
		<title>Форум QUIK [тема: Подразумеваемая волатильность]</title>
		<link>http://forum.quik.ru</link>
		<description>Новое в теме Подразумеваемая волатильность форума  на сайте Форум QUIK [forum.quik.ru]</description>
		<language>ru</language>
		<docs>http://backend.userland.com/rss2</docs>
		<pubDate>Sat, 23 May 2026 17:30:13 +0300</pubDate>
		<item>
			<title>Подразумеваемая волатильность</title>
			<description><![CDATA[<b><a href="http://forum.quik.ru/messages/forum9/message34371/topic4003/">Подразумеваемая волатильность</a></b> <i>Расчет подразумеваемой волатильности</i> в форуме <a href="http://forum.quik.ru/forum9/">Программирование на языке QPILE</a>. <br />
			Спасибо за пример кода. Только прямой расчет по Б-Ш я знаю.<br /><br />====quote====<br /><a class="blog-p-user-name" id="bp_CHkDJoty" href="/user/1103/" bx-tooltip-user-id="1103">Imersio Arrigo</a> написал:<br />Вроде это не сложно сделать.Где-то тут Сергей Горохов выкладывал скрипты с примером расчётов на луа. Среди них есть расчёт Б-Ш. Методом последовательных приближений несложно вычислить волу по цене.<br />=============<br />Да речь об этом. Думал есть готовый. Сделаю сам, спасибо. <br />
			<i>12.10.2018 23:48:45, Виктор Севастьянов.</i>]]></description>
			<link>http://forum.quik.ru/messages/forum9/message34371/topic4003/</link>
			<guid>http://forum.quik.ru/messages/forum9/message34371/topic4003/</guid>
			<pubDate>Fri, 12 Oct 2018 23:48:45 +0300</pubDate>
			<category>Программирование на языке QPILE</category>
		</item>
		<item>
			<title>Подразумеваемая волатильность</title>
			<description><![CDATA[<b><a href="http://forum.quik.ru/messages/forum9/message34347/topic4003/">Подразумеваемая волатильность</a></b> <i>Расчет подразумеваемой волатильности</i> в форуме <a href="http://forum.quik.ru/forum9/">Программирование на языке QPILE</a>. <br />
			<br />====quote====<br /><a class="blog-p-user-name" id="bp_KVhSQL56" href="/user/1103/" bx-tooltip-user-id="1103">Imersio Arrigo</a> написал:<br />Где-то тут Сергей Горохов выкладывал скрипты с примером расчётов на луа.<br />=============<br />Да было дело, речь про скрипт Greek.lua<br /><table class="forum-spoiler"><thead onclick="if (this.nextSibling.style.display=='none') { this.nextSibling.style.display=''; BX.addClass(this, 'forum-spoiler-head-open'); } else { this.nextSibling.style.display='none'; BX.removeClass(this, 'forum-spoiler-head-open'); } BX.onCustomEvent('BX.Forum.Spoiler:toggle', [{node: this}]); event.stopPropagation();"><tr><th><div>Скрытый текст</div></th></tr></thead><tbody class="forum-spoiler" style="display:none;"><tr><td>
====code====
<pre>--&#91;&#91;
Что делает:
&nbsp;&nbsp; По Таблице текущих параметров строит таблицу опционов с расcчитанными греками
&nbsp;&nbsp; Формулы взяты отсюда:
&nbsp;&nbsp; http://en.wikipedia.org/wiki/Black%96Scholes
&nbsp;&nbsp; http://en.wikipedia.org/wiki/Greeks_%28finance%29
&nbsp;&nbsp; 
Как использовать:
&nbsp;&nbsp; откройте Таблицу Текущих Параметров (меню Таблицы -&#62; Текущая Таблица)
&nbsp;&nbsp; Укажите настройки, после чего, запустите скрипт (меню Таблицы - Lua - Доступные скрипты)
&nbsp;&nbsp; чтобы сохранить в CSV файл, текущее состояние таблицы, нужно нажать комбинацию клавиш Ctrl+S файл сохраняется в папку со скриптом, с именем HHHMMDD.csv
&#93;&#93;
-------------------------------НАСТРОЙКИ-------------------------------
RiskFree=0/100 --безрисковая ставка %, Указывается вручную

BaseClassCode = "SPBFUT" --Класс базового актива
ClassCode = "SPBOPT" --Класс опционов

--Список базовых активов, через запятую, по которым отображать опционы:
BaseSecList = "RIU7" --getClassSecurities(BaseClassCode) --все сразу
 
--Список опционов через запятую:
SecList = getClassSecurities(ClassCode) --все сразу

INTERVAL = 1000 --Интервал обновления таблицы

doLogging=false --включает запись в файл, формата csv. 
log_file=getScriptPath() .. "&#92;&#92;Greek.csv" --путь к csv файлу 

-----------------------------------------------------------------------

-------------------------------ТО ЧТО НИЖЕ, ТРОГАТЬ НЕ НАДО------------------------------------------------------------------
--Параметры таблицы
tbl = {
&#91;"caption"&#93;="Greek",
&#91;1&#93;="Название",
&#91;2&#93;="Код опциона",
&#91;3&#93;="Тип опциона",
&#91;4&#93;="Баз. актив",
&#91;5&#93;="Расчетная цена",
&#91;6&#93;="Страйк",
&#91;7&#93;="Волатильность",
&#91;8&#93;="До исполнения",
&#91;9&#93;="Дельта",
&#91;10&#93;="Гамма(%)",
&#91;11&#93;="Тэта",
&#91;12&#93;="Вега",
&#91;13&#93;="Ро",
&#91;"t_id"&#93;=0
}

abTable = {}
BaseCol = {}
Sec2row = {}
file = nil
Sep = ";"
YearLen=365.0 --Число дней в году
WORK = true
CALC = false
G_ROW = -1
if (BaseSecList == "") or (BaseSecList == nil) then
&nbsp;&nbsp;&nbsp;BaseSecList = getClassSecurities(BaseClassCode)
end

if (SecList == "") or (SecList == nil) then
&nbsp;&nbsp;&nbsp;SecList = getClassSecurities(ClassCode)
end

-------------------------------ФУНКЦИИ------------------------------------------------------------------
function Logging(str) --Пишет лог
&nbsp;&nbsp;&nbsp;if file~=nil and doLogging then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;file:write(str .. "&#92;n")
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;file:flush()
&nbsp;&nbsp;&nbsp;end
end

function N(x) --Нормальное среднее
&nbsp;&nbsp;&nbsp;&nbsp;if (x &#62; 10) then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return 1
&nbsp;&nbsp;&nbsp;elseif (x &#60; -10) then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return 0
&nbsp;&nbsp;&nbsp;else
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local t = 1 / (1 + 0.2316419 * math.abs(x))
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local p = 0.3989423 * math.exp(-0.5 * x * x) * t * ((((1.330274 * t - 1.821256) * t + 1.781478) * t - 0.3565638) * t + 0.3193815)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if x &#62; 0 then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p=1-p
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return p&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;end
end

function pN(x) --производная от функции нормального среднего
&nbsp;&nbsp;&nbsp;return math.exp(-0.5 * x * x) / math.sqrt(2 * math.pi) 
end

function Greek(tmpParam)
&nbsp;&nbsp;&nbsp;local b = tmpParam.volatility / 100 --"b" волатильность доходности (квадратный корень из дисперсии) базисной акции.
&nbsp;&nbsp;&nbsp;local S = tmpParam.settleprice --"S" текущая цена базисной акции;
&nbsp;&nbsp;&nbsp;local Tt = tmpParam.DAYS_TO_MAT_DATE / YearLen --"T-t" время до истечения срока опциона (период опциона);
&nbsp;&nbsp;&nbsp;local K =&nbsp;&nbsp;tmpParam.strike --"K" цена исполнения опциона;
&nbsp;&nbsp;&nbsp;local r = RiskFree --"r" безрисковая процентная ставка;
&nbsp;&nbsp;&nbsp;local d1 = (math.log(S / K) + (r + b * b * 0.5) * Tt) / (b * math.sqrt(Tt))
&nbsp;&nbsp;&nbsp;local d2 = d1-(b * math.sqrt(Tt))
&nbsp;&nbsp;&nbsp;
local Delta = 0
local Gamma = 0
local Theta = 0
local Vega = 0
local Rho = 0 

local e = math.exp(-1 * r * Tt)
&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;Gamma = pN(d1) / (S * b * math.sqrt(Tt))
&nbsp;&nbsp;&nbsp;Vega = S * e * pN(d1) * math.sqrt(Tt)
&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;Theta = (-1 * S * b * e * pN(d1)) / (2 * math.sqrt(Tt))

&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;if tmpParam.Optiontype == "Call" then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Delta = e * N(d1)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Theta = Theta - (r * K * e * N(d2)) + r * S * e * N(d1)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;----Theta = Theta - (r * K * e * N(d2))
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Rho = K * Tt * e * N(d2)
&nbsp;&nbsp;&nbsp;else
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Delta = -1 * e * N(-1*d1)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Theta = Theta + (r * K * e * N(-1 * d2)) - r * S * e * N(-1 * d1)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;----Theta = Theta + (r * K * e * N(-1 * d2))
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Rho = -1 * K * Tt * e * N(-1 * d2)
&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;

&nbsp;&nbsp;&nbsp;return {
&nbsp;&nbsp;&nbsp;&#91;"Delta"&#93; = Delta,
&nbsp;&nbsp;&nbsp;&#91;"Gamma"&#93; = 100 * Gamma,
&nbsp;&nbsp;&nbsp;&#91;"Theta"&#93; = Theta / YearLen,
&nbsp;&nbsp;&nbsp;&#91;"Vega"&#93; = Vega / 100,
&nbsp;&nbsp;&nbsp;&#91;"Rho"&#93; = Rho / 100
&nbsp;&nbsp;&nbsp;}
end

function GetRow(ID,row) --возвращает строку таблицы
local rows, col = GetTableSize(ID)
local result = ""
if rows~=nil and row&#60;=rows then
&nbsp;&nbsp;&nbsp;for i=1,col do
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;result=result..GetCell(ID,row,i).image .. Sep
&nbsp;&nbsp;&nbsp;end
end
&nbsp;&nbsp;&nbsp;return result
end

function CSV(T) --пишет таблицу в csv файл
&nbsp;&nbsp;&nbsp;function FTEXT(V) --ПРОВЕРЯЕМ КОРРЕКТНОСТЬ КОЛИЧЕСТВА СИМОЛОВ ПЕРЕМЕННОЙ
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;V=tostring(V)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (string.len(V)==1) or (string.len(V)==5) then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;V="0".. V
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return V&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;end
local temp = os.date("*t")
local Fname =getScriptPath() .. "&#92;&#92;" .. FTEXT(temp.year) .. FTEXT(temp.month) .. FTEXT(temp.day) .. ".csv"
&nbsp;&nbsp;&nbsp;CSVFile = io.open(Fname, "w+")
&nbsp;&nbsp;&nbsp;if CSVFile~=nil then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local rows, col = GetTableSize(T.t_id)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for i=1,col do --расставляем заголовки
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CSVFile:write(T&#91;i&#93; .. Sep)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CSVFile:write("&#92;n")
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for i=1,rows do --пишем таблицу
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CSVFile:write(GetRow(T.t_id,i).."&#92;n")
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CSVFile:flush()
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CSVFile:close()
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;message("Файл успешно сохранен:&#92;n"..Fname, 1)
&nbsp;&nbsp;&nbsp;else 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;message("Ошибка при сохранении файла:&#92;n"..Fname, 3)
&nbsp;&nbsp;&nbsp;end&nbsp;&nbsp;&nbsp;
end

function round(num, idp) --округляет до указанного количества знаков
&nbsp;&nbsp;&nbsp;local mult = 10^(idp or 0)
&nbsp;&nbsp;&nbsp;return math.floor(num * mult + 0.5) / mult
end 

function comma_value(n) --ставит разделители в числах
&nbsp;&nbsp;&nbsp;local left,num,right = string.match(n,'^(&#91;^%d&#93;*%d)(%d*)(.-)$')
&nbsp;&nbsp;&nbsp;return left..(num:reverse():gsub('(%d%d%d)','%1 '):reverse())..right
end

function CreateDataSourceEX(Class,Sec,Par)
&nbsp;&nbsp;&nbsp;local ds,err = CreateDataSource(Class, Sec, INTERVAL_TICK, Par)
&nbsp;&nbsp;&nbsp;if ds==nil then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;message("Ошибка при получении параметра "..Par..":&#92;n"..err, 3)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return false
&nbsp;&nbsp;&nbsp;else
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;ds:SetEmptyCallback()
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;while (ds:Size()==0) and (WORK) do
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sleep(100)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return true
&nbsp;&nbsp;&nbsp;end
end

function Stop()
&nbsp;&nbsp;&nbsp;if doLogging then 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;file:close() 
&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;WORK = false
end


function Calculate(row,do_calc)
if (row~=nil) and (row&#62;=0) and (do_calc) then

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local T=BaseCol&#91;row&#93;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local tmpParam ={
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"Optiontype"&#93; = T.Optiontype,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"settleprice"&#93; = getParamEx(BaseClassCode,T.Optionbase,"settleprice").param_value+0,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"strike"&#93; = getParamEx(ClassCode,T.SecCode,"strike").param_value+0,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"volatility"&#93; = getParamEx(ClassCode,T.SecCode,"volatility").param_value+0,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"DAYS_TO_MAT_DATE"&#93; = T.DAYS_TO_MAT_DATE
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local tmpGreek = Greek(tmpParam)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 5, comma_value(tmpParam.settleprice), tmpParam.settleprice) -- "Расчетная цена",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 6, comma_value(tmpParam.strike), tmpParam.strike) --"Страйк",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 7, tostring(tmpParam.volatility), tmpParam.volatility) -- "Волатильность",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 8, tostring(tmpParam.DAYS_TO_MAT_DATE), tmpParam.DAYS_TO_MAT_DATE) --"До исполнения",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 9, tostring(round(tmpGreek.Delta,2)), tmpGreek.Delta) --"Дельта",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 10, tostring(round(tmpGreek.Gamma,4)), tmpGreek.Gamma) -- "Гамма(%)",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 11, tostring(round(tmpGreek.Theta,2)), tmpGreek.Theta) -- "Тэта",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 12, tostring(round(tmpGreek.Vega,2)), tmpGreek.Vega) -- "Вега",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 13, tostring(round(tmpGreek.Rho,2)), tmpGreek.Rho) -- "Ро",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if doLogging then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Logging(os.date().. Sep .. GetRow(tbl.t_id,row))
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end
end
return false
end

-------------------------------Колбэки------------------------------------------------------------------
function f_cb(t_id,msg,par1,par2) --событие на нажатие клавиш
&nbsp;&nbsp;&nbsp;if (msg==QTABLE_CHAR) and (par2==19) then --сохранить в CSV файл текущее состояние таблицы нужно нажать комбинацию клавиш Ctrl+S
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CSV(tbl)
&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;if (msg==QTABLE_CLOSE) then --закрытие окна
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Stop()
&nbsp;&nbsp;&nbsp;end

&nbsp;&nbsp;&nbsp;if (msg==QTABLE_VKEY) and (par2==116) then --функция принудительного обновления таблицы при нажатии клавиши Ctrl+F5
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for SecCode in string.gmatch(SecList, "(&#91;^,&#93;+)") do --перебираем опционы по очереди.
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Calculate(Sec2row&#91;SecCode&#93;,true)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Highlight(tbl.t_id, Sec2row&#91;SecCode&#93;, QTABLE_NO_INDEX, RGB(255,0,0), QTABLE_DEFAULT_COLOR, INTERVAL)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end&nbsp;&nbsp;&nbsp;

&nbsp;&nbsp;&nbsp;end
end

function OnStop()
&nbsp;&nbsp;&nbsp;Stop()
&nbsp;&nbsp;&nbsp;DestroyTable(tbl.t_id)
end

function OnInit()
local STR = ""
&nbsp;&nbsp;&nbsp;if doLogging then 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;file = io.open(log_file, "w+") 
&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;tbl.t_id = AllocTable()
&nbsp;&nbsp;&nbsp;for i=1,table.maxn(tbl) do --добавляем колонки
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if i&#60;=4 then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;AddColumn(tbl.t_id, i, tbl&#91;i&#93;, true, QTABLE_CACHED_STRING_TYPE, string.len(tbl&#91;i&#93;)*2)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;else
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;AddColumn(tbl.t_id, i, tbl&#91;i&#93;, true, QTABLE_DOUBLE_TYPE, 10)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if doLogging then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;STR=STR..tbl&#91;i&#93;..Sep
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;Logging("Дата Время".. Sep .. STR)
&nbsp;&nbsp;&nbsp;CreateWindow(tbl.t_id)
&nbsp;&nbsp;&nbsp;SetWindowCaption(tbl.t_id,tbl.caption)
&nbsp;&nbsp;&nbsp;SetTableNotificationCallback(tbl.t_id, f_cb)
end

function OnParam(class, sec)
if (class==ClassCode) and (WORK) and (string.find(SecList,sec)~=nil) then
&nbsp;&nbsp;&nbsp;G_ROW = Sec2row&#91;sec&#93;
&nbsp;&nbsp;&nbsp;if (G_ROW~=nil) and (G_ROW&#62;=0) then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Highlight(tbl.t_id, G_ROW, QTABLE_NO_INDEX, RGB(255,0,0), QTABLE_DEFAULT_COLOR, INTERVAL)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CALC=true
&nbsp;&nbsp;&nbsp;end
end
end

function main()

WORK = false
CALC=true
&nbsp;&nbsp;&nbsp;for SecCode in string.gmatch(SecList, "(&#91;^,&#93;+)") do --перебираем опционы по очереди.
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local Optionbase=getParamEx(ClassCode,SecCode,"optionbase").param_image
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local Optiontype=getParamEx(ClassCode,SecCode,"optiontype").param_image
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (string.find(BaseSecList,Optionbase)~=nil) then
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local row = InsertRow(tbl.t_id,-1)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;local T={
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"Name"&#93; = getSecurityInfo(ClassCode,SecCode).name,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"SecCode"&#93; = SecCode,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"Optiontype"&#93; = Optiontype,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"Optionbase"&#93; = Optionbase,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#91;"DAYS_TO_MAT_DATE"&#93; = getParamEx(ClassCode,SecCode,"DAYS_TO_MAT_DATE").param_value+0
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;BaseCol&#91;row&#93;=T
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;--заполняем статичные параметры
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Sec2row&#91;SecCode&#93;=row
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 1, BaseCol&#91;row&#93;.Name) -- "Название опциона",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 2, BaseCol&#91;row&#93;.SecCode) --"Код опциона",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 3, BaseCol&#91;row&#93;.Optiontype) -- "Тип опциона",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;SetCell(tbl.t_id, row, 4, BaseCol&#91;row&#93;.Optionbase) --"Баз. актив",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;--заказ данных
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CreateDataSourceEX(BaseClassCode,T.Optionbase,"settleprice")
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CreateDataSourceEX(ClassCode,T.SecCode,"strike")
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CreateDataSourceEX(ClassCode,T.SecCode,"volatility")

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;--заполняем динамичные параметры
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CALC=Calculate(row,true) 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end
&nbsp;&nbsp;&nbsp;end
WORK = true
while WORK do
&nbsp;&nbsp;&nbsp;CALC=Calculate(G_ROW,CALC)
&nbsp;&nbsp;&nbsp;sleep(INTERVAL)
end
end

</pre>
=============
</td></tr></tbody></table> <br />
			<i>11.10.2018 13:50:46, Sergey Gorokhov.</i>]]></description>
			<link>http://forum.quik.ru/messages/forum9/message34347/topic4003/</link>
			<guid>http://forum.quik.ru/messages/forum9/message34347/topic4003/</guid>
			<pubDate>Thu, 11 Oct 2018 13:50:46 +0300</pubDate>
			<category>Программирование на языке QPILE</category>
		</item>
		<item>
			<title>Подразумеваемая волатильность</title>
			<description><![CDATA[<b><a href="http://forum.quik.ru/messages/forum9/message34345/topic4003/">Подразумеваемая волатильность</a></b> <i>Расчет подразумеваемой волатильности</i> в форуме <a href="http://forum.quik.ru/forum9/">Программирование на языке QPILE</a>. <br />
			<br />====quote====<br /><a class="blog-p-user-name" id="bp_tthMQNgo" href="/user/1430/" bx-tooltip-user-id="1430">Виктор Севастьянов</a> написал:<br />Есть такой готовый код на Lua или Qpile? Спасибо.<br />=============<br />Вроде это не сложно сделать.<br />Где-то тут Сергей Горохов выкладывал скрипты с примером расчётов на луа. Среди них есть расчёт Б-Ш. Методом последовательных приближений несложно вычислить волу по цене. <br />
			<i>11.10.2018 13:29:14, Imersio Arrigo.</i>]]></description>
			<link>http://forum.quik.ru/messages/forum9/message34345/topic4003/</link>
			<guid>http://forum.quik.ru/messages/forum9/message34345/topic4003/</guid>
			<pubDate>Thu, 11 Oct 2018 13:29:14 +0300</pubDate>
			<category>Программирование на языке QPILE</category>
		</item>
		<item>
			<title>Подразумеваемая волатильность</title>
			<description><![CDATA[<b><a href="http://forum.quik.ru/messages/forum9/message34330/topic4003/">Подразумеваемая волатильность</a></b> <i>Расчет подразумеваемой волатильности</i> в форуме <a href="http://forum.quik.ru/forum9/">Программирование на языке QPILE</a>. <br />
			Спасибо! Жаль. <br />
			<i>10.10.2018 14:41:48, Виктор Севастьянов.</i>]]></description>
			<link>http://forum.quik.ru/messages/forum9/message34330/topic4003/</link>
			<guid>http://forum.quik.ru/messages/forum9/message34330/topic4003/</guid>
			<pubDate>Wed, 10 Oct 2018 14:41:48 +0300</pubDate>
			<category>Программирование на языке QPILE</category>
		</item>
		<item>
			<title>Подразумеваемая волатильность</title>
			<description><![CDATA[<b><a href="http://forum.quik.ru/messages/forum9/message34329/topic4003/">Подразумеваемая волатильность</a></b> <i>Расчет подразумеваемой волатильности</i> в форуме <a href="http://forum.quik.ru/forum9/">Программирование на языке QPILE</a>. <br />
			<br />====quote====<br /><a class="blog-p-user-name" id="bp_TAEVcyvC" href="/user/1430/" bx-tooltip-user-id="1430">Виктор Севастьянов</a> написал:<br />Я правильно понимаю?<br />=============<br />К сожалению затруднимся ответить.<br /><br />====quote====<br /><a class="blog-p-user-name" id="bp_7WnNGYja" href="/user/1430/" bx-tooltip-user-id="1430">Виктор Севастьянов</a> написал:<br />Есть такой готовый код на Lua или Qpile? Спасибо.<br />=============<br />К сожалению нет. <br />
			<i>10.10.2018 14:36:35, Sergey Gorokhov.</i>]]></description>
			<link>http://forum.quik.ru/messages/forum9/message34329/topic4003/</link>
			<guid>http://forum.quik.ru/messages/forum9/message34329/topic4003/</guid>
			<pubDate>Wed, 10 Oct 2018 14:36:35 +0300</pubDate>
			<category>Программирование на языке QPILE</category>
		</item>
		<item>
			<title>Подразумеваемая волатильность</title>
			<description><![CDATA[<b><a href="http://forum.quik.ru/messages/forum9/message34328/topic4003/">Подразумеваемая волатильность</a></b> <i>Расчет подразумеваемой волатильности</i> в форуме <a href="http://forum.quik.ru/forum9/">Программирование на языке QPILE</a>. <br />
			День добрый! <br /><br />Волатильность в таблице текущих параметров и доске опционов, как понимаю, теоретическая волатильность:<br />Volatility = 0+GET_VALUE(GET_PARAM_EX(Class_id_opt, Opt,&quot;volatility&quot;),&quot;PARAM_VALUE&quot;)/100<br /><br />В методике биржи сказано:<br /><I>&quot;Теоретическая волатильность по каждому </I><I>опциону рассчитывается на основании кривой волатильности. </I><I>Кривая волатильности опционов определяется на основе подразумеваемой </I><I>волатильности активных заявок на покупку и продажу опционов. Подразумеваемая </I><I>волатильность заявки (подразумеваемая волатильность фьючерсного контракта, </I><I>являющегося базовым активом опциона, для соответствующей заявки) определяется </I><I>исходя из цен активных заявок на покупку и продажу по опционам на основании </I><I>модели Блэка&quot;<br /></I><p>Теоретические цены опционов Call (t) и Put (t) рассчитываются по формуле<br /></p><img src="https://tradersblog.ru/wp-content/uploads/2016/08/81376c.png" alt="Пользователь добавил изображение" border="0" /><br /><br />Здесь, согласно методике биржи, сигма - теоретическая волатильность. Я правильно понимаю, что если у меня реальные цены опционов из стакана, а нужна подразумеваемая волатильность мне нужно использовать формулы Блэка наизнанку - выразить сигму через цену. Так как аналитически этого не сделаешь, то видимо ее нужно считать численными методами приближенно. Я правильно понимаю? Есть такой готовый код на Lua или Qpile? Спасибо. <br />
			<i>10.10.2018 14:21:46, Виктор Севастьянов.</i>]]></description>
			<link>http://forum.quik.ru/messages/forum9/message34328/topic4003/</link>
			<guid>http://forum.quik.ru/messages/forum9/message34328/topic4003/</guid>
			<pubDate>Wed, 10 Oct 2018 14:21:46 +0300</pubDate>
			<category>Программирование на языке QPILE</category>
		</item>
	</channel>
</rss>
