Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Π½Π° Lua β ΡΠ΄Π°Π»ΡΠ½Π½Π°Ρ ΡΠ°Π±ΠΎΡΠ° Π² ΠΠΎΡΠΊΠ²Π΅
ΠΠ°ΡΠ°: 2025-02-08
ΠΠ΅ΡΠ°Π»ΠΈ
Π Π΅Π³ΠΈΠΎΠ½
ΠΠΎΡΠΊΠ²Π°
ΠΠ°Π½ΡΡΠΎΡΡΡ
Π΄ΠΈΡΡΠ°Π½ΡΠΈΠΎΠ½Π½ΠΎ
Π‘ΡΠΎΠΈΠΌΠΎΡΡΡ
Π΄ΠΎΠ³ΠΎΠ²ΠΎΡΠ½Π°Ρ
ΠΠ°ΡΠ° ΠΏΡΠ±Π»ΠΈΠΊΠ°ΡΠΈΠΈ
2025-02-08
ΠΠΏΠΈΡΠ°Π½ΠΈΠ΅
Tabletop Simulator. Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Ρ Π½ΡΠ»Ρ. ΠΠΎΡΠ»Π΅ ΠΎΠ±ΡΡΠΆΠ΄Π΅Π½ΠΈΡ.
ΠΠΎΡ
ΠΎΠΆΠΈΠ΅ Π·Π°ΠΊΠ°Π·Ρ
Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Π½Π° Lua
Π΄ΠΈΡΡΠ°Π½ΡΠΈΠΎΠ½Π½ΠΎ
Π΄ΠΎΠ³ΠΎΠ²ΠΎΡΠ½Π°Ρ
ΠΠ²ΡΠΎΠΌΠ°ΡΠΈΠ·Π°ΡΠΈΡ ΠΈΠ½Π²Π΅ΡΡΠΈΡΠΈΠΎΠ½Π½ΠΎΠΉ ΡΡΡΠ°ΡΠ΅Π³ΠΈΠΈ. ΠΡΡΡ ΠΌΠ°ΡΠ΅ΠΌΠ°ΡΠΈΡΠ΅ΡΠΊΠΎΠ΅ ΠΎΠΏΠΈΡΠ°Π½ΠΈΠ΅ ΠΌΠΎΠ΄Π΅Π»ΠΈ - Π΅Π΅ Π½ΡΠΆΠ½ΠΎ ΠΏΠ΅ΡΠ΅Π»ΠΎΠΆΠΈΡΡ Π² ΠΊΠΎΠ΄ Π½Π° 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.
ΠΠΎΡΠΊΠ²Π°
Π€ΡΠΈΠ»Π°Π½ΡΠ΅ΡΡ
2025-02-19
Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Π½Π° Lua
Π΄ΠΈΡΡΠ°Π½ΡΠΈΠΎΠ½Π½ΠΎ
Π΄ΠΎΠ³ΠΎΠ²ΠΎΡΠ½Π°Ρ
ΡΠΊΡΠΈΠΏΡ Π΄Π»Ρ ΡΠΏΡΠ°Π²Π»Π΅Π½ΠΈΡ ΠΎΠΊΠ½Π°ΠΌΠΈ ΠΈ Π΄Π΅ΡΠΊΡΠΎΠΏΠ°ΠΌ Π½Π° mac os. Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Ρ Π½ΡΠ»Ρ. Π Π°ΡΠΊΠΈΠ΄Π°ΡΡ ΠΎΠΏΡΠ΅Π΄Π΅Π»Π΅Π½Π½ΡΠ΅ ΠΎΠΊΠ½Π°/Π²ΠΊΠ»Π°Π΄ΠΊΠΈ Ρ
ΡΠΎΠΌ ΠΈ ya Π±ΡΠ°ΡΠ·Π΅Ρ ΠΏΠΎ ΡΠ°Π·Π½ΡΠΌ ΡΠ°Π±ΠΎΡΠΈΠΌ ΡΡΠΎΠ»Π°ΠΌ Π½Π° mac os. ΠΡΠ΅Π΄Π»Π°Π³Π°Π΅ΡΡΡ ΠΈΡΠΏΠΎΠ»ΡΠ·ΠΎΠ²Π°ΡΡ https://www.hammerspoon.org/.
ΠΠΎΡΠΊΠ²Π°
Π€ΡΠΈΠ»Π°Π½ΡΠ΅ΡΡ
2025-02-19
Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Π½Π° Lua
Π΄ΠΈΡΡΠ°Π½ΡΠΈΠΎΠ½Π½ΠΎ
Π΄ΠΎΠ³ΠΎΠ²ΠΎΡΠ½Π°Ρ
Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° ΠΈΠ³ΡΡ Π² Roblox Studio. Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Ρ Π½ΡΠ»Ρ.
ΠΠΎΡΠΊΠ²Π°
Π€ΡΠΈΠ»Π°Π½ΡΠ΅ΡΡ
2025-02-06
Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Π½Π° Lua
Π΄ΠΈΡΡΠ°Π½ΡΠΈΠΎΠ½Π½ΠΎ
Π΄ΠΎΠ³ΠΎΠ²ΠΎΡΠ½Π°Ρ
ΠΠ»Ρ ΠΈΠ³ΡΡ Π² ΡΠΎΠ±Π»ΠΎΠΊΡ. Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Ρ Π½ΡΠ»Ρ, ΡΠ΅ΡΡΠΈΡΠΎΠ²Π°Π½ΠΈΠ΅. Π‘ΠΊΡΠΈΠΏΡ ΠΊΠΎΡΠΎΡΡΠΉ ΠΏΠΎΠ·Π²ΠΎΠ»ΡΠ΅Ρ ΠΎΡΠΊΡΡΠ²Π°ΡΡ ΠΈΠ³ΡΠΎΠ²ΡΠ΅ ΠΊΠ΅ΠΉΡΡ ΡΠΎ ΡΡΠΎΡΠΎΠ½Ρ ΠΊΠ»ΠΈΠ΅Π½ΡΠ° Π° Π½Π΅ ΡΠ΅ΡΠ²Π΅ΡΠ° ΠΌΠΎΠ³Ρ ΠΏΠΎΠΊΠ°Π·Π°ΡΡ Π½Π° ΠΏΡΠΈΠΌΠ΅ΡΠ΅ ΠΏΡΠΎΡΠ΅ ΠΎΠ±ΡΡΡΠ½ΠΈΡΡ ΡΠ΅ΠΌ Π½Π°ΠΏΠΈΡΠ°ΡΡ.
ΠΠΎΡΠΊΠ²Π°
Π€ΡΠΈΠ»Π°Π½ΡΠ΅ΡΡ
2025-02-03
Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Π½Π° Lua
Π΄ΠΈΡΡΠ°Π½ΡΠΈΠΎΠ½Π½ΠΎ
Π΄ΠΎΠ³ΠΎΠ²ΠΎΡΠ½Π°Ρ
Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° ΠΌΠΎΠ΄Π° Π΄Π»Ρ GTA 5. Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Ρ Π½ΡΠ»Ρ. Π’ΡΠ΅Π±ΡΠ΅ΡΡΡ ΡΠ°Π·ΡΠ°Π±ΠΎΡΠΊΠ° ΠΌΠΎΠ΄Π° Π΄Π»Ρ ΠΈΠ³ΡΡ GTA 5 Π½Π° ΠΏΠ»Π°ΡΡΠΎΡΠΌΠ΅ FiveM. ΠΡΠΆΠ½ΠΎ ΠΏΡΠΎΡΠ°Π±ΠΎΡΠ°ΡΡ ΠΈΠ½Π²Π΅Π½ΡΠ°ΡΡ, ΡΠΈΡΡΠ΅ΠΌΡ Π»ΡΡΠ°, ΡΠΈΡΡΠ΅ΠΌΡ Π°Π½ΠΈΠΌΠ°ΡΠΈΠΉ (ΡΠ°ΠΌΠΈ Π°Π½ΠΈΠΌΠ°ΡΠΈΠΈ Π΄Π΅Π»Π°ΡΡ Π½Π΅ Π½ΡΠΆΠ½ΠΎ), ΡΠ΄Π΅Π»Π°ΡΡ ΠΌΠ΅Π½Ρ ΡΠΎΠ·Π΄Π°Π½ΠΈΠ΅ ΠΏΠ΅ΡΡΠΎΠ½Π°ΠΆΠ°, ΡΠ΄Π΅Π»Π°ΡΡ Π½Π΅ΡΠΊΠΎΠ»ΡΠΊΠΎ Π²ΠΈΠ΄ΠΎΠ² ΡΠ°ΡΡ (ΠΌΡΡΠ°Π½ΡΠΎΠ²) Ρ ΠΊΠ°ΠΆΠ΄ΠΎΠΉ ΡΠ°ΡΡ ΡΠ²ΠΎΠΈ ΡΠΏΠΎΡΠΎΠ±Π½ΠΎΡΡΠΈ ΠΈ ΠΎΠΏΡΠ΅Π΄Π΅Π»Π΅Π½Π½Π°Ρ Π²Π΅ΡΠΊΠ° ΠΏΡΠΎΠΊΠ°ΡΠΊΠΈ (ΠΏΡΠΈΠΌΠ΅ΡΡ ΡΠ°ΠΊΠΈΡ
ΡΠ°Π±ΠΎΡ, ΠΊΠ°ΠΊ ΠΎΠ½ΠΈ Π²ΡΠ³Π»ΡΠ΄ΡΡ, ΠΏΡΠ΅Π΄ΠΎΡΡΠ°Π²Π»Ρ), Π°Π½ΠΎΠΌΠ°Π»ΡΠ½ΡΠ΅ Π·ΠΎΠ½Ρ ΠΈ Π½ΠΏΡ Π·ΠΎΠΌΠ±ΠΈ.
ΠΠΎΡΠΊΠ²Π°
Π€ΡΠΈΠ»Π°Π½ΡΠ΅ΡΡ
2025-01-28
Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Π½Π° Lua
Π΄ΠΈΡΡΠ°Π½ΡΠΈΠΎΠ½Π½ΠΎ
Π΄ΠΎΠ³ΠΎΠ²ΠΎΡΠ½Π°Ρ
Ardupilot. Π Π°Π·ΡΠ°Π±ΠΎΡΠΊΠ° Ρ Π½ΡΠ»Ρ. Π£ΠΏΡΠ°Π²Π»Π΅Π½ΠΈΠ΅ 2 ΠΌΡ ΡΠ΅ΡΠ²ΠΎΠΏΡΠΈΠ²ΠΎΠ΄Π°ΠΌΠΈ ΠΏΠΎ ΠΎΡΠΈΠ΅Π½ΡΠ°ΡΠΈΠΈ ΠΊΠΎΠΌΠΏΠ°ΡΠ° ΠΈ Π³ΠΈΡΠΎΡΠΊΠΎΠΏΠ° ΠΏΠΎΠ»Π΅ΡΠ½ΠΎΠ³ΠΎ ΠΊΠΎΠΌΠΏΡΡΡΠ΅ΡΠ°.
ΠΠΎΡΠΊΠ²Π°
Π€ΡΠΈΠ»Π°Π½ΡΠ΅ΡΡ
2024-10-16