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:45 pm (UTC)(link)
Ты знаешь, я вообще-то не люблю вот так вот сразу людей идиотами считать, я всегда пытаюсь найти какое-то логичное обоснование. Ну мало ли, вдруг в процессе исполнения программы параллельный поток подгрузит новые классы? Или переопределит класс, исполняющийся в твоём потоке? Никогда и ни в чём нельзя быть уверенным!

[identity profile] birdwatcher.livejournal.com 2011-10-04 08:11 pm (UTC)(link)
В S в какой-то момент циклы тоже были официально в миллиард раз медленнее эквивалентных векторных операций, но в R этот кусок, вроде, переписали.

[identity profile] och.livejournal.com 2011-10-04 08:15 pm (UTC)(link)
параллельный поток подгрузит новые классы? Или переопределит класс, исполняющийся в твоём потоке?
константа-то небось еще и final была? :)

[identity profile] green-fr.livejournal.com 2011-10-04 08:19 pm (UTC)(link)
Не сыпь мне соль на рану, в MatLab'е вообще нет просто static, есть только Constant (аналог static final). Представляешь, да, сколько граблей с оригинальными методами их обхода...