Wiki source code of Примеры заведения датчиков
                  Version 53.2 by Андрей Калиновский on 2024/07/23 12:57
              
      Show last authors
| author | version | line-number | content | 
|---|---|---|---|
| 1 | {{html}} | ||
| 2 | <iframe width="560" height="315" src="https://www.youtube.com/embed/T3alpKIQ4cE?si=HezGsPWOhtEUqeIh" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe> | ||
| 3 | {{/html}} | ||
| 4 | |||
| 5 | ((( | ||
| 6 | **Содержание страницы:** | ||
| 7 | |||
| 8 | |||
| 9 | {{toc/}} | ||
| 10 | |||
| 11 | |||
| 12 | ))) | ||
| 13 | |||
| 14 | = (% style="color:#000000; font-size:16px" %)**Простые датчики**(%%) = | ||
| 15 | |||
| 16 | == (% style="color:#000000; font-size:16px" %)**Зажигание** по дискретному входу(%%) == | ||
| 17 | |||
| 18 | [[image:image-20220519165301-1.png]] | ||
| 19 | |||
| 20 | |||
| 21 | == (% style="color:#000000; font-size:16px" %)**Зажигание** по аналоговому входу (датчик сработает при напряжении более > 6000 мВ)(%%) == | ||
| 22 | |||
| 23 | [[image:image-20220519165301-2.png]] | ||
| 24 | |||
| 25 | == (% style="color:#000000; font-size:16px" %)**Топливораздача** со счетного импульсного входа(%%) == | ||
| 26 | |||
| 27 | [[image:image-20220519165301-3.png]] | ||
| 28 | |||
| 29 | В зависимости от алгоритма подсчета импульсов терминалом выбирается тип тарировки «Накопитель» или «Разница от пред.». | ||
| 30 | |||
| 31 | Аналогичным образом создаются датчики проточных расходомеров топлива - в этом случае тип датчика следует выбрать «Расход топлива». | ||
| 32 | |||
| 33 | == (% style="color:#000000; font-size:16px" %)**Уровень зерна** полученный по интерфейсу RS485(%%) == | ||
| 34 | |||
| 35 | [[image:image-20220519165301-4.png]] | ||
| 36 | |||
| 37 | == (% style="color:#000000; font-size:16px" %)**Уровень топлива** полученный по интерфейсу RS485(%%) == | ||
| 38 | |||
| 39 | [[image:image-20220519165301-5.png]] | ||
| 40 | |||
| 41 | Значения **меньше, чем указано в первой строке и больше или равные указанному в последней строке считаются невалидными и игнорируются.** Рекомендуется в последней строке таблицы добавлять входное значение выше максимально возможного. Например 1024 или 4096 для датчиков которые максимально передают уровень топлива в диапазонах 0-1023 или 0-4095. Выходное значение можно рассчитать линейно. | ||
| 42 | |||
| 43 | == (% style="color:#000000; font-size:16px" %)**Температура прицепа **полученная по по интерфейсу 1-Wire(%%) == | ||
| 44 | |||
| 45 | [[image:image-20220519165301-6.png]] | ||
| 46 | |||
| 47 | |||
| 48 | == (% style="color:#000000; font-size:16px" %)**Датчик пробега**(%%) == | ||
| 49 | |||
| 50 | Для того, чтобы создать корректно работающий датчик пробега необходимо выбрать тип датчика **Датчик пробега**, указать тип тарировки **Таблица **и задать тарировку типа **0:0; 9999999:9999999**. Такая тарировка позволит корректно реагировать на те периоды, когда данные с датчика пробега не поступают в систему. | ||
| 51 | |||
| 52 | Датчик настроенный как на примере ниже позволит вам использовать его при расчете значения **Текущий пробег**, из вкладки нормы, а также рассчитывать начальный и конечный пробег. | ||
| 53 | |||
| 54 | [[image:image-20230607115954-1.png||height="600" width="615"]] | ||
| 55 | |||
| 56 | |||
| 57 | (% style="color:#000000; font-size:16px" %)**Датчик моточасов**(%%) | ||
| 58 | |||
| 59 | |||
| 60 | Данный тип датчика используется для замещения рассчитанного значения количества моточасов. | ||
| 61 | |||
| 62 | Во вкладке "Нормы" при настройке объекта есть строка "Расчет моточасов". Там вы можете выбрать значение из выпадающего списка. | ||
| 63 | |||
| 64 | [[image:https://redmine.glonasssoft.ru/attachments/download/18929/screenshot_1_1696932373.png]] | ||
| 65 | |||
| 66 | В списке три варианта: по датчику зажигания, по датчику моточасов и по датчику относительных моточасов: | ||
| 67 | |||
| 68 | по датчику зажигания: | ||
| 69 | |||
| 70 | * Текущие моточасы - расчет по времени работы датчика зажигания | ||
| 71 | * Моточасы в отчете - расчет по времени работы датчика зажигания | ||
| 72 | |||
| 73 | по датчику моточасов: | ||
| 74 | |||
| 75 | * Текущие моточасы - т.к. расчет происходит с некоторой периодичностью, то текущие моточасы в нормах рассчитываются как: (значение датчика на конец периода - значение на начало) + текущее значение моточасов. Если при расчете (значение датчика на конец периода - значение на начало) значение получается ниже нуля, то значение будет равно 0. | ||
| 76 | * Моточасы в отчете - рассчитываются моточасы за период по датчику. Моточасы на холостом ходу определяются как периоды, когда значение датчика моточасов изменялось в периоды события Стоянка. | ||
| 77 | |||
| 78 | по датчику относительных моточасов: | ||
| 79 | |||
| 80 | * Текущие моточасы - сумма полученных значений с датчика типа "Относительные моточасы". | ||
| 81 | * Моточасы в отчете - моточасы с учетом коэффициента, зависящего от величины оборотов двигателя. | ||
| 82 | |||
| 83 | Датчик с типом Относительные моточасы автоматически не заменяет значения в отчете. В отчете значения моточасов рассчитывать в зависимости от выбранного метода расчета. | ||
| 84 | |||
| 85 | Например - если выбран метод расчета по датчику зажигания, а у объекта есть датчики с типом Датчик моточасов и Датчик относительных моточасов, то в отчетах моточасы продолжат рассчитываться по датчику зажигания. | ||
| 86 | |||
| 87 | Метод расчета по умолчанию - по датчику зажигания. | ||
| 88 | В случае, если отсутствует выбранный датчик, то моточасы будут рассчитаны по времени движения. | ||
| 89 | \\(% style="color:#000000; font-size:16px" %)**Весовой датчик** | ||
| 90 | |||
| 91 | Для получения данных по отвесам необходимо создать датчик с типом **Весовой терминал**. | ||
| 92 | |||
| 93 | [[image:image-20230809160201-1.png||height="529" width="541"]] | ||
| 94 | |||
| 95 | |||
| 96 | Рекомендуем также указать тарировку** -1:-1, 99999:99999,** это позволит предупредить случаи появления сообщений без данных, что поможет избежать дублирования отвесов. | ||
| 97 | |||
| 98 | Для того, чтобы получать данные по взвешиваниям необходимо помимо датчика веса иметь rfid-считыватель. По rfid-метке два отвеса могут быть объединены в одно взвешивание, что позволит найти разницу в весе между ними. Для этого объект весовой, помимо датчика с типом **Весовой терминал**, должен иметь датчик с типом **RFID-водителя** и активной опцией** Постоянный сигнал RFID объекта рядом**. | ||
| 99 | |||
| 100 | |||
| 101 | == (% style="color:#000000; font-size:16px" %)**Датчик бортового напряжения**(%%) == | ||
| 102 | |||
| 103 | Для создания датчика бортового напряжения с целью отображения данных на графике необходимо указать тип датчика **"Произвольный"** и во вкладке "**Доп. настройки" **выбрать на каких графиках отображать данные (на графике объекта/ полезной нагрузки) и** **указать тип отрисовки **"Линия"**: | ||
| 104 | |||
| 105 | [[image:image-20240220123952-1.png]] | ||
| 106 | |||
| 107 | = (% style="color:#000000; font-size:16px" %)**Виртуальные**(%%) = | ||
| 108 | |||
| 109 | {{video url="https://www.youtube.com/watch?v=T3alpKIQ4cE" width="50%"/}} | ||
| 110 | |||
| 111 | [[**Датчик зажигания **по бортовому напряжению>>doc:Панель управления.Раздел "Объекты".Настройка зажигания по напряжению.WebHome]] | ||
| 112 | |||
| 113 | |||
| 114 | == (% style="color:#000000; font-size:16px" %)**Подавление сигнала GNSS** полученное от терминала УМКа3хх(%%) == | ||
| 115 | |||
| 116 | [[image:image-20220519165301-7.png]] | ||
| 117 | |||
| 118 | |||
| 119 | Для терминалов УМКа3хх поле STATUS отображается в десятичном виде на входе *А(100), подавление сигнала GNSS меняет девятый бит. В датчике задаем выражение getbit(adc100,9) | ||
| 120 | |||
| 121 | {{video url="https://youtu.be/8i1A0xIBBpc" width="50%"/}} | ||
| 122 | |||
| 123 | == (% style="color:#000000; font-size:16px" %)**Уровень топлива **с агрегирующей функцией суммирования или определения среднего значения.(%%) == | ||
| 124 | |||
| 125 | [[image:image-20220519165301-8.png]] | ||
| 126 | |||
| 127 | |||
| 128 | [[image:image-20220519165301-9.png]] | ||
| 129 | |||
| 130 | Агрегирующая функция «Сумма» применяется **при установке в каждый бак по одному датчику уровня топлива**. | ||
| 131 | |||
| 132 | Агрегирующая функция «Среднее» применяется **при установке в один бак нескольких датчиков уровня топлива**. | ||
| 133 | |||
| 134 | {{video url="https://youtu.be/hLFIcktZ9EM" width="50%"/}} | ||
| 135 | |||
| 136 | |||
| 137 | **Уровень топлива **с валидацией по зажиганию | ||
| 138 | |||
| 139 | При использовании штатных датчиков топлива с инвертированной тарировочной таблицей возникает эффект когда при отключении зажигания напряжение с датчика падает в 0, что детектируется как полный бак. Для фильтрации можно использовать валидацию по датчику зажигания. | ||
| 140 | |||
| 141 | |||
| 142 | Для этого создаем физические датчики зажигания и уровня топлива с указанием псевдонимов ign и fuel | ||
| 143 | |||
| 144 | [[image:image-20220519165301-10.png]] | ||
| 145 | |||
| 146 | [[image:image-20220519165301-11.png]] | ||
| 147 | |||
| 148 | Затем создаем виртуальный датчик уровня топлива с выражением **//if(ign, fuel, 0)//** - если включено зажигание то передаем топливо как есть, в противном случае передаем вместо него 0. Заполняем тарировочную таблицу 2-мя сточками - 0 - 0 и максимальный_объем_бака - максимальный_объем_бака, что будет отсекать 0 полученный из условия формулы. В результате система будет считать невалидным уровень топлива полученный при отключенном датчике зажигания. | ||
| 149 | |||
| 150 | [[image:image-20220519165301-12.png]] | ||
| 151 | |||
| 152 | == (% style="color:#000000; font-size:16px" %)**Уровень топлива **по датчику с изменившимся номером входа.(%%) == | ||
| 153 | |||
| 154 | Для этого создаем физические датчики с типом «Произвольный», тарировочными таблицами, старым и новым номерами входов и указанием псевдонимов fuel_old и fuel_new. | ||
| 155 | |||
| 156 | [[image:image-20220519165301-13.png]] | ||
| 157 | Затем создаем виртуальный датчик уровня топлива с выражением **//if(time > cdate('2021-12-22 00:00:00', 'yyyy-MM-dd HH:mm:ss'), fuel_new, fuel_old)//** - после 2021-12-22 00:00:00 (время по UTC) топливо отображается с нового ДУТ, а до этого времени включительно со старого ДУТ. | ||
| 158 | |||
| 159 | [[image:image-20220519165301-14.png]] | ||
| 160 | |||
| 161 | //Пример заведения аналогового датчика в статье [["Настройка аналогового ДУТ" >>https://wiki.glonasssoft.ru/bin/view/%D0%9F%D0%B0%D0%BD%D0%B5%D0%BB%D1%8C%20%D1%83%D0%BF%D1%80%D0%B0%D0%B2%D0%BB%D0%B5%D0%BD%D0%B8%D1%8F/%D0%A0%D0%B0%D0%B7%D0%B4%D0%B5%D0%BB%20%22%D0%9E%D0%B1%D1%8A%D0%B5%D0%BA%D1%82%D1%8B%22/%D0%9D%D0%B0%D1%81%D1%82%D1%80%D0%BE%D0%B9%D0%BA%D0%B0%20%D0%B0%D0%BD%D0%B0%D0%BB%D0%BE%D0%B3%D0%BE%D0%B2%D0%BE%D0%B3%D0%BE%20%D0%94%D0%A3%D0%A2/]]// |