EM4100(EMID)卡使用记录

3 篇文章 0 订阅
1 篇文章 1 订阅
本文详细介绍了基于单片机RDM6300ID卡读卡器模块的RFID射频识别系统,包括硬件测试(读卡极限距离为3.8cm)、理论部分(如数据存储结构和位周期)以及程序解析和数据采集代码。重点讨论了数据位周期和解码程序,提供了快速解码的实现,解码周期约32.768ms。
摘要由CSDN通过智能技术生成

目录

1、硬件部分

2、理论部分

2.1、数据存储结构

2.2、数据位周期

3、程序解析

 4、数据采集代码

5、整个测试工程的代码


1、硬件部分

测试读卡器实物:单片机RDM6300 ID卡读卡器模块RFID射频/UART串口输出模块 125KHz-淘宝网 (taobao.com)

实测读卡极限距离能到3.8cm,效果还不错。

良心卖家,还给电路原理图了,淘宝自行下载。

 载波发射部分


数据信号提取


 弱信号放大二值化


2、理论部分

2.1、数据存储结构

EM4100包含64位信息,分为5组信息。9位用于报头,10行奇偶校验位(P0-P9),4列奇偶校验位(PC0-PC3),40个数据位(D00-D93),1个停止位设置为逻辑0。

 EM4100数据手册 EM4100 pdf

2.2、数据位周期

就是传输一个bit位(0/1)所需要的载波信号的周期(载波信号125khz)。Trdb是可选的,有64/32/16三种。

实测手里的钥匙扣是64个载波周期。

时间(选Tred=64f):

        EM4100包含64位信息,每个bit为占用64个载波周期,每个载波周期为1/125khz = 8us

所以,

一个bit周期:

        64*8us = 512us

半bit周期 :

        512us/2 = 256us

传输一个包用时:      

        64 x (64 x 8us) = 32.768ms

读取周期也就那么快,在门禁场景足够了,但是想运动状态快速获取场景就有点吃力了。

实测:

    30.04s读取包个数918个

          30.04s / 918 = 32.7233 ms 

3、程序解析

  • 连续检测16个边沿信号,必须满足其周期T1如下,40为误差允许范围单位us。存在一个不满足则计数清零。
        (T1 > (256 - 40) && T1 < (256 + 40))

9个前导数据头1,并非就一定有18个边沿信号,检测16个即可。严格来说9这个前导1会和多个连续的数据0冲突,不做深度讨论。

  • 通过前导1的下降沿同步数据时钟周期。
  • 如果边沿周期T1满足如下条件,表示T1跨越了数据周期,结束记作半周期。如果上山沿记作1,下降沿记作0.
        (T1 > 512-40 && T1 < 512+40) //跨周期

 4、数据采集代码


void capture_signal()
{
    if (__HAL_TIM_GET_IT_SOURCE(&htim2, TIM_IT_CC1) != RESET)
    {
        __HAL_TIM_CLEAR_IT(&htim2, TIM_IT_CC1);

        static uint16_t last_value = 0;
        static bool half_period = false; //之前是半个周期
        static uint8_t bit_index = 0;

        uint16_t value = htim2.Instance->CCR1;
        uint16_t T1 = value - last_value;
        last_value = value;

        bool edge_rise = false;
        //翻转补货电平
        if (htim2.Instance->CCER & (1 << 1))
        {
            edge_rise = true;
            htim2.Instance->CCER &= (~TIM_CCER_CC1P);
        }
        else
        {
            //下降沿
            htim2.Instance->CCER |= TIM_CCER_CC1P;
        }

        if (bit_index < 16) //查找起始信号
        {
            if (T1 > (256 - 40) && T1 < (256 + 40))
            {
                bit_index++;
            }
            else
            {
                bit_index = 0;
            }

            if (edge_rise)
            {
                half_period = true;
            }
            else
            {
                half_period = false;
            }
            bit_len = 0;
        }
        else
        {
            if (half_period == false) //bit周期开始
            {
                if (T1 > (256 - 40) && T1 < (256 + 40))
                {
                    if (edge_rise)
                    {
                        if (append_bit(1))
                        {
                            bit_index++;
                        }
                        else
                        {
                            bit_index = 0;
                        }
                    }
                    else
                    {
                        if (append_bit(0))
                        {
                            bit_index++;
                        }
                        else
                        {
                            bit_index = 0;
                        }
                    }
                    half_period = true;
                }
                else
                {
                    bit_index = 0; //数据异常
                }
            }
            else
            {
                if (T1 > 512 - 40 && T1 < 512 + 40) //跨周期
                {
                    if (edge_rise)
                    {
                        if (append_bit(1))
                        {
                            bit_index++;
                        }
                        else
                        {
                            bit_index = 0;
                        }
                    }
                    else
                    {
                        if (append_bit(0))
                        {
                            bit_index++;
                        }
                        else
                        {
                            bit_index = 0;
                        }
                    }
                    half_period = true;
                }
                else if (T1 > (256 - 40) && T1 < (256 + 40)) //过度半周期
                {
                    half_period = false;
                }
                else
                {
                    bit_index = 0; //数据异常
                }
            }
        }

        //解析数据
    }
}

具体解析校验就相对简单了,参考EM4100文档。

5、整个测试工程的代码

EM4100快速解码程序-嵌入式文档类资源-CSDN下载EM4100解码程序,实现理论上的最快32.768ms解码周期,细节参考本人CSDN更多下载资源、学习资料请访问CSDN下载频道.https://download.csdn.net/download/ai5945fei/85391114

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值