omar siedahmed
/
ECE595_Spring2021_Pr1
PIR sensor with Groove buzzer
Revision 0:e1efa9331623, committed 2021-03-22
- Comitter:
- omar1646
- Date:
- Mon Mar 22 01:29:55 2021 +0000
- Commit message:
- PIR sensor with Groover Buzzer
Changed in this revision
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/.gitignore Mon Mar 22 01:29:55 2021 +0000 @@ -0,0 +1,4 @@ +.build +.mbed +projectfiles +*.py*
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/CONTRIBUTING.md Mon Mar 22 01:29:55 2021 +0000 @@ -0,0 +1,5 @@ +# Contributing to Mbed OS + +Mbed OS is an open-source, device software platform for the Internet of Things. Contributions are an important part of the platform, and our goal is to make it as simple as possible to become a contributor. + +To encourage productive collaboration, as well as robust, consistent and maintainable code, we have a set of guidelines for [contributing to Mbed OS](https://os.mbed.com/docs/mbed-os/latest/contributing/index.html).
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/ESP8266.lib Mon Mar 22 01:29:55 2021 +0000 @@ -0,0 +1,1 @@ +https://os.mbed.com/users/quevedo/code/ESP8266/#77388e8f0697
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/README.md Mon Mar 22 01:29:55 2021 +0000 @@ -0,0 +1,64 @@ +![](./resources/official_armmbed_example_badge.png) +# Blinky Mbed OS example + +The example project is part of the [Arm Mbed OS Official Examples](https://os.mbed.com/code/) and is the [getting started example for Mbed OS](https://os.mbed.com/docs/mbed-os/v5.14/quick-start/index.html). It contains an application that repeatedly blinks an LED on supported [Mbed boards](https://os.mbed.com/platforms/). + +You can build the project with all supported [Mbed OS build tools](https://os.mbed.com/docs/mbed-os/latest/tools/index.html). However, this example project specifically refers to the command-line interface tool [Arm Mbed CLI](https://github.com/ARMmbed/mbed-cli#installing-mbed-cli). +(Note: To see a rendered example you can import into the Arm Online Compiler, please see our [import quick start](https://os.mbed.com/docs/mbed-os/latest/quick-start/online-with-the-online-compiler.html#importing-the-code).) + +1. [Install Mbed CLI](https://os.mbed.com/docs/mbed-os/latest/quick-start/offline-with-mbed-cli.html). + +1. Clone this repository on your system, and change the current directory to where the project was cloned: + + ```bash + $ git clone git@github.com:armmbed/mbed-os-example-blinky && cd mbed-os-example-blinky + ``` + + Alternatively, you can download the example project with Arm Mbed CLI using the `import` subcommand: + + ```bash + $ mbed import mbed-os-example-blinky && cd mbed-os-example-blinky + ``` + + +## Application functionality + +The `main()` function is the single thread in the application. It toggles the state of a digital output connected to an LED on the board. + +## Building and running + +1. Connect a USB cable between the USB port on the board and the host computer. +2. <a name="build_cmd"></a> Run the following command to build the example project and program the microcontroller flash memory: + ```bash + $ mbed compile -m <TARGET> -t <TOOLCHAIN> --flash + ``` +The binary is located at `./BUILD/<TARGET>/<TOOLCHAIN>/mbed-os-example-blinky.bin`. + +Alternatively, you can manually copy the binary to the board, which you mount on the host computer over USB. + +Depending on the target, you can build the example project with the `GCC_ARM`, `ARM` or `IAR` toolchain. After installing Arm Mbed CLI, run the command below to determine which toolchain supports your target: + +```bash +$ mbed compile -S +``` + +## Expected output +The LED on your target turns on and off every 500 milliseconds. + + +## Troubleshooting +If you have problems, you can review the [documentation](https://os.mbed.com/docs/latest/tutorials/debugging.html) for suggestions on what could be wrong and how to fix it. + +## Related Links + +* [Mbed OS Stats API](https://os.mbed.com/docs/latest/apis/mbed-statistics.html). +* [Mbed OS Configuration](https://os.mbed.com/docs/latest/reference/configuration.html). +* [Mbed OS Serial Communication](https://os.mbed.com/docs/latest/tutorials/serial-communication.html). +* [Mbed OS bare metal](https://os.mbed.com/docs/mbed-os/latest/reference/mbed-os-bare-metal.html). +* [Mbed boards](https://os.mbed.com/platforms/). + +### License and contributions + +The software is provided under Apache-2.0 license. Contributions to this project are accepted under the same license. Please see contributing.md for more info. + +This project contains code from other projects. The original license text is included in those source files. They must comply with our license guide.
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/main.cpp Mon Mar 22 01:29:55 2021 +0000 @@ -0,0 +1,106 @@ +// This program will represent an intrusion detection systesm that will, it's simply a secuirty.. +/// system for homes to which will combat against any home burglary. It consists of a infrared motion sensor +/// and grove buzzer. The infrared IC will be able to detect human presense and the grove buzzer will buzz and +/// emitt an alarming sound. This sound will human presence and will scare off any outside interference. The program also +/// will have live detectin update via thingspeak. + + +#include "mbed.h" +Serial pc(USBTX, USBRX); // tx, rx +InterruptIn motion(D0); +DigitalOut buzzer(D3); +DigitalOut Red(LED2); +void wifi_send(void); //Connect and Push Data Channel to Cloud Server + +int num = 0; +int distance1, distance2; +float dist_remaining1, dist_percent1, dist_remaining2, dist_percent2; +char snd[255],rcv[1000]; //snd: send command to ESP8266 + //rcv: receive response from ESP8266 + +Serial pc(USBTX,USBRX); //Serial Communication with PC +ESP8266 wifi(PTC17, PTC16, 115200); //Tx Pin:PTC17; Rx Pin:PTC17; Baud rate:115200 + +int motion_detected = 0; + +void irq_handler(void) +{ + motion_detected = 1; +} + +int main () +{ + pc.baud(115200); + + + pc.printf("Initial Setup\r\n"); + wifi.SetMode(1); //Set ESP mode to 1 + wifi.RcvReply(rcv, 1000); //Receive a response from ESP + pc.printf("%s\r", rcv); + + pc.printf("Connecting to WiFi\r\n"); //AP Setup Initialization + wifi.Join("SSID", "PWD");//Put your Wifi SSID followed by Password WiFi_SSID WiFi_Password + wifi.RcvReply(rcv, 1000); + pc.printf("%s\n", rcv); + wait(8); + + wifi.GetIP(rcv); //Obtains an IP address from the AP + + while (1) + { + wifi_send(); + + RLed = 1; + GLed = 1; + BLed = 0; + wait(2.0f); + } +} + +void wifi_send(void) +{ + while(num<1000000000000) + { + num=num+1; + pc.printf("\nCloud Sync Instance #: %d\n\r", num); + pc.printf("Syncing Data with Cloud, Please Wait.\n\r"); + + while(1) + { + if(motion_detected) + { + cnt++; + motion_detected = 0; + pc.printf("Hello! I've detected %d times since reset\r\n", cnt); + Red=0; + //wait(5); + buzzer= on; + Red=1; + wait(5); + } else{ + pc.printf("did not detect\r\n"); + } + + //Sending Data to the Cloud Server via ESP8266 WiFi Module + strcpy(snd,"AT+CIPMUX=0\n\r"); //AT+CIPMUX: Enabling Single Channel Mode + wifi.SendCMD(snd); + wait(1); + wifi.RcvReply(rcv, 1000); + wait(1); + + //Establish TCP connection w/ Cloud Server + sprintf(snd,"AT+CIPSTART=4,\"TCP\",\"%s\",80\n",CloudIP); + wait(1); + wifi.RcvReply(rcv, 1000); + wait(1); + + //Set length of the data that will be sent + strcpy(snd,"AT+CIPSEND=100\n\r"); + wifi.SendCMD(snd); + pc.printf("%s\r", rcv); + wait(1); + wifi.RcvReply(rcv, 1000); + pc.printf("%s\r", rcv); + wait(1); + } + \ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed-os.lib Mon Mar 22 01:29:55 2021 +0000 @@ -0,0 +1,1 @@ +https://github.com/ARMmbed/mbed-os/#cf4f12a123c05fcae83fc56d76442015cb8a39e9
Binary file resources/official_armmbed_example_badge.png has changed