Quikos_1 (Автор тем)

Выбрать дату в календареВыбрать дату в календаре

Страницы: 1
SetUpdateCallback и обнудение стека Lua
 
Здравствуйте,

Слезно прошу помощи, я что то не вьезжаю, что происходит. Раньше вроде все работало, сейчас, как будто бы перестало.

Использую LUA C API - для вызова SetUpdateCallback, вот такой просто С++ код:  да понимаю, что вероятность, что кто-то будет смтреть код стремится к нулю, поэтому срезюмирую поведение кода:

С помощью QLua C API:

-1:Я вызываю CreteDataSorce: вызов происходит успешно, мне возвращается таблица и нулевая ошибка.
-2:Я подтверждаю это проверкой стека Lua: на вершине стека находится таблица и нулевая ошибка.


-3:Затем я вызываю SetUpdateCallback и передаю вв него саму колбек функцию, которая будет вызыватся при каждой совершенной сделке.  Так же дополнительно я связываю по типу лямбды любое значение, чтбы предать для последующего ивзлечения его в самом колбеке.

-4:Вызыва SetUpdateCallback, убеждаюсь, что вызов SetUpdateCallback прошел успешно и опять проверяю стек на наличие ранее заказанной таблицы CreateDataSource - ОНИ НА МЕСТЕ!
.
-5: И наконец на рынке совершается сделка по заказанному инстурменту и вызывается колбек "my_callback__for__SetUpdateCallback". Все что я делаю в данном примере в этом колбеке это проверяю наличие моей таблицы CrateDataSourc в стеке Lua. ИИИИИИ ее там нет!!!! Весь стека кромер первого элемента был "кем-то" очищен!

ВОПРОС: КТО И ЗАЧЕМ очитстил стек ?? КАК видно из кода, между вызовов SetUpdateCallback и вызовом самой колбек-функции нет ни одной строчки кода, которая бы редактировала стек. Так что происходит тогда ?


Код
lua_State* L_global;
int static nummer_table_from_stack;

Код
void SetUpdateCallcak_wrapper(lua_State* L)
{

    L_global = L;
    std::cout << "L_global_adress:" << &L_global << std::endl;


    //-----------------------------------------------------------------1-Вызовем функцию CreateDataSource:Начало--------------------------------------------
    lua_getglobal(L, "CreateDataSource");                 

    lua_pushstring(L, "TQBR");       //Добавим первый параметр функции CreateDataSource на вершину стека
    lua_pushstring(L, "SBER");          //Добавим второй параметр функции CreateDataSource на вершину стека
    lua_pushnumber(L, 1);            //Добавим третий параметр функции CreateDataSource на вершину стека

    int status_lua_pcall = lua_pcall(L, 3, 2, 0);    //Так как все необходимые параметры добавлены в стек, то вызываем функцию lua_pcall - которая использя доабвенные параметры в правильном порядке - реализует вызов функции CreateDataSource: 2-ой параметр - это число аргументов, которые мы добаили в стек и которая принимает функция CreateDataSource; 2-ой: параметр - это число параметров, которое возвращает функция CreateDataSource. После успешного выполнения lua_pcall удаляет и значение функции и переданные аргменты со стека в кол-во указанном во втором параметре(не велючая функцию) и доабвляеи результат на стек в кол-во указанном во втором параметре.
    //-----------------------------------------------------------------1-Вызовем функцию CreateDataSource:Конец--------------------------------------------



    //-------------------------------------------------------------------5-Проверка на ошибку lua_pcall:Начало---------------------------------------------------------------------
    if (status_lua_pcall != 0)
    {
        //Ошибка произошла при вызове функции lua_pcall при вызове CreateDataSource:
        std::cout << "ERROR CreateDataSource" << std::endl;
        return;
    }
    //-------------------------------------------------------------------5-Проверка на ошибку lua_pcall:Конец---------------------------------------------------------------------
    else
    {

         nummer_table_from_stack = lua_gettop(L) - 1;   //Это номер элемента в стеке L - в котором теперь размещается полученная от CreateDataSource таблица. "-1" - потому что CreateDataSource поместила на вершину стека две перменные: таблицу и переменную об ошибке. То есть таблица находить на предпоследнем месте с вершины стека.

         my_call_SetUpdateCallback(L);     //Вызываем SetUpdateCallback wrapper
    }

}

