Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: mbed 4DGL-uLCD-SE mbed-rtos nRF24L01P
Diff: main.cpp
- Revision:
- 11:a9f4237eaaa1
- Parent:
- 10:a8fcfc869fa5
- Child:
- 12:efcfe4c0d9f2
diff -r a8fcfc869fa5 -r a9f4237eaaa1 main.cpp --- a/main.cpp Wed Apr 18 15:36:04 2018 +0000 +++ b/main.cpp Wed Apr 18 23:09:40 2018 +0000 @@ -2,7 +2,7 @@ #include "rtos.h" #include "Microphone.h" #include "nRF24L01P.h" - +#define TRANSFER_SIZE 4 //added 5:54pm 4/18/18 Serial pc(USBTX, USBRX); // tx, rx nRF24L01P my_nrf24l01p(p5, p6, p7, p8, p9, p10); // mosi, miso, sck, csn, ce, irq @@ -11,17 +11,23 @@ DigitalOut myled3(LED3); Microphone mymicrophone(p16); -DigitalIn Button(p20); +InterruptIn Button(p20); //changed DitialIn to InterruptIn at 5:54 4/18/18 +AnalogOut speaker(p18); //added 6:34 pm at 4/18/18 + + char txData[TRANSFER_SIZE], rxData[TRANSFER_SIZE]; //making these usable by other voids. + int txDataCnt = 0;//and this. + int rxDataCnt = 0;//and this. //David Rechtmann 6.24 pm 4/18/18 + void startup() { // The nRF24L01+ supports transfers from 1 to 32 bytes, but Sparkfun's // "Nordic Serial Interface Board" (http://www.sparkfun.com/products/9019) // only handles 4 byte transfers in the ATMega code. -#define TRANSFER_SIZE 4 +//define TRANSFER_SIZE 4 - char txData[TRANSFER_SIZE], rxData[TRANSFER_SIZE]; - int txDataCnt = 0; - int rxDataCnt = 0; + // char txData[TRANSFER_SIZE], rxData[TRANSFER_SIZE]; //making these usable by other voids. + // int txDataCnt = 0;//and this. + // int rxDataCnt = 0;//and this. //David Rechtmann 6:24 pm 4/18/18 my_nrf24l01p.powerUp(); @@ -77,17 +83,44 @@ myled3 = !myled3; } } - } + //} + +void receive() { //most of this function added by david at 6:02pm 4/18/18 + float sample; + float average = 0.67/3.3;//initial DC bias level + while (Button == 0) { + if (my_nrf24l01p.readable(0)) { + my_nrf24l01p.read(0, rxData, 1 );//replace thrid val w/ 1? + sample = uint8_t (rxData); + average = 0.9999*average + 0.0001*sample; //This is in the mPA demo but I'm not sure how it works -david + speaker = 0.5 +((sample - average)*33.0); + } + if ( txDataCnt >= sizeof( txData ) ) { //i'm not sure what this does??? -david + + // Send the transmitbuffer via the nRF24L01+ + my_nrf24l01p.write( NRF24L01P_PIPE_P0, txData, txDataCnt ); + + txDataCnt = 0; + } + + } + } + void transmit() { // while (mymycrophone.getData()) { // txData[txDataCnt++] = mymicrophone.getData(); // } // txData[txDataCnt++] = ; - while (Button = 1) { - my_nrf24l01p.write(0, mymicrophone.getData(), txDataCnt); + my_nrf24l01P.setTransmitMode(); // for latest revision 5:52pm 4/18/1, this doesn't compile and I don't know why. + speaker = 0; + while (Button == 1) { + my_nrf24l01P.write(0, mymicrophone.getData(), txDataCnt); } } -main (1) { +int main() { + Button.mode(PullUp);//added 6:23pm 4/18/18 + Button.rise(&transmit); + Button.fall(&receive); while (1) { }