Π‘Π»ΠΎΠ³
Π‘Ρ‚Ρ€ΠΎΠΈΡ‚Π΅Π»ΡŒΡΡ‚Π²ΠΎ ΠΈ Ρ€Π΅ΠΌΠΎΠ½Ρ‚
Π Π΅ΠΏΠ΅Ρ‚ΠΈΡ‚ΠΎΡ€Ρ‹
ΠšΡ€Π°ΡΠΎΡ‚Π°
ЀрилансСры
Π Π°Π·Π½Ρ‹Π΅ спСциалисты
Π£Ρ…ΠΎΠ΄ Π·Π° ΠΆΠΈΠ²ΠΎΡ‚Π½Ρ‹ΠΌΠΈ
Π’Ρ€Π΅Π½Π΅Ρ€Ρ‹
Автоинструкторы

Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° Lua β€” удалённая Ρ€Π°Π±ΠΎΡ‚Π° Π² МосквС

Π”Π°Ρ‚Π°: 2025-02-19
Π”Π΅Ρ‚Π°Π»ΠΈ
Π Π΅Π³ΠΈΠΎΠ½
Москва
Π—Π°Π½ΡΡ‚ΠΎΡΡ‚ΡŒ
дистанционно
Π‘Ρ‚ΠΎΠΈΠΌΠΎΡΡ‚ΡŒ
договорная
Π”Π°Ρ‚Π° ΠΏΡƒΠ±Π»ΠΈΠΊΠ°Ρ†ΠΈΠΈ
2025-02-19
ОписаниС
Автоматизация инвСстиционной стратСгии. Π•ΡΡ‚ΡŒ матСматичСскоС описаниС ΠΌΠΎΠ΄Π΅Π»ΠΈ - Π΅Π΅ Π½ΡƒΠΆΠ½ΠΎ ΠΏΠ΅Ρ€Π΅Π»ΠΎΠΆΠΈΡ‚ΡŒ Π² ΠΊΠΎΠ΄ Π½Π° Lua для Ρ‚ΠΎΡ€Π³ΠΎΠ²ΠΎΠ³ΠΎ Ρ‚Π΅Ρ€ΠΌΠΈΠ½Π°Π»Π° Quik. 1. Π‘ΠΊΠ°Ρ‡Π°Ρ‚ΡŒ историчСскиС ΠΊΠΎΡ‚ΠΈΡ€ΠΎΠ²ΠΊΠΈ Π½Π° Π·Π°ΠΊΡ€Ρ‹Ρ‚ΠΈΠ΅ дня ΠΏΠΎ API с ΠœΠΎΡΠ±ΠΈΡ€ΠΆΠΈ (150 Ρ‚ΠΈΠΊΠ΅Ρ€ΠΎΠ²), ΡΠΎΡ…Ρ€Π°Π½ΠΈΡ‚ΡŒ ΠΈΡΡ‚ΠΎΡ€ΠΈΡŽ Π² эксСль Ρ„Π°ΠΉΠ». 2. На историчСских ΠΊΠΎΡ‚ΠΈΡ€ΠΎΠ²ΠΊΠ°Ρ… Ρ€Π°ΡΡΡ‡ΠΈΡ‚Π°Ρ‚ΡŒ ΠΊΠΎΠ²Π°Ρ€ΠΈΠ°Ρ†ΠΈΠΈ, коррСляции, ΠΏΡ€ΠΎΡ‡ΠΈΠ΅ ΠΏΠ°Ρ€Π°ΠΌΠ΅Ρ‚Ρ€Ρ‹ (ΠΎΠΊΠΎΠ»ΠΎ 5-6 ΡˆΡ‚ΡƒΠΊ Π½Π° Ρ‚ΠΈΠΊΠ΅Ρ€). 3. Π‘Ρ€Π°Π²Π½ΠΈΡ‚ΡŒ ΠΏΠΎΠ»ΡƒΡ‡Π΅Π½Π½Ρ‹Π΅ Ρ€Π΅Π·ΡƒΠ»ΡŒΡ‚Π°Ρ‚Ρ‹ ΠΌΠ΅ΠΆΠ΄Ρƒ собой ΠΈ Π²Ρ‹Π±Ρ€Π°Ρ‚ΡŒ Ρ‚ΠΎΠΏ 5 ΠΈ 5 снизу 4. ΠžΡ‚ΠΏΡ€Π°Π²ΠΈΡ‚ΡŒ сигнал ΠΊ ΠΏΠΎΠΊΡƒΠΏΠΊΠ΅ этих Π°ΠΊΡ†ΠΈΠΉ Π² Π΅Π΄ΠΈΠ½Ρ‹Ρ… долях ΠΎΡ‚ портфСля (ΠΏΠΎ 20% Π½Π° Π°ΠΊΡ†ΠΈΡŽ). Π’Π°ΠΆΠ½ΠΎ, Ρ‡Ρ‚ΠΎ Π°Π»Π³ΠΎΡ€ΠΈΡ‚ΠΌ Π΄ΠΎΠ»ΠΆΠ΅Π½ сначала Π·Π°ΠΏΡ€Π°ΡˆΠΈΠ²Π°Ρ‚ΡŒ ΡΡ‚ΠΎΠΈΠΌΠΎΡΡ‚ΡŒ ΠΏΠΎΠ·ΠΈΡ†ΠΈΠΉ ΠΈ исходя ΠΈΠ· этого ΠΏΡ€ΠΎΠ²ΠΎΠ΄ΠΈΡ‚ΡŒ рСбалансировку, хотябы ΠΏΡ€ΠΈΠ±Π»ΠΈΠ·ΠΈΡ‚Π΅Π»ΡŒΠ½ΠΎ Ρ‡Ρ‚ΠΎΠ±Ρ‹ Π½Π΅ ΠΏΡ€ΠΎΠ΄Π°Π²Π°Ρ‚ΡŒ ΠΈ Π½Π΅ ΠΏΠΎΠΊΡƒΠΏΠ°Ρ‚ΡŒ ΠΏΠΎΡ€Ρ‚Ρ„Π΅Π»ΡŒ Π·Π°Π½ΠΎΠ²ΠΎ (Π½Π΅ ΠΏΠ»Π°Ρ‚ΠΈΠΌ комиссию Π±Ρ€ΠΎΠΊΠ΅Ρ€Π° лишнюю) 5. ΠΠΊΡ‚ΠΈΠ²ΠΈΡ€ΠΎΠ²Π°Ρ‚ΡŒ Ρ€ΠΎΠ±ΠΎΡ‚Π° Ρ€Π°Π· Π² дСнь Ρ€ΠΎΠ²Π½ΠΎ Π² 18:30 ΠΏΠΎ мск, Π·Π°Ρ†ΠΈΠΊΠ»ΠΈΡ‚ΡŒ Π― попросил Ρ‡Π°Ρ‚ ΠΆΠΏΡ‚ ΡΠ΄Π΅Π»Π°Ρ‚ΡŒ это - ΠΎΠ½ Π²Ρ‹Π΄Π°Π» Π²ΠΎΡ‚ ΠΊΠ°ΠΊΠΈΠ΅ строки, Π½ΠΎ сдСлки ΠΈ рСбалансировку ΠΎΠ½ Π½Π΅ ΠΌΠΎΠΆΠ΅Ρ‚ Π²Π΅Ρ€Π½ΠΎ Π·Π°Π»ΠΎΠΆΠΈΡ‚ΡŒ - Π½ΡƒΠΆΠ½Π° ΠΏΠΎΠΌΠΎΡ‰ΡŒ спСциалиста function main() waitForConnection() message(“Starting trading algorithm“, 1) while true do local stocks = {} local benchmark_returns = getReturns(“IMOEX“, window) if not benchmark_returns then message(“Error: No IMOEX returns received“, 3) else message(“IMOEX returns successfully loaded“, 1) end for _, ticker in ipairs(tickers) do message(“Processing stock: “ .. ticker, 1) local stock_returns = getReturns(ticker, window) if stock_returns and benchmark_returns then local alpha, beta = calculate_alpha_beta(stock_returns, benchmark_returns, window) if alpha and beta then table.insert(stocks, {ticker = ticker, alpha = alpha, beta = beta}) message(“Stock: “ .. ticker .. “ | Alpha: “ .. tostring(alpha) .. “ | Beta: “ .. tostring(beta), 1) else message(“Alpha/Beta calculation failed for “ .. ticker, 3) end else message(“Error retrieving data for “ .. ticker, 3) end end if #stocks == 0 then message(“No valid stocks found. Skipping order execution.“, 3) else message(“Selected stocks for purchase:“, 1) local top_5 = select_top_5(stocks) for _, stock in ipairs(top_5) do-- LUA script for QUIK: Top-5 stocks by alpha with a 45-day window -- Author: ChatGPT -- Functionality: Connects to QUIK, retrieves stock quotes, calculates alpha and beta, rebalances portfolio with stop-losses -- Connection parameters local IP = “127.0.0.1“ -- QUIK server IP local PORT = “34130“ -- QUIK server port local window = 45 -- Alpha calculation window local tickers = {“GAZP“, “LKOH“, “SBER“, “ROSN“, “VTBR“, “MGNT“, “NVTK“, “GMKN“, “CHMF“, “RUAL“, “MOEX“, “TATN“, “YNDX“, “SNGS“, “SNGSP“, “PHOR“, “PLZL“, “ALRS“, “MTSS“, “AFKS“, “IRAO“, “PIKK“, “FIVE“, “SMLT“, “TRNFP“, “DSKY“, “BANEP“, “ENPG“, “MRKP“, “MRKU“, “MRKS“, “MRKC“, “MRKZ“, “MRKY“, “MRKV“, “MRKK“, “MRKN“, “MRKS“, “MRKM“, “MRKB“, “MRKP“, “RTKM“, “RTKMP“, “FEES“, “LSRG“, “TCSG“, “POLY“, “SELG“, “MTLR“, “MTLRP“, “BSPB“, “ABRD“, “HYDR“, “LSNG“, “LSNGP“, “TGKA“, “TGKB“, “TGKBP“, “TGKN“, “TGKM“, “TGKO“, “TGKP“} -- Stocks to analyze local portfolio = {} -- Current portfolio local lots = 10 -- Number of lots per trade local stop_loss_pct = 0.97 -- Stop-loss at 3% below purchase price -- Checking connection to QUIK server function waitForConnection() message(“Checking connection to QUIK...“, 1) while not isConnected() do sleep(5000) -- Wait 5 seconds message(“Waiting for connection to QUIK...“, 2) end message(“Connection to QUIK established!“, 1) end -- Function to calculate alpha and beta function calculate_alpha_beta(stock_returns, benchmark_returns, period) if #stock_returns < period or #benchmark_returns < period then return nil, nil end local function moving_average(data, period) local sum = 0 for i = #data - period + 1, #data do sum = sum + data[i] end return sum / period end local function covariance(x, y, period) local mean_x = moving_average(x, period) local mean_y = moving_average(y, period) local cov = 0 for i = #x - period + 1, #x do cov = cov + (x[i] - mean_x) * (y[i] - mean_y) end return cov / (period - 1) end local mean_stock = moving_average(stock_returns, period) local mean_bench = moving_average(benchmark_returns, period) local cov = covariance(stock_returns, benchmark_returns, period) local var_bench = covariance(benchmark_returns, benchmark_returns, period) if var_bench == 0 then return nil, nil end local beta = cov / var_bench local alpha = mean_stock - beta * mean_bench return alpha, beta end -- Function to get stock prices and calculate percentage returns function getReturns(ticker, period) local prices = {} for i = period, 1, -1 do local price = getParamEx(“TQBR“, ticker, “LAST“).param_value if price then table.insert(prices, tonumber(price)) end sleep(100) end if #prices < 2 then return nil end local returns = {} for i = 2, #prices do table.insert(returns, (prices[i] - prices[i-1]) / prices[i-1]) end return returns end -- Main loop message(stock.ticker, 1) end execute_orders(top_5) end message(“Waiting for the next trading day...“, 1) sleep(86400) -- Wait 1 day (86400 seconds) end end.
ΠŸΠΎΡ…ΠΎΠΆΠΈΠ΅ Π·Π°ΠΊΠ°Π·Ρ‹
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° Lua
дистанционно
договорная
Код для Π’Π‘ QUIK. Π”ΠΎΡ€Π°Π±ΠΎΡ‚ΠΊΠ° ΡΡƒΡ‰Π΅ΡΡ‚Π²ΡƒΡŽΡ‰Π΅Π³ΠΎ ΠΏΡ€ΠΎΠ΄ΡƒΠΊΡ‚Π°, Ρ€Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° с нуля. ПоТСлания ΠΈ особСнности: НСобходимо Π½Π°ΠΏΠΈΡΠ°Ρ‚ΡŒ/ΠΈΡΠΏΡ€Π°Π²ΠΈΡ‚ΡŒ ΠΈΠ½Π΄ΠΈΠΊΠ°Ρ‚ΠΎΡ€ для Ρ‚ΠΎΡ€Π³ΠΎΠ²ΠΎΠΉ систСмы QUIK Π½Π° языкС Lua.
Москва
ЀрилансСры
2025-08-10
ΠžΡ‚ΠΊΠ»ΠΈΠΊΠ½ΡƒΡ‚ΡŒΡΡ
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° Lua
дистанционно
договорная
созданиС ΠΊΠ°Ρ€Ρ‚ Π² ΠΈΠ³Ρ€Π΅ roblox. Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° с нуля. Π—Π°Π΄Π°Ρ‡Π° Ρ‚Π°ΠΊΠΎΠ²Π°,Π½ΡƒΠΆΠ½ΠΎ Ρ‡Π΅Ρ€Π΅Π· ΠΏΡ€ΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠ΅ роблокс студио ΡΠΎΠ·Π΄Π°Ρ‚ΡŒ ΠΊΠ°Ρ€Ρ‚Ρƒ ΠΏΠΎ ΠΌΠΎΠ΅ΠΌΡƒ ТСланию.
Москва
ЀрилансСры
2025-07-25
ΠžΡ‚ΠΊΠ»ΠΈΠΊΠ½ΡƒΡ‚ΡŒΡΡ
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° Lua
дистанционно
договорная
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° ΠΏΡ€ΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠΉ для ПК. Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° с нуля. Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° ΠΈΠ³Ρ€Ρ‹ Π² Roblox studio.
Москва
ЀрилансСры
2025-07-14
ΠžΡ‚ΠΊΠ»ΠΈΠΊΠ½ΡƒΡ‚ΡŒΡΡ
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° Lua
дистанционно
договорная
Auto-rotation bot (World of Warcraft). Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° с нуля. Π˜Ρ‰Ρƒ Ρ€Π°Π·Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠ° lua, ΠΏΡ€Π΅Π΄ΠΎΡΡ‚Π°Π²Π»ΡŽ Π°Π½Π»ΠΎΠΊΠ΅Ρ€ ΠΈ Π°ΠΏΠΈ для Ρ€Π°Π±ΠΎΡ‚Ρ‹ с ΠΏΠΎΠ»Π½Ρ‹ΠΌ Π³Π°ΠΉΠ΄ΠΎΠΌ, ΠΆΠ΅Π»Π°Ρ‚Π΅Π»ΡŒΠ½ΠΎ ΠΏΠΎΠ½ΠΈΠΌΠ°Π½ΠΈe ΠΈΠ³Ρ€Ρ‹ World of Warcraft.
Москва
ЀрилансСры
2025-07-13
ΠžΡ‚ΠΊΠ»ΠΈΠΊΠ½ΡƒΡ‚ΡŒΡΡ
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° Lua
дистанционно
договорная
Π½Π°ΠΏΠΈΡΠ°Ρ‚ΡŒ ΠΊΠΎΠ΄ для ΠΈΠ³Ρ€Ρ‹ Π½Π° Lua. Π”ΠΎΡ€Π°Π±ΠΎΡ‚ΠΊΠ° ΡΡƒΡ‰Π΅ΡΡ‚Π²ΡƒΡŽΡ‰Π΅Π³ΠΎ ΠΏΡ€ΠΎΠ΄ΡƒΠΊΡ‚Π°. БущСствуСт скрипт Π² Π½Π΅ΠΌ Π½Π°Π΄ΠΎ Π½Π°ΠΏΠΈΡΠ°Ρ‚ΡŒ ΠΊΠΎΠ΄ для ΠΎΠ½Π»Π°ΠΉΠ½ ΠΈΠ³Ρ€Ρ‹. Π§Ρ‚ΠΎΠ±Ρ‹ Π²Ρ‹Π΄Π°Π²Π°Π» ΠΏΡ€Π΅Π΄ΠΌΠ΅Ρ‚Ρ‹ Ρ€Π°Π· Π² дСнь. Π₯ΠΎΡ‡Ρƒ Π²ΠΈΠ΄Π΅Ρ‚ΡŒ ΠΏΡ€ΠΈΠΌΠ΅Ρ€ ΠΊΠ°ΠΊ Ρ‚ΡƒΡ‚ Π½Π° скринС. Π²ΠΎΡ‚ сам скрипт. ΠΈΠ· этого Π½Π°Π΄ΠΎ Π½Π°ΠΏΠΈΡΠ°Ρ‚ΡŒ ΠΊΠΎΠ΄ Ρ‡Ρ‚ΠΎΠ±Ρ‹ Π±Ρ‹Π»ΠΈ Π½Π°Π³Ρ€Π°Π΄Ρ‹. -- local t = { [1] = { -- [1] window with index 1 is always function window name = { default = "Function window", }, -- 12 entiries - requires 12 state flags data = { { icon = { 4, 13, 4, 0 }, clientWindow = 1, -- CHAR INFO -- customWindow = 2, -- Optional. 2-... for client custom windows (this script windows) instant open. -- raceLimit = { 0, 1, 2 }, -- Optional. -- raceBoss = { 0, 1, 2, 3, 4, 5, 6, 7, 8 }, -- Optional. -- guildGrade = { 1, 2 }, -- Optional. -- isGM = false, -- Optional. -- isPremium = false, -- Optional. }, { icon = { 4, 13, 12, 0 }, clientWindow = 2, -- INVENTORY }, { icon = { 4, 13, 5, 0 }, clientWindow = 3, -- SKILL }, { icon = { 4, 13, 6, 0 }, clientWindow = 4, -- FORCE }, { icon = { 4, 13, 7, 0 }, raceLimit = { 1 }, clientWindow = 5, -- SUMMON (CORA ONLY) }, { icon = { 4, 13, 11, 0 }, clientWindow = 6, -- MACRO }, { icon = { 4, 13, 8, 0 }, clientWindow = 7, -- PARTY }, { icon = { 4, 13, 9, 0 }, clientWindow = 8, -- GUILD }, { icon = { 4, 13, 13, 0 }, clientWindow = 9, -- MAIL }, { icon = { 4, 13, 14, 0 }, clientWindow = 10, -- REP BELLATO raceLimit = { 0 }, raceBoss = { 0, 1, 5 }, }, { icon = { 4, 13, 15, 0 }, clientWindow = 10, -- REP CORA raceLimit = { 1 }, raceBoss = { 0, 1, 5 }, }, { icon = { 4, 13, 16, 0 }, clientWindow = 10, -- REP ACCRETIA raceLimit = { 2 }, raceBoss = { 0, 1, 5 }, }, { -- VISIBLE TO GM ONLY icon = { 4, 13, 3, 0 }, customWindow = 2, isGM = true }, }, }, [2] = { name = { default = "Custom window", }, width = 400, height = 250, layout = { 50, 50, 50, 0 }, -- column width headerWindowID = 0, -- Optional footerWindowID = 0, -- Optional strModal_Ok = { -- optional. default = "OK", }, strModal_Cancel = { -- optional. default = "Cancel", }, strModal_Text = { -- optional. default = "Are you sure? ", }, overlayIcons = { -- optional. max 26 { 8, 0, 19, 295 }, { 0, 0, 0, 0 }, { 0, 0, 0, 0 }, { 0, 0, 0, 0 }, }, data = { { icon = { 8, 0, 26, 183 }, description = { -- Optional. default = "custom tooltip", }, durability = 0, -- Optional. tooltip = { -- Optional. name = { text = { default = "Pseudo name", }, color = 0xFF00FF00, }, info = { default = { { "Left 1", "Right 1" }, { "Left 2", "Right 2" }, { "Left 3", "Right 3" }, }, }, }, }, { item = "iwswd45", upgrade = 0x70000000, durability = 0, -- Optional }, { icon = { 8, 0, 26, 195 }, description = { default = "on hover text", }, }, { text = { default = "ΠšΡ‚ΠΎ Π­Ρ‚ΠΎ?)", }, }, }, }, } return t.
Москва
ЀрилансСры
2025-07-08
ΠžΡ‚ΠΊΠ»ΠΈΠΊΠ½ΡƒΡ‚ΡŒΡΡ
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° Lua
дистанционно
договорная
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° ΠΏΡ€ΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠΉ для ПК. Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° с нуля. Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° интСрфСйса ΠΈ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΎΠ½Π°Π»Π° Π² wow 3.3.5.
Москва
ЀрилансСры
2025-07-08
ΠžΡ‚ΠΊΠ»ΠΈΠΊΠ½ΡƒΡ‚ΡŒΡΡ
Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° Lua
дистанционно
договорная
Π‘ΠΎΠ·Π΄Π°Π½ΠΈΠ΅ ΠΈΠ³Ρ€. Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° с нуля. ΠžΠ±ΡƒΡ‡Π΅Π½ΠΈΠ΅ ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠΈΡ€ΠΎΠ²Π°Π½ΠΈΡŽ созданиС ΠΈΠ³Ρ€ Π² Roblox.
Π‘Π°Π½ΠΊΡ‚-ΠŸΠ΅Ρ‚Π΅Ρ€Π±ΡƒΡ€Π³
ЀрилансСры
2025-07-05
ΠžΡ‚ΠΊΠ»ΠΈΠΊΠ½ΡƒΡ‚ΡŒΡΡ