PMKIND
Dependencies: rohm-rpr0521 rohm-sensor-hal Servo TextLCD
Revision 0:51001d8fdeff, committed 2021-06-24
- Comitter:
- emilija
- Date:
- Thu Jun 24 15:11:30 2021 +0000
- Child:
- 1:7b52bdcdac4e
- Commit message:
- pmkINDUSTRIJA1
Changed in this revision
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/.gitignore Thu Jun 24 15:11:30 2021 +0000 @@ -0,0 +1,4 @@ +.build +.mbed +projectfiles +*.py*
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/CONTRIBUTING.md Thu Jun 24 15:11:30 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/README.md Thu Jun 24 15:11:30 2021 +0000 @@ -0,0 +1,64 @@ + +# 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/Servo.lib Thu Jun 24 15:11:30 2021 +0000 @@ -0,0 +1,1 @@ +https://os.mbed.com/users/simon/code/Servo/#36b69a7ced07
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/TextLCD.lib Thu Jun 24 15:11:30 2021 +0000 @@ -0,0 +1,1 @@ +https://os.mbed.com/users/simon/code/TextLCD/#308d188a2d3a
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/color.cpp Thu Jun 24 15:11:30 2021 +0000
@@ -0,0 +1,76 @@
+#include "mbed.h"
+#include "color.h"
+ ColorSensor::ColorSensor(PinName ss0, PinName ss1, PinName ss2, PinName ss3, PinName sout):
+ s0(ss0), s1(ss1), s2(ss2), s3(ss3), _out(sout)
+ {
+ s0.write(1);
+ s1.write(1);
+ s2.write(0);
+ s3.write(0);
+ interrupted = 12345;
+ countR = counter;
+ countG = counter;
+ countB = counter;
+ counter = 0;
+ flag = 0;
+ _out.mode(PullUp);
+ _out.rise(this, &ColorSensor::incCount);
+ ts.attach(this, &ColorSensor::getReading, .01);
+
+ }
+
+ int ColorSensor::getRed()
+ {
+ return countR;
+ }
+ int ColorSensor::getBlue()
+ {
+ return countB;
+ }
+ int ColorSensor::getGreen()
+ {
+ return countG;
+ }
+ void ColorSensor::incCount()
+ {
+ counter++;
+ }
+ void ColorSensor::getReading()
+ {
+
+ flag++;
+ if(flag == 1)
+ {
+ countR = counter;
+ s2.write(1);
+ s3.write(1);
+ }
+ else if(flag == 2)
+ {
+ countG = counter;
+ s2.write(0);
+ s3.write(1);
+ }
+ else if(flag ==3)
+ {
+ countB = counter;
+ s2.write(0);
+ s3.write(0);
+ }
+ else if(flag == 4)
+ {
+ flag = 0;
+ }
+ counter = 0;
+
+ }
+
+
+ void ColorSensor::poll()
+ {
+
+ ColorSensor::getReading();
+
+ }
+
+
\ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/color.h Thu Jun 24 15:11:30 2021 +0000
@@ -0,0 +1,30 @@
+
+class ColorSensor{
+ public:
+ ColorSensor(PinName ss0, PinName ss1, PinName ss2, PinName ss3, PinName sout);
+ DigitalOut s0;
+ DigitalOut s1;
+ DigitalOut s2;
+ DigitalOut s3;
+ InterruptIn _out;
+ Ticker ts;
+ void poll();
+ int interrupted;
+ int countR;
+ int countG;
+ int countB;
+ int counter;
+ int flag;
+ int getRed();
+ int getGreen();
+ int getBlue();
+ void getReading();
+ void incCount();
+
+ private:
+
+
+ protected:
+
+
+ };
\ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/main.cpp Thu Jun 24 15:11:30 2021 +0000
@@ -0,0 +1,227 @@
+/* mbed Microcontroller Library
+ * Copyright (c) 2019 ARM Limited
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+#include "mbed.h"
+#include "platform/mbed_thread.h"
+#include "Servo.h"
+#include "color.h"
+#include <string>
+#include <MQTTClientMbedOs.h>
+
+// Blinking rate in milliseconds
+#define BLINKING_RATE_MS 500
+
+Servo servo0(D3);
+Servo servo1(D4);
+InterruptIn button(USER_BUTTON);
+int arrivedcount = 0;
+TCPSocket socket;
+MQTTClient client(&socket);
+MQTT::Message message;
+int button_pressed=0;
+char* topic_pub = "PMK-client-temperature";
+char* topic_sub = "PMK_industrija/micro2/#";
+
+WiFiInterface *wifi;
+volatile int mems_event = 0;
+uint32_t previous_tick = 0;
+uint32_t current_tick = 0;
+uint8_t high = 0, low = 0;
+float temperature = 0.0f;
+char buffer[32];
+static char *print_double(char *str, double v, int decimalDigits = 2)
+{
+ int i = 1;
+ int intPart, fractPart;
+ int len;
+ char *ptr;
+
+ /* prepare decimal digits multiplicator */
+ for (; decimalDigits != 0; i *= 10, decimalDigits--);
+
+ /* calculate integer & fractinal parts */
+ intPart = (int)v;
+ fractPart = (int)((v - (double)(int)v) * i);
+
+ /* fill in integer part */
+ sprintf(str, "%i.", intPart);
+
+ /* prepare fill in of fractional part */
+ len = strlen(str);
+ ptr = &str[len];
+
+ /* fill in leading fractional zeros */
+ for (i /= 10; i > 1; i /= 10, ptr++) {
+ if (fractPart >= i) {
+ break;
+ }
+ *ptr = '0';
+ }
+
+ /* fill in (rest of) fractional part */
+ sprintf(ptr, "%i", fractPart);
+
+ return str;
+}
+
+const char *sec2str(nsapi_security_t sec)
+{
+ switch (sec) {
+ case NSAPI_SECURITY_NONE:
+ return "None";
+ case NSAPI_SECURITY_WEP:
+ return "WEP";
+ case NSAPI_SECURITY_WPA:
+ return "WPA";
+ case NSAPI_SECURITY_WPA2:
+ return "WPA2";
+ case NSAPI_SECURITY_WPA_WPA2:
+ return "WPA/WPA2";
+ case NSAPI_SECURITY_UNKNOWN:
+ default:
+ return "Unknown";
+ }
+}
+
+int scan_demo(WiFiInterface *wifi)
+{
+ WiFiAccessPoint *ap;
+ printf("Scan:\n");
+ int count = wifi->scan(NULL,0);
+ if (count <= 0) {
+ printf("scan() failed with return value: %d\n", count);
+ return 0;
+ }
+ /* Limit number of network arbitrary to 15 */
+ count = count < 15 ? count : 15;
+ ap = new WiFiAccessPoint[count];
+ count = wifi->scan(ap, count);
+ if (count <= 0) {
+ printf("scan() failed with return value: %d\n", count);
+ return 0;
+ }
+ for (int i = 0; i < count; i++) {
+ printf("Network: %s secured: %s BSSID: %hhX:%hhX:%hhX:%hhx:%hhx:%hhx RSSI: %hhd Ch: %hhd\n", ap[i].get_ssid(),
+ sec2str(ap[i].get_security()), ap[i].get_bssid()[0], ap[i].get_bssid()[1], ap[i].get_bssid()[2],
+ ap[i].get_bssid()[3], ap[i].get_bssid()[4], ap[i].get_bssid()[5], ap[i].get_rssi(), ap[i].get_channel());
+ }
+ printf("%d networks available.\n", count);
+ delete[] ap;
+ return count;
+}
+
+void messageArrived(MQTT::MessageData& md)
+{
+ MQTTString &topic = md.topicName;
+ string topic_name = topic.lenstring.data;
+ printf("Topic name %d : %s\r\n",topic.lenstring.len,topic_name.c_str() );
+ MQTT::Message &message = md.message;
+ printf("Message arrived: qos %d, retained %d, dup %d, packetid %d\r\n", message.qos, message.retained, message.dup, message.id);
+ printf("Payload %.*s\r\n", message.payloadlen, (char*)message.payload);
+ char* poruka = (char*)message.payload;
+ if(topic_name.find("servo0")!=std::string::npos) {
+ printf("blblabla\n");
+ for(float p=0; p<1.0; p += 0.1) {
+ servo0 = p;
+
+ }
+ wait(2);
+ for(float p=1.0; p>0.0; p -= 0.1) {
+ servo0 = p;
+
+ }
+ }
+ ++arrivedcount;
+}
+
+
+void buttonFunction() {
+ button_pressed=1;
+}
+
+int main()
+{
+ // Initialise the digital pin LED1 as an output
+
+ ColorSensor cs(PA_5,PA_6,PA_7,PB_6,PC_7);
+ DigitalOut led(LED1);
+ servo0.calibrate(0.0005,90);
+ button.rise(&buttonFunction);
+ const char* hostname = "broker.mqttdashboard.com";
+ int port = 1883;
+
+ wifi = WiFiInterface::get_default_instance();
+ if (!wifi) {
+ printf("ERROR: No WiFiInterface found.\n");
+ return -1;
+ }
+
+ int count = scan_demo(wifi);
+ if (count == 0) {
+ printf("No WIFI APs found - can't continue further.\n");
+ return -1;
+ }
+
+ printf("\nConnecting to %s...\n", MBED_CONF_APP_WIFI_SSID);
+ int ret = wifi->connect(MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD, NSAPI_SECURITY_WPA_WPA2);
+ if (ret != 0) {
+ printf("\nConnection error: %d\n", ret);
+ return -1;
+ }
+
+ printf("Success\n\n");
+ printf("MAC: %s\n", wifi->get_mac_address());
+ printf("IP: %s\n", wifi->get_ip_address());
+ printf("Netmask: %s\n", wifi->get_netmask());
+ printf("Gateway: %s\n", wifi->get_gateway());
+ printf("RSSI: %d\n\n", wifi->get_rssi());
+
+ socket.open(wifi);
+ socket.connect(hostname, port);
+
+ int rc=0;
+
+ MQTTPacket_connectData data = MQTTPacket_connectData_initializer;
+ data.MQTTVersion = 3;
+ data.clientID.cstring = "PMK-client2";
+ //data.username.cstring = "testuser";
+ //data.password.cstring = "testpassword";
+
+ if ((rc = client.connect(data)) != 0)
+ printf("rc from MQTT connect is %d\r\n", rc);
+
+
+ if ((rc = client.subscribe(topic_sub, MQTT::QOS2, messageArrived)) != 0)
+ printf("rc from MQTT subscribe is %d\r\n", rc);
+
+
+
+ while (true) {
+ led = !led;
+ thread_sleep_for(BLINKING_RATE_MS);
+ if (button_pressed==1) {
+ button_pressed=0;
+ printf("Publishing data\r\n");
+ // QoS 0
+ char buf[100];
+ printf("r: %d", cs.getRed());
+
+ printf("g: %d", cs.getGreen());
+ printf("b: %d", cs.getBlue());
+ //sprintf(buf, "RGB: %7s C\r\n", print_double(buffer, cs.getRed()*100000000+cs.getGreen()*10000+cs.getBlue()));
+
+ //message.qos = MQTT::QOS0;
+ //message.retained = false;
+ //message.dup = false;
+ //message.payload = (void*)buf;
+ //message.payloadlen = strlen(buf)+1;
+ //client.publish(topic_pub, message);
+
+ }
+ printf("Yielding");
+ client.yield(1000);
+ printf(" -> Yielded\r\n");
+ }
+}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed-mqtt.lib Thu Jun 24 15:11:30 2021 +0000 @@ -0,0 +1,1 @@ +https://github.com/ARMmbed/mbed-mqtt/#2a83f4993401cca786e0843faeed82219ed9ae77
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed-os.lib Thu Jun 24 15:11:30 2021 +0000 @@ -0,0 +1,1 @@ +https://github.com/ARMmbed/mbed-os/#cf4f12a123c05fcae83fc56d76442015cb8a39e9
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/mbed_app.json Thu Jun 24 15:11:30 2021 +0000
@@ -0,0 +1,65 @@
+{
+ "config": {
+ "wifi-ssid": {
+ "help": "WiFi SSID",
+ "value": "\"rcopen\""
+ },
+ "wifi-password": {
+ "help": "WiFi Password",
+ "value": "\"12345678\""
+ }
+ },
+ "target_overrides": {
+ "*": {
+ "platform.stdio-convert-newlines": true
+ },
+ "NUCLEO_L476RG": {
+ "target.network-default-interface-type" : "WIFI",
+ "esp8266.tx" : "D8",
+ "esp8266.rx" : "D2",
+ "esp8266.provide-default" : true,
+ "drivers.uart-serial-rxbuf-size" : 1024,
+ "drivers.uart-serial-txbuf-size" : 1024
+ },
+ "NUCLEO_F746ZG": {
+ "target.network-default-interface-type" : "WIFI",
+ "esp8266.tx" : "D1",
+ "esp8266.rx" : "D0",
+ "esp8266.provide-default" : true,
+ "drivers.uart-serial-rxbuf-size" : 1024,
+ "drivers.uart-serial-txbuf-size" : 1024
+ },
+ "NUCLEO_L4R5ZI": {
+ "target.network-default-interface-type" : "WIFI",
+ "esp8266.tx" : "D1",
+ "esp8266.rx" : "D0",
+ "esp8266.provide-default" : true,
+ "drivers.uart-serial-rxbuf-size" : 1024,
+ "drivers.uart-serial-txbuf-size" : 1024
+ },
+ "NUCLEO_H743ZI2": {
+ "target.network-default-interface-type" : "WIFI",
+ "esp8266.tx" : "D1",
+ "esp8266.rx" : "D0",
+ "esp8266.provide-default" : true,
+ "drivers.uart-serial-rxbuf-size" : 1024,
+ "drivers.uart-serial-txbuf-size" : 1024
+ },
+ "NUCLEO_F103RB": {
+ "target.network-default-interface-type" : "WIFI",
+ "esp8266.tx" : "D8",
+ "esp8266.rx" : "D2",
+ "esp8266.provide-default" : true,
+ "drivers.uart-serial-rxbuf-size" : 1024,
+ "drivers.uart-serial-txbuf-size" : 1024
+ },
+ "NUCLEO_F401RE": {
+ "target.network-default-interface-type" : "WIFI",
+ "esp8266.tx" : "D8",
+ "esp8266.rx" : "D2",
+ "esp8266.provide-default" : true,
+ "drivers.uart-serial-rxbuf-size" : 1024,
+ "drivers.uart-serial-txbuf-size" : 1024
+ }
+ }
+}
Binary file resources/official_armmbed_example_badge.png has changed