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.
Revision 0:339d1e10c98b, committed 2020-12-04
- Comitter:
- 10782824
- Date:
- Fri Dec 04 15:50:51 2020 +0000
- Commit message:
- Thermister, DR and POT included;
Changed in this revision
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/.gitignore Fri Dec 04 15:50:51 2020 +0000 @@ -0,0 +1,4 @@ +.build +.mbed +projectfiles +*.py*
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/CONTRIBUTING.md Fri Dec 04 15:50:51 2020 +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 Fri Dec 04 15:50:51 2020 +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/main.cpp Fri Dec 04 15:50:51 2020 +0000
@@ -0,0 +1,91 @@
+/* mbed Microcontroller Library
+ * Copyright (c) 2019 ARM Limited
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+#include "mbed.h"
+#include "platform/mbed_thread.h"
+#include "stdio.h"
+/* Reference resistor in series with the thermistor is of 10 KOhm */
+#define R_REFERENCE (float)(10000)
+/* Beta constant of this thermistor is 3380 Kelvin. See the thermistor
+ (NCP18XH103F03RB) data sheet for more details. */
+#define B_CONSTANT (float)(3380)
+/* Resistance of the thermistor is 10K at 25 degrees C (from data sheet)
+ Therefore R0 = 10000 Ohm, and T0 = 298.15 Kelvin, which gives
+ R_INFINITY = R0 e^(-B_CONSTANT / T0) = 0.1192855 */
+#define R_INFINITY (float)(0.1192855)
+/* Zero Kelvin in degree C */
+#define ABSOLUTE_ZERO (float)(-273.15)
+//static DigitalIn thermVDD(P10_0); // if wing is detached and powered from 3.3v
+//static DigitalIn thermGND(P10_3); // don't need to control power to thermistor
+
+
+// Blinking rate in milliseconds
+#define BLINKING_RATE_MS 500
+// #define SW2 P0_4
+// #define SW3 P12_3
+
+char buffer[80];
+/* prototype of function */
+void displayAt( int x, int y, char *buffer );
+
+int main()
+{
+ // Initialise the digital pin LED1 as an output
+// DigitalOut led(LED1);
+// DigitalIn pushButton(SW2, PullUp);
+ AnalogIn vTherm(P10_1); //Input pin of Thermister potential divider
+ AnalogIn lightLevel(P10_4); //
+ DigitalOut redLed2 (P10_5);
+ DigitalOut greenLed (P10_0);
+ DigitalOut yellowLed (P0_5);
+ DigitalIn switch3 (P12_3);
+ AnalogIn pot (P10_2);
+
+ printf("\033[2J\033[H"); // clear screen and move the cursor to 0, 0
+ printf("\033[?25l"); // Turn off visible cursor
+ printf("Environmental Control System");
+// printf( "\033[34m" );
+ fflush(stdout); // send the codes to the terminal
+
+ while (true) {
+ if (switch3 == 1)
+ redLed2 = !redLed2;
+
+ float potValue = pot.read();
+ if (potValue < 0.3)
+ greenLed = !greenLed;
+
+ if (potValue > 0.7)
+ yellowLed = !yellowLed;
+ // thread_sleep_for(BLINKING_RATE_MS);
+/* if (pushButton == 0) {
+ led = !led;
+ // read thermistor Voltage
+ float refVoltage = vTherm.read() * 2.4; // Range of ADC 0->2*Vref
+ float refCurrent = refVoltage / 10000.0; // 10k Reference Resistor
+ float thermVoltage = 3.3 - refVoltage; // Assume supply voltage is 3.3v
+ float thermResistance = thermVoltage / refCurrent;
+ float logrT = (float32_t)log((float64_t)thermResistance);
+
+ // Calculate temperature from the resistance of thermistor using Steinhart-Hart Equation
+ float stEqn = (float32_t)((0.0009032679) + ((0.000248772) * logrT) +
+ ((2.041094E-07) * pow((float64)logrT, (float32)3)));
+
+ float temperatureC = (float32_t)(((1.0 / stEqn) - 273.15) + 0.5);
+
+ sprintf(buffer, "Temperature is %2.1f\r\n", temperatureC);
+ displayAt(0, 3, buffer);
+
+ float lightPercent = ( 1 - lightLevel.read()) * 100;
+ sprintf( buffer, "Ambient Light is: %3.1f", lightPercent );
+ displayAt(1, 4, buffer);
+ thread_sleep_for(BLINKING_RATE_MS); */
+ }
+}
+
+void displayAt( int x, int y, char *buffer ) {
+ printf( "\033[%d;%dH%s", y, x, buffer);
+ fflush(stdout);
+ }
\ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed-os.lib Fri Dec 04 15:50:51 2020 +0000 @@ -0,0 +1,1 @@ +https://github.com/ARMmbed/mbed-os/#cf4f12a123c05fcae83fc56d76442015cb8a39e9
Binary file resources/official_armmbed_example_badge.png has changed