Судя по всему, теперь каждый glSet должен включать в себя glBind (что-то)
Не совсем. Это наоборот, как описано в нескольких параграфах ниже.
Даже если бы это было так, помните, что команды GL от клиентского приложения к серверу GL (он же драйвер) имеют много накладных расходов по сравнению с обычным вызовом функции. Даже если мы предположим, что функции DSA являются просто обертками вокруг существующих функций, они являются обертками, которые находятся внутри GL-сервера и, следовательно, могут иметь (немного) меньшую нагрузку.
если OpenGL все еще является конечным автоматом, он не может использовать преимущества потоковых изменений, примененных к одному объекту.
Графические процессоры не являются конечными автоматами. Интерфейс конечного автомата GL - это эмуляция, которая оборачивает DSA-подобные драйверы, а не наоборот.
Удаление одного уровня упаковки - уровня, который требует чрезмерного количества вызовов на сервер GL, - это, безусловно, выигрыш, даже если он небольшой.
Подход конечного автомата также не имеет большого смысла при работе с несколькими потоками; GL все еще ужасен в этом случае использования, но драйверы часто используют потоки за кулисами, и конечный автомат требует много синхронизации потоков или действительно причудливых параллельных алгоритмов / конструкций, чтобы заставить вещи работать надежно.
Расширение DSA продолжает формулировать свою работу в терминах изменений состояния, потому что это, в конце концов, расширение существующего документа на основе состояния, а не совершенно новый API, поэтому оно должно быть готово подключиться к существующей спецификации GL язык и терминология документа. Даже если этот существующий язык довольно ужасно подходит для его работы в качестве современного графического аппаратного API.
Пожалуйста, объясните причины и преимущества нового DSA.
Самым большим аргументом является то, что старый способ был болью. Это очень затрудняло составление библиотек, которые могли бы изменять или полагаться на состояние GL. Это затрудняло эффективную упаковку GL API в объектно-ориентированном или функциональном стиле из-за его глубоких процедурных корней управления состоянием, которые затрудняли упаковку API в различные языки, не связанные с C, а также затрудняли создание эффективных оболочек графических устройств. тот абстрактный OpenGL от Direct3D.
Во-вторых, это процедурные издержки API конечного автомата, как описано ранее.
В-третьих, функции DSA изменили семантику, где это было необходимо, по сравнению со старыми API, что позволило повысить эффективность. Например, вещи, которые ранее были изменяемыми, стали неизменяемыми, что удаляет большую часть кода бухгалтерского учета с сервера GL. Вызовы приложения могут отправляться на аппаратное обеспечение или проверяться раньше (или несколькими параллельными модами), когда серверу GL не приходится иметь дело с изменяемыми объектами.
-
Дополнительное обоснование и объяснение даны в спецификации расширения EXT_direct_state_access .
-
Аппаратные изменения, которые имеют отношение к дизайну API, довольно многочисленны.
Помните, что OpenGL датируется 1991 годом. Целевым оборудованием были не видеокарты потребительского уровня (таких не было), а большие рабочие станции САПР и тому подобное. Аппаратные средства той эпохи имели очень разные огибающие производительности, чем сегодня; многопоточность была реже, шины памяти и процессоры имели меньший разрыв в скорости, а графический процессор делал немного больше, чем рендеринг треугольников с фиксированными функциями.
Все больше и больше фиксированных функций были добавлены. Были добавлены различные модели освещения, режимы текстур и т. Д., Каждая из которых нуждалась в отдельном состоянии. Простой основанный на состоянии подход работал, когда у вас было несколько состояний. По мере того, как все больше и больше состояний добавлялось, API начал разрываться по швам. API стал более неловким, но не слишком отличался от аппаратных режимов, поскольку они действительно основывались на множестве переключателей состояний.
Затем пришло программируемое оборудование. Аппаратное обеспечение становится все более и более программируемым, и теперь аппаратное обеспечение поддерживает небольшое состояние, некоторые пользовательские программы и множество буферов. Все это состояние из предыдущей эпохи должно было быть эмулировано, так же как все функции фиксированной функции той эпохи эмулировались водителями.
Аппаратное обеспечение также изменилось, чтобы быть более параллельным. Это потребовало других изменений оборудования, которые сделали изменения состояния графики очень дорогими. Аппаратное обеспечение работает в больших блоках неизменного состояния. Из-за этих изменений драйвер не мог просто применить каждый бит состояния, которое пользователь установил немедленно, но должен был автоматически пакетировать изменения и применять их при необходимости неявно.
Современное оборудование работает еще дальше от классической модели OpenGL. DSA - это одно небольшое изменение, которое было необходимо около 10+ лет назад (изначально оно было обещано как часть OpenGL 3.0), подобно тому, как это делал D3D10. Многие из вышеперечисленных аппаратных изменений требуют гораздо большего, чем просто DSA, чтобы поддерживать актуальность OpenGL, поэтому доступны еще более крупные расширения, которые кардинально меняют модель OpenGL . Тогда есть целый новый GLnext API плюс D3D12, Mantle, Metal и т. Д., Ни один из которых не поддерживает устаревшую абстракцию конечного автомата.
Обзор оправдывает это:
Я думаю, что термин «более эффективный» относится как к меньшим затратам на ведение бухгалтерского учета для авторов библиотек, так и к повышению производительности. С текущим API, чтобы «хорошо себя вести», вам нужно запросить состояние, спрятать его, изменить состояние, чтобы сделать то, что вам нужно, а затем восстановить исходное состояние.
подобно
Предположительно, старое оборудование может быть сделано более производительным с явным изменяющим состояние API; в противном случае это довольно странный ритуал. Это расширение подразумевает (и просто посмотрите на список авторов!), Что избегание этого извлечения, установки, восстановления танца теперь больше выигрыша в производительности на текущем оборудовании, даже с дополнительным параметром при каждом вызове.
источник
get/bind/do/set
используется редко, потому что «Получить» очень медленно. Обычно приложения должны поддерживать реплику переменных в любом случае, поэтому она сводится к простомуbind/do
. Хотя я вижу смысл.