दस्तावेज़

RFID रीडर इंटीग्रेशन मैनुअल

सीरियल संचार सेटअप, एंटेना कॉन्फ़िगरेशन, टैग एन्कोडिंग ऑपरेशन (EPC Gen2 / ISO 18000-6C), और पावर प्रबंधन को कवर करने वाला व्यापक दस्तावेज़। मल्टी-एंटीना तैनाती और हाई-स्पीड इन्वेंटरी स्कैनिंग के उदाहरण शामिल हैं।

सीरियल संचार सेटअप

Nextwaves NRN प्रोटोकॉल RFID रीडर सीरियल पोर्ट (RS-232 या USB-to-Serial) के माध्यम से संचार करते हैं। स्थिर डेटा ट्रांसमिशन सुनिश्चित करने के लिए कनेक्शन पैरामीटर सही ढंग से कॉन्फ़िगर किए जाने चाहिए।

Baud Rate

115200

Data Bits

8

Stop Bits

1

Parity

None

ब्राउज़र-आधारित WebSerial API कनेक्शन के लिए, app.nextwaves.com/reader पर Nextwaves Reader Connect का उपयोग करें। एप्लिकेशन COM पोर्ट का स्वतः पता लगाता है और कनेक्शन पैरामीटर कॉन्फ़िगर करता है।

TypeScript — WebSerial Connection
// Request serial port access
const port = await navigator.serial.requestPort();
await port.open({
  baudRate: 115200,
  dataBits: 8,
  stopBits: 1,
  parity: "none",
  flowControl: "none",
  bufferSize: 4096,
});

// Get reader/writer streams
const reader = port.readable.getReader();
const writer = port.writable.getWriter();
Python — PySerial Connection
import serial

port = serial.Serial(
    port="/dev/ttyUSB0",      # Linux/macOS
    # port="COM3",            # Windows
    baudrate=115200,
    bytesize=serial.EIGHTBITS,
    stopbits=serial.STOPBITS_ONE,
    parity=serial.PARITY_NONE,
    timeout=2.0,
)

# Flush buffers before communication
port.reset_input_buffer()
port.reset_output_buffer()

Nextwaves NRN प्रोटोकॉल फ्रेम संरचना

प्रत्येक NRN प्रोटोकॉल कमांड एक बाइनरी फ्रेम में समाहित होता है जिसमें शामिल हैं: हेडर (0x5A), PCW (प्रोटोकॉल कंट्रोल वर्ड), श्रेणी, MID (संदेश ID), लंबाई, डेटा पेलोड, और CRC16-CCITT चेकसम।

फ़ील्डआकारविवरण
Header1 byteहमेशा 0x5A. फ्रेम मार्कर की शुरुआत
PCW2 bytesप्रोटोकॉल फ़्लैग (संस्करण, पता)
Category1 byteकमांड श्रेणी (0x00=सिस्टम, 0x01=डिवाइस, 0x02=RFID)
MID1 byteश्रेणी के भीतर संदेश आईडी
Length2 bytesबाइट्स में पेलोड लंबाई (बड़ा-एंडियन)
DataN bytesकमांड-विशिष्ट पेलोड
CRC162 bytesहेडर के बाद बाइट्स का CRC16-CCITT चेकसम

कमांड उदाहरण

QUERY_INFO — Query reader serial number & firmware
TX → 5A 00 01 01 00 00 00 DC E5
       ┌──┐ ┌────┐ ┌──┐ ┌──┐ ┌────┐ ┌────┐
       │5A│ │0001│ │01│ │00│ │0000│ │DCE5│
       └──┘ └────┘ └──┘ └──┘ └────┘ └────┘
       HDR   PCW   CAT  MID  LEN    CRC16
READ_EPC_TAG — Start continuous EPC tag inventory
TX → 5A 00 01 02 10 00 00 04 5A
       HDR  PCW   CAT MID LEN   CRC16
       
Response notifications (PID 0x1231) contain:
  • Antenna ID (1 byte)
  • RSSI value (1 byte, raw ADC 0-255)
  • EPC data (12+ bytes)
  • Frequency channel index (1 byte)
STOP_INVENTORY — Stop running inventory scan
TX → 5A 00 01 02 FF 00 00 88 5A
       HDR  PCW   CAT MID LEN   CRC16

मुख्य कमांड संदर्भ

