1

所以,我必须完成这个挑战,即为一个 8051 微控制器实现一个摄像头监控系统。

这些是规格:

  1. 每个摄像机都与一个运动传感器相关联,每次检测到运动时,该摄像机的记录都会被注册并保存。如果传感器超过 5 秒没有捕捉到任何动作,则此摄像机将不再被记录;

  2. 如果没有摄像头,录像机必须处于“暂停”状态;

  3. 如果打开了多个摄像机,则必须使用多路复用器(mux)以某种方式选择摄像机信号,以便在 3 秒内记录每个摄像机。这样,必须在 3 秒内记录所有活动的摄像机。如果只有一台摄像机处于活动状态,则它的信号必须是多路复用器中唯一的一台。

我已经在下面的代码中完成了这一点。而我们现在要做的就是在没有编译器优化的情况下优化代码的大小。代码现在是 198 字节,但我试图低于 180 字节。

可能吗?我已经尝试进行#define 的计算,但编译器已经为我优化了它。

#include <REG51F.h>

#define TIMEOUT 50
#define TIMEOUT_REC 30

#define FrClk 12000000
#define FreqTimer0_emHz 10
#define VALOR_TH0 ((65536 - (FrClk /(12 * FreqTimer0_emHz ))) >> 8)
#define VALOR_TL0 ((65536 - (FrClk /(12 * FreqTimer0_emHz ))) & 0xFF)


data bit PAUSE_INT;
data bit PAUSE_TMP;
sbit PAUSE = P0^0;
sbit SENSOR1 = P0^1;
sbit SENSOR2 = P0^2;
sbit SENSOR3 = P0^3;
sbit SENSOR4 = P0^4;
sbit MUX0 = P0^5;
sbit MUX1 = P0^6;

data unsigned char CAM[4];
data unsigned char REC;
data unsigned char index;
data unsigned char count;

void timer0_int (void) interrupt 1 using 2 {
    for (index = 0; index < 4; index++)
        if(CAM[index])
        CAM[index]--;

    if (!PAUSE_INT && REC)
        REC--;
    else
    { 
         REC = TIMEOUT_REC;
         index = (index + 1) & 0x03;
         for (count = 0; !CAM[index] && count < 4; index = (index + 1) & 0x03, count++);

         MUX0 = index & 0x1;
         MUX1 = index & 0x2;


         PAUSE_INT = 0;
    }   
}

int main(void)
{

    PAUSE_TMP = 1;
    PAUSE_INT = 0;

    index = 0;

    //timer0_init
    EA = 1;
    TR0 = 0;              
    TMOD = (TMOD & 0xF0) | 0x01;  
    TH0 = VALOR_TH0;  
    TL0 = VALOR_TL0;
    ET0 = 1;     
    TR0 = 1;     

    while(1) {

        if (SENSOR1)
        {
                CAM[0] = TIMEOUT;
        }

        if (SENSOR2)
        {
                CAM[1] = TIMEOUT;
        }

        if (SENSOR3)
        {
                CAM[2] = TIMEOUT;
        }

        if (SENSOR4)
        {
                CAM[3] = TIMEOUT;
        }

        if (CAM[0] || CAM[1] || CAM[2] || CAM[3])
        {
                if (PAUSE_TMP)
                        PAUSE_INT = 1;
                PAUSE_TMP = 0;
        }
        else {
                PAUSE_TMP = 1;
        }

            PAUSE = PAUSE_TMP;
    }


}
4

2 回答 2

1

您可能必须查看为此生成的汇编代码,以便从中提取最后几个字节。通过重用变量或组合操作,可能会在这里和那里刮掉一些。生成的代码不会很漂亮——或可维护——但它可能会让你低于你的临界值。

于 2012-05-22T04:05:56.123 回答
0

我认为开关盒而不是 if(sensor1,2,3,4) 可以帮助一些。

于 2012-05-21T22:01:50.200 回答