Декодирование сигнала AC123-01 433 МГц, передатчик не получает информацию о контроллере - PullRequest
0 голосов
/ 25 апреля 2020

Я пытаюсь скопировать волну 433 МГц из контроллера кондиционера с приемником 433, мне удалось получить волну с некоторым кодом, но эта волна мне совсем не помогла, у меня есть AC123-01 контроллер. Я использую приемник и передатчик RF-модули для Arduino. Я попробовал библиотеку R C -Switch для сбора двоичного кода с контроллера, но безуспешно.
Это контроллер, который я хочу скопировать https://www.youtube.com/watch?v=H_PyVQf_4i8
Код, который мне удается получить в форме волны:

#define DATA 2

void setup() {
Serial.begin(9600);
pinMode(DATA, INPUT);
}

void loop() {
 Serial.println(digitalRead(DATA));
}

Это контроллер и мой Arduino с передатчик: My Setup

С этим кодом из библиотеки R c -Switch я не могу поймать сигнал любого типа от моего контроллера. Ответа нет вообще:

#include <RCSwitch.h>

RCSwitch mySwitch = RCSwitch();

void setup() {
Serial.begin(9600);
mySwitch.enableReceive(0);  // Receiver on interrupt 0 => that is pin #2
}

void loop() {
if (mySwitch.available()) {
output(mySwitch.getReceivedValue(), mySwitch.getReceivedBitlength(), 
mySwitch.getReceivedDelay(), 
mySwitch.getReceivedRawdata(),mySwitch.getReceivedProtocol());
mySwitch.resetAvailable();
}
}

Мне удается использовать веб-сайт для получения волн, первые две строки - от кнопки вниз, а две другие - от кнопки ВВЕРХ. Waves Исходные данные, полученные из контроллера:

Start here first frame =>888,5208,648,556,252,152,648,548,248,156,648,
156,644,160,648,548,240,
564,248,156,648,160,644,552,244,556,248,156,656,540,268,144,648,548,256,148,
660,148,656,144,648,552,252,148,660,536,260,152,640,556,252,156,644,160,644,
552,240,172,632,564,244,548,256,548,244,168,640,160,648,156,652,152,644,160,
648,144,652,152,656,148,644,552,256,148,652,152,652,152,636,172,636,156,
648,156,644,160,628,176,632,164,640,568,240,160,632,172,628,164,644,160,648
,548,260,540,256,552,256,148,656,540,264,540,256,548,256,548,252,148,656
,152,636,556<=end frame
start next 
frame=>884,5220,640,560,252,148,656,540,260,152,660,136,664,140,664,
532,264,540,264,140,660,144,664,532,256,548,256,148,652,552,248,156,636,
560,248,156,648,160,644,160,644,548,248,156,648,556,252,152,656,536,264,
140,664,140,664,532,276,136,656,540,264,540,268,528,268,144,652,156,640,
152,652,152,648,160,636,168,632,160,644,160,644,552,244,172,632,160,644,
160,648,156,640,164,640,152,656,148,656,148,652,152,644,552,252,148,656,
152,640,164,640,152,648,548,252,552,244,564,240,164,640,552,256,548,244,
564,240,564,240,160,648,156,636,556<=end frame
start next frame=>892,5212,648,548,252,152,656,540,260,
156,636,164,640,156,648,548,256,548,248,168,636,160,648,544,260,544,252,
160,652,544,264,136,660,536,260,156,648,148,660,144,660,536,252,160,644,
548,252,156,648,544,252,164,636,160,648,560,236,164,632,564,244,560,
244,560,244,156,644,164,640,152,660,144,656,148,644,160,648,144,656,
152,648,544,264,152,644,148,648,160,644,160,640,164,632,160,640,164,
640,164,644,160,632,564,236,168,640,160,644,160,636,168,640,556,248,
544,264,544,248,164,640,552,252,544,260,544,252,552,248,156,648,156
,640,552,3300,84,484,672,160<=end frame 

