加入星計(jì)劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入

基于雙核LPC55S69為主控芯片的NFC門鎖,采用I2C端口讀取NFC讀卡器

07/22 13:17
1246
服務(wù)支持:
技術(shù)交流群

完成交易后在“購買成功”頁面掃碼入群,即可與技術(shù)大咖們分享疑惑和經(jīng)驗(yàn)、收獲成長和認(rèn)同、領(lǐng)取優(yōu)惠和紅包等。

虛擬商品不可退

當(dāng)前內(nèi)容為數(shù)字版權(quán)作品,購買后不支持退換且無法轉(zhuǎn)移使用。

加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論
放大
實(shí)物圖
相關(guān)方案
  • 方案介紹
  • 相關(guān)文件
  • 推薦器件
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請(qǐng)入駐 產(chǎn)業(yè)圖譜

一、項(xiàng)目名稱:

NFC門鎖

二、項(xiàng)目概述:

本系統(tǒng)是基于雙核LPC55S69為主控芯片的NFC門鎖,采用I2C端口讀取NFC讀卡器的數(shù)據(jù),經(jīng)過身份驗(yàn)證后,啟動(dòng)伺服電機(jī)控制門鎖開鎖。延時(shí)后再次掃描讀卡器,如果沒有更新并保持的最新讀卡器數(shù)據(jù)后,控制伺服電機(jī)返回,關(guān)閉門鎖。

補(bǔ)充說明:原計(jì)劃的門鎖是采用Tensorflow Lite的智能門鎖項(xiàng)目,用攝像頭掃描,捕捉人體接近并啟動(dòng)圖片識(shí)別功能,符合安全身份認(rèn)證后,開啟門鎖。原計(jì)劃中,NFC門鎖是其中的一個(gè)多重身份驗(yàn)證工具,運(yùn)行在Core0在低功耗運(yùn)行。CV識(shí)別運(yùn)行在core1,高速執(zhí)行。

LPC55S69本身功能強(qiáng)大,可以勝任告訴圖片讀取的功能,但是在導(dǎo)入tensorflow lite的過程中,發(fā)現(xiàn)了公版model的問題,就是這個(gè)系統(tǒng)太大,不能支持MCU的運(yùn)行。tensorflow lite對(duì)于內(nèi)存的最小要求是1M內(nèi)存,680k閃存已經(jīng)足夠大,但是不能支持經(jīng)過測試的公版model(如mobileNet-0.25x0.25執(zhí)行flatten后仍然有1.68M)。

自行設(shè)計(jì)model并訓(xùn)練更小的模型,在性能上不能得到驗(yàn)證,所以在提交截止期之前,只能實(shí)現(xiàn)現(xiàn)有的功能。

感謝本次挑戰(zhàn)賽的開發(fā)過程,引出了一個(gè)有趣的新題目,就是如何在高性能MCU上執(zhí)行大的模型運(yùn)行,如VGG這樣的深度網(wǎng)絡(luò)模型,后續(xù)仍然繼續(xù)沿著這個(gè)思路開發(fā),力爭在這個(gè)板子上實(shí)現(xiàn)公版模型的適用。

經(jīng)過多次實(shí)驗(yàn),已經(jīng)有了初步的設(shè)計(jì)框架:在不啟動(dòng)MMU功能的情況下,如何構(gòu)建一個(gè)SWAP空間,仍然能夠快速實(shí)現(xiàn)擴(kuò)址訪問,只需要再做一個(gè)overlay的內(nèi)存管理庫就可以了。

三、作品實(shí)物圖

NFC讀卡器的鏈接I2C

NFC讀卡器的型號(hào)

鏈接9G伺服電機(jī)

讀卡器讀取NFC卡的ID信息

四、演示視頻

動(dòng)態(tài)演示這個(gè)程序執(zhí)行過程

五、項(xiàng)目文檔

5.1 使用的硬件包括

-??LPC55S69 dev board

- NFC tag reader ID-12LA,

5.2 主要的代碼如下:其中實(shí)現(xiàn)servo控制使用了ctime庫,定義一個(gè)50Hz的占空比再2.5%~12.5%可調(diào)的PWM信號(hào)來控制伺服電機(jī)。