कमांडकोडविवरण
QUERY_INFO0x0100रीडर सीरियल नंबर और फर्मवेयर संस्करणों को क्वेरी करें
QUERY_RFID_ABILITY0x1000RFID क्षमताओं को क्वेरी करें (पावर रेंज, एंटीना गणना)
READ_EPC_TAG0x0210निरंतर EPC टैग इन्वेंटरी शुरू करें
WRITE_EPC_TAG0x0211टैग के EPC बैंक में डेटा लिखें
STOP_INVENTORY0x02FFचल रही टैग इन्वेंटरी बंद करें
CONFIGURE_READER_POWER0x0201ट्रांसमिट पावर सेट करें (प्रति एंटीना 0-33 dBm)
CONFIGURE_ANTENNA_ENABLE0x0203एंटीना पोर्ट को सक्षम/अक्षम करें (बिटमास्क)
SET_WORKING_FREQUENCY0x0205विशिष्ट कार्यशील आवृत्तियों को सेट करें
SET_FILTER_SETTINGS0x0209टैग डुप्लिकेट फ़िल्टर कॉन्फ़िगर करें (समय-आधारित)
BUZZER_SWITCH0x011Eबज़र मोड को नियंत्रित करें

एंटीना कॉन्फ़िगरेशन

RFID रीडर 32 एंटेना पोर्ट तक सपोर्ट करते हैं। प्रत्येक पोर्ट को 4-बाइट बिटमास्क के माध्यम से सक्षम या अक्षम किया जाता है। एंटेना को 1 से 32 तक गिना जाता है, जिसमें प्रत्येक बिट एक पोर्ट के अनुरूप होता है।

एंटीना बिटमास्क

एंटेना 1-4 सक्षम करें

0x0F, 0x00, 0x00, 0x00

Binary: 00001111 → Ports 1,2,3,4 ON

केवल एंटेना 1 और 3 सक्षम करें

0x05, 0x00, 0x00, 0x00

Binary: 00000101 → Ports 1,3 ON

CONFIGURE_ANTENNA_ENABLE — Enable ports 1-4
TX → 5A 00 01 02 03 00 04 0F 00 00 00 E1 EF
                              ┌───────────┐
       Payload:               │0F 00 00 00│ ← bitmask
                              └───────────┘
       Bit 0 = ANT1, Bit 1 = ANT2, Bit 2 = ANT3, Bit 3 = ANT4
       0x0F = 0b00001111 → all 4 ports enabled

मल्टी-एंटीना तैनाती

एकाधिक एंटेना तैनात करते समय, ध्रुवीकरण (रैखिक बनाम गोलाकार), एंटेना के बीच की दूरी, और ओवरलैपिंग कवरेज क्षेत्रों पर विचार करें। रीडर सक्षम एंटेना के माध्यम से क्रमिक रूप से स्कैन करता है, और प्रत्येक टैग रिपोर्ट में स्थिति निर्धारण के लिए एंटेना आईडी शामिल होती है।

डॉक डोर

प्रति पोर्टल 2-4 एंटेना, गोलाकार ध्रुवीकरण, 30 dBm पावर

कनवेयर बेल्ट

प्रति स्टेशन 1-2 एंटेना, रैखिक ध्रुवीकरण, 20-25 dBm

रिटेल शेल्फ

निकट-क्षेत्र एंटेना, कम शक्ति 15-20 dBm, उच्च घनत्व

टैग एन्कोडिंग (EPC Gen2 / ISO 18000-6C)

UHF RFID EPC Gen2 मानक (ISO 18000-6C) का पालन करता है। प्रत्येक टैग में 4 मेमोरी बैंक हैं: आरक्षित (पासवर्ड), EPC (96+ बिट पहचानकर्ता), TID (अपरिवर्तनीय चिप ID), और उपयोगकर्ता (कस्टम डेटा)।

टैग मेमोरी संरचना

बैंकआईडीविशिष्ट आकारउपयोग
Reserved0064 bitsकिल पासवर्ड (32b) + एक्सेस पासवर्ड (32b)
EPC0196-128 bitsSGTIN-96, SSCC-96, या कस्टम एन्कोडिंग
TID1096+ bitsचिप निर्माता आईडी (केवल-पढ़ने योग्य, अद्वितीय)
User110-512 bitsएप्लिकेशन-विशिष्ट डेटा (चिप-निर्भर)

SGTIN-96 डिकोडिंग उदाहरण

SGTIN-96 खुदरा और आपूर्ति श्रृंखला उत्पादों के लिए सबसे आम एन्कोडिंग है। 24-वर्ण हेक्स EPC को GTIN-14, सीरियल नंबर और GS1 डिजिटल लिंक में बदलें।

SGTIN-96 Decode — Example
EPC Hex: 3034257BF7194E4000001A85

Decoded:
  Header:         0x30 (SGTIN-96)
  Filter:         1 (Point-of-Sale)
  Partition:      5
  Company Prefix: 0614141
  Item Reference: 812345
  Serial:         6789
  GTIN-14:        80614141123458
  Digital Link:   https://id.gs1.org/01/80614141123458/21/6789
WRITE_EPC_TAG — Write EPC data to tag
// NRN protocol WRITE_EPC_TAG command
TX → 5A 00 01 02 11 00 0C [EPC_DATA_12_BYTES] [CRC16]

// The reader will:
// 1. Select the tag in its field
// 2. Write the provided EPC data to Bank 01
// 3. Return success/failure notification

