Тел.: +7 (495) 783-68-51 Email: info@izmeril.ru ‌‌‍‍‌‌‍‍
Меню

Преимущества графического программирования NI LabVIEW

Более 35 лет инженеры и ученые используют NI LabVIEW для разработки измерительных систем, испытательных стендов и систем управления. В основе LabVIEW лежит графический язык программирования G. Помимо самой возможности программирования среда LabVIEW предоставляет в распоряжение пользователя широкий спектр инструментов и библиотек: от интерактивных мастеров настройки и пользовательских интерфейсов до встроенных компилятора, компоновщика и средств отладки.

Краткая история развития высокоуровневого программирования

Чтобы лучше понять основные преимущества концепции графического программирования, стоит обратиться к истории появления первого высокоуровневого языка. В середине 50-х годов XX века, на заре развития компьютерной техники, небольшое подразделение в IBM разработало альтернативный способ программирования суперкомпьютеров IBM 704 – язык FORTRAN. В отличие от существовавшего в то время низкоуровневого языка, предложенный специалистами язык был ближе к прикладной области, проще воспринимался человеком и позволял ускорить процесс разработки.

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

Несмотря на то, что высокоуровневые языки все время совершенствуются, вопрос повышения удобства и скорости работы остается актуальным и на сегодняшний день. Это объясняет популярность и широкое распространение языка G, с тех пор как он появился в 1986 году. Этот язык предоставляет максимально возможный уровень абстракции, что позволяет пользователям работать более эффективно, практически не проигрывая в производительности кода таким языка как FORTRAN, C и C++.

LabVIEW: графическое потоковое программирование

Существует два основных отличия LabVIEW от других языков программирования. Во-первых, LabVIEW реализует концепцию графического программирования, поэтому исходный код представляет собой блок-диаграмму (соединенные друг с другом пиктограммы элементов языка), которая затем компилируется в машинный код. Несмотря на такой подход, в LabVIEW используются те же конструкции и методы программирования, что и в других языках: типы данных, циклы, переменные, рекурсия, обработка событий и объектно-ориентированное программирование.
Вторая отличительная особенность LabVIEW - это поддержка выполнения кода, написанного на языке G, в режиме потока данных (потоковое программирование), в то время как традиционные текстовые языки (например, C и C++) обеспечивают выполнение кода в виде последовательности команд. В основе языков потокового программирования (таких как G, Agilent VEE, Microsoft Visual Programming Language и Apple Quartz Composer) лежит концепция потока данных, который и определяет последовательность выполнения функциональных узлов программы.

Поначалу может показаться, что отличие подобного подхода от традиционного не существенно, однако на практике оказывается иначе. А именно, потоковое программирование в среде LabVIEW позволяет разработчику полностью сфокусироваться на данных и путях их обработки. Узлы программы - функции, циклы и прочие конструкции языка - получают данные через входы, производят их обработку и выводят данные с помощью выходов. Как только значения параметров поступают на каждый из входных терминалов узла, происходит выполнение кода узла (обработка поступивших данных), после чего значения выходных параметров оказываются доступными на выходных терминалах узла для дальнейшей их передачи на другие узлы согласно логике потока данных. Соответственно, из двух последовательно связанных узлов, второй сможет быть выполнен только после получения данных от предыдущего.

Интуитивное использование средств графического языка

Как и большинство людей, многие инженеры и ученые решают поставленные перед собой задачи, оперируя образами или символами. Подобный поход развивается в процессе обучения и применения соответствующих инструментов обработки информации – различных схем и диаграмм. Однако большинство языков программирования требуют изучения специфического синтаксиса и адаптации моделей прикладной области к возможностям языка. В тоже время, графический язык G позволяет работать с интуитивно понятными структурами.

Код языка LabVIEW удобнее для инженеров и ученых, потому что они привыкли к визуальной работе с данными, моделированию процессов с помощью блок-схем и диаграмм состояний, которые так же отражают потоки данных. Помимо этого, потоковое программирование обусловливает необходимость работать в терминологическом поле прикладной области задачи. Например, типичное приложение на LabVIEW сперва получает данные с нескольких каналов датчиков температуры, затем передает данные функции, выполняющей анализ, и, наконец, сохраняет данные на диск. Графическое представление программы наглядно демонстрирует порядок выполнение операций и потоки данных.

Интерактивные средства отладки

Поскольку концепция языка G проста для понимания, LabVIEW предоставляет в распоряжение пользователя столь же удобные и интуитивно понятные инструменты среды разработки. Например, уникальные средства отладки позволяют наглядно отобразить процесс распространения данных по проводникам, а также отобразить соответствующие значения на входах и выходах узлов кода (речь идет об анимации выполнения).

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

Отладочные средства позволяют установить пробники одновременно на многих участках программы, приостановить выполнение и выполнить вход в подпрограмму. Подобный функционал есть и в других средах разработки, однако LabVIEW, благодаря графической сути языка G, в более удобной форме отображает текущее состояние программы и взаимосвязи параллельных участков кода.

Одна из отличительных особенностей процесса отладки в LabVIEW – это скрытое компилирование кода. Пока вы работаете с кодом, компилятор постоянно проводит семантический и синтаксический анализ кода. В случае обнаружения ошибок, блокируется возможность выполнения программы, а на инструментальной панели отображается пиктограмма со сломанной стрелкой.

В такой ситуации, нажатие на кнопку запуска приводит к отображению окна с перечнем ошибок, которые необходимо исправить. Как только они буду устранены, программа может быть скомпилирована, а ее производительность будет сопоставима с программами, написанными на большинстве традиционных языков типа языка C.

Автоматическое распараллеливание