Код
static void ckeck_Lua_Stack(lua_State* L)
{

    std::cout << "----------------------------------------" << std::endl;

    int top = lua_gettop(L);
    std::cout << "Total element is stack:"<< top << std::endl;

    for (int i = 1; i <= top; i++) 
    {
        int type = lua_type(L, i);

        const char* type_name = lua_typename(L, type);

        std::cout << "type:" << type_name << ":";


        if (type == LUA_TSTRING || type == LUA_TNUMBER) 
        {
            std::cout << lua_tostring(L, i) << std::endl;
        }
        else
        {
            std::cout << std::endl;
        }
    }
    std::cout << "----------------------------------------" << std::endl << std::endl;


    //std::this_thread::sleep_for(std::chrono::milliseconds(100000));

}
Код
static int my_callback__for__SetUpdateCallback(lua_State* L)
{

//Значит произошла сделка!

    std::cout << "Number_candle:"<< lua_tonumber(L, -1) << std::endl;

    ckeck_Lua_Stack(L_global);         //Проверяем стек Lua!!! И теперь в нем находится сдедующее:

----------------------------------------
Total element is stack:1                          //Куда черт возьми делать моя ранее заказанная таблица CreateDataSource ?????
type:number:1
----------------------------------------


    return 0;

}

Код
static void my_call_SetUpdateCallback(lua_State* L)
{

    
    //--------------------------------------------------------
    lua_getfield(L_global, nummer_table_from_stack, "SetUpdateCallback");                       //"Извлекаем" из "таблицы" функцию SetUpdateCallback.
     
    lua_pushvalue(L_global, nummer_table_from_stack);                                                       //Помещаем копию обьекта таблицы CreateDataSource на вершину стека.
    //--------------------------------------------------------


    lua_pushnumber(L_global, 555);  //Просто для примера связываю какое то любое значение для передачи в колбек. 

    lua_pushcclosure(L_global, my_callback__for__SetUpdateCallback, 1);       //Захватываем.


    //--------------------------------------------------------
    int status_lua_pcall = lua_pcall(L_global, 2, 0, 0);                  //Реализауем вызов функции SetUpdateCallback с аргументом таблицы, которую поместили на вершину стека 
    //--------------------------------------------------------
    

    if (status_lua_pcall != 0)
    {
        std::cout << "lua_pcall__ERROR" << std::endl;
        return; 
    }
    else
    {
        std::cout << "SetUpdateCallback Success Call" << std::endl;
        
        ckeck_Lua_Stack(L_global);       //Проверяю что находится на данный момент в стеке Lua.

       //Находится следующее:

 ----------------------------------------
Total element is stack:3
type:string:1     //Таблица глобьальный функций
type:table:        //Это как раз запрошенная таблица CreateDataSource
type:nil:            //Ошибка при запросе таблицы CreateDataSource - то есть nil - ошибки нет.
----------------------------------------

        return;
    }


}
SetUpdateCallback Опять косячит ?
 
Здравствуйте,

Развейте пожалуйста мои сомнения насчет того, что Quik и в частности SetUpdateCallback() - опять работают, какбудто бы их написал через %опу, и что руки их %опы, растут, как раз таки у меня.

Использую такой простейший код для теста: просто вывожу последнюю цену сделки и обьем по последней минутной свече:

Код
function main()
    local class_code = "TQBR" -- Код класса
    local sec_code = "SBER" -- Код бумаги

    ds = CreateDataSource(class_code, sec_code, INTERVAL_M1)
    ds:SetUpdateCallback(function(index)
        local last_price = ds:C(index)
        local volume = ds:V(index) -- Получение объема по свече
        message("Last Price of " .. sec_code .. ": " .. tostring(last_price) .. ", Volume: " .. tostring(volume)) -- Вывод цены и объема по свече
    end)

    while true do
        sleep(1000)
    end
end

Данный код исправно работает.
НО, как только я вывожу код SetUpdateCallback в отдельный колбек, то ничего более не работает. Ошибок также в скрипте нет, но он не сообщает ни о каких измененениях, то есть колбек функция указанная в качестве параметра для SetUpdateCallback - тупо не вызывается при изменнеии цены:
Код
function updateCallback(index)
    local last_price = ds:C(index)
    local volume = ds:V(index) -- Получение объема по свече
    message("Last Price of " .. sec_code .. ": " .. tostring(last_price) .. ", Volume: " .. tostring(volume)) -- Вывод цены и объема по свече
end

function main()
    local class_code = "TQBR" -- Код класса
    local sec_code = "SBER" -- Код бумаги

    ds = CreateDataSource(class_code, sec_code, INTERVAL_M1)
    ds:SetUpdateCallback(updateCallback)

    while true do
        sleep(1000)
    end
end
Кто из нас рукожоп ? Я или разрабы Квика ? Надеюсь, что я.
Quik не запрашивает PIN-код по СМС, Quik не запрашивает PIN-код по СМС
 
