दस्तावेज़
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 पोर्ट का स्वतः पता लगाता है और कनेक्शन पैरामीटर कॉन्फ़िगर करता है।
// 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();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 चेकसम।
| फ़ील्ड | आकार | विवरण |
|---|---|---|
| Header | 1 byte | हमेशा 0x5A. फ्रेम मार्कर की शुरुआत |
| PCW | 2 bytes | प्रोटोकॉल फ़्लैग (संस्करण, पता) |
| Category | 1 byte | कमांड श्रेणी (0x00=सिस्टम, 0x01=डिवाइस, 0x02=RFID) |
| MID | 1 byte | श्रेणी के भीतर संदेश आईडी |
| Length | 2 bytes | बाइट्स में पेलोड लंबाई (बड़ा-एंडियन) |
| Data | N bytes | कमांड-विशिष्ट पेलोड |
| CRC16 | 2 bytes | हेडर के बाद बाइट्स का CRC16-CCITT चेकसम |
कमांड उदाहरण
TX → 5A 00 01 01 00 00 00 DC E5
┌──┐ ┌────┐ ┌──┐ ┌──┐ ┌────┐ ┌────┐
│5A│ │0001│ │01│ │00│ │0000│ │DCE5│
└──┘ └────┘ └──┘ └──┘ └────┘ └────┘
HDR PCW CAT MID LEN CRC16TX → 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)TX → 5A 00 01 02 FF 00 00 88 5A
HDR PCW CAT MID LEN CRC16मुख्य कमांड संदर्भ
| कमांड | कोड | विवरण |
|---|---|---|
| QUERY_INFO | 0x0100 | रीडर सीरियल नंबर और फर्मवेयर संस्करणों को क्वेरी करें |
| QUERY_RFID_ABILITY | 0x1000 | RFID क्षमताओं को क्वेरी करें (पावर रेंज, एंटीना गणना) |
| READ_EPC_TAG | 0x0210 | निरंतर EPC टैग इन्वेंटरी शुरू करें |
| WRITE_EPC_TAG | 0x0211 | टैग के EPC बैंक में डेटा लिखें |
| STOP_INVENTORY | 0x02FF | चल रही टैग इन्वेंटरी बंद करें |
| CONFIGURE_READER_POWER | 0x0201 | ट्रांसमिट पावर सेट करें (प्रति एंटीना 0-33 dBm) |
| CONFIGURE_ANTENNA_ENABLE | 0x0203 | एंटीना पोर्ट को सक्षम/अक्षम करें (बिटमास्क) |
| SET_WORKING_FREQUENCY | 0x0205 | विशिष्ट कार्यशील आवृत्तियों को सेट करें |
| SET_FILTER_SETTINGS | 0x0209 | टैग डुप्लिकेट फ़िल्टर कॉन्फ़िगर करें (समय-आधारित) |
| BUZZER_SWITCH | 0x011E | बज़र मोड को नियंत्रित करें |
एंटीना कॉन्फ़िगरेशन
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
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), और उपयोगकर्ता (कस्टम डेटा)।
टैग मेमोरी संरचना
| बैंक | आईडी | विशिष्ट आकार | उपयोग |
|---|---|---|---|
| Reserved | 00 | 64 bits | किल पासवर्ड (32b) + एक्सेस पासवर्ड (32b) |
| EPC | 01 | 96-128 bits | SGTIN-96, SSCC-96, या कस्टम एन्कोडिंग |
| TID | 10 | 96+ bits | चिप निर्माता आईडी (केवल-पढ़ने योग्य, अद्वितीय) |
| User | 11 | 0-512 bits | एप्लिकेशन-विशिष्ट डेटा (चिप-निर्भर) |
SGTIN-96 डिकोडिंग उदाहरण
SGTIN-96 खुदरा और आपूर्ति श्रृंखला उत्पादों के लिए सबसे आम एन्कोडिंग है। 24-वर्ण हेक्स EPC को GTIN-14, सीरियल नंबर और GS1 डिजिटल लिंक में बदलें।
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// 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 तक समायोज्य है। उच्च शक्ति रीड रेंज को बढ़ाती है लेकिन हस्तक्षेप और बिजली की खपत को भी बढ़ाती है।
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 readersRSSI मॉनिटरिंग
टैग से 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) तक गिने जाते हैं।
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इष्टतम स्कैनिंग वर्कफ़्लो
एंटीना पोर्ट और पावर स्तरों को कॉन्फ़िगर करें
कार्यशील आवृत्तियों को सेट करें (घने वातावरण के लिए FHSS)
डुप्लिकेट फ़िल्टर कॉन्फ़िगर करें (उपयोग के मामले के आधार पर 500ms-3000ms)
लगातार इन्वेंटरी शुरू करने के लिए READ_EPC_TAG भेजें
टैग सूचनाओं (PID 0x1231) को संसाधित करें जैसे ही वे आते हैं
हो जाने पर STOP_INVENTORY भेजें
// 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");