LU-DSP-b
Īssaites: Kalendārs | Uzdevumi | Resursi | Šodiena: 01.11.24 : Rītdiena: 2.11.24 (ja ir lekcija)
Digitālā (ciparu) signālu apstrāde
LU DF bakalauru kurss.
- Pasniedzējs Leo Seļāvo [vards.uzvards @gmail.com].
Mērķi
- Iepazīties ar Digitālās Signālu Apstrādes pielietojumiem un principiem. Praktiskas darbības ar signālu apstrādi. Sistēmu Matlab un Octave iepazīšana un programmēšana tajās.
Motivācija
"Think how electronics has changed the world in the last 50 years. DSP will have the same role over the next 50 years. Learn it or be left behind!" - Steve Smith, autors "DSP Guide"
Mājas darbi un citi iesniedzamie darbi
- Iesniegšanas termiņa laiks ir 30 minūtes pirms nākamās lekcijas sākuma, ja netiek noteikts cits termiņš.
- Ja darbs tiek iesniegts ar novēlošanos, rezultāts tiek samazināts par 50%. Ja darbs iesniegts vairāk kā nedēļu pēc termiņa, pasniedzējs darbu var nepieņemt.
- Darbi iesniedzami elektroniski, E-studijās, izņemot ja prasīts cits iesniegšanas veids.
- Teksts noformējams PDF faila formātā. Piemēram MD2 fails būtu sekojošs: DSP_MD2_Vards_Uzvards.pdf
- Ja iesniedzami vairāk par vienu failu, tie arhivējami ZIP formātā, sekojoši: DSP_MD2_Vards_Uzvards.zip Atspiežot šo failu tam jārada direktorija ar tādu pašu nosaukumu, kur atrodas visi faili.
Vērtējums kursā
Kursa galējais vērtējums sastāv no sekojošām komponentēm:
- 10% - dalība lekcijās un diskusijās
- 20% - mājas darbi, praktiskie darbi un testi
- 20+20% - divi kontroldarbi semestra vidū
- 30% - rakstisks gala eksāmens
- Obligāta kursa aptaujas anketas aizpildīšana LUIS sistēmā
Kalendārs
Datums | Tēma, saturs | Uzdevumi | |
---|---|---|---|
12.02.21 |
Lasāmviela un resursi:
|
||
19.02.21 |
Lasāmviela un resursi:
|
| |
26.02.21 |
|
| |
05.03.21 |
Apskatam sitēmas f(x)=2*x, g(x)=x+5 un m(x)=x*x. Pārbaudam vai tās ir lineāras sistēmas. Lasāmviela un resursi: |
| |
12.03.21 |
Lasāmviela un resursi: |
||
19.03.21 |
Vidus semestra kontroldarbs KD-1. Lasāmviela un resursi:
|
| |
26.03.21 |
Digitālie filtri, kustīgā vidējā (moving average) filtrs. Lasāmviela un resursi:
|
| |
02.04.21 |
Brīvlaiks |
||
09.04.21 |
Praktiskā nodarbība. Izmantojot Octave, konstruēt algoritmu, kas apstrādā audio failu.
Resursi:
|
||
16.04.21 |
Audio uztvere in apstrāde Lasāmviela un resursi: |
| |
23.04.21 |
Attēlu uztvere un apstrāde Lasāmviela un resursi: |
| |
30.04.21 |
Praktiskā nodarbība. Attēlu apstrāde. |
| |
07.05.21 |
Vidus semestra kontroldarbs KD2
|
KD2 - pieejams no e-Studijām. | |
14.05.21 |
Lasāmviela un resursi:
|
| |
21.05.21 |
Pratiskais darbs: Izmantojot Octave, izveidot Short-time DFT jeb spektrogrammu runas signālam.
|
||
28.05.21 |
Lasāmviela un resursi: |
||
04.06.21 |
Lasāmviela un resursi:
|
||
10.06.21 |
|
Uzdevumi
MD1
Analizēt nejaušu skaitļu (RND) un to summas histogrammu sekojošiem gadījumiem:
- RND
- RND + RND
- RND + RND + RND + RND
Pētījumu veikt vismaz 100000 nejaušiem skaitļiem.
Ar RND saprotam funkciju, kas katrā izsaukumā atgriež nejaušu skaitli no 0 līdz 1.0.
Katram no iepriekš minētajiem gadījumiem uzrakstīt programmu, kas izrēķina un uzzīmē histogrammu.
Programmu ieteicams rakstīt Octave vidē, bet šoreiz atļauts arī kādā citā jums pazīstamā valodā.
E-studijās kā MD1 iesniegt PDF failu ar risinājumu, kurā katram no gadījumiem doti:
- Programma, kas ģenerē histogrammu
- Histogramma
- Secinājumi, kas sanāca, un kāpēc tā.
MD_Octave
Mērķis: Apgūt un praktizēties Octave vides un valodas lietošanā.
Uzdevums
Atrisināt Octave vidē sekojošus uzdevumus:
1. Izdomāt īsu bet efektīvu Octave komandu, kas izveido sekojošu matricu A:
1 3 5 7 9 11 1 4 9 16 25 36 4 8 16 32 64 128
2. Izdomāt tādas matricas B, C un D, lai tās reizinot ar A iegūst sekojošo:
- A * B = ( A kolonnu 2 un 5 summa )
- C * A = ( A matricas otrā rinda )
- D * A = ( A matrica kurā 1 un 2 rindas ir samainītas vietām )
3. Izdomāt vektora matricas S, T, V un W tādas, lai to reizinājumi būtu sekojoši:
- S * T =
1 2 3 1 2 3
- V * W =
1 1 2 2 3 3
Ieteikumi
- Risinājumus saglabāt failā md_octave.m
- Octave skriptus (faila-vārds.m failus) var darbināt ar
run faila-vārds.m
- Lai rakstītu komentārus, Octave valodā jālieto
%
rindas sākumā - Kāpināšanas operatori ir
^
un.^
- Transponēšanas operācija ir
.'
- Vektora matrica ir vienas dimensijas matrica, piemēram, ar tikai vienu kolonnu vai tikai vienu rindu.
Iesniegt
Risinājumu (md_octave.m failu) iesniegt estudijās MD_Octave sadaļā. Risinājuma failā jābūt komentētam skriptam, kas definē visas matricas A, B, C, D, S, T, V un W.
MD_Audio
Izmantojot Octave, konstruēt algoritmu, kas izgriež pauzes runas signālam.
Skaņas faili, piemēram:
Darbības plāns:
- Ielasīt audio failu
- Izveidot filtra kodolu lai nofiltrētu augstfrekvenču troksni, "pīķus" signālā, it īpaši paužu laikā
- pielietot šo filtru izmantojot konvolūciju
- uzlikt slieksni filtrētajam audio signālam: pauzes uz 0, pārējais uz 1.
- kombinējot oriģinālo un filtrēto signālus, konstruēt jaunu signālu bez pauzēm.
Ieteikumi
- Risinājumus saglabāt failā md_audio.m
- Rakstiet kodā arī komentārus
- Audio failu var ielasīt no faila un rakstīt failā ar komandām
audioread
unaudiowrite
- Vairāk informāciju par komandām var uzzināt ar
help nezināmā-komanda
Iesniegt
Risinājumu (md_audio.m failu) iesniegt estudijās MD_Audio sadaļā.
MD_Synth
Izmantojot Octave, uzrakstīt funkcijas vairākiem skaņas efektiem.
Turpmākajos uzdevumos:
- 'sample' ir skaņas matrica (viena kolonna ar mērījumiem - "samples"). Līdzīgi kā lasīts ar audioread, bet viens kanāls.
- 'fs' ir sample-rate, piemēram 44100.
- 'length' ir skaņas ilgums, sekundēs
Uzdevumi
- Izgriež 1 sekundi no skaņas
- Funkcija
onesec(sample, fs)
- kas atgriež vektora matricu kas veidota no 'sample'
- Funkcija
- Nospēlēt oktāvu: 8 skaņas no Do līdz Do, katru noti 0.25 sekundes ilgi.
- Funkcija
oneoctave(fs)
- kas atgriež matricu ar skaņu.
- Funkcija
- Atskaņot skaņu kas sastāv no 3 sinusoīdām ar maināmu frekvenci un amplitūdu
- Funkcija
sine3(f1, f2, f3, a1, a2, a3, fs, length)
- kurf*
ir frekvences una*
ir amplitūdas.
- Funkcija
- Piemērot ADSR skaņas avotam, piemēram, sinusoīdai
- Funkcija
adsr(sample, fs, attack, decay, sustain, release)
- kas pielieto ADSR "envelope" effektu signālam. "a,d,s,r" parametru summai jābūt 1.
- Funkcija
- Izveidot sintētiskās skaņas instrumentu, pēc savas radošās izvēles.
- Funkcija
mysynth(freq, fs)
- kas ņem vērā pamata frekvenci freq efektam un atgriež skaņas matricu. Matricas garums atkarīgs no jūsu efekta garuma.
- Funkcija
Resursi
- Envelope, ADSR
- Digital sound and music - sadaļa 6.7.1 - par skaņas sintēzi.
- Ģenerēto skaņu iespējams rakstīt audio failā ar audiowrite funkciju.
- Skaņu iespējams atspēlēt arī no Octave. Sīkāk skat
help audioplayer
Iesniegt
- md_synth.m failu ar visām funkcijām
- Estudijās, MD_Synth sadaļā.
Piemēri
Piemērs, kurā tiek ģenerēts 1 sekundi garš mazās oktāvas La signāls un saglabāts kā skaņas fails
// Example, La=220Hz, 1 second fs = 44100; freq = 220; samples_per_period = fs/freq; step = 2*pi / samples_per_period; limit = fs/step; t = 0: step: limit; s = sin(t); stereo = [s', s'] audiowrite ("la.ogg", stereo, fs);
Alternatīvs risinājums šim pašam uzdevumam
fs = 44100; freq = 220; t = linspace(0, 1, fs); s = sin( t * 2*pi * freq ); stereo = [s', s'];
Veids, kā spēlēt signālu no Octave:
player = audioplayer (stereo, 44100, 8); play (player);
MD_Image
Izmantojot Octave, uzrakstīt funkcijas attēlu apstrādei.
Turpmākajos uzdevumos:
- 'path' ir taciņa uz skaņas failu, iekļaujot faila vārdu.
- 'img' ir 2d matrica ar (bezkrāsainu) attēlu. Katra vērtība ir vesels skaitlis no 0 līdz 255.
- 'colorimg' ir matrica ar krāsainu RGB attēlu, līdzīgi ka IMG daļa no imread() funkcijas
Uzdevumi
- Ielasīt attēlu no faila (piemēram picture.jpg) un atgriezt 2D matricu ar melnbaltu attēlu.
- Funkcija
file2gray(path)
- kas atgriež matricu ar attēlu, ko var rādīt ar imshow().
- Funkcija
- Pielietot 2D konvolūciju attēlam. Funkcijai jāatgriež apstrādātais attēls.
- Funkcija
filter1(img, kernel)
- kas atgriež matricu ar attēlu, ko var rādīt ar imshow().
- Funkcija
- Pārbaudīt filtra kodolu. Ko dara sekojošais filtra kodols? Uzrakstīt funkciju kas to pārbauda, un komentāros aprakstīt rezultātu.
- Funkcija
test3(img)
- kas atgriež matricu ar attēlu pēc tā apstrādes ar sekojošu filtra kodolu h: h = [4 3 2; 1 0 -1; -2 -3 -4]
- Funkcija
- Atrast filtru, kas veic sekojošu uzdevumu: iezīmē attēla kontūras.
- Funkcija
edgifyer(img)
- kurimg
ir frekvences una*
ir amplitūdas.
- Funkcija
- Atrast filtru, kas veic sekojošu uzdevumu: izveido attēla "negatīvu", ņemot vērā krāsas piemērs negatīvam attēlam.
- Funkcija
negimage(colorimg)
- kurimg
ir frekvences una*
ir amplitūdas.
- Funkcija
Resursi
- Funkcijas attēlu lasīšanai un rakstīšanai failos: imread(), imwrite()
- Funkcija attēlu rādīšanai uz ekrāna: imshow()
- 2D konvolūciju var veikt ar conv2() funkciju. Ņemiet vērā, ka tai ir trešais parametrs, ar kuru var norādīt kā rīkoties robežgadījumos. "same" ir variants kā paturēt rezultējošās matricas izmērus tādus pat kā sākotnējai.
- Ņemiet vērā, ka ielasot attēlu no faila tam var būt triju krāsu komponentes RGB. Apstrādājot ar conv2() nepieciešams vai no to darīt katrai krāsai atsevišķi, vai melnbaltā režīmā. Te var noderēt funkcija rgb2gray()
- Ņemiet vērā, ka imshow() funkcija sagaida attēla matricas elementus
- robežās no 0 līdz 255 ja tiem ir uint8 tips, vai
- robežās no 0.0 līdz 1.0, ja tie ir double.
Iesniegt
- md_image.m failu ar visām funkcijām
- Estudijās, MD_Image sadaļā.
Piemēri
Piemērs, kurā tiek lasīts krāsains un attēlots attēls kā melnbalts
[im, map, alpha] = imread ("lowres1.jpg"); r = im(:,:,1); g = im(:,:,2); b = im(:,:,3); y = 0.299 * r + 0.587 * g + 0.114 * b; imshow (y)
Piemērs, kā konvertēt 2D matricu b uz tipu, ko sapratis imshow() - pie nosacījuma ka elementu vērtības ir starp 0..255
a = uint8(b) imshow(a)
Resursi
Kursa materiāli
- DSP Guide gramata tiešsaistē
- "The Scientist and Engineer's Guide to Digital Signal Processing, copyright ©1997-1998 by Steven W. Smith. For more information visit the book's website at: www.DSPguide.com"
Furjē transformācija
- Ievada video
- Furjē transformācijas vizualizācija
- lekcija par Inverso FT (1.daļa)
- lekcija par FT (2.daļa)
FIR & IIR
Citi resursi
- Signals and Systems - kurss Berkeley universitātē
- Learning DSP illustrated
- Lineāras laika invariantas sistēmas @Brilliant wiki
- Laika invariantas sistēmas - videolekcija ar pierādījumu piemēriem.
- Attēlu filtru kodoli - vizuāls skaidrojums