int main(void)
{
    i2c_master_config_t masterConfig;
    status_t reVal        = kStatus_Fail;
    uint8_t deviceAddress = 0x01U;
        
          ctimer_config_t config;
    uint32_t srcClock_Hz;
    uint32_t timerClock;
                uint8_t        updatedutyCyclePercent;

    /* attach 12 MHz clock to FLEXCOMM0 (debug console) */
    CLOCK_AttachClk(BOARD_DEBUG_UART_CLK_ATTACH);

    /* attach 12 MHz clock to FLEXCOMM8 (I2C master) */
    CLOCK_AttachClk(kFRO12M_to_FLEXCOMM4);

            /* Use 12 MHz clock for some of the Ctimers */
    CLOCK_AttachClk(kFRO_HF_to_CTIMER2);
        
    /* reset FLEXCOMM for I2C */
    RESET_PeripheralReset(kFC4_RST_SHIFT_RSTn);

    BOARD_InitPins();
    BOARD_BootClockPLL150M();
    BOARD_InitDebugConsole();
                
    /* CTimer0 counter uses the AHB clock, some CTimer1 modules use the Aysnc clock */
    srcClock_Hz = CTIMER_CLK_FREQ;

    PRINTF("CTimer example to generate a PWM signalrn");

    CTIMER_GetDefaultConfig(&config);
    timerClock = srcClock_Hz / (config.prescale + 1);

    CTIMER_Init(CTIMER, &config);

    /* Get the PWM period match value and pulse width match value of 50hz PWM signal with 2.5%~12.5% dutycycle , 20ms peoriod*/
    CTIMER_GetPwmPeriodValue(50, 10, timerClock);                
    CTIMER_SetupPwmPeriod(CTIMER, CTIMER_MAT_OUT, g_pwmPeriod, g_pulsePeriod, false);
    CTIMER_StartTimer(CTIMER);
                //CTIMER_UpdatePwmDutycycle(CTIMER_Type *base, ctimer_match_t matchChannel, uint8_t dutyCyclePercent);
                
    PRINTF("rnI2C board2board polling -- Master transfer.rn");

    g_master_txBuff[0] = I2C_DATA_LENGTH - 1U;
    for (uint32_t i = 1U; i < I2C_DATA_LENGTH; i++)
    {
        g_master_txBuff[i] = i - 1;
    }


    I2C_MasterGetDefaultConfig(&masterConfig);

    /* Change the default baudrate configuration */
    masterConfig.baudRate_Bps = I2C_BAUDRATE;

    /* Initialize the I2C master peripheral */
    I2C_MasterInit(EXAMPLE_I2C_MASTER, &masterConfig, I2C_MASTER_CLOCK_FREQUENCY);


    /* Wait until the slave is ready for transmit, wait time depend on user's case.
       Slave devices that need some time to process received byte or are not ready yet to
       send the next byte, can pull the clock low to signal to the master that it should wait.*/
    for (uint32_t i = 0U; i < WAIT_TIME; i++)
    {
        __NOP();
    }
    PRINTF("Receive sent data from slave :");
                
                while (1)
    {
    for (uint32_t i = 0U; i < WAIT_TIME; i++)
    {        __NOP();    }
    /* Receive blocking data from slave */
    if (kStatus_Success == I2C_MasterStart(EXAMPLE_I2C_MASTER, I2C_MASTER_SLAVE_ADDR_7BIT, kI2C_Write))
    {

        reVal = I2C_MasterReadBlocking(EXAMPLE_I2C_MASTER, g_master_rxBuff, I2C_DATA_LENGTH - 1, kI2C_TransferDefaultFlag);
        if (reVal != kStatus_Success)
        {
            return -1;
        }

        reVal = I2C_MasterStop(EXAMPLE_I2C_MASTER);
        if (reVal != kStatus_Success)
        {
            return -1;
        }
    }

    for (uint32_t i = 0U; i < 4; i++)
                    //for (uint32_t i = 0U; i < I2C_DATA_LENGTH - 1; i++)
    {
        if (i % 8 == 0)
        {
            PRINTF("rn");
        }
        PRINTF("0x%2x  ", g_master_rxBuff[i]);
                                if (g_master_rxBuff[i]== g_match_id[i] ){g_master_rxBuff[I2C_DATA_LENGTH-1]=127;}
    }
    PRINTF("rnrn");
                
                // LOCK_UNLOCK, refreshed every loop and return to LOCK off status,
                updatedutyCyclePercent= LOCK_ON ? (g_master_rxBuff[I2C_DATA_LENGTH-1]==127):LOCK_OFF;
                g_pulsePeriod = (g_pwmPeriod * (100 - updatedutyCyclePercent)) / 100;
                CTIMER_UpdatePwmDutycycle(CTIMER, CTIMER_MAT_OUT, g_pulsePeriod);

    }                
    // PRINTF("rnEnd of I2C example .rn");
}

 

  • NFC門鎖.docx

推薦器件

更多器件
器件型號(hào) 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊 ECAD模型 風(fēng)險(xiǎn)等級(jí) 參考價(jià)格 更多信息
LM6171AIM 1 National Semiconductor Corporation IC 1 CHANNEL, VIDEO AMPLIFIER, PDSO8, SO-8, Audio/Video Amplifier
$6.08 查看
TPA2011D1YFFR 1 Texas Instruments 3.2-W, mono, analog input Class-D audio amplifier with auto-recovering short-circuit protection 9-DSBGA -40 to 85

ECAD模型

下載ECAD模型
$0.89 查看
TFP401APZPG4 1 Texas Instruments 165-MHz TMDS DVI receiver/deserializer with HSYNC &amp; Panelbus&trade; integrated circuit 100-HTQFP 0 to 70

ECAD模型

下載ECAD模型
$9.99 查看

相關(guān)推薦

電子產(chǎn)業(yè)圖譜