Избранное трейдера Holod_Dmitry
Решил проанализировать свою торговлю за прошедший год, с осени 2019 по осень 2020. Обычно такое делают в конце года, но тогда мне, скорее всего, будет не до этого, поэтому решил сделать это сейчас.
И внезапно обнаружил, что этот год оказался, по моим меркам, рекордно прибыльным. До этого, несмотря на увеличения счёта внутри года на 100-200%, на долгосроке все эти результаты размывались и год закрывался или в существенный убыток, или в 0, или в скромнейшие (и совершенно неприемлемые для плечевой торговли) 15-25% годовых.
В этом же году уже получаются +65%, причём это именно постепенно накопленный результат, а не следствие взятого однажды импульса.
Неужели я научился торговать?
Стал проверять это смелое предположение.
Первым делом посмотрел на эквити.
Она, как была «пьяной» и шатающейся туда-сюда по воле ветра трендов, так и осталась.
Может просто повезло и было много трендов?
Так их и раньше было много, лови — не хочу. Значит, дело и не в этом.
Простите за банальность, работа с данными начинается с их получения из внешнего источника. Мы будем получать их из CSV-файла архива котировок, скачанного с сайта Финам. Для работы с другими источниками вам надо будет немного изменить программу.
Я уже давно не работаю непосредственно с CSV, и храню все данные в БД SQLite. Поначалу я хотел написать программу чтения CSV с нуля, но выяснилось, что я уже подзабыл как это делается, однако нашелся рояль в кустах — моя старая библиотека читающая данные из CSV-файла непосредственно в программу. Ее мы и будем использовать.
Собственно, Python и ориентирован на работу с библиотеками, и не нужно знать что там внутри, важно только уметь с ними работать, а сами программы с использованием библиотек станут очень простыми.
Для начала качаем с Финам историю в формате CSV-файла следующего вида:
<TICKER>,<PER>,<DATE>,<TIME>,<OPEN>,<HIGH>,<LOW>,<CLOSE>,<VOL> SPFB.Si-12.20,1,04/05/20,10:00:00,76900.0000000,76990.0000000,76900.0000000,76990.0000000,3 SPFB.Si-12.20,1,04/05/20,10:06:00,77695.0000000,77695.0000000,77400.0000000,77400.0000000,8 SPFB.Si-12.20,1,04/05/20,10:08:00,77781.0000000,77781.0000000,77700.0000000,77750.0000000,30 SPFB.Si-12.20,1,04/05/20,10:13:00,78088.0000000,78098.0000000,78088.0000000,78098.0000000,6 SPFB.Si-12.20,1,04/05/20,10:14:00,78100.0000000,78100.0000000,78100.0000000,78100.0000000,1
Settings= { Name = "Zigzag_MNK", -- название индикатора delta=1.0, -- дельта зигзага showperiod=5000,--колич баров за которые строится line= { { Name = "zigzagline2", Type =TYPE_LINE, Width = 2, Color = RGB(255,0, 0) } } } function Init() vMin = 0 vMax = 0 vMinindex = 0 vMaxindex = 0 voldMinindex = 0 voldMaxindex = 0 a1 = 0 a2 = 0 a3 = 0 a4 = 0 cind = 0 v = null vFrom=0 vsl = 0 return 1 end function calcmnk(index, vFrom, a1, a2, a3, a4, cind, vMinindex, vMaxindex) v = null v2 = null showperiod = Settings.showperiod if index-1 > 1 and vFrom > 1 and index > Size()-showperiod then --[[ for i=vFrom, index-1 do a1 = a1+i*C(i) a2 = a2+i a3 = a3+C(i) a4 = a4+i*i end for i=index, index do a01 = a1+i*C(i) a02 = a2+i a03 = a3+C(i) a04 = a4+i*i end n = index - vFrom + 1 if((n*a04 - a02*a02) ~= 0) then a = (n*a01 - a02*a03)/(n*a04 - a02*a02) b = (a03 - a*a02)/n v = a*index + b end --]] a1 = 0 a2 = 0 a3 = 0 a4 = 0 vto = index if vMinindex < vMaxindex then vto = vMaxindex end if vMinindex > vMaxindex then vto = vMinindex end for i=vFrom, vto do a1 = a1+i*C(i) a2 = a2+i a3 = a3+C(i) a4 = a4+i*i end n = vto - vFrom + 1 if((n*a4 - a2*a2) ~= 0) then a = (n*a1 - a2*a3)/(n*a4 - a2*a2) b = (a3 - a*a2)/n v = a*index + b end vmindel = 0 for i=vFrom, vto do y = a*i + b if vMinindex < vMaxindex and y - C(i) > vmindel then vmindel = y - C(i) end if vMinindex > vMaxindex and C(i) - y > vmindel then vmindel = C(i) - y end end y = a*index + b if vMinindex < vMaxindex then v2 = y - vmindel end if vMinindex > vMaxindex then v2 = y + vmindel end if vMinindex < vMaxindex and O(index) < v2 and vsl == 0 then vsl = C(vMaxindex) v2 = vsl end if vMinindex > vMaxindex and O(index) > v2 and vsl == 0 then vsl = C(vMinindex) v2 = vsl end if vsl ~= 0 then v2 = vsl end if vMinindex < vMaxindex and O(index) > vsl and vsl ~= 0 then vsl = 0 --v2 = y - vmindel end if vMinindex > vMaxindex and O(index) < vsl and vsl ~= 0 then vsl = 0 --v2 = y + vmindel end --[[ --]] cind = index end return v, v2 end function OnCalculate(index) v = null v2 = null if index < 3 then vMin = C(index) vMax = C(index) vMinindex = index vMaxindex = index voldMinindex = index voldMaxindex = index else --if index > 18000 then if voldMaxindex >= voldMinindex then if C(index) > (1 + Settings.delta/100)*vMin then vMin = C(index) vMax = C(index) vMaxindex = index voldMinindex = vMinindex vFrom = vMinindex vsl = 0 a1 = 0 a2 = 0 a3 = 0 a4 = 0 v, v2 = calcmnk(index, vFrom, a1, a2, a3, a4, cind, vMinindex, vMaxindex) --[[ for i=vFrom, index-1 do a1 = a1+i*C(i) a2 = a2+i a3 = a3+C(i) a4 = a4+i*i end for i=index, index do a01 = a1+i*C(i) a02 = a2+i a03 = a3+C(i) a04 = a4+i*i end n = index - vFrom + 1 if((n*a04 - a02*a02) ~= 0) then a = (n*a01 - a02*a03)/(n*a04 - a02*a02) b = (a03 - a*a02)/n v = a*index + b end cind = index --]] else if vMin > C(index) then vMin = C(index) vMinindex = index vFrom = voldMaxindex -- else -- vFrom = vMinindex end v, v2 = calcmnk(index, vFrom, a1, a2, a3, a4, cind, vMinindex, vMaxindex) --[[ if cind ~= index then for i=index-1, index-1 do a1 = a1+i*C(i) a2 = a2+i a3 = a3+C(i) a4 = a4+i*i end end for i=index, index do a01 = a1+i*C(i) a02 = a2+i a03 = a3+C(i) a04 = a4+i*i end n = index - vFrom + 1 if((n*a04 - a02*a02) ~= 0) then a = (n*a01 - a02*a03)/(n*a04 - a02*a02) b = (a03 - a*a02)/n v = a*index + b end cind = index --]] end else if voldMaxindex <= voldMinindex then if C(index) < (1 - Settings.delta/100)*vMax then vMax = C(index) vMin = C(index) vMinindex = index voldMaxindex = vMaxindex vFrom = vMaxindex vsl = 0 a1 = 0 a2 = 0 a3 = 0 a4 = 0 v, v2 = calcmnk(index, vFrom, a1, a2, a3, a4, cind, vMinindex, vMaxindex) --[[ for i=vFrom, index-1 do a1 = a1+i*C(i) a2 = a2+i a3 = a3+C(i) a4 = a4+i*i end for i=index, index do a01 = a1+i*C(i) a02 = a2+i a03 = a3+C(i) a04 = a4+i*i end n = index - vFrom + 1 if((n*a04 - a02*a02) ~= 0) then a = (n*a01 - a02*a03)/(n*a04 - a02*a02) b = (a03 - a*a02)/n v = a*index + b end cind = index --]] else if vMax < C(index) then vMax = C(index) vMaxindex = index vFrom = voldMinindex -- else -- vFrom = vMaxindex end v, v2 = calcmnk(index, vFrom, a1, a2, a3, a4, cind, vMinindex, vMaxindex) --[[ if cind ~= index then for i=index-1, index-1 do a1 = a1+i*C(i) a2 = a2+i a3 = a3+C(i) a4 = a4+i*i end end for i=index, index do a01 = a1+i*C(i) a02 = a2+i a03 = a3+C(i) a04 = a4+i*i end n = index - vFrom + 1 if((n*a04 - a02*a02) ~= 0) then a = (n*a01 - a02*a03)/(n*a04 - a02*a02) b = (a03 - a*a02)/n v = a*index + b end cind = index --]] end end end -- end --[[ a1 = 0 a2 = 0 a3 = 0 a4 = 0 for i=vFrom, index do a1 = a1+i*C(i) a2 = a2+i a3 = a3+C(i) a4 = a4+i*i end n = index - vFrom + 1 if((n*a4 - a2*a2) ~= 0) then a = (n*a1 - a2*a3)/(n*a4 - a2*a2) b = (a3 - a*a2)/n v = a*index + b end --]] --[[ for i = vFrom, index do k = (C(index)- C(vFrom))/(index- vFrom); v = i*k + C(index) - index*k SetValue(i, 1, v) end --]] end return v2 end
Вот так пишут обычно все))). Я тоже можно так сказать его нашел, но только не грааль в привычном понимании этого слова. А некоторые фишки, которые так скажем, существенно влияют на результат торговли. В частности на данный момент этих фишек 3. Причем последнюю узнал всего 2 недели назад.
В этой статья я конечно не буду их раскрывать. Но попробую дать намек и пытливый ум возможно, о них додумается. Но профессионалы конечно о них уже знают. Поэтому это больше для начинающих.
Добавили фракталы. Можно выбрать либо по 3 свечам либо по 5.
Следующим шагом делаем проверку актуальности образования фрактала и пробития цены, например, не дальше чем 10 минут или час. Кроме того добавили фильтрацию по объему и размеру движения. То есть если был всплеск объема при подходе к цене, то вероятно мы пронесемся мимо уровня в направленном движении.
Добавили в модуль лонги. Реализована возможность входить лонг и шорт одновременно (если есть желание).
На текущий момент криптовалюты в передышке от направленного движения, потому конечно можно поторговать боковик немного от 400 до 410.
Так как сейчас в программе тслаб на бинансе есть спот, коин и фьючерс — уточню, что речь про фьючерс. На коине будут немного другие ориентиры цен.
При открытии реальных сделок внезависимости от результата — будет в статье актуализация информации.
Сам скрипт можно скачать тут
Живое общение в телеграмм канале t.me/tslabprorugroup
Скачать и начать использовать программу www.tslab.pro/ru-RU/home для binance, okex, lmax — бесплатно