Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[2022] Balansero #3

Open
wants to merge 26 commits into
base: master
Choose a base branch
from
Open

[2022] Balansero #3

wants to merge 26 commits into from

Conversation

apantelic
Copy link
Collaborator

No description provided.

@apantelic apantelic requested a review from a team as a code owner October 7, 2022 23:35
@apantelic apantelic requested a review from a team October 7, 2022 23:35
@KockaAdmiralac KockaAdmiralac requested a review from znjRoLS October 7, 2022 23:36
@cloudflare-workers-and-pages
Copy link

cloudflare-workers-and-pages bot commented Oct 7, 2022

Deploying with  Cloudflare Pages  Cloudflare Pages

Latest commit: 5a13607
Status: ✅  Deploy successful!
Preview URL: https://1e07ba0f.pfe-izvestaji.pages.dev
Branch Preview URL: https://2022-balansero.pfe-izvestaji.pages.dev

View logs

content/2022/balansero.md Outdated Show resolved Hide resolved
@KockaAdmiralac KockaAdmiralac changed the title Metode skoro gotove [2022] Balansero Oct 10, 2022
##### *Od aparature koristile smo:*

-**IMU** (Inercijalni navigacioni sistem MPU6050) senzor koji meri ugao nagiba i ugaonu brzinu koristeći
kombinaciju akcelerometara i žiroskopa. U njemu postoji I2C kolo koje služi za komunikaciju između senzora i mikrokontrolera. IMU se nalazi na dnu robota kako bi se postigla precizna rezolucija za merenje nagibnog ugla robota.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

IMU se nalazi na dnu robota kako bi se postigla precizna rezolucija za merenje nagibnog ugla robota.

Za ovakvu tvrdnju je potrebno dodatno obrazloženje ili referenca ka nekom radu koji se time bavio.


-**Mikrokontroler (Arduino Uno)** očitava izmereni ugao i brzinu sa senzora i očitava
rotacionu brzinu točkova sa enkodera. Vrši obradu signala (pretvara signal iz analognog u
digitalni) i nakon dobijanja svih varijabli, kontroliše ugaonu brzinu točkova pomoću dva PWM signala.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ovo vam je srž metoda za hardver, treba mnogo detaljnije da se opiše u metodu (sledeći odeljak).

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ja bih navođenje aparature stavio u uvod, u kome opisujete i sve pojmove sa kojima čitalac treba da se upozna pre obrazloženja metode.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Aparatura može da ode u dodatnu sekciju

>**Komplemetarni filter** je vrsta filtra
koja kombinuje merenja više senzora u unapred
određenim proporcijama. Prvo se računaju uglovi koji daju samo akcelerometar i žiroskop.
![filter](images\2022\balansero\komplementarni.png)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Dijagrame bi idealno bilo da otpremite u SVG formatu, a ako već nisu, barem da imaju transparentnu pozadinu.

@filiparag filiparag added the 2022 Projekti starih polaznika rađeni 2022. godine label Oct 16, 2022
@filiparag filiparag marked this pull request as draft October 16, 2022 20:26

## Grafički apstrakt

<p align="left">
Copy link

@znjRoLS znjRoLS Nov 15, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Dodajte slike kao sto su dodata u uputstvu. Primer:

![Tekst slike.](/images/2022/balansero/graficki%20prikaz.jpg)

Mozete videti kod uputstva ovde: https://raw.githubusercontent.com/pfe-rs/izvestaji/master/content/uputstvo.md

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Izmenio sam Roškov komentar iznad da se prikaže tačna sintaksa za Markdown sliku. Takođe, grafički apstrakt treba da bude u SVG formatu ukoliko je moguće, kao što ovde koliko vidim jeste.

Samobalansirajući robot predstavlja stabilizaciju dinamičkog sistema koji radi po principu inverznog klatna. Ovakvi roboti koriste sistem upravljanja povratnom spregom u zatvorenoj petlji - podaci iz senzora pokreta u realnom vremenu se koriste za kontrolu motora i brzu kompenzaciju promene ugla kako bi se robot održao uspravno.
Cilj ovog projekta je da se modelira, simulira i implementira samobalansirajući robot.

##### *Potrebna aparatura:*
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ovaj odeljak ne treba da bude deo Uvoda nego Aparature


