УИД — Проект GNU — Фонд свободного программного обеспечения
Ричард СтолменЦелью проекта, называемого УИД (унифицированный интерфейс драйверов) является определение единого интерфейса между ядрами операционных систем и драйверами устройств. Какую пользу движение за свободное программное обеспечение должно извлечь из этой идеи?
Если мы представим себе некоторое число операционных систем и разработчиков аппаратуры, которые все сотрудничают на равных, то УИД (если такое технически осуществимо) был бы очень хорошей идеей. Это позволило бы разрабатывать только один драйвер для любого заданного аппаратного устройства, а потом им могли бы пользоваться все. Это открыло бы возможность сотрудничества на более высоком уровне.
Когда мы применяем эту мысль к реальному миру, в котором есть как разработчики свободных программ, стремящиеся к сотрудничеству, так и разработчики несвободных программ, стремящиеся к господству, то мы получаем совсем другие последствия. УИД никоим образом не может быть полезен движению за свободное программное обеспечение. Это разделит и ослабит нас, если вообще приведет к каким-нибудь результатам.
Если бы со стороны Linux была поддержка УИД и если бы мы начали разрабатывать новые драйверы, которые связывались с Linux по УИД, каковы были бы последствия?
- Люди могли бы использовать свободные драйверы Linux, распространяемые по
GPL, на системах Windows.
Это помогло бы только пользователям Windows; это ничего не сделало бы для нас, пользователей свободных операционных систем. Это и не повредило бы нам напрямую; но разработчики свободных драйверов, распространяемых по GPL, могли бы разочароваться, видя, что их применяют таким образом, а это было бы очень плохо. Кроме того, соединение драйверов с несвободным ядром было бы нарушением GNU GPL. Увеличивать соблазн сделать это — значит напрашиваться на неприятности.
- Люди могли бы выполнять несвободные драйверы Windows на системах GNU/Linux
Напрямую это не сказалось бы на спектре аппаратуры, поддерживаемой свободными программами.
Но косвенно это привело бы к снижению спектра за счет того, что поставило бы перед искушением миллионы пользователей GNU/Linux, которые не приучились настаивать на свободе ради собственного блага. В той степени, в какой общество начало бы поддаваться искушению, мы стали бы двигаться к применению несвободных драйверов вместо написания свободных.Сам по себе УИД не мешал бы разработчикам свободных драйверов. Так что если достаточное число из нас устояло бы перед искушением, мы по-прежнему могли бы разрабатывать свободные драйверы, несмотря на УИД, точно так же, как мы делаем это без УИД.
Но для чего призывать сообщество быть слабее, чем необходимо? Зачем создавать ненужные затруднения для будущего свободного программного обеспечения? Поскольку УИД ничем нам не полезен, лучше от него отказаться.
При таких последствиях неудивительно, что компания Intel, поддерживающая УИД, начала “искать в сообществе Linux помощи по УИД”. Как богатая и эгоистичная компания подходит к сотрудничеству в сообществе? Конечно, она просит подачки. Попросив, она ничего не потеряет, а мы можем обмануться и сказать “да”.
Сотрудничество по УИД не исключено. Нам не следует предавать анафеме УИД, Intel или кого бы то ни было. Но перед тем, как мы примем участие в любом предложенном деле, мы должны это тщательно взвесить, чтобы убедиться, что оно выгодно для сообщества свободного программного обеспечения, а не только для разработчиков несвободных систем. В данном конкретном случае это означает, что сотрудничество должно продвигать нас на шаг вперед по пути, ведущему к конечной цели свободных ядер и драйверов: поддержке всей важной аппаратуры свободными драйверами.
Сделать эти работы полезными можно было бы, например, внеся поправку в сам проект по УИД. Эрик Реймонд предложил, чтобы соответствие УИД подразумевало, что драйвер является свободной программой. Это было бы идеально, но могли бы быть и другие альтернативы. Могло бы быть достаточным, если бы от исходных текстов драйвера требовалось, чтобы они были опубликованы и не были коммерческой тайной — потому что даже если этот драйвер не свободен, это, по крайней мере, предоставило бы нам сведения, необходимые для написания свободного драйвера.
Компания Intel могла бы также сделать что-нибудь вне работ по УИД, чтобы помочь сообществу свободного программного обеспечения решить эту проблему. Например, Intel может выдавать того или иного рода сертификаты, которые стремятся получить разработчики аппаратуры. В этом случае компания Intel могла бы согласиться затруднить сертификацию, если спецификации аппаратуры секретны. Это не могло бы решить проблему полностью, но это могло бы заметно помочь.
Одна из трудностей в любом сотрудничестве с Intel по УИД состоит в том, что сначала мы сделали бы свою работу, а отдача со стороны Intel растянулась бы на долгий срок. Фактически мы предоставили бы Intel долгосрочный кредит. Но пожелала бы ли компания продолжать выплачивать свой долг? Возможно — если у нас будет письменный договор, который нельзя обойти; в противном случае мы не можем на это рассчитывать. Вероломство корпораций хорошо известно; люди, с которыми мы имеем дело, могут быть добросовестны, но их решения могут переменить сверху, этих людей даже могут в любой момент заменить на других. Даже высшее руководство, владеющие большей частью акций, может смениться после продажи компании. При любых соглашениях о совместной работе с корпорацией требуйте письменных обязательств.
Непохоже, чтобы компания Intel предложила договор, который дает нам то, что нам нужно. На самом деле кажется, что УИД составлен, чтобы облегчить сохранение спецификаций в секрете.
Тем не менее не будет никакого вреда, если мы оставим дверь открытой — до тех пор, пока мы не позволяем входить всем без разбора.
Хранение GUID и размер индексов
Кузьменко Дмитрий, [email protected]
GUID – уникальный идентификатор. Его длина позволяет использовать GUID на разных машинах с весьма низкой вероятностью совпадения генерируемых GUIDs. Например, все документы (записи) баз данных Lotus Notes идентифицируются собственным GUID. Это позволяет решать проблемы при репликации документов. Некоторые сервера позволяют хранить GUID в его двоичном представлении, размером 16 байт. В IB нет возможности сохранить двоичное значение в строке, а blob для таких целей использовать будет неэффективно. Поэтому выход остается один – хранить GUID как строку.
Генерируемый функцией CoCreateGuid(ClassID) и StringFromCLSID(ClassID, P) GUID получается размером 38 символов, включая обрамляющие фигурные скобки и 4 символа ‘-‘. Например, {C9EAF9E0-9B6B-11D3-9C10-008048E8D560}. Такое представление годится для Registry, но для хранения в качестве первичного ключа несколько избыточно.
Если исключить те самые фигурные скобки и тире, останется 32 символа. Однако IB не может эффективно хранить такие значения. Дело в том, что в строковом выражении GUID меняется в своей левой части. Т. е. младшие разряды строкового GUID находятся в левой части строки.
Как известно, IB производит упаковку ключей и записей при обновлении с помощью алгоритма, похожего на RLE. Это означает, что если создана запись со строкой «Иванов», а затем запись со строкой «Иванова», то ключ индекса по строковому полю для второй записи будет содержать число совпадений с предыдущим ключом, и несовпадающие символы.
Буквально для нашего примера – 6’а’. При большом количестве таких упаковок, и при большом количестве совпадений, размер, требуемый для индекса на диске, должен быть существенно ниже.Попробуем произвести тест. Создадим кроме функции CreateGUID функцию CreateRevGUID (см. guid_udf.zip), где строка GUID будет перевернутой, т. е. младшие разряды окажутся в правой части строки.
Примечание. В Windows 2000, XP, 2003 и далее GUID генерируется функцией CoCreateGuid целиком случайно, а не последовательно, как это было на момент написания данного документа.
Создадим две таблицы у каждой по одному полю CHAR(32), и это поле сделаем первичным ключом. В одну таблицу вставим 100 тысяч записей с обычным CreateGUID, а во вторую – с CreateRevGUID.
Примечание. В Firebird 2.5 появилась встроенная функция GEN_UUID.
После наполнения размер таблиц оказался одинаковым (это естественно), т. к. для записей при вставке упаковка не производится. (Размер страницы БД – 8К).
NGUIDS (130)
Primary pointer page: 135, Index root page: 136
Data pages: 953, data page slots: 953, average fill: 69%
Fill distribution:
0 — 19% = 0
20 — 39% = 1
40 — 59% = 0
60 — 79% = 952
80 — 99% = 0
А вот размер индексов оказался существенно разным. Для таблицы с CreateGUID:
Index RDB$PRIMARY3 (0)
Depth: 3, leaf buckets: 770, nodes: 100000
Average data length: 25.00, total dup: 0, max dup: 0
Fill distribution:
0 — 19% = 1
20 — 39% = 0
40 — 59% = 763
60 — 79% = 0
80 — 99% = 6
т. е. количество страниц индекса – 770, а для таблицы с CreateRevGUID:
Index RDB$PRIMARY2 (0)
Depth: 2, leaf buckets: 92, nodes: 100000
Average data length: 1.00, total dup: 0, max dup: 0
Fill distribution:
0 — 19% = 1
20 — 39% = 0
40 — 59% = 8
60 — 79% = 0
80 — 99% = 83
т. е. 92 страницы, что в 8 раз меньше!
После backup/restore эта разница оказывается в 2 раза меньшей (т. е. 4 раза), за счет того, что после restore индексные страницы оказываются заполненными на ~100% – индекс RDB$PRIMARY3 после restore занимал 384 страницы.
Разумеется, скорость поиска, выборки и сортировки по упакованным ключам выше, чем обычно, т. к. с диска требуется считывать меньшее количество страниц индекса.
Выводы:
- IB производит упаковку ключей индексов, даже если производится только вставка записей.
- Упаковываемые ключи плотнее заполняют пространство на страницах данных, чем неупаковываемые
- Для функций, аналогичных CreateGUID максимальной эффективности можно достичь, только если часто изменяемая часть строки находится в правой части.
Примечание. Еще большей степени упаковки можно достичь, используя функции PackedGUID. Длина строки при использовании этих функций получается 26 байт. Однако результат функции NxPackGUID необходимо перевернуть так же, как и в CreateRevGUID (или производить конвертацию TGUID со старшего байта).
Примечание. Можно попробовать хранить GUID в естественном виде, т. е. длиной 16 байт. При этом строка должна быть создана как CHARACTER SET OCTETS. Этот набор символов позволяет хранить в строках произвольные символы, в том числе 0x. Однако клиентская часть также должна уметь сохранять строку целой, т. е. не обрезать ее до первого символа 0x, как это принято для строк C или строк pchar.
Например, в IBX или FreeIBComponents для этих целей компоненты, использующие стандартные Fields, не годятся – IBTable, IBDataSet, IBQuery. Они отрезают часть после 0x еще на этапе занесения значения параметров. А вот компонент IBSQL (FIBQuery) вполне подходит, и как записывает данные с 0x в такое поле, так и извлекает их обратно, поскольку работает с XSQLVAR в качестве полей запроса или его параметров.
Precision Spraying — опрыскиватель для сорняков
Обращать внимание! Ваш браузер устарел, это может негативно сказаться на работе пользователя. Скачать Chrome
X
Наслаждайтесь просмотром видео в браузере.С 1999 года WEED-IT является самой точной, быстрой и самой простой в использовании технологией обнаружения и уничтожения сорняков. Опрыскивая только сорняки, вы экономите до 90% затрат на химикаты!
Посмотрите, как WEED-IT может помочь и вам!
Наслаждайтесь просмотром видео в браузере.
Новый
WEED-IT Quadro
Посмотрите, как наша новейшая технология WEED-IT Quadro снова устанавливает стандарты!
Рассчитайте рентабельность инвестиций
Сколько можно сэкономить, перейдя на способ прополки WEED-IT?
WEED-IT в поле
Узнайте, что фермеры со всего мира говорят о WEED-IT.
Наши приложения
Три различных режима внесения гарантируют, что система WEED-IT — это все, что вам нужно для уничтожения всех видов сорняков с помощью опрыскивателя любого типа и марки.
Посмотреть все приложения
Точечное опрыскивание
В режиме точечного опрыскивания WEED-IT нацеливается на всю живую зелень на залежах, чтобы максимизировать доступность влаги и свести к минимуму конкуренцию и устойчивость к гербицидам.
Двойное опрыскивание
В режиме двойного опрыскивания WEED-IT применяет низкую норму внесения (например, 30 л/га) на всю ширину и более высокую норму (например, 100 л/га) на каждый обнаруженный сорняк.
Полное покрытие
С помощью WEED-IT вы можете не только выявлять сорняки, но и применять любые гербициды, инсектициды и фунгициды с помощью технологии сверхбыстрой ШИМ с частотой до 200 Гц.
Девин
Horse Heaven, Вашингтон
Успешная демонстрация привлекла его внимание
Девин Мун управляет фермой в Horse Heaven, Соединенные Штаты Америки. AgriTech America спросила его об окупаемости технологии WEED-IT на его ферме.
Читать полностью
Фермы Тима и Ричи Глисон
Натя (Виктория), Австралия
Мы очень довольны результатами!
Читать полностьюAgroservice Brazil
Luis Eduardo Magalhães (Bahia), Бразилия
Использование гербицидов для сплошного опрыскивания полей приводит к очень высоким эксплуатационным расходам.
В системе WEED-IT мы наносим только 20-30% химикатов по сравнению с сплошным распылением. Мы можем работать с необходимой скоростью для решения проблемы, но при гораздо меньших затратах.
Читать полностью
slider-pijl-links-groenСоздано с помощью Sketch.slider-pijl-rechts-groenСоздано с помощью Sketch.WEED-IT может быть встроен практически в любой тип и марку опрыскивателя
Внедрение
Систему WEED-IT можно установить на любой тип и марку планерного и прицепного опрыскивателя, квадроцикла, садового опрыскивателя, инструментальной панели, самоходного опрыскивателя и даже автономные опрыскиватели с шириной захвата до 36 м. Вы называете это, мы построили это!
slider-pijl-links-groenСоздано с помощью Sketch.slider-pijl-rechts-groenСоздано с помощью Sketch.Центр новостей и знаний
Узнайте больше о решениях для опрыскивания сорняков
Узнайте из того, что мы узнали о выявлении сорняков и борьбе с ними за более чем 20 лет. Наш центр знаний предоставляет ноу-хау, ответы и решения по технологии точечного распыления.
Посетите наш Центр знаний
Дилеры
Найдите ближайшего дилера
WEED-IT продается, монтируется и обслуживается опытными официальными дилерами по всему миру. Не можете найти дилера рядом с вами? Обязательно свяжитесь с нами.
Найдите своего дилера
Станьте дилером
Подпишитесь на нас
WEED-IT в Instagram
Подпишитесь на WEED-IT в Instagram, чтобы узнать больше о наших технологиях, наших пользователях и познакомиться с новейшими приложениями, советами и ухищрения.
WEED-IT Quadro — Обнаружение и уничтожение сорняков
WEED-IT Quadro снова устанавливает стандарты точного опрыскивания. Эффективное обнаружение и уничтожение сорняков становится все более важным в современных условиях выращивания с меньшим количеством осадков, ограничениями на использование гербицидов и устойчивыми сорняками. Чтобы помочь производителям более эффективно бороться с сорняками, специалист по точному опрыскиванию Rometron представляет WEED-IT Quadro: точечное опрыскивание следующего поколения.
Улучшайте прополку с помощью технологии обнаружения и уничтожения сорняков WEED-IT Quadro
Сколько можно сэкономить на стоимости химикатов?
Переход на способ прополки WEED-IT? За несколько простых шагов вы можете рассчитать, сколько и как быстро вы можете сэкономить на расходах на химикаты!
Калькулятор рентабельности инвестиций
Лучше, быстрее, точнее
WEED-IT Quadro объединяет 10-летний мировой опыт работы с сельскохозяйственной системой WEED-IT. Quadro относится к четырем зонам обнаружения каждого датчика обнаружения WEED-IT, каждая из которых составляет 25 см (10 дюймов) от всей ширины штанги опрыскивателя. Дополнительные небольшие зоны с улучшенной оптикой гарантируют, что система никогда не пропустит ни одного сорняка.
В дополнение к повышенной точности и эффективности двухъядерный процессор обеспечивает быструю связь и высокую частоту дискретизации. Это гарантирует более высокие скорости связи, необходимые для включения VRA, картирования сорняков и биомассы и работы с картами внесения.
Основные преимущества технологии WEED-IT Quadro
- Надежные датчики обнаружения
- Быстрые соленоиды PWM
- Правильная норма опрыскивания в нужном месте
- Работа днем и ночью
- Автоматическая калибровка фона
- Двойное опрыскивание
- Подходит для любого опрыскивателя
- Одинарная линия погружной штанги
WEED-IT может быть установлен практически на опрыскиватель любой марки и типа.
Реализации
Систему WEED-IT можно встроить в опрыскиватель для садов любой марки и типа, четырехъядерный, планерный и прицепной опрыскиватель, самоходный опрыскиватель, инструментальную панель и даже автономные опрыскиватели с рабочей шириной до 36 м. Вы называете это, мы построили это!
slider-pijl-links-groenСоздано с помощью Sketch.slider-pijl-rechts-groenСоздано с помощью Sketch.Дополнительные режимы работы
Усовершенствованное управление форсунками с широтно-импульсной модуляцией (ШИМ) позволяет индивидуально регулировать поток для каждой форсунки, что открывает технологию для двух дополнительных режимов работы:
- Двойное распыление
- Режим покрытия
Это означает что с системой WEED-IT вы можете не только использовать систему в режиме точечного опрыскивания, чтобы нацеливаться на всю живую зелень на залежах. При двойном опрыскивании вы можете применять низкие нормы внесения (например, 30 л/га) по всей ширине и более высокие нормы (например, 100 л/га) с помощью всего одной линии опрыскивания. WEED-IT — один из немногих производителей, способных предложить технологию двойного распыления! А в режиме покрытия WEED-IT действует как обычный опрыскиватель с широтно-импульсной модуляцией, что позволяет непрерывно изменять скорость.
Двойное распыление
WEED-IT — единственная система, которая вам нужна для двойного опрыскивания всего с одной линией распыления.
Режим покрытия
Этот режим идеален, если вы хотите максимально эффективно использовать свой (самоходный) опрыскиватель.
Более легкая установка
Систему WEED-IT с ее единым встроенным жгутом проводов датчика и соленоида не только проще установить практически на любой тип и марку опрыскивателя, но и при необходимости легко снять.
И даже после добавления всех этих новых и улучшенных функций датчики WEED-IT не прибавили в весе, что довольно необычно в наши дни… С весом 700 граммов каждый, они даже потеряли вес по сравнению с предыдущей системой WEEDit Ag!
С системой WEED-IT Quadro компания WEED-IT снова устанавливает стандарты точного распыления!
Характеристики
- Высота обнаружения: 110 см
- Ширина обнаружения: 100 см, разделенная на 4 зоны по 25 см
- Вес датчика: 700 грамм
- Размер датчика Д x Ш x В: макс.