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: scale
Revision 0:14905a591b02, committed 2021-12-17
- Comitter:
- dhaldek
- Date:
- Fri Dec 17 11:46:06 2021 +0000
- Commit message:
- Generator zvuka promjenjive frekvencije
Changed in this revision
--- /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 @@ + +# 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