-**Arduino** očitava izmereni ugao i brzinu sa senzora i očitava
rotacionu brzinu točkova sa enkodera. Vrši obradu signala (pretvara signal iz analognog u
digitalni) i nakon dobijanja svih varijabli, kontroliše ugaonu brzinu točkova pomoću dva PWM signala.
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Opisite bolje kako se dobija kontrolni signal od ulaznih signala.


Za projektovanje upravljanja koriste se [filtri](https://sr.wikipedia.org/wiki/Elektronski_filtar/) u cilju dobijanja što preciznijih rezultata.

**Komplemetarni filtar** je vrsta filtra koja kombinuje merenja više senzora u unapred određenim proporcijama. Prvo se računaju uglovi koji daju samo akcelerometar i žiroskop.
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Mozda da prepakujete ovo da prvo objasnite sta su niskofrekventni filtar i da ste ga koristili za podatke sa akcelerometra, pa visokofrekventni i ziroskop, pa onda komplementarni


### Kontroleri

U trenutku kada robota izvedemo iz ravnotenog položaja, on će pasti na stranu na koju je otklonjen, osim ako neka sila ne počne da deluje na robota u suprotnom smeru kako bi smanjila ugao otklona. Sila koja robota vraća u ravnotežni položaj je inercijalna sila izazvana radom motora, tj njegovim okretanjem točkova. Da bi se robot stabilizovao vrši se implementacija kontrolera.
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

otkud inercijalna sila?

<img src="https://github.com/pfe-rs/izvestaji/blob/radna_verzija/static/images/2022/balansero/pid%20kontroler.png" width="350">
</p>

PID kontroler je stabilizator koji se sastoji iz tri zasebna kontrolera - P (proporcionalni), I (integralni) i D (derivacioni tj. izvodni) kontroler. Oni primaju grešku na ulazu, a na izlazu daju napon koji se šalje na motor i time kontroliše robot.
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Objasnite PID kontroler malo bolje, kako se ponasa sistem ako probamo samo P da koristimo, kako ako koristimo samo PD.... i tako dalje

<img src="https://github.com/pfe-rs/izvestaji/blob/radna_verzija/static/images/2022/balansero/pid-blocks.png" width="450">
</p>

Prvi (C1) dobija vrednosti o veličini ugla robota i potom računa njegovu grešku. Drugi (C2) određuje potrebnu ugaonu brzinu, a treći (C3) - postavlja C3 na željenu poziciju.
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ne "postavlja C3" nego postavlja referentnu poziciju koja se koristi za racunanje greske ugla, ili tako nesto

Balansirajući robot je imao poteškoća pri stabilizaciji zbog previše velikog šuma usled jakog potresanja osovine robota koje je prouzrokovao motor. Senzori nisu mogli da dovoljno dobro očitaju grešku čak i pored filtera, te kontroler nije davao dobre izlaze dovoljno brzo.


## Reference
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Naravno, dodajte reference...

Copy link
Member

@KockaAdmiralac KockaAdmiralac left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Komentari u vezi sa formatom izveštaja.

Comment on lines +10 to +18
## Sadržaj

1. Apstrakt
2. Grafički apstrakt
2. Uvod
3. Aparatura
4. Metode
5. Istraživanje i rezultati
6. Zaključak
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Odeljak sa sadržajem je nepotreban. Ukoliko odlučimo da imamo sadržaj, napravićemo da se automatski generiše na neki način.


## Grafički apstrakt

<p align="left">
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Izmenio sam Roškov komentar iznad da se prikaže tačna sintaksa za Markdown sliku. Takođe, grafički apstrakt treba da bude u SVG formatu ukoliko je moguće, kao što ovde koliko vidim jeste.

Samobalansirajući robot predstavlja stabilizaciju dinamičkog sistema koji radi po principu inverznog klatna. Ovakvi roboti koriste sistem upravljanja povratnom spregom u zatvorenoj petlji - podaci iz senzora pokreta u realnom vremenu se koriste za kontrolu motora i brzu kompenzaciju promene ugla kako bi se robot održao uspravno.
Cilj ovog projekta je da se modelira, simulira i implementira samobalansirajući robot.

##### *Potrebna aparatura:*
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Zaglavlje petog nivoa ne sme da ide ispod zaglavlja drugog, posle drugog nivoa može eventualno zaglavlje trećeg nivoa da ide. Nemojte da ređate # kao način kontrole fonta, jer se zaglavlja koriste za logičku podelu dokumenta po poglavljima. Takođe, izbaciti kurziv i dvotačku na kraju.

Comment on lines +36 to +56
-**Mikrokontroler _(Arduino Uno)_** koristi se za izradu interaktivnih prototipa. Ima 14 digitalnih ulazno/izlaznih p inova i 6 analognih ulaza. Radi na 5V i komunicira preko USB-porta.

-**IMU** (Inercijalni navigacioni sistem MPU6050) senzor koji meri ugao nagiba i ugaonu brzinu koristeći
kombinaciju akcelerometara i žiroskopa. U njemu postoji I2C kolo koje služi za komunikaciju između senzora i mikrokontrolera. IMU je postavljen na dno robota.

<p align="left">
<img src="https://github.com/pfe-rs/izvestaji/blob/radna_verzija/static/images/2022/balansero/mpu.jpg" width="350">
</p>


-**Roatacioni enkoder** je elektromehanički uređaj koji pretvara ugaoni položaj ili kretanje osovine u analogne tj. digitalne izlazne signale.


-**Arduino motor kontroler** (l298n) pomoću koga upravljamo motor

<p align="left">
<img src="https://github.com/pfe-rs/izvestaji/blob/radna_verzija/static/images/2022/balansero/l298n.jpg" width="350">
</p>

-**DC motor** (12V) sa jednom osovinom

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Markdown i slovne ispravke. Ono što nisam ovde ispravio je da slike treba da idu ispod liste, ne unutar nje.

Suggested change
-**Mikrokontroler _(Arduino Uno)_** koristi se za izradu interaktivnih prototipa. Ima 14 digitalnih ulazno/izlaznih p inova i 6 analognih ulaza. Radi na 5V i komunicira preko USB-porta.
-**IMU** (Inercijalni navigacioni sistem MPU6050) senzor koji meri ugao nagiba i ugaonu brzinu koristeći
kombinaciju akcelerometara i žiroskopa. U njemu postoji I2C kolo koje služi za komunikaciju između senzora i mikrokontrolera. IMU je postavljen na dno robota.
<p align="left">
<img src="https://github.com/pfe-rs/izvestaji/blob/radna_verzija/static/images/2022/balansero/mpu.jpg" width="350">
</p>
-**Roatacioni enkoder** je elektromehanički uređaj koji pretvara ugaoni položaj ili kretanje osovine u analogne tj. digitalne izlazne signale.
-**Arduino motor kontroler** (l298n) pomoću koga upravljamo motor
<p align="left">
<img src="https://github.com/pfe-rs/izvestaji/blob/radna_verzija/static/images/2022/balansero/l298n.jpg" width="350">
</p>
-**DC motor** (12V) sa jednom osovinom
- **Mikrokontroler** (_Arduino Uno_) koristi se za izradu interaktivnih prototipa. Ima 14 digitalnih ulazno/izlaznih pinova i 6 analognih ulaza. Radi na 5V i komunicira preko USB-porta.
- **IMU** (Inercijalni navigacioni sistem MPU6050) senzor koji meri ugao nagiba i ugaonu brzinu koristeći
kombinaciju akcelerometara i žiroskopa. U njemu postoji I2C kolo koje služi za komunikaciju između senzora i mikrokontrolera. IMU je postavljen na dno robota.
<p align="left">
<img src="https://github.com/pfe-rs/izvestaji/blob/radna_verzija/static/images/2022/balansero/mpu.jpg" width="350">
</p>
- **Rotacioni enkoder** je elektromehanički uređaj koji pretvara ugaoni položaj ili kretanje osovine u analogne tj. digitalne izlazne signale.
- **Arduino motor kontroler** (l298n) pomoću koga upravljamo motor
<p align="left">
<img src="https://github.com/pfe-rs/izvestaji/blob/radna_verzija/static/images/2022/balansero/l298n.jpg" width="350">
</p>
- **DC motor** (12V) sa jednom osovinom


-**Arduino** očitava izmereni ugao i brzinu sa senzora i očitava
rotacionu brzinu točkova sa enkodera. Vrši obradu signala (pretvara signal iz analognog u
digitalni) i nakon dobijanja svih varijabli, kontroliše ugaonu brzinu točkova pomoću dva PWM signala.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Varijable → promenljive.


U trenutku kada robota izvedemo iz ravnotenog položaja, on će pasti na stranu na koju je otklonjen, osim ako neka sila ne počne da deluje na robota u suprotnom smeru kako bi smanjila ugao otklona. Sila koja robota vraća u ravnotežni položaj je inercijalna sila izazvana radom motora, tj njegovim okretanjem točkova. Da bi se robot stabilizovao vrši se implementacija kontrolera.

- **FLC kontroler**
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ovo može da bude odeljak za sebe.

Suggested change
- **FLC kontroler**
#### FLC kontroler


_Fuzzy-logic_ kontroler je stabilizator koji se bavi algortimima koji simuliraju ljudsko razmišljanje i donošenje odluka. Radi po setu pravila po principu *ako – onda* (eng. *if – then*), koja se intuitivno određuju.

Kontroler prolazi kroz dve faze - fuzifikaciju i defuzifikaciju. U prvoj on prevodi veličinu greške (odstupanja trenutnog položaja od stabilnog, željenog položaja) sa točkova u fuzzy oblik. Fazifikovana vrednost greške se ubacuje u set prethodno određenih pravila. Neophodno je izračunati udeo te greške u svakom od pravila, a potom geometrijskom sredinom dobiti precizni izlazni rezultat. Taj proces nazivamo defuzifikacijom. Izlazna vrednost - napon, šalje se na motor, kontrolišu se točkovi - kreću se u određenom smeru i određenom ugaonom brzinom čime se postiže ispravljanje greške - robot balansira.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Na srpskom kažemo fazi logika.

Suggested change
Kontroler prolazi kroz dve faze - fuzifikaciju i defuzifikaciju. U prvoj on prevodi veličinu greške (odstupanja trenutnog položaja od stabilnog, željenog položaja) sa točkova u fuzzy oblik. Fazifikovana vrednost greške se ubacuje u set prethodno određenih pravila. Neophodno je izračunati udeo te greške u svakom od pravila, a potom geometrijskom sredinom dobiti precizni izlazni rezultat. Taj proces nazivamo defuzifikacijom. Izlazna vrednost - napon, šalje se na motor, kontrolišu se točkovi - kreću se u određenom smeru i određenom ugaonom brzinom čime se postiže ispravljanje greške - robot balansira.
Kontroler prolazi kroz dve faze - fazifikaciju i defazifikaciju. U prvoj on prevodi veličinu greške (odstupanja trenutnog položaja od stabilnog, željenog položaja) sa točkova u fazi oblik. Fazifikovana vrednost greške se ubacuje u skup prethodno određenih pravila. Neophodno je izračunati udeo te greške u svakom od pravila, a potom geometrijskom sredinom dobiti precizni izlazni rezultat. Taj proces nazivamo defazifikacijom. Izlazna vrednost - napon, šalje se na motor, kontrolišu se točkovi - kreću se u određenom smeru i određenom ugaonom brzinom čime se postiže ispravljanje greške - robot balansira.

FLC kontroler je implementiran u simulaciji.


- **PID kontroler**
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Isto kao iznad.

Suggested change
- **PID kontroler**
#### PID kontroler


PID kontroler je stabilizator koji se sastoji iz tri zasebna kontrolera - P (proporcionalni), I (integralni) i D (derivacioni tj. izvodni) kontroler. Oni primaju grešku na ulazu, a na izlazu daju napon koji se šalje na motor i time kontroliše robot.
Jednačina PID kontrolera je:

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Komentar koji ćete razrešiti kada dodate ovu jednačinu.

Jednačina PID kontrolera je:


## Istraživanje i rezultati
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ovde mi deluje da fali teksta da bih mogao da komentarišem išta oko formata odeljka. Razrešite komentar kad dodate teksta kako bih mogao da pogledam format ponovo.

@KockaAdmiralac KockaAdmiralac marked this pull request as ready for review November 20, 2022 18:12
@KockaAdmiralac KockaAdmiralac enabled auto-merge (squash) November 20, 2022 22:23
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
2022 Projekti starih polaznika rađeni 2022. godine
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants