TVZ2021 / Mbed OS generator_zvuka

Dependencies:   scale

Files at this revision

API Documentation at this revision

Comitter:
dhaldek
Date:
Fri Dec 17 11:46:06 2021 +0000
Commit message:
Generator zvuka promjenjive frekvencije

Changed in this revision

.gitignore Show annotated file Show diff for this revision Revisions of this file
CONTRIBUTING.md Show annotated file Show diff for this revision Revisions of this file
README.md Show annotated file Show diff for this revision Revisions of this file
main.cpp Show annotated file Show diff for this revision Revisions of this file
mbed-os.lib Show annotated file Show diff for this revision Revisions of this file
resources/official_armmbed_example_badge.png Show annotated file Show diff for this revision Revisions of this file
scale.lib Show annotated file Show diff for this revision Revisions of this file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/.gitignore	Fri Dec 17 11:46:06 2021 +0000
@@ -0,0 +1,4 @@
+.build
+.mbed
+projectfiles
+*.py*
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/CONTRIBUTING.md	Fri Dec 17 11:46:06 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	Fri Dec 17 11:46:06 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	Fri Dec 17 11:46:06 2021 +0000
@@ -0,0 +1,72 @@
+#include "mbed.h"
+#include "scale.h"                      //Library za linearno skaliranje ulaza
+
+char SegConvert(char SegValue) {        // funkcija 'SegConvert' za 7-segment display za brojanje jedinica
+ char SegByte=0x00; 
+ switch (SegValue) {                    //Binarni zapis radi lakseg predocenja izlaza na displayu
+ case 0 : SegByte = 0b00111111;break;   
+ case 1 : SegByte = 0b00000110;break;   
+ case 2 : SegByte = 0b01011011;break;   
+ case 3 : SegByte = 0b01001111;break;    
+ case 4 : SegByte = 0b01100110;break;    
+ case 5 : SegByte = 0b01101101;break;    
+ case 6 : SegByte = 0b01111101;break;    
+ case 7 : SegByte = 0b00000111;break;    
+ case 8 : SegByte = 0b01111111;break;    
+ case 9 : SegByte = 0b01101111;break;     
+ } 
+ return SegByte;                        //Vracanje odgovarajuce vrijednosti
+}
+
+char LEDConvert(char LEDValue) {        // funkcija 'SegConvert' za 3 LED diode za brojanje desetica
+ char LEDByte=0x00; 
+ switch (LEDValue) {                    //Binarni zapis radi lakseg predocenja izlaza na LED diodama
+ case 0 : LEDByte = 0b00000000;break;    
+ case 1 : LEDByte = 0b00000001;break;    
+ case 2 : LEDByte = 0b00000011;break;     
+ case 3 : LEDByte = 0b00000111;break;    
+ } 
+ return LEDByte;                        //Vracanje odgovarajuce vrijednosti
+}
+
+float freq;                             //Varijabla tipa "float" za spremanje realnih vrijednosti iz varijale "pot" za kasniju obradu
+int i;                                  //Varijabla tipa "int" za kasniju pretvorbu iz float u integer varijable "freq"(float) u "i"(integer)
+
+DigitalIn zout(D15);                    //Digitalni ulaz, pritiskom tipkala na D15 generira se zvuk odredjene frekvencije
+AnalogIn pot(A0);                       //Analogni ulaz potenciometra za namjestanje frekvencije zvuka
+PwmOut zvuk(D10);                       //Digitalni izlaz PWM za generiranje zvuka na zvucniku
+Ticker tocka;
+DigitalOut tocka_led(D6);               //Digitalni izlaz koji upravlja tockom na 7-segment displayu. Tocka treperi tijekom zvucnog signala
+
+void flip_tocka2(){                     //Funkcija za invertiranje stanja LED diode tocke(DP) na 7-segment displayu
+    tocka_led=!tocka_led;               //Invertiranje
+       }
+void sviraj(){                          //Funkcija koja prilikom izvrsavanja generira zvuk na zvucniku
+    zvuk=0.5;                           //Sirina periode signala od 50%
+    zvuk.period(1/(freq*100));          //Trajanje periode signala, frekvencija signala, x100 je iz razloga sto je korak namjestanja frekvencije 100 Hz
+    }
+
+BusOut Seg1(D3,D2,D7,D8,D9,D4,D5);      //Redoslijed skupa izlaznih pinova za 7-segment display
+BusOut LED(D11,D12,D13);                //Redoslijed skupa izlaznih pinova za 3-LED diode
+
+int main() {                            //Glavni program
+ tocka_led=0;                           //Postavljanje tocke, GP LED diode na nulu
+ zout.mode(PullUp);                     //U mirovanju, pin zout(D15) je u stanju HIGH
+ 
+ while (1) {                            //Trajno izvrsavanje programa do nestanka napajanja
+   freq=scale(pot, 0.0, 1.0, 1, 39);    //Skaliranje ulaza prema potrebi, u ovom slucaju od 1 do 39, daje mogucnost generiranja zvuka od 100 Hz do 3900 Hz okretanjem potenciometra
+   i=freq;                              //Pretvorba iz float u integer
+   Seg1=SegConvert(i%10);               //Zadnje dvije linije koda i ukljucujuci ovu su obrada vrijednosti potenciometra za prikaz jedinica na 7-segment displayu
+   LED=LEDConvert(i/10);                //Predzadnje dvije linije koda i ukljucujuci ovu su obrada vrijednosti potenciometra za prikaz desetica na 3 LED diode
+   if(zout==0){                         //Interrupt, pritiskom tipkala "zout"(D15) pocinje izvrsavanje koda za generiranje zvucnog signala
+    wait_us(50000);                     //Delay od 50ms zbog moguceg osciliranja stanja tipkala
+    tocka.attach(&flip_tocka2, 0.1);    //Pokretanje tickera za invertiranje tocke GP LED diode na 7-segment displayu prilikom zvucnog signala
+    sviraj();                           //Pokretanje funkcije za generiranje zvucnog signala
+    wait_us(3000000);                   //Delay od 3 sekunde koji odredjuje vrijeme zvucnog signala
+    tocka.detach();                     //Iskljucenje tickera
+    tocka_led=0;                        //Postavljanje GP LED diode na nulu
+    zvuk=0;                             //Prestanak generiranja zvucnog signala
+    }
+   wait_us(100000);                     //Delay od 100ms u glavnom dijelu programa, vrijeme osvjezavanja promjene na displayu
+ } 
+} 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mbed-os.lib	Fri Dec 17 11:46:06 2021 +0000
@@ -0,0 +1,1 @@
+https://github.com/ARMmbed/mbed-os/#cf4f12a123c05fcae83fc56d76442015cb8a39e9
Binary file resources/official_armmbed_example_badge.png has changed
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/scale.lib	Fri Dec 17 11:46:06 2021 +0000
@@ -0,0 +1,1 @@
+https://os.mbed.com/teams/TVZ2021/code/scale/#b89a80d42611