Здравствуйте,

После аварийного завершения Quik и повторного запуска Quik - аутентификация происходит только через пароль без PIN кода в СМС.

Это корректное поведение или косяк ?
CreateDataSource иногда возвращает ошибку - "TQBR - unknown class code"
 
Собственно вопрос: Почему CreateDataSource иногда возвращает ошибку: "TQBR - unknown class code" ??
Это еще блин че такое на графике Яндекса (YNDX) ???
 
Заметил, что по Яндексу CreateDataSource выдает какую  * .

Решил  посмотреть на реальный месячный график в самом Квике, вот скрин  месячного-интервального графика: на скрине подробное описание проблемы:





По другим интервалам Яндекса - проблем нет. По другим месячным  интервалам других инструментов - проблем нет. Но это явная извините  херня какая то.
Это еще блин че такое на графике Яндекса (YNDX) ???
 
Заметил, что по Яндексу CreateDataSource выдает какую  * .

Решил посмотреть на реальный месячный график в самом Квике, вот скрин месячного-интервального графика: на скрине подробное описание проблемы:




КУ

По другим интервалам Яндекса - проблем нет. По другим месячным интервалам других инструментов - проблем нет. Но это явная извините херня какая то.
CreateDataSource и SetUpdateCallback - по разным интервалам
 
Подскажите, я правильно понимаю, что когда я вызваю:

-CreateDataSource и потом SetUpdateCallback по одному инструменту, но с разными интервалами, для примера:

-"TQBR" ,"SBER",  "INTERVAL_M1"
"TQBR" ,"SBER",   "INTERVAL_M3"
"TQBR" ,"SBER",   "INTERVAL_M5"
"TQBR" ,"SBER",   "INTERVAL_M10"

То на сервер при SetUpdateCallback - идет по сути только один запрос по интервалу - "INTERVAL_TICK", а уже пришедшая цена с датой раскидывается по интервалу силами Квика ?
Ограничения Квик на однорвеемнные вызовы CreateDataSource
 
Подскажите пожалуйста, я правильно понимаю, что у Квика есть лимит по вызовам CreateDataSource ?

Запускаю простой скрипт:
Код
my_status = my_CreateDataSource__HISTORY__wrapper("TQBR","SBER", "INTERVAL_M1")
my_status = my_CreateDataSource__HISTORY__wrapper("TQBR","GAZP", "INTERVAL_M1")
my_status = my_CreateDataSource__HISTORY__wrapper("TQBR","ZILL", "INTERVAL_M1")
my_status = my_CreateDataSource__HISTORY__wrapper("TQBR","YRSBP", "INTERVAL_M1")
my_status = my_CreateDataSource__HISTORY__wrapper("TQBR","YRSB", "INTERVAL_M1")
my_status = my_CreateDataSource__HISTORY__wrapper("TQBR","YNDX", "INTERVAL_M1")
my_status = my_CreateDataSource__HISTORY__wrapper("TQBR","YKENP", "INTERVAL_M1")
...
и так штук 200-300

-------------------------
while not stopped do 
sleep(1)
end 
-------------------------


Квик падает с ошибкой:


[img][/img]
По некотрым акциям - формируются не все интервалы свечи
 
Здравствуйте,

По некоторым акциям - формируются не все интервалы.

Для примера: TQBR: ZILL

В самом Квике на графике интервалы 1 и 3 минуты не формируются - окно просто черное.
А вот с 5 минутным интервалом без проблем.

Это так и должно быть или такое поведение допускается или это ошибка ?
Индикаторы RSI и EMA на графике
 
Здравствуйте,

Подскажите, где я ошибаюсь или как Квик рассчитывает эти два индикатора ?

Вот скриншот из Квика с периодом индикаторов == 3:

У  меня вопрос, как RSI и EMA рачитались для третьей с начала свечи с  периодом 3, если для их расчета нужно кол-во свечей равное: period + 1,  то ест ьв данном случае для расчета нужны 4 свечи с указанным периодом.  Или я чего то неправильно понимаю ?

Индикаторы RSI и EMA на графике
 
Здравствуйте,

Подскажите, где я ошибаюсь или как Квик рассчитывает эти два индикатора ?

Вот скриншот из Квика с периодом индикаторов == 3:

У меня вопрос, как RSI и EMA рачитались для третьей с начала свечи с периодом 3, если для их расчета нужно кол-во свечей равное: period + 1, то ест ьв данном случае для расчета нужны 4 свечи с указанным периодом. Или я чего то неправильно понимаю ?


Страницы: 1
Наверх