Языки потокового программирования, такие как LabVIEW, позволяют автоматически распараллеливать выполнение кода. В отличие от языков с последовательным выполнением команд, таких как C и C++, графические языки изначально содержат в себе информацию о том, какие участи кода следует выполнять параллельно. Рассмотрим, к примеру, шаблон проектирования «Производитель/Потребитель», в котором два цикла While выполняются независимо: первый цикл генерирует или получает данные, а второй – обрабатывает их. Несмотря на то, что циклы выполняются параллельно, данные между ними успешно передаются с помощью механизма очередей, которые поддерживаются и в стандартных языках.

Параллелизм также позволяет увеличить производительность программ. В настоящее время становится все более популярной новая архитектура процессоров - многоядерные процессоры.

Чтобы до конца использовать все преимущества многоядерной архитектуры процессора, программы должны содержать участки кода, которые могут выполняться независимо (т.е. быть многопоточными). В обычных текстовых языках создание и управление потоками является сложной задачей для неопытного специалиста в программировании.

Явное преимущество языка LabVIEW по сравнению с обычными текстовыми языками программирования заключается в том, что реализация многопоточных приложений является весьма простой задачей. Встроенный компилятор самостоятельно определяет участки кода, имеющие параллельно расположенные узлы, и организует раздельные потоки для их параллельного исполнения. В компьютерной терминологии такой механизм называется «неявный параллелизм», т.е. реализация параллелизма осуществляется автоматически средствами разработки, а не специально написанным кодом.

Помимо поддержки многопоточности на многоядерных системах, LabVIEW позволяет создавать приложения для параллельных вычислений на ПЛИС – интегральных микросхемах с программируемой логикой, в которых выполнение независимых участков кода организуется абсолютно независимыми участками микросхемы, которые не влияют на производительность друг друга. LabVIEW очень хорошо подходит для программирования ПЛИС, потому что в его основе лежит работа с параллельными потоками данных. Именно поэтому он становится всё более популярным среди разработчиков, которым требуются параллельные детерминированные вычисления.

Уровень абстракции низкоуровневых операций

В примере с языком FORTRAN было показано, что уровни абстракции, обеспечиваемые языками высокого уровня – их главное преимущество, которое проявляется в более наглядном виде кода по сравнению с низкоуровневыми языками. LabVIEW автоматически обеспечивает выполнение ряда задач (например, управление памятью), которое в текстовых языках обычно ложится на плечи разработчика. В подобных случаях вы самостоятельно должны обеспечить выделение памяти перед ее использованием и освобождение – после, а также следить за тем, чтобы не выйти за границы выделенной области.

Автоматическое управление памятью – одно из главных преимуществ языка LabVIEW. Когда вы пишите программу на графическом языке программирования, вам не нужно ни выделять память для переменных, ни присваивать им значения. Вместо этого, вы создаете блок-диаграмму, отражающую движение данных. Узлы блок-диаграммы, которые генерируют данные, автоматически обеспечивают выделение памяти для данных. Высвобождение памяти происходит автоматически после того как данные оказываются не нужны. Как только вы добавляете дополнительные данные в массив или строку, вызываются процедуры выделение дополнительного объема памяти. Таким образом, вы можете сосредоточиться на решении поставленной задачи, а не разбираться в тонкостях языка и не допускать ошибок при программировании.

В то же время, если вам необходимо управление памятью на низком уровне, вы можете задействовать встроенные утилиты мониторинга использования памяти, чтобы оценить эффективность разных техник программирования.

Если программа на LabVIEW демонстрирует неожиданные результаты, вы можете воспользоваться как упомянутыми выше средствами отладки, так и инструментарием для продвинутых пользователей, а именно – тулкитом Desktop Execution Trace Toolkit, который позволяет провести динамический анализ кода на наличие:

• Утечек памяти и ошибки ссылок/указателей
• Участков кода, вызывающих не желаемое поведение программы
• Участков программы, на которых может быть увеличена производительность
• Определение вызова предшествующего ошибке
• Сравнение работы кода на разных платформах

Интеграция LabVIEW с другими языками

Несмотря на то, что LabVIEW идеально подходит для организации распараллеливания кода, а также скрывает тонкости управления памятью, он не является наиболее оптимальным выбором для решения некоторых задач. В частности, математические формулы и уравнения могут быть более наглядно представлены в текстовом виде, поэтому в LabVIEW реализованы механизмы добавления на блок-диаграмму текстового кода.

Например, в LabVIEW есть узел, называющийся Formula Node, который позволяет рассчитывать значения по текстовым формулам и выполнять текстовые программы с C-подобным синтаксисом.

Аналогично, узел MathScript Node позволяет встраивать в программу на LabVIEW код .m файлов

Оптимальный способ решения ваших задач

Графический язык и концепция потокового программирования LabVIEW позволяет вам решать задачи более удобными и эффективными методами, чем традиционные текстовые языки. Ключевые особенности программирования на языке LabVIEW, а именно интуитивно понятный и наглядный графический код, а также управляемое потоком данных выполнение программы, позволяют сделать процесс программирования более близким к процессам мышления, чем другие языки. Несмотря на высокий уровень абстракции кода, производительность программ, написанных в среде LabVIEW, остается сопоставимой с языками типа C, благодаря встроенному компилятору кода.

Хотите купить LabView?

Напишите нам на почту!

© All Rights Reserved.
ООО Модульные Измерительные Решения

официальный дистрибьютор National Instruments


e-mail: info@izmeril.ru

тел: +7 (495) 783-68-51
тел: +7 (843) 290-06-83

420066, г.Казань, ул. Солдатская,
зд.8, пом. 13
National Instruments

11500 N Mopac Expwy

Austin, TX 78759-3504