Нормализация данных из 3 кадров в Excel: wave

1 Ответ

1 голос
/ 25 апреля 2020

Как декодировать Чтобы получить коды в двоичном формате для использования вами скачайте библиотеку RC_switch 2.6.3 и установите ее в директорию вашей библиотеки через Sketch -> Library manager -> Add zip library.
Затем загрузите File > Examples > RC_Switch > ReceiveDemo_Advanced и compole на плату.
После загрузки эскиза подключите радиочастотный приемник 433 МГц к Digital Pin 2 вашей платы Arduino UNO. Откройте последовательный монитор Arduino IDE и начните нажимать кнопки на пульте дистанционного управления.
После однократного нажатия каждой кнопки вы можете увидеть двоичный код для каждой кнопки (он выделен красным цветом): imageenter image description here"> Сохраняйте свои двоичные коды для каждого нажатия кнопки (вы также можете использовать десятичные или трехзначные коды):

Button 3 ON = (24Bit) Binary: 000101010101000101010101
Button 3 OFF = (24Bit) Binary: 000101010101000101010100
Button 4 ON = (24Bit) Binary: 000101010101010001010101
Button 4 OFF = (24Bit) Binary: 000101010101010001010100

Сохраняйте длину импульса: 416 микросекунд и протокол: 1.
Как для отправки
Вам необходимо настроить следующий эскиз с вашими двоичными кодами, длиной импульса и протоколом:

#include <RCSwitch.h>
RCSwitch mySwitch = RCSwitch();
void setup() {
  Serial.begin(9600);
  // Transmitter is connected to Arduino Pin #10  
  mySwitch.enableTransmit(10);

  // Optional set pulse length.
  mySwitch.setPulseLength(REPLACE_WITH_YOUR_PULSE_LENGTH);
  // Optional set protocol (default is 1, will work for most appliancies)
  mySwitch.setProtocol(REPLACE_WITH_YOUR_PROTOCOL);

  // Optional set number of transmission repetitions.
  // mySwitch.setRepeatTransmit(15);
}
void loop() {
  // Binary code - button 3 ON
  mySwitch.send("000101010101000101010101");  // YOUR_CODE_HERE
  delay(1000); 
 // Binary code - button 3 OFF 
  mySwitch.send("000101010101000101010100");   // YOUR_CODE_HERE
  delay(1000);
  // Binary code - button 4 ON
  mySwitch.send("000101010101010001010101");    // YOUR_CODE_HERE
  delay(1000);  
 // Binary code - button 4 OFF
  mySwitch.send("000101010101010001010100");    // YOUR_CODE_HERE
  delay(1000);
}

Таким образом, нет сигналов отсекающей волны или аналогичных, просто систематизируйте c нажатия Кнопки записи и воспроизведения.
РЕДАКТИРОВАТЬ Для решения ваших особых задач необходимо декодирование протокола AC123.
Декодирование выполняется путем адаптации приведенной ниже программы передатчика и вилки R C библиотека переключателей . В качестве AC123 используются 2-син c -биты и 64 байта данных. Настройки протокола (добавляются только в библиотеку pevar):

 {15, 132, 50, {99, 13}, {5, 13}, {11, 6}, {11, 101}, false }

Как добавить новый пульт ДУ, прочитайте эту вики , но используйте раздвоенный библиотека. В качестве справки, если вы используете simple_scanner (в примерах), вы получите что-то вроде того, где вы ищете первые 844 (thirvalue - в этом примере 840 у вас может быть 860 или похожее) от следующего числа до последнего числа перед следующими 844 ( то, что вы сделали вначале) это код в виде массива int:

212,572,
from =>844,5144,596,576,212,180,612,564,212,192,600,180,608,
180,608,564,216,576,216,180,608,180,612,564,212,576,212,576,
216,564,224,180,600,188,604,180,608,576,212,564,216,576,212,
180,612,572,216,180,596,192,604,180,608,572,216,180,600,576,
212,180,612,572,216,180,608,564,216,180,612,180,608,180,608,
180,600,180,608,180,612,180,608,564,216,184,608,180,608,184,
608,180,596,192,600,180,608,180,608,180,604,188,600,576,212,
184,608,180,596,192,600,180,608,564,224,564,220,188,600,576,
212,180,608,180,600,576,216,176,612,180,608,564,212,
576<= till here
,844,5140,600,572,216,176,612,568,220,180,600,
180,612,180,608,564,224,564,220,180,608,180,608,564,228,560,
216,572,216,572   .... goes on for x lines

Массив можно отправить с помощью этого форка библиотеки R C -switch , добавив 0 в конце массива

Для отправки самогенерируемого сигнала вы должны использовать этот форк библиотеки после того, как вы проанализировали загрузку данных в соответствии с вики
Протокол AC123 построен следующим образом (вам все еще нужно использовать RC_Scanner для получения данных для вашего оборудования!):

Remote ID Byte 1 (possibly Manufacturer ID)    10100011
Remote ID Byte 2                               01101110 
Remote ID Byte 3                               00010100
Remote ID Byte 4                               00110101      
Channel Byte 1                                 00000001
Channel Byte 2                                 00000000    
Control Code                                   00001011  
Checksum                                      11000011
 The command byte works as follows for my system:
 UP         STOP            DOWN
00001011    00100011    01000011    

Контрольная сумма рассчитывается как сложение Remote ID Байт 2 + Remote ID Байт 3 + Удаленный идентификатор Байт 4 + Канал Байт 1 + Канал Байт 2 + Код управления. Это может добавить до 1 байта, в этом случае MSB игнорируется.
Примечание: это исключает байт 1 удаленного идентификатора, который может указывать на то, что он является идентификатором производителя.
Вот самый быстрый набросок, который можно использовать и экспериментировать с:

// Transmitter for AC123 - Manufacturer ID 1
#include <RCSwitch.h> // Use this lib variant: https://github.com/perivar/rc-switch/

const unsigned long Remote = 0xA362281F;

const uint8_t CHANNEL_PADDING = B0000;
const uint8_t UP = B00001011;
const uint8_t STOP = B00100011;
const uint8_t DOWN = B01000011;

RCSwitch mySwitch = RCSwitch();

void setup() {
  Serial.begin(9600);
  // Transmitter is connected to Pin 5 change to your setuo
  mySwitch.enableTransmit(5);
  // AC123 Protocol define as 15
  mySwitch.setProtocol(15);
  mySwitch.setPulseLength(50);
}

void loop() {
  Serial.println("Send Command");
  sendCommand(Remote, B00001111, DOWN);
  delay(2000);
  sendCommand(Remote, B00001111, STOP);
  delay(2000);
  sendCommand(Remote, B00001111, UP);
  delay(2000);
}

void comUp(unsigned long Remote, uint8_t channels) {
  sendCommand(Remote, channels, UP);
}

void comDown(unsigned long Remote, uint8_t channels) {
  sendCommand(Remote, channels, DOWN);
}

void comStop(unsigned long Remote, uint8_t channels) {
  sendCommand(Remote, channels, STOP);
}
// This is the part you'll have to adept to your hardware
void sendCommand(unsigned long Remote, uint8_t channels, uint8_t commandR) {
  uint8_t RemoteByte1 __attribute__((unused)) = Remote >> 24; // possibly Manufacturer ID not used at the moment
  uint8_t RemoteByte2 = Remote >> 16;
  uint8_t RemoteByte3 = Remote >> 8;
  uint8_t RemoteByte4 = Remote;
  uint8_t Checksum = RemoteByte2 + RemoteByte3 + RemoteByte4 + channels + CHANNEL_PADDING + commandR;
  char SendCodeChar[64];
  uint8_t bitPos = 31;
  for (uint8_t i = 0; i <= 31; i++) {
    if bitRead(Remote, bitPos) SendCodeChar[i] = '1';
    else SendCodeChar[i] = '0';
    bitPos--;
  }
  bitPos = 7;
  for (uint8_t i = 32; i <= 39 ; i++) {
    if bitRead(channels, bitPos) SendCodeChar[i] = '1';
    else SendCodeChar[i] = '0';
    bitPos--;
  }
  bitPos = 7;
  for (uint8_t i = 40; i <= 47 ; i++) {
    if bitRead(CHANNEL_PADDING, bitPos) SendCodeChar[i] = '1';
    else SendCodeChar[i] = '0';
    bitPos--;
  }
  bitPos = 7;
  for (uint8_t i = 48; i <= 55 ; i++) {
    if bitRead(commandR, bitPos) SendCodeChar[i] = '1';
    else SendCodeChar[i] = '0';
    bitPos--;
  }
  bitPos = 7;
  for (uint8_t i = 56; i <= 63 ; i++) {
    if bitRead(Checksum, bitPos) SendCodeChar[i] = '1';
    else SendCodeChar[i] = '0';
    bitPos--;
  }
  mySwitch.send(SendCodeChar);
}

РЕДАКТИРОВАТЬ 2
Поскольку ОП изменил свой вопрос и добавил захваченные данные (его работающий OMG), здесь ответ, который я дал в дискуссии, чтобы помочь другим, как декодировать.
Я проанализировал в электронной таблице, и вы должны найти комбинации 8xx (импульс) и 5XXX (кодирование AC123-0x) в вашем случае кадр включает запятые всегда длиной 1750 символов

Start here first frame =>888,5208,648,556,252,152,648,548,248,156,648,
156,644,160,648,548,240,
564,248,156,648,160,644,552,244,556,248,156,656,540,268,144,648,548,256,148,
660,148,656,144,648,552,252,148,660,536,260,152,640,556,252,156,644,160,644,
552,240,172,632,564,244,548,256,548,244,168,640,160,648,156,652,152,644,160,
648,144,652,152,656,148,644,552,256,148,652,152,652,152,636,172,636,156,
648,156,644,160,628,176,632,164,640,568,240,160,632,172,628,164,644,160,648
,548,260,540,256,552,256,148,656,540,264,540,256,548,256,548,252,148,656
,152,636,556<=end frame
start next frame=>884,5220,640,560,252,148,656,540,260,152,660,136,664,140,664,
532,264,540,264,140,660,144,664,532,256,548,256,148,652,552,248,156,636,
560,248,156,648,160,644,160,644,548,248,156,648,556,252,152,656,536,264,
140,664,140,664,532,276,136,656,540,264,540,268,528,268,144,652,156,640,
152,652,152,648,160,636,168,632,160,644,160,644,552,244,172,632,160,644,
160,648,156,640,164,640,152,656,148,656,148,652,152,644,552,252,148,656,
152,640,164,640,152,648,548,252,552,244,564,240,164,640,552,256,548,244,
564,240,564,240,160,648,156,636,556<=end frame
start next frame=>892,5212,648,548,252,152,656,540,260,
156,636,164,640,156,648,548,256,548,248,168,636,160,648,544,260,544,252,
160,652,544,264,136,660,536,260,156,648,148,660,144,660,536,252,160,644,
548,252,156,648,544,252,164,636,160,648,560,236,164,632,564,244,560,
244,560,244,156,644,164,640,152,660,144,656,148,644,160,648,144,656,
152,648,544,264,152,644,148,648,160,644,160,640,164,632,160,640,164,
640,164,644,160,632,564,236,168,640,160,644,160,636,168,640,556,248,
544,264,544,248,164,640,552,252,544,260,544,252,552,248,156,648,156
,640,552,3300,84,484,672,160<=end frame 

Так что на самом деле у вас есть три команды в опубликованном коде. Не забудьте добавить 0 в конце перед передачей в виде массива

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...