模拟技术
Register | Bit | Register address | Power-on RESET state | R/W | |||||||
7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ||||
Status | |||||||||||
Interrupt status | — | — | — | — | — | — | — | INTS | 0x00 | 0x00 | R |
Interrupt enable | — | — | — | — | — | — | — | INTE | 0x01 | 0x00 | R/W |
Configuration | |||||||||||
Configuration | CONT | MANUAL | — | — | CDR | TIM[2:0] | 0x02 | 0x03 | R/W | ||
LUX reading | |||||||||||
LUX high byte | E3 | E2 | E1 | E0 | M7 | M6 | M5 | M4 | 0x03 | 0x00 | R |
LUX low byte | — | — | — | — | M3 | M2 | M1 | M0 | 0x04 | 0x00 | R |
Threshold set | |||||||||||
Upper threshold high byte | UE3 | UE2 | UE1 | UE0 | UM7 | UM6 | UM5 | UM4 | 0x05 | 0xFF | R/W |
Lower threshold high byte | LE3 | LE2 | LE1 | LE0 | LM7 | LM6 | LM5 | LM4 | 0x06 | 0x00 | R/W |
Threshold timer | T7 | T6 | T5 | T4 | T3 | T2 | T1 | T0 | 0x07 | 0xFF | R/W |
Illumination Zone | External Lux (typ) | Backlight Strength (%) | External Lux, Lower Threshold (typ) | External Lux, Upper Threshold (typ) | Lower Threshold (10% Glass) | Upper Threshold (10% Glass) |
Dark | 4 | 25 | < 0 | > 10 | < 0 | > 1 |
Dim | 20 | 45 | < 10 | > 50 | < 1 | > 5 |
Home | 100 | 65 | < 50 | > 200 | < 5 | > 20 |
Office | 400 | 85 | < 200 | > 1000 | < 20 | > 100 |
Sunlight | > 2000 | 100 | < 1000 | > Maximum | < 100 | > Maximum |
Ambient light count | 2^(Exponent) × Mantissa |
Exponent = 8xE3 + 4xE2 + 2xE1 + E0 | |
Mantissa = 128xM7 + 64xM6 + 32xM5 + 16xM4 + 8xM3 + 4xM2 + 2xM1 + M0 | |
Upper threshold count | 2^(Exponent) × Mantissa |
Exponent = 8xE3 + 4xE2 + 2xE1 + E0 | |
Mantissa = 128xM7 + 64xM6 + 32xM5 + 16xM4 + 15 | |
Lower threshold count | 2^(Exponent) × Mantissa |
Exponent = 8xE3 + 4xE2 + 2xE1 + E0 | |
Mantissa = 128xM7 + 64xM6 + 32xM5 + 16xM4 |
Zone | Lower Threshold, 10% Glass (Lux) | Upper Threshold, 10% Glass (Lux) | Desired Lower Threshold Counts | Desired Upper Threshold Counts | Lower Threshold Register Byte | Upper Threshold Register Byte | Actual Lower Threshold Counts | Actual Upper Threshold Counts | Actual Lower Threshold (Lux) | Actual Upper Threshold (Lux) |
Dark | < 0 | > 1 | 0 | 22 | 0000 0000 |
0000 0001 |
0 | 31 | < 0 | > 1.395 |
Dim | < 1 | > 5 | 22 | 111 | 0000 0001 |
0000 0110 |
16 | 111 | < 0.72 | > 4.995 |
Home | < 5 | > 20 | 111 | 556 | 0000 0110 |
0010 1001 |
96 | 636 | < 4.32 | > 28.62 |
Office | < 20 | > 100 | 556 | 2222 | 0010 1001 |
0100 1000 |
576 | 2288 | < 25.92 | > 102.96 |
Sunlight | < 100 | > Maximum | 2222 | 4177920 | 0100 1000 |
1110 1111 |
2048 | 4177920 | < 92.16 | > 188006 |
// begin definition of slave device address #define MAX9635_WR_ADDR 0x96 #define MAX9635_RD_ADDR 0x97 // begin definition of slave register addresses for MAX9635 #define INT_STATUS 0x00 #define INT_ENABLE 0x01 #define CONFIG_REG 0x02 #define HIGH_BYTE 0x03 #define LOW_BYTE 0x04 #define THRESH_HIGH 0x05 #define THRESH_LOW 0x06 #define THRESH_TIMER 0x07 // end definition of slave addresses for MAX9635 // define some lookup tables for the upper and lower thresholds as well as the // brightness. All tables values are taken from text of application notes #define NUM_REGIONS 5 uint8 upperThresholds[NUM_REGIONS] = {0x01, 0x06, 0x29, 0x48, 0xEF}; uint8 lowerThresholds[NUM_REGIONS] = {0x00, 0x01, 0x06, 0x29, 0x48}; uint8 backlightBrightness[NUM_REGIONS] = {0x40, 0x73, 0xA6, 0xD9, 0xFF}; /** Function: SetPWMDutyCycle Arguments: uint8 dc - desired duty cycle Returns: none Description: sets the duty cycle of a 8-bit PWM, assuming that in this architecture, 0x00 = 0% duty cycle 0x7F = 50% and 0xFF = 100% **/ extern void SetPWMDutyCycle(uint8 dc); extern void SetupMicro(void); extern void Idle(void); /** Function: I2C_WriteByte Arguments: uint8 slaveAddr - address of the slave device uint8 regAddr - destination register in slave device uint8 data - data to write to the register Returns: ACK bit Description: performs necessary functions to send one byte of data to a specified register in a specific device on the I²C bus **/ extern uint8 I2C_WriteByte(uint8 slaveAddr, uint8 regAddr, uint8 data); /** Function: I2C_ReadByte Arguments: uint8 slaveAddr - address of the slave device uint8 regAddr - destination register in slave device uint8 *data - pointer data to read from the register Returns: ACK bit Description: performs necessary functions to get one byte of data from a specified register in a specific device on the I²C bus **/ extern uint8 I2C_ReadByte(uint8 slaveAddr, uint8 regAddr, uint8* data); /** Function: findNewThresholdsAndBrightness Arguments: uint8 luxCounts - light counts High Byte uint8 *highThresh - pointer to memory storing upper threshold byte uint8 *lowThresh - pointer to memory storing lower threshold byte Returns: none Description: Based on what the lux reading was (in counts), this routine determines the current operating illumination zone. The zones are defined by upper and lower bounds in a lookup table. After knowing the operating zone, this function may set new interrupt thresholds and a backlight brightness. Since the interrupt only fires when the lux reading is outside the defined region, these threshold and brightness settings are not overwritten with the same data repeatedly. **/ void findNewThresholdsAndBrightness(uint8 luxCounts, uint8 *highThresh, uint8 *lowThresh); void main() { uint8 *highThresholdByte; // upper and lower threshold bytes uint8 *lowThresholdByte; uint8 *timerByte; uint8 max9635Interrupt = 0; // status of MAX9635 interrupt register uint8 luxCounts; // computed as shown below SetupMicro(); // some subroutine which initializes this CPU *highByte = 0; *lowByte = 0; *highThresholdByte = 0xEF; // upper threshold counts // initially = POR setting (maximum possible = 0xEF) *lowThresholdByte = 0x00; // lower threshold counts // initially POR setting (minimum possible = 0x00) *timerByte = 0x14; // initial timer delay for thresholds: // 0x14 * 100ms = 2 seconds // initialize MAX9635 threshold and timer registers I2C_WriteByte(MAX9635_WR_ADDR, THRESH_HIGH, *highThresholdByte); I2C_WriteByte(MAX9635_WR_ADDR, THRESH_LOW, *lowThresholdByte); I2C_WriteByte(MAX9635_WR_ADDR, THRESH_TIMER, *timerByte); I2C_WriteByte(MAX9635_WR_ADDR, INT_ENABLE, 0x01);// enable sensor interrupts while(1) { // do other tasks until an interrupt fires // assume that this function waits for the status of a GPIO-type pin to // change states while (! GPIO_StatusChanged() ) { // some idling subroutine, shown with polling a port for // simplicity - but alternate interrupt-based routines are more // efficient Idle(); } // loop until an interrupt occurs // ok... an interrupt fired! was it from the MAX9635? I2C_ReadByte(MAX9635_RD_ADDR, INT_STATUS, max9635Interrupt); /** Place code to check other devices here, if desired **/ if (max9635Interrupt) { // get the current lux reading from the MAX9635 I2C_ReadByte(MAX9635_RD_ADDR, HIGH_BYTE, luxCounts); findNewThresholdsAndBrightness(luxCounts, highThresholdByte, lowThresholdByte); // write to the threshold and timer registers with new data I2C_WriteByte(MAX9635_WR_ADDR, THRESH_HIGH, *highThresholdByte); I2C_WriteByte(MAX9635_WR_ADDR, THRESH_LOW, *lowThresholdByte); max9635Interrupt = 0; // interrupt serviced, clear the bits } // only executes if the MAX9635's interrupt fired // perform other tasks which are only done after change of a GPIO pin } // loop forever } // main routine void findNewThresholdsAndBrightness(uint8 luxCounts, uint8 *highThresh, uint8 *lowThresh) { uint8 i; for (i=0; i < NUM_REGIONS; ++i) { if ((luxCounts >= lowerThresholds[i]) && (luxCounts <= upperThresholds[i])){ *highThresh = upperThresholds[i]; *lowThresh = lowerThresholds[i]; // PWM duty cycle sets the brightness of the backlight SetPWMDutyCycle(backlightBrightness[i]); return; // found the region -- no point in continuing the loop } // found the right region } // check where the lux reading lies in terms of threshold regions } // findNewThresholdsAndBrightness
全部0条评论
快来发表一下你的评论吧 !