green_fr: (Default)
green_fr ([personal profile] green_fr) wrote2011-10-04 04:56 pm
Entry tags:

MatLab classes overhead

Пытаемся причесать немного нашу программу на MatLab’е, группируем написанные разными людьми скрипты в классы.
И вдруг замечаю, что функция, оформленная в виде метода, исполняется в разы медленнее... Один и тот же код (copy-paste), только данные не в глобальных переменных, а члены класса.

Позвонил в support, они мне говорят, что это не баг, это фича: доступ к переменным объекта занимает слегка больше времени, чем доступ к простым переменным. Пообещали передать разработчикам, но, судя по внутренней базе, разработчики не считают это поведение анормальным.

Оказалось, MatLab не помнит результатов проверок, которые он проводил только что. Например, в методе класса есть цикл, в цикле мы обращаемся к переменной класса (мой случай — к статической константе!). Так вот, он на каждой итерации будет проверять, существует ли такая переменная, не переопределена ли она дочерними классами, и какой у неё уровень доступа.

Написал «патч»: в начале каждого метода считываю константы в локальные переменные.
Одна из функций разогналась с 42 секунд до полутора.
Послал предложение усовершенствования в MathWorks, может премию вышлют :-)

[identity profile] green-fr.livejournal.com 2011-10-04 07:47 pm (UTC)(link)
Это да. Я по поводу твоего «я бы не рассчитывал» — нет, блин, я на эту премию уже заложился!
А что у тебя за фича была?

[identity profile] green-fr.livejournal.com 2011-10-05 07:19 am (UTC)(link)
Да уж, я в это время пешком под стол ходил, и про MatLab даже не подозревал.
С тех пор я прикрутил в MatLab собственный сервер через c++ sockets - могу исходники подкинуть :-Р

[identity profile] kalvado.livejournal.com 2011-10-05 04:42 pm (UTC)(link)
да я тогда сделал, через примочку в дельфях - си я так до сих пор и не знаю
И неактуально уже..