// Access password required if tag is locked:
TX → 5A 00 01 02 11 00 10 [ACCESS_PWD_4B] [EPC_DATA_12B] [CRC16]

ऑनलाइन EPC एन्कोडर टूल का उपयोग करें /tools/tds-rfid-converter SGTIN-96, SSCC-96, GRAI-96 को सीधे अपने ब्राउज़र में एन्कोड और डिकोड करने के लिए।

पावर प्रबंधन

रीडर ट्रांसमिट पावर प्रति एंटेना पोर्ट 0 से 33 dBm तक समायोज्य है। उच्च शक्ति रीड रेंज को बढ़ाती है लेकिन हस्तक्षेप और बिजली की खपत को भी बढ़ाती है।

CONFIGURE_READER_POWER — Set 30 dBm on all 4 ports
TX → 5A 00 01 02 01 00 04 1E 1E 1E 1E 67 FE
                              ┌───────────┐
       Payload:               │1E 1E 1E 1E│
                              └───────────┘
       0x1E = 30 decimal = 30 dBm per port
       
Power guidelines:
  • 33 dBm — Maximum range (~10m), dock doors
  • 30 dBm — Standard range (~6-8m), general use
  • 25 dBm — Medium range (~3-5m), conveyor belts
  • 20 dBm — Short range (~1-2m), point-of-sale
  • 15 dBm — Near-field (~0.5m), shelf readers

RSSI मॉनिटरिंग

टैग से RSSI (प्राप्त सिग्नल स्ट्रेंथ इंडिकेटर) मान कच्चे ADC बाइट्स (0-255) के रूप में रिपोर्ट किए जाते हैं। सटीक dBm मान प्राप्त करने के लिए रूपांतरण सूत्र का उपयोग करें।

रूपांतरण सूत्र

dBm = -100 + round((raw × 70) / 255)

Raw 128

-65 dBm

अच्छा

Raw 180

-51 dBm

मजबूत

Raw 220

-40 dBm

उत्कृष्ट

उच्च गति वाली इन्वेंटरी स्कैनिंग

उच्च गति वाली इन्वेंटरी स्कैनिंग के लिए, कार्यशील आवृत्तियों, डुप्लिकेट टैग फ़िल्टर और निरंतर स्कैन मोड को कॉन्फ़िगर करें। रीडर इष्टतम कॉन्फ़िगरेशन के साथ प्रति सेकंड 700 टैग तक का समर्थन करते हैं।

आवृत्ति कॉन्फ़िगरेशन

UHF RFID 920-925 MHz बैंड (दक्षिण पूर्व एशिया) में 0.5 MHz चैनल स्पेसिंग के साथ संचालित होता है। चैनल 0 (920 MHz) से 10 (925 MHz) तक गिने जाते हैं।

SET_WORKING_FREQUENCY — 6 channels (920-925 MHz)
TX → 5A 00 01 02 05 00 06 00 02 04 06 08 0A C4 1B

Channel mapping (formula: 920.0 + index × 0.5 MHz):
  Ch 0  → 920.0 MHz
  Ch 2  → 921.0 MHz
  Ch 4  → 922.0 MHz
  Ch 6  → 923.0 MHz
  Ch 8  → 924.0 MHz
  Ch 10 → 925.0 MHz

इष्टतम स्कैनिंग वर्कफ़्लो

1

एंटीना पोर्ट और पावर स्तरों को कॉन्फ़िगर करें

2

कार्यशील आवृत्तियों को सेट करें (घने वातावरण के लिए FHSS)

3

डुप्लिकेट फ़िल्टर कॉन्फ़िगर करें (उपयोग के मामले के आधार पर 500ms-3000ms)

4

लगातार इन्वेंटरी शुरू करने के लिए READ_EPC_TAG भेजें

5

टैग सूचनाओं (PID 0x1231) को संसाधित करें जैसे ही वे आते हैं

6

हो जाने पर STOP_INVENTORY भेजें

Complete inventory flow — TypeScript
// 1. Enable antennas 1-4
await sendFrame("CONFIGURE_ANTENNA_ENABLE", [0x0F, 0x00, 0x00, 0x00]);

// 2. Set power to 30 dBm on all ports
await sendFrame("CONFIGURE_READER_POWER", [0x1E, 0x1E, 0x1E, 0x1E]);

// 3. Set working frequencies
await sendFrame("SET_WORKING_FREQUENCY", [0, 2, 4, 6, 8, 10]);

// 4. Set duplicate filter to 1000ms  
await sendFrame("SET_FILTER_SETTINGS", [0x03, 0xE8]);

// 5. Start inventory
await sendFrame("READ_EPC_TAG");

// 6. Process tags...
reader.on("tag", (tag) => {
  const rssiDbm = -100 + Math.round((tag.rssi * 70) / 255);
  console.log(`EPC: ${tag.epc}, Ant: ${tag.antenna}, RSSI: ${rssiDbm} dBm`);
});

// 7. Stop when done
await sendFrame("STOP_INVENTORY");