ડોક્યુમેન્ટેશન
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 | કેટેગરીની અંદરનો સંદેશ ID |
| 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મલ્ટિ-એન્ટેના જમાવટ
જ્યારે બહુવિધ એન્ટેનાને જમાવતા હોવ, ત્યારે ધ્રુવીકરણ (રેખીય વિરુદ્ધ પરિપત્ર), એન્ટેના વચ્ચેનું અંતર અને ઓવરલેપિંગ કવરેજ ઝોન ધ્યાનમાં લો. રીડર સક્ષમ એન્ટેના દ્વારા ક્રમિક રીતે સ્કેન કરે છે, અને દરેક ટૅગ રિપોર્ટમાં સ્થાન નિર્ધારણ માટે એન્ટેના ID શામેલ છે.
ડોક ડોર
પોર્ટલ દીઠ 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 | ચિપ ઉત્પાદક ID (માત્ર-વાંચન, અનન્ય) |
| 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 બેન્ડ (Southeast Asia) માં 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");