Wavelet-analyse av tidsvariable signaler
|
|
|
- Elsa Aase
- 8 år siden
- Visninger:
Transkript
1 FYS2130 Prosjektoppgave vår 2009, ved UiO Wavelet-analyse av tidsvariable signaler av kandidat nummer 43 1
2 Innholdsfortegnelse Innledning 3 Teori 4 Vurdering av ulike Morlet wavelets (Deloppgave 1) 6 Sammenhengen mellom skala og frekvens 11 Presisjon på frekvensoppløsningen og tidsoppløsningen 13 Et dataprogram for wavelet transform på intuitivt enkleste måte (Deloppgave 2) 16 Et mer effektivt dataprogram for wavelet transform (Deloppgave 3) 18 Analyse (Deloppgave 4) 22 Konklusjon 31 Vedlegg 1 - Dataprogrammet brukt i Deloppgave 1 32 Vedlegg 2 - Dataprogrammet brukt i Deloppgave 2 34 Vedlegg 3 - Dataprogrammet brukt i Deloppgave 3 36 Vedlegg 4 - Forklar kontinuerlig wavelet transform til en medstudent (Deloppgave 5) 39 2
3 Innledning I denne prosjektoppgaven blir wavelet-analyse introdusert og utforsket. Wavelet-analyse er en teknikk man kan bruke for å analysere mange forskjellige typer signaler; alt fra jordskjelv til finansiell informasjon til musikk. I denne rapporten skal jeg undersøke Morlet wavelets, lage et enkelt dataprogram for kontinuerlig wavelet transform, gjøre dette programmet mer effektivt ved hjelp av fourier transform og til slutt analysere diverse lydfiler. Programmet som er brukt for analysene er Matlab. 3
4 Teori Wavelet-analyse er en teknikk lignende fourier-analyse, men med forskjellige parametere. Fourieranalyse gjør om et signal fra å se på tidsutviklingen av det til å se på hvilke frekvenser det inneholder, mens wavelet-analyse er et 3D-plot der man ser på både tidsutviklingen og hvilke frekvenser hvert tidspunkt inneholder. Fordi fourier-transformen ikke inneholder et tidsperspektiv mister vi mye informasjon hvis signalet forandrer seg over tid. Fourier-transform er best når vi ser på et repeterende signal. Man kan tenke seg at det også er mulig å se på tidsutviklingen ved hjelp av en teknikk kalt stykkevis fourier-transform, der man deler opp et signal i mange små biter, kalt vinduer, og gjør fourier-transform på hvert vindu. Dette er en nyttig teknikk, men problemet med den er at oppløsningen på vinduene er konstant og vi vil kunne miste informasjon i signaler der frekvensen endres mye. Dette kan forbedres ved å la vinduene overlappe hverandre for så å sette sammen informasjonen etterpå. Figur 1. Fourier-transform gir amplitude for hver frekvens, stykkevis fourier (STFT) gir frekvenser (og deres amplitude i et 3D-plot) med faste tidsintervaller. Wavelet-analyse gir en skala, som kan konverteres til frekvens,på samme måte som STFT, men man kan samtidig forandre på tidsintervallet for hvert vindu. Teknikken som brukes i denne oppgaven er basert på at vinduene overlapper, og de blir flyttet kontinuerlig ett steg om gangen fra den ene enden til den andre, så teknikken kalles for kontinuerlig wavelet transform. Dette kjøres flere ganger med forskjellige størrelser slik at man er sikker på at man får med seg hele frekvensspekteret. Det er også mulig å forandre på steglengden slik at det ikke er en kontinuerlig forflytning, og det kalles for diskret wavelet transform, men skal ikke gjøres her. I kontinuerlig wavelet transform kan man selv velge størrelsene på vinduene helt fritt, men det kan man ikke på den diskret måten nok en grunn for at det heter kontinuerlig. Wavelet transform ligner ganske mye på fourier transform. Der fourier transform er basert på sinus og cosinusbølger med varierende frekvens er wavelet transform basert på små bølger, kalt wavelets, med varierende bredde og posisjon. Fourier transform er gitt ved ligningen og wavelet transform er gitt ved ligningen 4
5 Der f(t) er signalet som transformeres, exp(-iωt) er sinus og cosinusbølgene brukt i fourier transform og Ψ* s,τ (t) er den kompleks konjugerte av waveleten. Waveletens bredde og posisjon varieres. Disse er gitt ved variablene s og τ. Bredden, s, kalles skalaen til waveleten og er et mål på frekvensen. Denne virker på samme måte for en wavelet som for en vanlig sinusfunksjon. Hvis man har en sinusfunksjon sin(t/s) vil frekvensen til funksjonen øke proporsjonalt med s, og funksjonen blir mer sammentrykt. På samme måte vil en wavelet bli mer sammentrykt når s øker. Når waveleten er liten vil den være følsom for høye frekvenser i signalet, mens en større wavelet vil være bedre egnet for lave frekvenser. τ er en variabel med nær sammenheng til tid, men som viser forflytningen til waveleten når waveleten flyttes bortover signalet som et vindu. Forflytning for en sinusbølge er gitt ved sin(t n) der n er forflytningen, og det er på akkurat samme måte for wavelets som sett i ligningene nedenfor. En wavelet kan ha veldig mange forskjellige former. Dette er en av fordelene med waveletanalyse fordi waveletene kan tilpasses de dataene man har om man er flink. I denne oppgaven brukes en bestemt type wavelet kalt kompleks Morlet wavelet. 1 1 Kilder for teoridelen, og mye av resten av oppgaven er: Matlab Help-fil (Wavelet Toolbox), Kapittel 17 i kompendiet Wavelet analyse av Arnt Inge Vistnes. 5
6 Vurdering av ulike Morlet wavelets (Deloppgave 1) Morlet waveleten som brukes i denne oppgaven er gitt ved funksjonen men omgjøres til diskret form der n er en teller som gir forlytningen langs signalet og n er plasseringen av midtpunktet til waveleten. dt er tiden mellom to forflytninger. Konstantene foran eksponentleddene er der for å normalisere waveleten slik at γ(s, τ) 2 gir energien i hvert punkt. Det er i hovedsak energien som regnes ut fordi faseinformasjonen er vanskelig å beholde i en wavelet transform. Dette kan være en ulempe i forhold til fourier transform. Eksponentleddene har hver sin betydning. Det første, exp(iωt/ s), gir en konstant sinusoidal bølge slik som i fourier analyse, men ganget med det andre leddet blir det avgrenset som sett i Figur 2. Det andre leddet er på gaussisk form og gir altså omhyllingskurven til waveleten. Det vil da si at ω er omtrent antall perioder innenfor denne omhyllingskurven. (1) M o r l e t W a v e l e t - R e a l d e l W a v e l e t A b s o l u t t v e r d i e n 2 O m h y l l i n g s k u r v e 0. 1 W a v e l e t t i d s s t e g Figur 2. Realdelen av en kompleks Morlet wavelet med ω = 4 og s = 15*dt, dt = 0,1. I Figur 2 er realdelen av en kompleks Morlet wavelet plottet i Matlab. ω er satt til å være lik 4, og som kan ses så stemmer dette overens med at waveleten har fire perioder innenfor omhyllingskurven. I Figur 3 er den imaginære delen plottet med de samme parameterne. Det er et par forskjeller mellom disse to figurene. Den imaginære delen er litt ut av fase i forhold til den reelle delen. Dette er en positiv egenskap, for om den reelle delen såvidt blir lagt ut av fase med det 6
7 innkommende signalet slik at vi ikke får en fin maksimumsverdi, så vil den imaginære delen som følger rett etter kunne ligge riktig, og omvendt. Dette kan illustreres ved å late som om omhyllingskurven er signalet. I imaginærdelen ville da waveleten vært null der amplituden er størst, og altså ville produktet blitt null og vi hadde mistet informasjon. Derimot er waveleten størst der amplituden til signalet er størst slik at her ville vi fått med oss denne informasjonen M o r l e t W a v e l e t - I m a g i n æ r d e l W a v e l e t A b s o l u t t v e r d i e n 2 O m h y l l i n g s k u r v e W a v e l e t t i d s s t e g Figur 3. Kompleksdelen av en kompleks Morlet wavelet med ω = 4 og s = 15*dt, dt = 0,1. En annen forskjell er at imaginærdelen alltid er symmetrisk om tidsaksen. Det er ikke realdelen og det kan skape problemer fordi det er et krav at middelverdien til waveleten er lik null. Dette kommer fra admissibilitetsbetingelsen For at dette skal holde må middelverdien av Ψ(t) være lik null, og altså må integralet av den samme funksjonen også være lik null. Dette kan lett sjekkes i dataprogrammet. For ω = 4 og s = 15*dt viser det seg at integralet av realdelen er 0,0024 og for imaginærdelen er det 2,1124 x Integralet for imaginærdelen er ganske likt null, og for realdelen er det ikke så stort heller, men vi vil helst ha litt bedre presisjon. Hvis integralet av en wavelet ikke er likt null risikerer vi å få en feil som summeres opp til en potensielt enda større feil. Dette skjer fordi vi multipliserer waveleten og signalet i hvert eneste tidspunkt og summerer produktene. Feilen vil altså da summeres opp like mange ganger som waveletens utstrekning og dette fører til at signalet kan virke sterkere eller svakere enn det det egentlig er. 2 For å sjekke hvordan dette integralet forandrer seg med forskjellige ω og s setter jeg opp en tabell med verdier der den ene varieres og den andre holdes konstant. Fra Tabell 1 kan man se at når ω øker blir integralet nærmere og nærmere null. Dette er logisk, fordi med flere bølgelengder 2 Dette er svar på deloppgave 1g. 7
8 innenfor omhyllingskurven vil funksjonen være mindre avhengig av hvor bølgetoppene treffer, og bli mer symmetrisk. Som sett i Figur 2 så treffer den første bølgetoppen ganske lavt, bølgebunnen etter det treffer ganske høyt i absoluttverdi, mens den neste bølgetoppen er enda høyere. Denne forskjellen blir mindre når ω øker. Dette kan ses i Figur 6 og 7. ω = 4 er på grensen og ω = 5 er ganske bra, men for å være sikker bør man bruke ω = 6 eller høyere. Det er en grunn til at vi ikke bare velger en veldig høy ω. Når ω er høy er det mange perioder innenfor omhyllingskurven til waveleten. Er ω veldig høy kan dette gjøre at vi får problemer med presisjon i Matlab fordi bølgene er for nærme hverandre og for skarpe. Når vi bruker verdiene videre er vi i hovedsak interessert i kvadratet av dem, og da blir integralet enda mindre. ω = 6 er godt nok fordi en datamaskin uansett har en presisjonsfeil, og integralet er såpass lite at det ikke får merkbare konsekvenser for analysen. Skalaen, s, er den andre variablen. Vi setter ω = 6 og varierer s fra 2*dt til 12*dt for å finne ut hvordan integralet endrer seg med skalaen. I Tabell 2 er dataene fra denne kjøringen av programmet. Integralet av realdelen holder seg konstant lav, mens imaginærdelen er veldig lav, men øker sakte. Konklusjonen er at selv om integralene er avhengig av skalaen, så er denne avhengigheten forsvinnende liten i forhold til avhengigheten av ω. Integralverdier for varierende ω, s = 8*dt ω Realdel Imaginærdel 2 7,21E-001 8,06E ,92E-002 3,08E ,79E-003-1,84E ,98E-005-2,41E ,11E-008 2,57E ,22E-010 1,78E ,85E-014-3,11E ,68E-015-8,46E ,45E-015 3,33E-015 Tabell 1. Integralverdier for varierende ω, s = 8*dt, dt = 0,1. Integralverdier for varierende s*dt, ω = 6, dt = 0,1 s*dt Realdel Imaginærdel 0,20 4,17E-008-1,90E-019 0,30 4,97E-008 1,37E-017 0,40 5,73E-008-1,14E-017 0,50 6,41E-008 4,26E-017 0,60 7,02E-008 2,53E-018 0,70 7,59E-008 1,68E-017 0,80 8,11E-008-8,02E-018 0,90 8,60E-008 2,00E-017 1,00 9,07E-008 1,13E-017 1,10 9,51E-008-2,38E-017 1,20 9,93E-008-1,19E-016 Tabell 2. Integralverdier for varierende s*dt, ω = 6, dt = 0,1. Nedenfor er inkludert noen grafer med waveletene fra kjøringene ovenfor. I Figur 8 og 9 endres skalaen og ω holdes konstant lik 6. Det er tydelig at utstrekningen av waveleten øker. Med skala 2*dt er utstrekningen omtrent 40 punkter, og med skala 12*dt er utstrekningen omtrent 80 punkter. Waveletverdiene, langs y-aksen, er forskjellige for de to. Dette er fordi waveleten er 8
9 normalisert slik at energien er den samme. Normaliseringen er avhengig av en over roten av skalaen s. En viktig ting å huske på er at man må passe på å ha nok tidssteg slik at waveleten får plass. I figurene nedenfor er det brukt 128 tidssteg, som er nok for s = 12*dt, men med høyere skalaverdier bør man sikre seg at waveleten faktisk har en utstrekning mindre enn antallet tidssteg M o r l e t W a v e l e t - R e a l d e l W a v e l e t A b s o l u t t v e r d i e n 2 O m h y l l i n g s k u r v e 0. 1 W a v e l e t t i d s s t e g Figur 4. Kompleksdelen av en kompleks Morlet wavelet med ω = 6 og s = 8*dt, dt = 0, M o r l e t W a v e l e t - K o m p l e k s d e l W a v e l e t A b s o l u t t v e r d i e n 2 O m h y l l i n g s k u r v e 0. 1 W a v e l e t t i d s s t e g Figur 5. Kompleksdelen av en kompleks Morlet wavelet med ω = 6 og s = 8*dt, dt = 0,1. 9
10 0. 3 M o r l e t W a v e l e t - R e a l d e l W a v e l e t A b s o l u t t v e r d i e n 2 O m h y l l i n g s k u r v e 0. 1 W a v e l e t t i d s s t e g Figur 6. Kompleksdelen av en kompleks Morlet wavelet med ω = 10 og s = 8*dt, dt = 0, M o r l e t W a v e l e t - K o m p l e k s d e l W a v e l e t A b s o l u t t v e r d i e n 2 O m h y l l i n g s k u r v e 0. 1 W a v e l e t t i d s s t e g Figur 7. Kompleksdelen av en kompleks Morlet wavelet med ω = 10 og s = 8*dt, dt = 0,1. 10
11 M o r l e t W a v e l e t - R e a l d e l W a v e l e t A b s o l u t t v e r d i e n 2 O m h y l l i n g s k u r v e W a v e l e t t i d s s t e g Figur 8. Realdelen av en kompleks Morlet wavelet med ω = 6 og s = 2*dt, dt = 0, M o r l e t W a v e l e t - R e a l d e l W a v e l e t A b s o l u t t v e r d i e n 2 O m h y l l i n g s k u r v e 0. 1 W a v e l e t t i d s s t e g Figur 9. Realdelen av en kompleks Morlet wavelet med ω = 6 og s = 12*dt, dt = 0,1. Sammenhengen mellom skala og frekvens I wavelet-analyse brukes uttrykket skala og ikke frekvens. Jeg har til nå bare diskutert skalaen, men siden lydsignalene som skal analyseres er best forstått ved frekvenser er det viktig å finne sammenhengen mellom disse to. Wavelet-analyse er generelt og kan for eksempel brukes til å analysere korn-størrelser i krystaller, og det er ikke vanlig å snakke om en frekvens av kornstørrelser. Derfor er skala en bedre generell betegnelse enn frekvens. Sammenhengen mellom skala og frekvens kan være veldig komplisert i wavelets fordi en wavelet med en gitt skala kan tilpasses mange 11
12 frekvenser. Waveleten vi bruker, Morlet waveleten, er av en gaussisk form og periodene er uniforme innenfor dette område slik at i dette tilfellet kan vi finne en sammenheng. For å se på hva slags frekvens en wavelet med en gitt ω og en gitt skala s tilsvarer refereres det til Figur 10. Når waveleten har samme periodetid som signalet vil vi få størst utslag i alle ledd. Dette gir da størst utslag på transform-verdiene, som man får ved å multiplisere signalet med waveleten og så danne en sum av produktene. Wavelet 2 vil i motsetning gi en mye mindre sum fordi noen av verdiene oppveier hverandre. Dette betyr at perioden til hver bølge innenfor waveleten bør være lik perioden til signalet, og herfra kan vi finne en sammenheng. Figur 10. Et sinusformet signal (i midten) sammen med en wavelet med samme periodetid (øverst) og en wavlet med noe kortereperiodetid (nederst). Det er ikke lett å dele tidsutstrekningen til waveleten med antallet perioder ω fordi waveleten ikke har en definerbar utstrekning. Det blir en subjektiv avgjørelse om hvor nær null kantene bør være før man sier at waveleten er ferdig. Derimot kan vi gjøre en analyse av uttrykket for waveleten for å finne frekvensen. Exp[i ω(n n)dt/s] gir den delen av waveleten som er inne i omhyllingskurven. Skalaen oppgir vi i en skalafaktor sf ganget med dt. For at denne skal være periodisk må ω*(n -n)/sf = 2*π når vi har gått n punkter som tilsvarer en periode. n er også en variabel, men som en approksimasjon holder vi den i ro når vi flytter på n. Dette gir oss at (n n) = Δn ω*δn/sf = 2*π Δn = (2*π*sf) / (ω) Δn er altså en bølgelengde og ganger vi denne med dt gir det oss perioden T. Δn*dt = T = (2*π*sf*dt) / (ω) 12
13 Frekvensen er 1/T slik at F = ω / (2*π*s) Presisjon på frekvensoppløsningen og tidsoppløsningen Frekvensoppløsningen og tidsoppløsningen er nært knyttet til hverandre. For å se på denne sammenhengen måler jeg den relative båndbredden av fourier transformen som et mål på frekvensoppløsningen og bredden på omhyllingskurven til waveleten som et mål på tidsoppløsningen. Det er viktig at vi bruker samme akseverdier på de to målingene slik at de kan sammenlignes. For å måle den relative båndbredden av fourier transformen plottes fourier transformen av en wavelet med ω = 6 og s = 8*dt. Deretter overførte jeg den til Paint slik at alle verdiene kunne måles med piksel-presisjon. På figuren min tilsvarte 30 verdier på x-aksen til fourier transformen 900 piksler og 300 verdier på y-aksen tilsvarte 1240 piksler. Y-aksen bestod bare av 256 punkter slik at dette tilsvarte 1058 piksler. Figur 11. Måling av relativ båndbredde av en fourier transform. ω = 6 og s = 8*dt, dt = 0,1. Toppen av kurven var på piksel 845 nedenfra. Metoden som brukes er full width at half max (FWHM) og halvveis ned fra toppen er kurven 35 piksler bred. Den relative båndbredden er da 35/1058 = 0,
14 På samme måte blir tidsdelen, waveleten, analysert, vist i Figur 12. I Paint er figuren akkurat like bred som det frekvensfiguren var, det vil si at 256 punkter tilsvarer 1058 piksler. Y-aksen er denne gangen opp til 0,3 og figuren er 385 piksler høy. Toppen er på piksel 341 nedenfra. Halvveis ned fra toppen er kurven 79 piksler bred. Dette gir oss en relativ tidshalvverdi på 79/1058 = 0, Figur 12. Måling av relativ halvverdibredde av en wavelet. ω = 6 og s = 8*dt, dt = 0,1 Vi kan utifra disse verdiene regne ut en Δt og en Δf. Δf = fmax * 35/1058 Δt = T * 79/1058 der T = N * dt. Vi brukte N = 256 punkter og dt var satt til å være 0,1. fmax = 1/dt. Sammenhengen mellom disse verdiene er da T * fmax = N. Δf = (1/dt) * 35/1058 = 0,3308 Δt = N*dt * 79/1058 = 1,912 Den samme fremgangsmåten gjøres nå med en wavelet med ω = 6 og s = 16*dt. Den relative båndbredden til frekvensbildet er 17/1058, og den relative halvverdibredden av tidsbildet er 156/1058. Dette ser veldig ut som om den frekvenspresisjonen er omtrent doblet og tidspresisjonen er halvert. Δf = (1/dt) * 17/1058 = 0,1607 Δt = N*dt * 156/1058 = 3,775 For å teste om det er en dobling/halvering av presisjon når skalaen dobles gjør jeg et nytt forsøk der ω = 6 og s = 32*dt. Her får jeg at den relative båndbredden er 9/1058 og halvverdibredden er 338. Sistnevnte er litt mer enn en dobling av den forrige verdien, men dette kan være på grunn av dårlig presisjon i målingene. Δf = (1/dt) * 9/1058 = 0,08507 Δt = N*dt * 338/1058 = 8,178 14
15 Det ser ut som om det er en nær sammenheng mellom produktene Δt * Δf i de forskjellige målingene. Produktene er ganske like, oppsummert i Tabell 3, noe som antyder at når vi vil øke presisjonen til frekvensen må vi samtidig minke presisjonen til tiden. Skala Δf Δt Δf * Δt 8*dt 0,3308 1,912 0, *dt 0,1607 3,775 0, *dt 0, ,178 0,6957 Tabell 3. Oppsummering av verdier for Δf, Δt og produktet Δf*Δt for forskjellige skalaer. ω = 6, dt = 0,1. Vi har altså da en omtrentlig sammenheng Δf*Δt = 0,65. Ganger man på begge sider med Plancks konstant h får man Δhf*Δt = 0,65h som er det samme som ΔE*Δt = 0,65h der E er energien. Dette er en versjon av Heissenbergs uskarphetsfunksjon. Konklusjonen er at tidspresisjonen og frekvenspresisjonen ikke bare er begrenset av måleteknikkene vi bruker, men også av uskarphetsfunksjonen. Det er signalet selv som begrenser hva vi kan måle. Hvis signalet varer lenge kan vi stadig øke skalaen slik at waveleten blir bredere og dette ville gitt en god frekvensoppløsning helt til waveleten er like stor som signalet. Samtidig vil vi få en dårligere tidsoppløsning. ω kan også justeres for å forbedre enten frekvensoppløsningen eller tidsoppløsningen. Jo større ω er jo bedre frekvensoppløsning og jo dårligere tidsoppløsning får vi. Dataprogrammet som er brukt i kjøringene så langt er lagt til i Vedlegg 1. 15
16 Et dataprogram for wavelet transform på intuitivt enkleste måte (Deloppgave 2) Den mest intuitive måten å lage et dataprogram som gjør wavelet transform er å sette inn ligning (1), repetert under for enkelhets skyld, rett inn i programmet. Denne ligningen gir waveleten og man velger alle verdiene bortsett fra n som varieres. Koden jeg brukte for å beregne waveleten var [Start Matlab-kode] % Beregne waveleten wln = 160; % Waveletens utstrekning (med god margin for å klare skala "21") psi = zeros(1,wln); % Initierer waveleten psi psi = psi + i.*psi; % Definerer psi som kompleks wln_mid = wln/2; % Waveletens midtpunkt for n = 1:wlN eta = (wln_mid - n)*dt/s(s2); psi(n) = pi^(-1/4) * sqrt(dt/s(s2)) * exp(i*w*eta) * exp(-(eta^2)/2); end [Slutt Matlab-kode] Fordi waveleten starter og slutter utenfor dataene legger jeg til 0-verdier både foran og bak på dataene. Fordi produktet blir null blir summen null og dataene blir ikke påvirket annet enn at de blir dempet i kantene (som de ville blitt uansett). [Start Matlab-kode] y_pad = padarray(y,[(wln_mid-1) 0]); % Legger til wln_mid-1 nuller før og etter [Slutt Matlab-kode] Nå er alt klart for å gjøre selve wavelet transformen. Transformen gjøres ved å multiplisere waveleten med dataene (y) og summe alt opp, waveletens første element skal ganges med dataenes første element, helt til waveletens siste element ganges med dataenes siste element. [Start Matlab-kode] % For å ikke regne ut dette hver gang løkken kjøres start_m = (wln_mid); stop_m = length(y_pad)-(wln_mid-1); start_n = -(wln_mid-1); stop_n = (wln_mid); for (m = start_m:stop_m) 16
17 o = 0; for (n = start_n:stop_n) o = o + 1; wl_sum(s2,m+start_n) = y_pad(m+n) * psi(o) + wl_sum(s2,m+start_n); end end [Slutt Matlab-kode] Alt dette kjøres flere ganger med ulike skalaer helt til vi får en matrise som er delt i skalaer den ene veien og tid den andre veien. Indeksen s2 i koden ovenfor viser til forskjellige skalaverdier. Hele programmet er lagt til i Vedlegg 2. Programmet brukte 117 sekunder med 40 forskjellige skalaverdier og 2^15 punkter. Det er ganske tregt å gjøre denne utregningen steg for steg og i neste seksjon gjøres dette på en mer effektiv måte. Figur 13 viser wavelet transformen av lydfilen Granmeis2.wav, som er fuglekvitring med høy frekvens. 3 Det er usikkert om frekvensverdiene på skalaen til Figur 13 er riktige. Formelen brukt er den utledet i seksjonen Sammenhengen mellom skala og frekvens, men stemmer ikke overens med frekvensene fra fourier transformen som vist i neste seksjon. W a v e l e t T r a n s f o r m F r e k v e n s [ H z ] T i d [ s ] Figur 13. Wavelet transform av lydfilen Granmeis2.wav. ω = 6 og s = 8*dt til s = 21*dt i 40 lineære steg. Lydfilen består av 2^15 punkter. 3 Alle lydfilene brukt i denne oppgaven kan bli lastet ned fra 17
18 Et mer effektivt dataprogram for wavelet transform (Deloppgave 3) For å gjøre programmet mer effektivt kan man kombinere wavelet transform med fourier transform. Vi benytter da en egenskap ved fourier transform som er slik at transformen av produktet av to funksjoner på samme tidsintervall er lik produktet av transformen av hver av dem separat. Det vil si at vi kan ta fourier transformen av signalet og gange det med fourier transformen av waveleten for å få den fourier transformerte av begge. Nå har vi frekvensspekteret for disse to funksjonene ganget sammen, og for å få tidsspekteret kan vi ta den invers fourier transformerte av dette uttrykket. Da får vi ut samme informasjon som med wavelet transformen. Dette forutsetter at vi har en analytisk uttrykk for fourier transformen av waveleten, og det har vi i denne oppgaven fått oppgitt. Det er flere andre ting man kan gjøre for å forbedre programmet i forrige del. En intuitiv ting er at man kan gjøre om skala/frekvens-aksen til å være logaritmisk. Dette er i samsvar med at mennesker oppfatter frekvenser logaritmisk. For å lage logaritmiske akser skriver jeg skalaen slik: s = s0*2.^((0:sn-1)*dds) Der s0 er en startskalaverdi og (0:sN-1) tilsvarer en vektor som går fra 0 til sn-1. 1/dds bestemmer hvor mange oppdelinger vi skal ha hver oktav. Antall skalaer skriver jeg nå som sn = fix(11/dds) Der tallet 11 kan forandres og gir antall oktaver. Det er dessverre komplisert å få en logaritmisk skala på plottefunksjonen imagesc i Matlab, så jeg har valgt å fjerne aksene. En annen forbedring er at jeg legger inn en usikkerhetskurve kalt Cone of Influence (COI) i plottet. Når waveleten ganges med signalet vil deler av waveleten til tider ligge utenfor signalet. Dette medfører en demping av verdiene på starten og slutten av signalet. Figur 14. Når waveleten først settes mot signalet er halvparten av den utenfor. Dette medfører at de første verdiene blir dempet. 18
19 Måten jeg har laget denne kurven på er ved å først beregne bredden på waveletene ved hver skalaverdi, for deretter å legge dette inn i den opprinnelige matrisen ved de lengdene halvparten av bredden av waveletene tilsvarer. Fordi jeg legger dette inn sammen med de opprinnelige dataene er det viktig at jeg ikke legger inn verdier som gjør at skalaen til amplituden til frekvensene blir feil. Derfor gjør jeg slik at verdiene får samme verdi som maksverdiene som allerede er i matrisen, og linjene som betegner usikkerhetsområdet blir da av samme farge som maksverdiene. [Start Matlab-kode] % Cone of Influence (COI) approx = 1000; % Waveletens utstrekning slutter når verdien av den er 1/approx av maks wl_width = ((s/dt) * 2*sqrt(2*log(approx))); wl_width_vector = zeros(sn,n); max_fboth = max(max(plot_fboth)); % COI shading all values outside for s2 = 1:sN for n = 1:3:fix(wl_width(s2)/2) wl_width_vector(s2,n) = max_fboth - plot_fboth(s2,n); wl_width_vector(s2,n-n) = max_fboth - plot_fboth(s2,n-n); end end [Slutt Matlab-kode] Man kan beregne waveletens utstrekning ved å se når omhyllingskurven er tilnærmet lik null. I koden ovenfor har jeg satt at tilnærmet lik null betyr 1/1000 av waveletens maksimumsverdi. Waveletens maksimumsverdi er når (n n) = 0, da er exp(0) = 1. Hvis waveleten har en bredde n er midtpunktet n = n/2. Vi kan da sette inn i uttrykket for omhyllingskurven og at verdien skal være 1/1000 av maksimumsverdien som er 1. exp[-((n/2 n)*dt/s)^2/2] = 1/1000 ((n/2 n)*dt/s)^2 =2 * ln(1000) n = (s/dt) * 2 (2) (ln(1000)) Dette er uttrykket som er brukt i koden. Det er vanlig å plotte wavelet power spekteret når man bruker wavelet transform. Wavelet power spekter er transformverdiene kvadrert. I Matlab kan dette gjøre at vi mister informasjon om de lavere frekvensene på grunn av graderingen av farger. Under er vist tre figurer med forskjellige funksjoner og man kan klart se at det er en fordel, i hvert fall i dette tilfellet, å se på enten verdiene som de er, eller kvadratroten av de. Fordelen med å se på kvadratet er at det blir mindre støy. COIen ses ikke i disse plottene fordi den ikke er betydningsfull i så høye frekvenser som avbildet her. Aksene er logaritmiske. 19
20 Figur 15. Wavelet power spekter, verdiene kvadrert Figur 16. Verdiene er plottet som de kommer ut av transformen. 20
21 Figur 17. Kvadratet av verdiene av transformen. Mulige forbedringer av koden Dataprogrammet jeg har skrevet er ikke optimalt. Den viktigste forbedringen er kanskje å få på riktige akser med frekvensverdier. Dette viste seg å være veldig vanskelig å få til i Matlab, men det skal være mulig. Det beste hadde vært om man kunne valgt frekvensene man vil se på og ikke forandre på skalaverdiene som man må nå. Da kunne man sett på fourier-spekteret og valgt ut det frekvensområde som er vist der. Det er mulig å lage waveleten uten å bruke for-løkker, dette ville få programmet til å gå fortere. Dette programmet var allikevel mye kjappere enn det forrige. Dette programmet brukte 5 sekunder med 40 forskjellige skalaverdier og 2^15 punkter, mens det forrige brukte 117 sekunder. Dette er mye om man trenger et slikt program og ikke har all verdens tid. Koden for COI-delen er heller ikke ideell. Den burde ha vært lagt i en vektor og så plottet oppå verdiene istedenfor å bli satt sammen med verdiene. Den er heller ikke så veldig rask på grunn av beregninger jeg måtte gjøre for å få satt dem sammen. 21
22 Analyse (Deloppgave 4) I denne delen av oppgaven skal jeg analysere fire lydfiler og se på detaljer det ikke er mulig å se ved fourier analyse. Disse fire lydfilene er Granmeis2.wav, GrexVocalis3.wav, havbolge2.wav og fagott1.wav. På begynnelsen av hver analyse viser jeg et oversiktsbilde over wavelet analysen der de samme parameterne er brukt i hvert bilde. Detter er for å vise hvilke frekvenser som finnes i signalet og for å vise usikkerhetskurven (COI). Det er viktig å vite om det er en usikkerhet forbundet med de frekvensene som blir analysert. Granmeis2.wav Dette er lydfilen som er brukt som eksempel tidligere i denne oppgaven. Den består av en fugl som kvitrer med korte plystrelyder i korte perioder. Tidsbildet, fourier transformen og wavelet transformen er plottet i Figur 18, 19 og O p p r i n n e l i g s i g n a l t i d [ s ] Figur 18. Opprinnelig signal av Granmeis2.wav. 22
23 A b s o l u t t - v e r d i e r a v f r e k v e n s s p e k t e r e t F ( f r e k v ) r ( ) F e k v e n s H z Figur 19. Fourier transform, zoomet inn på aktuelle verdier. W a v e l e t t r a n s f o r m F r e k v e n s [ H z ] T i d [ s ] Figur 20. Oversiktsbilde over wavelet transformen til Granmeis2.wav. N = 2^16 punkter, ω = 6, s0 = 5*dt og skalaen er 11 oktaver, kvadratroten av verdiene er plottet. I tidsbildet i Figur 18 ser vi at signalet er periodisk og at intensiteten minker innenfor hver bit. I frekvensspekteret kan vi se at frekvensene er veldig samlet uten rom imellom og at det er mest av den lavere frekvensen. Dette kan vi også se med wavelet analysen, men der kan vi også se at frekvensen endrer seg fra en høy frekvens til en lavere frekvens samtidig som intensiteten minker. Variasjonen av tiden og frekvensen samtidig får vi altså ikke fra de to andre figurene. Dette ser man 23
24 tydligere når vi zoomer inn på et av plystringene i Figur 21. Da er ω lik 6 for å bedre tidsoppløsningen for et så kort signal. W a v e l e t t r a n s f o r m F r e k v e n s [ H z ] T i d [ s ] Figur 21. En fugleplystring. N = 2^14 punkter, ω = 6, s0 = 5*dt og skalaen er 2,5 oktaver, kvadratroten av verdiene er plottet. I følge frekvensspekteret skulle man tro at den laveste frekvensen var den med høyest intensitet, men dette stemmer ikke i følge wavelet analysen. Det frekvensspekteret viser er hvor mye det er av hver totalt, og det er umulig å vite at den lave frekvensen med lav intensitet går i lenger tid en den høye frekvensen med høy intensitet uten å se på wavelet transformen. GrexVocalis3.wav GrexVocalis3.wav er en veldig lys syngende stemme. Fra tidssignalet får vi vite at amplituden varierer litt, og ganske mye på slutten av signalet. Av frekvensspekteret får at syngingen har en høy amplitude på en lys frekvens på 400Hz og at det er overtoner på 800 Hz og såvidt noe på 1600 Hz O p p r i n n e l i g s i g n a l t id [ s ] Figur 22. Opprinnelig signal av GrexVocalis3.wav. 24
25 A b s o l u t t - v e r d i e r a v f r e k v e n s s p e k t e r e t F ( f r e k v ) F r e k v e n s ( H z ) Figur 23. Fourier transform, zoomet inn på aktuelle verdier. W a v e l e t t r a n s f o r m F r e k v e n s [ H z ] T i d [ s ] Figur 24. Oversiktsbilde over wavelet transformen til GrexVocalis3.wav. N = 2^16 punkter, ω = 6, s0 = 5*dt og skalaen er 11 oktaver, kvadratroten av verdiene er plottet. 25
26 W a v e l e t t r a n s f o r m F r e k v e n s [ H z ] T i d [ s ] Figur 25. Begynnelsen av GrexVocalis3.wav, zoomet inn. N = 2^16 punkter, ω = 6, s0 = 5*dt og skalaen er 4,5 oktaver, kvadratroten av verdiene er plottet. Skalaen jeg bruker i dataprogrammet er logaritmisk og er delt opp i oktaver med 10 skalaer i hver oktav. Det er interessant å telle antall ruter mellom de tre frekvensene; det er akkurat 10 ruter mellom hver. Denne sangerinnen har en ganske perfekt stemme. Det at det er overtoner her kunne man ha gjettet seg til, men ikke visst sikkert, fra fourier transformen. Det er greit å få det bekreftet at de forskjellige frekvensene forekommer samtidig. En annen ting man bare kan finne ut fra wavelet analysen er at intensiteten for hver av frekvensene øker samtidig, slik at det er ikke av og til en annen frekvens er lettere å høre. Fordi det ikke er noe særlig endring i frekvensen til dette signalet er ikke waveleter så nødvendig som for andre signaler. Derimot er det en veldig fin måte å få alle detaljene på en gang, og at sigalet faktisk er slik man antar det er fra tidsbildet og frekvensspekteret. havbolge2.wav havbolge2.wav er som navnet tilsier, brusingen fra en havbølge. Dette signalet har en veldig ujevn lokal intensitet, men globalt avtar intensiteten. Frekvensspekteret viser at det er flest lave frekvenser, fra 40 Hz til 200 Hz, men med frekvenser helt opp til 7000 Hz. Det frekvensspekteret ikke viser er hvordan veldig mange av frekvensene forekommer samtidig. Det viser heller ikke at det er mange «frekvenshull» ved hvert tidspunkt, frekvensene er ikke jevnt fordelt utover. Begge disse sidene av signalet kan man se med wavelet-analysen. Signalet er veldig kaotisk, og selv på den frekvensen med høyest intensitet er det mange områder uten lyd i det hele tatt. 26
27 1 O p p r i n n e l i g s i g n a l t i d [ s ] Figur 26. Opprinnelig signal av havbolge2.wav. A b s o l u t t - v e r d i e r a v f r e k v e n s s p e k t e r e t F ( f r e k v ) F r e k v e n s ( H z ) Figur 27. Fourier transform, zoomet inn på aktuelle verdier. 27
28 W a v e l e t t r a n s f o r m F r e k v e n s [ H z ] T i d [ s ] Figur 28. Oversiktsbilde over wavelet transformen til havbolge2.wav. N = 2^16 punkter, ω = 6, s0 = 5*dt og skalaen er 11 oktaver, kvadratroten av verdiene er plottet. fagott1.wav fagott1.wav er et instrument som spiller lyder med ganske lave frekvenser. Man hører at det er to forskjellige noter. Først en note, så en litt lavere, og så den første noten igjen O p p r i n n e l i g s i g n a l t i d [ s ] Figur 29. Opprinnelig signal av havbolge2.wav. 28
29 A b s o lu t t -ve rd ie r a v fre k ve n s s p e k t e re t F (f re k v ) F re k ve n s (H z ) Figur 30. Fourier transform, zoomet inn på aktuelle verdier. W a v e l e t t r a n s f o r m F r e k v e n s [ H z ] T i d [ s ] Figur 31. Oversiktsbilde over wavelet transformen til fagott1.wav. N = 2^16 punkter, ω = 6, s0 = 5*dt og skalaen er 11 oktaver, kvadratroten av verdiene er plottet. 29
30 W a v e l e t t r a n s f o r m F r e k v e n s [ H z ] T i d [ s ] Figur 32. Begynnelsen av fagott1.wav. N = 2^16 punkter, ω = 6, s0 = 20*dt og skalaen er 5 oktaver, kvadratroten av verdiene er plottet. I tidsbildet i Figur 29 ser vi at den første tredjedelen har ganske jevn intensitet og det samme kan vi se fra wavelet analysen i Figur 32. I wavelet analysen kan man i tillegg se at den variasjonen som er i den første tredjedelen kommer fra høyere frekvenser enn hoveddelen av signalet. Når det er variasjon i intensiteten til signalet kan vi også se at variasjonen for det meste skjer på de høyere frekvensene også innad i tonene (sagform). I fourier transformen ser det ut som om det er en frekvens vi har mye av, og at det er omtrent like mye av frekvensene under og over. Dette kan vi se grunnen til på wavelet analysen. Det er egentlig bare to toner her, en i midten og en under, men det er en god del overtoner som gjør at det virker som om det også er en over. En annen ting jeg ikke klarte å høre på lydfilen var at den andre lavere tonen egentlig består av omtrent like mye av den lavere tonen og den over. Og den høyere tonen har alltid en liten del av den lavere tonen i seg. 30
31 Konklusjon Wavelet analyse er en teknikk som kan brukes for å se på hvordan frekvensen endrer seg med tiden. Det er en teknikk som ligner veldig på fourier analyse, men fourier analyse ser bare på frekvensene som forekommer i løpet av hele signalet det har ingen tidsperspektiv. Wavelet analyse er veldig nyttig når frekvensene i signalet forandrer seg hyppig. En wavelet er avhengig av to parametere, skala og ω. Skalaen er en størrelse som blant annet kan erstattes med frekvens. ω er et parameter som bestemmer frekvensoppløsningen og tidsoppløsningen. Kontinuerlig wavelet transform er når en wavelet multipliseres med et signal for så å summere alle produktene for hvert tidspunkt. Dette gjør at man får et kontinuerlig vindu som ved hjelp av forskjellige skalaer får med seg mange frekvenser, og vi får som resultat hvilke frekvenser vi har ved hvert tidspunkt. Denne transformen er programmert på to måter. En intuitiv måte der alt er gjort rett fram og en mer effektiv måte som benytter seg av et triks at den fourier transformerte av to funksjoner ganget med hverandre er den samme som produktet mellom de fourier transformerte av de to funksjonene. Analysen viser oss at det er mange detaljer vi kan finne ved hjelp av wavelet transform som ikke er mulig å få ut av fourier transform og tidsbildet. Disse detaljene går i hovedsak ut på at vi kan ha flere frekvenser samtidig eller at frekvensene endrer seg med tid. Wavelets gir uansett et fint grafisk bilde av både frekvensutviklingen og tidsbildet i et og samme plot. 31
32 Vedlegg 1 - Dataprogrammet brukt i Deloppgave 1 % FYS Prosjekt % Deloppgave 1e clear all; clear figure; dt = 0.1; % tidsintervall N = 256; % Antall punkter langs x-aksen s = 32*dt; % Skala w = 6; % omega, vinkelfrekvens n2 = N/2; % Waveletens midtpunkt % for w = 2:10 % for t = 2:12 % s = t*dt; psi = zeros(1,n); psi = psi + i.*psi; omhyllingskurve = zeros(1,n); integral_of_psi_real = 0; integral_of_psi_imag = 0; for n = 1:N eta = (n2-n)*dt/s; psi(n) = pi^(-1/4) * sqrt(dt/s) * exp(i*w*eta) * exp(-(eta^2)/2); integral_of_psi_real = real(psi(n)) + integral_of_psi_real; integral_of_psi_imag = imag(psi(n)) + integral_of_psi_imag; end omhyllingskurve(n) = pi^(-1/4) * sqrt(dt/s)*exp(-(eta^2)/2); % Fouriertransformering av waveleten F_psi = fft(psi); % Plotter realdelen av waveleten figure(1); plot(real(psi)); title('morlet Wavelet - Realdel') xlabel('tidssteg') ylabel('wavelet') hold on; % Plotter kvadratet av absoluttverdien av waveletens realdel plot((abs(real(psi))).^2,'r'); plot(omhyllingskurve,'g'); legend('wavelet','omhyllingskurve') hold off; % Plotter imaginærdelen av waveleten figure(2); plot(imag(psi)); title('morlet Wavelet - Kompleksdel') xlabel('tidssteg') ylabel('wavelet') hold on; 32
33 % Plotter kvadratet av absoluttverdien av waveletens imaginærdel plot((abs(imag(psi))).^2,'r'); plot(omhyllingskurve,'g'); hold off; % Plotter kvadratet av absoluttverdien av den fourier transformerte av waveleten figure(3) plot(abs(f_psi).^2); title('morlet Wavelet - Fouriertransformert') xlabel('f') ylabel(' f ^2') % Skriver ut integralene fprintf('\n\nscale = %20.10f\nReal integral = %8.20f\nImag integral = %8.20f', s, integral_of_psi_real, integral_of_psi_imag); % end % end 33
34 Vedlegg 2 - Dataprogrammet brukt i Deloppgave 2 % FYS Prosjekt % Deloppgave 2 tic; % Tar tiden på programmet clf; clear all; clc; % Read wav file N = 2^15; % Hvor stor del av lydfilen som skal tas med nstart = 1; % Her kan man bestemme starttidspunktet for lydfilen nstop = nstart + N - 1; [y, Fs, nbits] = wavread('m:\fys2130\granmeis2.wav', [nstart nstop]); % Windows dt = 1/Fs; t = (0:N-1)*dt; % En tidsarray med alle tidsbitene fra tid 0 til tid (N-1)*dt. % Plotter det opprinnelige signalet figure(10); plot(fs*t,y) title('opprinnelig signal') xlabel('tid (millisekunder)') % Spiller av lyden %sound (y, Fs, nbits); w = 6; % Perioder innenfor omhyllingskurven % Scaling s0 = 5*dt; % Første skalaverdi s1 = 21*dt; % Siste skalaverdi sn = 20; % Antall skalaverdier vi vil bruke scaling_vector = linspace(s0,s1,sn); % Lager skalaverdiene, (første s, siste s, antall s); s = scaling_vector; freq = w./(2*pi*s); wl_sum = zeros(sn,n); wl_sum = wl_sum + i.*wl_sum; for s2 = 1:sN % Nå trenger jeg en matrise med midtpunktet, og en matrise med % wavelet-verdiene. % Beregne waveleten wln = 160; % Waveletens utstrekning (med god margin for å klare skala "21") psi = zeros(1,wln); % Initierer waveleten psi psi = psi + i.*psi; % Definerer psi som kompleks wln_mid = wln/2; % Waveletens midtpunkt for n = 1:wlN eta = (wln_mid - n)*dt/s(s2); 34
35 psi(n) = pi^(-1/4) * sqrt(dt/s(s2)) * exp(i*w*eta) * exp(- (eta^2)/2); end % Fordi waveleten starter og slutter utenfor dataene legger jeg til % 0-verdier både foran og bak på dataene. Fordi produktet blir null % blir summen null og dataene blir ikke påvirket annet enn at de blir % dempet i kantene (som de ville blitt uansett). y_pad = padarray(y,[(wln_mid-1) 0]); % Legger til wln_mid-1 nuller før og etter % Multiplisere waveleten med dataene (y) og summe alt opp, waveletens % første element skal ganges med dataenes første element, helt til % waveletens siste element ganges med dataenes siste element. % For å ikke regne ut dette hver gang løkken kjøres start_m = (wln_mid); stop_m = length(y_pad)-(wln_mid-1); start_n = -(wln_mid-1); stop_n = (wln_mid); for (m = start_m:stop_m) o = 0; for (n = start_n:stop_n) o = o + 1; wl_sum(s2,m+start_n) = y_pad(m+n) * psi(o) + wl_sum(s2,m +start_n); end end end figure(1); plot(real(psi)); title('morlet Wavelet - Realdel') xlabel('tidssteg') ylabel('wavelet') figure(3); imagesc(t,freq,real(abs(wl_sum))); title('wavelet Transform') xlabel('tid [s]') ylabel('frekvens [Hz]') set(gca,'ydir','normal') % Setter frekvensen øverst % Skriver ut tiden programmet brukte script_time = toc; fprintf('\n\nkjøringstid = %15.5f\n\n', script_time); 35
36 Vedlegg 3 - Dataprogrammet brukt i Deloppgave 3 % FYS Prosjekt % Deloppgave 2 tic; % Tar tiden på programmet clf; clear all; clc; % Read wav file N = 2^15; % Hvor stor del av lydfilen som skal tas med nstart = 1; % Her kan man bestemme starttidspunktet for lydfilen nstop = nstart + N - 1; [y, Fs, nbits] = wavread('m:\fys2130\granmeis2.wav', [nstart nstop]); % Windows dt = 1/Fs; t = (0:N-1)*dt; % En tidsarray med alle tidsbitene fra tid 0 til tid (N-1)*dt. data_time = (N-1)*dt; % lengden på signalet i sekunder % Plotter det opprinnelige signalet figure(10); plot(fs*t,y(1:n)) title('opprinnelig signal') xlabel('tid (millisekunder)') % Spiller av lyden %sound (y, Fs, nbits); F_y = fft(y,n); % Fourier transform av y, kommer til å bruke F_y(1:N) fordi lyden har to kanaler frekv_fft = (Fs/2)*linspace(0,1,N); % Frekvensvektor til fourier transform % Plotter den fourier transformerte av signalet figure(1); plot(frekv_fft,2*abs(f_y(1:n))) title('absolutt-verdier av frekvensspekteret') xlabel('frekvens (Hz)') ylabel(' F(frekv) '); w = 6; % omega0, ca antall bølgetopper i en wavelet s0 = 5*dt; % Initial scale s1 = 20*dt; % Final scale, bare for lineær dds = 0.10; % oppløsningsfaktor, for logaritmisk skala sn = fix(8/dds) % 1:dds intervaller per oktav, 11 oktaver % Velg logaritmisk eller lineær skala. 1 for lineær, 2 for logaritmisk s_choice = 2; if (s_choice == 2) s = s0*2.^((0:sn-1)*dds); % logaritmisk skala else s = linspace(s0,s1,sn) % lineær skala end 36
37 sf = s./dt; % Skalafaktor freq = w./(2*pi*s); wln = 160; % Waveletens utstrekning (med god margin for å klare skala "21") F_psi = zeros(sn,n); F_both = zeros(sn,n); f_both = zeros(sn,n); for s2 = 1:sN % Ingen fourier transform funksjon her, for dette uttrykket er allerede % fourier transformert F_psi(s2,1) = 0; for n = 2:(N/2+1) argument(n) = -0.5*((sf(s2)*2*pi*(n-1)/N) - w).^2; % (dvs elementvis kvadrert) F_psi(s2,n) = sqrt(2.0*sf(s2)*pi^(+0.25))* exp(argument(n)); end % Multiplikasjon av F_psi og F_y F_both(s2,:) = F_psi(s2,:).*F_y(1:N); end % Invers transform f_both(s2,:) = ifft(f_both(s2,:)); plot_fboth = sqrt(abs(f_both)); % Definerer hvilke funksjoner som skal virke på f_both figure(2); title('...') xlabel('tid [s]') ylabel('frekvens [Hz]') imagesc(t,freq,plot_fboth); set(gca,'ydir','normal') % Setter frekvensen øverst if (s_choice == 2) % Hvis logaritmisk skala så fjerner jeg y-aksen set(gca, 'YTickLabelMode', 'Manual') set(gca, 'YTick', []) end hold on % Cone of Influence (COI) approx = 1000; % Waveletens utstrekning slutter når verdien av den er 1/approx av maks wl_width = ((s/dt) * 2*sqrt(2*log(approx))); wl_width_vector = zeros(sn,n); max_fboth = max(max(plot_fboth)); % COI shading all values outside for s2 = 1:sN for n = 1:3:fix(wl_width(s2)/2) wl_width_vector(s2,n) = max_fboth - plot_fboth(s2,n); wl_width_vector(s2,n-n) = max_fboth - plot_fboth(s2,n-n); end end % Plotter de opprinnelige verdiene pluss coi 37
38 plot_coi = wl_width_vector+plot_fboth; imagesc(t,freq,plot_coi) colorbar hold off % Skriver ut tiden programmet brukte script_time = toc; fprintf('\n\nkjøringstid = %15.5f\n\n', script_time); 38
39 Vedlegg 4 Forklar kontinuerlig wavelet transform til en medstudent (Deloppgave 5) Wavelet-analyse er en teknikk lignende fourier-analyse, men med forskjellige parametere. Fourier-analyse gjør om et signal fra å se på tidsutviklingen av det til å se på hvilke frekvenser det inneholder, mens wavelet-analyse er et 3D-plot der man ser på både tidsutviklingen og hvilke frekvenser hvert tidspunkt inneholder. Fordi fouriertransformen ikke inneholder et tidsperspektiv mister vi mye informasjon hvis signalet forandrer seg over tid. Fourier-transform er best når vi ser på et repeterende signal. Målet med denne teksten er å forstå hvorfor wavelet-analyse er et godt alternativ til fourier-analyse. Man kan tenke seg at det også er mulig å se på tidsutviklingen ved hjelp av en teknikk kalt stykkevis fourier-transform, der man deler opp et signal i mange små biter, kalt vinduer, og gjør fourier-transform på hvert vindu. Dette er en nyttig teknikk, men problemet med den er at oppløsningen på vinduene er konstant og vi vil kunne miste informasjon i signaler der frekvensen endres mye. Dette kan forbedres ved å la vinduene overlappe hverandre for så å sette sammen informasjonen etterpå. Figur 1. Fourier-transform gir amplitude for hver frekvens, stykkevis fourier (STFT) gir frekvenser (og deres amplitude i et 3D-plot) med faste tidsintervaller. Wavelet-analyse gir en skala, som kan konverteres til frekvens,på samme måte som STFT, men man kan samtidig forandre på tidsintervallet for hvert vindu. Kontinuerlig wavelet transform er basert på at vinduene overlapper, og de blir flyttet kontinuerlig ett steg om gangen fra den ene enden til den andre. Dette kjøres flere ganger med forskjellige størrelser slik at man er sikker på at man får med seg hele frekvensspekteret. Det er også mulig å forandre på steglengden slik at det ikke er en kontinuerlig forflytning, dette kan gå mye fortere kalles for diskret wavelet transform, men skal ikke gjøres her. I kontinuerlig wavelet transform kan man selv velge størrelsene på vinduene helt fritt, men det kan man ikke på den diskret måten nok en grunn for at det heter kontinuerlig. Wavelet transform ligner ganske mye på fourier transform. Der fourier transform er basert på sinus og cosinusbølger med varierende frekvens er wavelet transform basert på små bølger, kalt wavelets, med varierende bredde og posisjon. Fourier transform er gitt ved ligningen til venstre og wavelet transform er gitt ved ligningen til høyre der f(t) er signalet som transformeres, exp(-iωt) er sinus og cosinusbølgene brukt i fourier transform og Ψ* s,τ (t) er den kompleks konjugerte av waveleten. Waveletens bredde og posisjon varieres. Disse er gitt ved variablene s og τ. Bredden, s, kalles skalaen til waveleten og er et mål på frekvensen. Denne virker på samme måte for en wavelet som for en vanlig sinusfunksjon. Hvis man har en sinusfunksjon sin(t/s) vil frekvensen til funksjonen øke proporsjonalt med s, og funksjonen blir mer sammentrykt. På samme måte vil en wavelet bli mer sammentrykt når s øker. Når waveleten er liten vil den være følsom for høye frekvenser i signalet, mens en større wavelet vil være bedre egnet for lave frekvenser. τ er en variabel med nær sammenheng til tid, men som viser forflytningen til waveleten når waveleten flyttes bortover signalet som et vindu. Forflytning for en sinusbølge er gitt ved sin(t n) der n er forflytningen, og det er på akkurat samme måte for wavelets som sett i ligningene nedenfor. En wavelet kan ha veldig mange forskjellige former. Dette er en av fordelene med wavelet-analyse fordi waveletene kan tilpasses de dataene man har om man er flink. 39
Prosjektoppgave i FYS2130 våren 2009 (m. korrigering mandag kl 1500)
1 Prosjektoppgave i FYS2130 våren 2009 (m. korrigering mandag kl 1500) I år er det samme prosjektoppgave for alle som skal opp til eksamen i kurset i vår. Selv de som har godkjent obliger fra tidligere
Noen presiseringer mhp Diskret Fourier Transform. Relevant for oblig 1.
FYS2130 Våren 2008 Noen presiseringer mhp Diskret Fourier Transform. Relevant for oblig 1. Vi har på forelesning gått gjennom foldingsfenomenet ved diskret Fourier transform, men ikke vært pinlig nøyaktige
0.1 Morlet wavelets i FYS2130-notasjon (v )
0.1 Morlet wavelets i FYS2130-notasjon (v 28.04.11) I wavelet-formalismen opererer vi ofte med en moder-wavelet som trekkes ut ved hjelp av en skaleringsfaktor for å lage såkalt wavelet-døtre. Dette er
Oblig 1 FYS2130. Elling Hauge-Iversen
Oblig 1 FYS2130 Elling Hauge-Iversen February 9, 2009 Oppgave 1 For å estimere kvalitetsfaktoren til basilarmembranen for ulike frekvenser har jeg laget et program som generer et rent sinussignal. Ideen
Obligatorisk oppgave nr 4 FYS Lars Kristian Henriksen UiO
Obligatorisk oppgave nr 4 FYS-213 Lars Kristian Henriksen UiO 18. februar 215 Diskusjonsoppgaver: Oppgave 1 Hvordan kan vi ved å ta utgangspunkt i et frekvensspekter lage en syntstisk lyd? Vil en slik
MAT-INF 2360: Obligatorisk oppgave 1
6. februar, MAT-INF 36: Obligatorisk oppgave Oppgave I denne oppgaven skal vi sammenligne effektiviteten av FFT-algoritmen med en mer rett frem algoritme for DFT. Deloppgave a Lag en funksjon y=dftimpl(x)
FYS2130 Svingninger og bølger, Obligatorisk oppgave C. Nicolai Kristen Solheim
FYS213 Svingninger og bølger, Obligatorisk oppgave C Nicolai Kristen Solheim FYS213 Svingninger og bølger Ukeoppgave, sett C Nicolai Kristen Solheim Ukeoppgave, sett C Oppgavetype 1 a) Læreboken beskriver
Fourier-analyse. Hittil har vi begrenset oss til å se på bølger som kan beskrives ved sinus- eller cosinusfunksjoner
Fourier-analyse Hittil har vi begrenset oss til å se på bølger som kan beskrives ved sinus- eller cosinusfunksjoner som yxt (, ) = Asin( kx ωt+ ϕ) En slik bølge kan karakteriseres ved en enkelt frekvens
FYS2130 OBLIG 1 Anders Hafreager
FYS23 OBLIG Anders Hafreager 28..29 28..29 OPPGAVE I denne oppgaven skal jeg prøve å bestemme kvalitetsfaktoren (Q-verdien) for svingehårene i basillarmembranen som ligger i øret. Jeg skal gjøre dette
Kapittel 17. Wavelet analyse Innledning*
Kapittel 17 Wavelet analyse [Copyright for kapittelet, tekst og figurer: Arnt Inge Vistnes.] 17.1 Innledning* Syng en a og hold tonen hele tiden mens vi digitaliserer lyden. Fourier-omvendes signalet vil
Obligatorisk oppgave nr 3 FYS Lars Kristian Henriksen UiO
Obligatorisk oppgave nr 3 FYS-13 Lars Kristian Henriksen UiO 11. februar 15 Diskusjonsoppgaver 1 Fjerde ordens Runge-Kutta fungerer ofte bedre enn Euler fordi den tar for seg flere punkter og stigningstall
HØGSKOLEN I SØR-TRØNDELAG Avdeling for teknologi
HØGSKOLEN I SØR-TRØNDELAG Avdeling for teknologi Målform: Bokmål Eksamensdato: 6.mai 215 Varighet/eksamenstid: 5 timer Emnekode: TELE 23 Emnenavn: Signalbehandling Klasse(r): 2EI 2EE Studiepoeng: 1 Faglærer(e):
TMA Matlab Oppgavesett 2
TMA4123 - Matlab Oppgavesett 2 18.02.2013 1 Fast Fourier Transform En matematisk observasjon er at data er tall, og ofte opptrer med en implisitt rekkefølge, enten i rom eller tid. Da er det naturlig å
Oblig 3 i FYS mars 2009
Oblig 3 i FYS230 2. mars 2009 Innledning [Copyright 2009: D.S.Amundsen og A.I.Vistnes.] David Skålid Amundsen har laget hovedskissen til denne obligen i en sommerjobb han utførte for oss sommeren 2008.
Løsningsforslag MAT102 Vår 2018
Løsningsforslag MAT102 Vår 2018 Universitetet i Bergen Det matematisk-naturvitenskapelige fakultet Eksamen i emnet MAT102 Tirsdag 12 juni 2018, kl 0900-1400 Oppgavesettet har fem oppgaver Hver deloppgave
INF 1040 høsten 2009: Oppgavesett 8 Introduksjon til lyd (kapittel 9 og 10)
INF 1040 høsten 2009: Oppgavesett 8 Introduksjon til lyd (kapittel 9 og 10) Vi regner med at decibelskalaen og bruk av logaritmer kan by på enkelte problemer. Derfor en kort repetisjon: Absolutt lydintensitet:
Matematikk Øvingsoppgaver i numerikk leksjon 9. Løsningsforslag
Matematikk 000 Øvingsoppgaver i numerikk leksjon 9 Løsningsforslag Oppgave Integral som en sum av rektangler a) 3 f(x) dx = 3 x 3 dx = [ ] 3 3 + x3+ = [ x 4 ] 3 4 = 34 = 20. 4 b) 0.5 f() + 0.5 f(.5) +
Prosjektoppgave i kurset FYS2130 våren 2011
Prosjektoppgave i kurset FYS2130 våren 2011 Generelt Oppgaven består av to helt forskjellige deler: 1. Beregninger av elektromagnetiske bølger ( stråling ) fra mobiltelefoniantenner, og 2. Waveletanalyse
Uke 10: Diskret Fourier Transform, II
Uke 10: Diskret Fourier Transform, II Jo Inge Buskenes Institutt for informatikk, Universitetet i Oslo INF3470/4470, høst 011 /38 Dagens temaer Spektral glatting pga endelig lengde data Bruk av DFT en
Sprettball Erfaren ComputerCraft PDF
Sprettball Erfaren ComputerCraft PDF Introduksjon Nå skal vi lære hvordan vi kan koble en skjerm til datamaskinen. Med en ekstra skjerm kan vi bruke datamaskinen til å kommunisere med verden rundt oss.
MAT-INF 2360: Obligatorisk oppgave 2
6. mars, 13 MAT-INF 36: Obligatorisk oppgave Innleveringsfrist: 4/4-13, kl. 14:3 Informasjon Den skriftlige besvarelsen skal leveres i obligkassa som står i gangen utenfor ekspedisjonen i 7. et. i Niels
0.1 Kort introduksjon til komplekse tall
Enkel introduksjon til matnyttig matematikk Vi vil i denne innledningen introdusere litt matematikk som kan være til nytte i kurset. I noen tilfeller vil vi bare skrive opp uttrykk uten å komme inn på
Introduksjon. «Diskret» sinus/cosinus i 1D. Funksjonen sin(θ) INF april 2010 Fourier -- En annen vinkling på stoffet i kapittel 4
Introduksjon INF 2310 13. april 2010 Fourier -- En annen vinkling på stoffet i kapittel 4 Fourier: Vi kan uttrykke ethvert bilde som en vektet sum av sinus- og cosinus-signaler med ulik frekvens og orientering
Dagens temaer. Endelig lengde data. Tema. Time 11: Diskret Fourier Transform, del 2. Spektral glatting pga endelig lengde data.
Dagens temaer Time : Diskret Fourier Transform, del Andreas [email protected], INF37 Institutt for informatikk, Universitetet i Oslo Spektral glatting pga endelig lengde data Bruk av en Frekvensestimering
f(t) F( ) f(t) F( ) f(t) F( )
NORGES TEKNISK-NATURVITENSKAPELIGE UNIVERSITET INSTITUTT FOR PETROLEUMSTEKNOLOGI OG ANVENDT GEOFYSIKK Oppgave SIG4045 Geofysisk Signalanalyse Lsningsforslag ving 3 a) ' xy (t) = x()y(t + )d : La oss, for
10 6 (for λ 500 nm); minste størrelse av
Sensorveiledning Eksamen FYS130 Oppgave 1 ( poeng) a) Brytningdeksen er forholdet mellom lyshastigheten i vakuum og lyshastigheten i mediet; siden lyshastigheten i et medium er alltid mindre enn i vakuum,
WAVELET-ANALYSE Ada Gjermundsen
WAVELET-ANALYSE Ada Gjermundsen FORORD Slik denne oppgaven var lagt opp skapte den mer forvirring enn forståelse hos meg. Det ble mer fokus på tekniske detaljer, enn selve metoden. Jeg tolket denne oppgaven
HØGSKOLEN I SØR-TRØNDELAG Avdeling for teknologi
HØGSKOLEN I SØR-TRØNDELAG Avdeling for teknologi Målform: Bokmål Eksamensdato: 7.mai 24 Varighet/eksamenstid: 5 timer Emnekode: TELE 23 Emnenavn: Signalbehandling Klasse(r): 2EI 2EE Studiepoeng: Faglærer(e):
Kanter, kanter, mange mangekanter. Introduksjon: Steg 1: Enkle firkanter. Sjekkliste. Skrevet av: Sigmund Hansen
Kanter, kanter, mange mangekanter Skrevet av: Sigmund Hansen Kurs: Processing Tema: Tekstbasert, Animasjon Fag: Matematikk, Programmering, Kunst og håndverk Klassetrinn: 8.-10. klasse, Videregående skole
TMA4123 - Kræsjkurs i Matlab. Oppgavesett 3 Versjon 1.2
TMA4123 - Kræsjkurs i Matlab. Oppgavesett 3 Versjon 1.2 07.03.2013 I dette oppgavesettet skal vi se på ulike måter fouriertransformasjonen anvendes i praksis. Fokus er på støyfjerning i signaler. I tillegg
Universitetet i Stavanger Institutt for petroleumsteknologi
Universitetet i Stavanger Institutt for petroleumsteknologi Side 1 av 6 Faglig kontakt under eksamen: Professor Ingve Simonsen Telefon: 470 76 416 Eksamen i PET110 Geofysikk og brønnlogging Mar. 09, 2015
EKSAMEN Løsningsforslag
5..7 EKSAMEN Løsningsforslag Emnekode: ITD5 Dato:. desember 7 Hjelpemidler: - To A-ark med valgfritt innhold på begge sider. - Formelhefte. - Kalkulator som deles ut samtidig med oppgaven. Emnenavn: Matematikk
TMA Kræsjkurs i Matlab. Oppgavesett 2/3
TMA4123 - Kræsjkurs i Matlab. Oppgavesett 2/3 28.02.2013 Oppgave 0: Bruk av fftshift og ifftshift Når du bruker fft i Matlab flyttes frekvensene over midten av spekteret, slik at får du ut frekvensdata
Lineære likningssystemer og matriser
Kapittel 3 Lineære likningssystemer og matriser I dette kapittelet skal vi sette sammen Kapittel 1 og 2. 3.1 Den utvidede matrisen til et likningssystem Vi starter med et lineært likningssystem med m likninger
Prosjektoppgave i FYS-MEK 1110
Prosjektoppgave i FYS-MEK 1110 03.05.2005 Kari Alterskjær Gruppe 1 Prosjektoppgave i FYS-MEK 1110 våren 2005 Hensikten med prosjektoppgaven er å studere Jordas bevegelse rundt sola og beregne bevegelsen
MAT-INF 2360: Obligatorisk oppgave 1
7. februar, 2013 MAT-INF 2360: Obligatorisk oppgave 1 Innleveringsfrist: 28/2-2013, kl. 14:30 Informasjon Skriftlige besvarelser skal leveres i obligkassa som står i gangen utenfor ekspedisjonen i 7. et.
Prosjektoppgave FYS2130. Vår Innleveringsfrist: 09/ , 20 CEST
Prosjektoppgave FYS2130 Vår 2017 Innleveringsfrist: 09/05-2017, 20 CEST L. B. N. Clausen Om prosjektet og rapporten Vi ønsker at arbeidet med prosjektoppgaven gir deg økt forståelse og innsikt i et fenomen
Prosjektoppgave i FYS2130
1 Prosjektoppgave i FYS2130 30. april - 7. mai 2012 Prosjektoppgaven består av fem deler som det går an å jobbe på parallelt en del av tiden. I del 1 skal vi finne ut hvordan en mekanisk svingekrets responderer
Matematikk 1000. Øvingsoppgaver i numerikk leksjon 5 Litt oppsummering undervegs Løsningsforslag
Matematikk 1000 Øvingsoppgaver i numerikk leksjon Litt oppsummering undervegs Løsningsforslag Oppgave 1 Et skjæringspunkt f(x) = x e x g(x) = 1 arctan x. a) Vi kan lage plottet slik i kommando-vinduet:
FY2045/TFY4250 Kvantemekanikk I, løsning øving 8 1 LØSNING ØVING 8
FY045/TFY450 Kvantemekanikk I, løsning øving 8 1 Løsning oppgave 8 1 LØSNING ØVING 8 Koherente tilstander for harmonisk oscillator a. Utviklingen (3) er en superposisjon av stasjonære tilstander for oscillatoren,
Løsningsforslag. Oppgave 1 Gitt matrisene ] [ og C = A = 4 1 B = 2 1 3
Prøve i Matematikk BYFE DAFE Dato: 27. mai 26 Hjelpemiddel: Kalkulator og formelark Alle svar skal grunngis. Alle deloppgaver har lik vekt. Løsningsforslag Oppgave Gitt matrisene [ 2 A 4 B [ 2 og C [ 2
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i : INF2310 Digital bildebehandling Eksamensdag : Tirsdag 25. mars 2014 Tid for eksamen : 15:00 19:00 Oppgavesettett er på : 6 sider
Løsningsforslag til ukeoppgave 12
Oppgaver FYS1001 Vår 018 1 Løsningsforslag til ukeoppgave 1 Oppgave 16.0 Loddet gjør 0 svingninger på 15 s. Frekvensen er da f = 1/T = 1,3 T = 15 s 0 = 0, 75 s Oppgave 16.05 a) Det tar et døgn for jorda
Fourier-Transformasjoner
Fourier-Transformasjoner Lars Vidar Magnusson February 21, 2017 Delkapittel 4.1 Background Delkapittel 4.2 Preliminary Concepts Fourier Fourier var en fransk matematiker/fysiker som levde på 1700/1800-tallet.
Bruk av tidsvindu. Diskret Fourier-transform. Repetisjon: Fourier-transformene. Forelesning 6. mai 2004
Repetisjon: Fourier-transformene Forelesning 6. mai 4 Spektralanalyse Pensum i boken: 3-4 til 3-5. Diskret tid Kontinuerlig tid Diskret frekvens DFT, X[k] Fourierrekker, {a k } Kontinuerlig frekvens DTFT,
Kanter, kanter, mange mangekanter
Kanter, kanter, mange mangekanter Nybegynner Processing PDF Introduksjon: Her skal vi se på litt mer avansert opptegning og bevegelse. Vi skal ta utgangspunkt i oppgaven om den sprettende ballen, men bytte
Verden. Steg 1: Vinduet. Introduksjon
Verden Introduksjon Processing Introduksjon Velkommen til verdensspillet! Her skal vi lage begynnelsen av et spill hvor man skal gjette hvilke verdensdeler som er hvor. Så kan du utvide oppgava til å heller
14. Wavelettransformasjon
14. Wavelettransformasjon Dette kapitlet tar opp følgende temaer: Tidsoppløst fouriertransanalyse, fourier- vs waveletanalyse, Morlet wavelets, frekvensoppløsning vs tidsoppløsning, optimaliserting, randproblem.
Lyd. Litt praktisk informasjon. Litt fysikk. Lyd som en funksjon av tid. Husk øretelefoner på øvelsestimene denne uken og en stund framover.
Lyd Hva er lyd? Sinuser, frekvenser, tidssignaler Hvordan representere lydsignaler matematisk? Litt praktisk informasjon Husk øretelefoner på øvelsestimene denne uken og en stund framover. Lydeksemplene
Fouriersyntese av lyd
Fouriersyntese av lyd Hensikt Laboppsettet vist p a bildet er kjent under navnet Fouriersyntese av lyd. Hensikten med oppsettet er a erfare hvordan ulike kombinasjoner av en grunntone og dens overharmoniske
Det du skal gjøre i denne oppgava er først å sette opp bakgrunnen til spillet og så rett og slett å få firkanter til å falle over skjermen.
Tetris Introduksjon Processing Introduksjon Lag starten på ditt eget tetris spill! Det du skal gjøre i denne oppgava er først å sette opp bakgrunnen til spillet og så rett og slett å få firkanter til å
Figur 2 viser spektrumet til signalet fra oppgave 1 med 20% pulsbredde. Merk at mydaqs spektrumsanalysator 2
Oppgave 1 teoretisk del; 2 poeng Figur 1 viser et stolpediagram fra MatLab der c k er plottet for a = 0.2, a = 0.5 og a = 0.01. V 0 = 1 for alle plottene. Oppgave 1 praktisk del; 2 poeng Figur 2 viser
Simulerings-eksperiment - Fysikk/Matematikk
Simulerings-eksperiment - Fysikk/Matematikk Tidligere dette semesteret er det gjennomført et såkalt Tracker-eksperiment i fysikk ved UiA. Her sammenlignes data fra et kast-eksperiment med data fra en tilhørende
HØGSKOLEN I SØR-TRØNDELAG Avdeling for teknologi
HØGSKOLEN I SØR-TRØNDELAG Avdeling for teknologi Målform: Eksamensdato: 14.5.213 Varighet/eksamenstid: Emnekode: Emnenavn: 5 timer EDT24T Signalbehandling Klasse(r): 2EI 2EE Studiepoeng: 1 Faglærer(e):
Fourier-Transformasjoner IV
Fourier-Transformasjoner IV Lars Vidar Magnusson March 1, 2017 Delkapittel 4.6 Some Properties of the 2-D Discrete Fourier Transform Forholdet Mellom Spatial- og Frekvens-Intervallene Et digitalt bilde
MAT 1110: Obligatorisk oppgave 1, V-07: Løsningsforslag
1 MAT 111: Obligatorisk oppgave 1, V-7: Løsningsforslag Oppgave 1. a) Vi deriverer på vanlig måte: ( e (sinh x) x e x ) = = ex + e x = cosh x, ( e (cosh x) x + e x ) = = ex e x = sinh x Enkel algebra gir
Tetris. Introduksjon. Skrevet av: Kine Gjerstad Eide. Lag starten på ditt eget tetris spill!
Tetris Skrevet av: Kine Gjerstad Eide Kurs: Processing Introduksjon Lag starten på ditt eget tetris spill! Det du skal gjøre i denne oppgava er først å sette opp bakgrunnen til spillet og så rett og slett
Kapittel 2. Fourier analyse. 2.1 Fourier transform*
Kapittel 2 Fourier analyse [Copyright for kapittelet, tekst og figurer: Arnt Inge Vistnes.] 2.1 Fourier transform* Vi kan fremstille svingefenomener, slik vi hittil har gjort, ved å angi en tidsvariabel
MAT-INF 2360: Obligatorisk oppgave 2
6. mars, 13 MAT-INF 36: Obligatorisk oppgave Innleveringsfrist: 4/4-13, kl. 14:3 Informasjon Den skriftlige besvarelsen skal leveres i obligkassa som står i gangen utenfor ekspedisjonen i 7. et. i Niels
Sprettende ball Introduksjon Processing PDF
Sprettende ball Introduksjon Processing PDF Introduksjon: I denne modulen skal vi lære et programmeringsspråk som heter Processing. Det ble laget for å gjøre programmering lett for designere og andre som
LØSNINGSFORSLAG TIL SIGNALBEHANDLING 1 JUNI 2010
LØSNINGSFORSLAG TIL SIGNALBEHANDLING JUNI Løsningsforslag til eksamen i Signalbehandling, mai Side av 5 Oppgave a) Inngangssignalet x(t) er gitt som x( t) = 5cos(π t) + 8cos(π 4 t). Bruker Eulers formel
Matematikk 1000. Øvingsoppgaver i numerikk leksjon 11 Eulers metode. Løsningsforslag
Matematikk 1000 Øvingsoppgaver i numerikk leksjon 11 Eulers metode Løsningsforslag Oppgave 1 Samanlikning med analytisk løsning y = 3 2 x y, y(0) = 1. a) Kandidat til løsning: y = e x3/2. Vi deriverer
INF mars 2017 Fourier I -- En litt annen vinkling på stoffet i kapittel 4
INF 2310 22. mars 2017 Fourier I -- En litt annen vinkling på stoffet i kapittel 4 I dag: Sinus-funksjoner i 1D og 2D 2D diskret Fouriertransform (DFT) Mandag 27. mars: Supplementsforelesning holdt av
HØGSKOLEN I SØR-TRØNDELAG Avdeling for teknologi
HØGSKOLEN I SØR-TRØNDELAG Avdeling for teknologi Målform: Eksamensdato: 17.12.2014 Varighet/eksamenstid: Emnekode: Emnenavn: Klasse(r): 3 timer TELE1001A 14H Ingeniørfaglig yrkesutøving og arbeidsmetoder
Prosjektoppgave, FYS-MEK1110 V06 ROBERT JACOBSEN
Prosjektoppgave, FYS-MEK1110 V06 ROBERT JACOBSEN Innledning Prosjektet i FYS-MEK1110 v06 handler om å forske litt på hvordan Jupiters bane er, og hvordan denne kan sammenliknes ved andre baner i solsystemet.
Konvolusjon og filtrering og frevensanalyse av signaler
Høgskolen i Østfold Avdeling for informasjonsteknologi Fag IAD33505 Bildebehandling og mønstergjenkjenning Laboppgave nr 2 Konvolusjon og filtrering og frevensanalyse av signaler Sarpsborg 21.01.2005 20.01.05
Kapittel 13. Wavelettransformasjon
Kapittel 13 Wavelettransformasjon 2.9 Sqrt(Wavelet Power Spectrum) Log10(frekvens i Hz) 2.8 2.7 2.6 0.0 0.5 1.0 1.5 Tid (s) 2.0 2.5 Ønsker du deg en samtidig frekvens- og tidsanalyse, er wavelettransformasjon
MAT-INF 1100: Obligatorisk oppgave 1
13. september, 2018 MAT-INF 1100: Obligatorisk oppgave 1 Innleveringsfrist: 27/9-2018, kl. 14:30 i Devilry Obligatoriske oppgaver («obliger») er en sentral del av MAT-INF1100 og er utmerket trening i å
Svingninger i en elektrisk RCL-krets med og uten påtrykt vekselspenning.
1 Noen gruppeoppgaver for uke 20 våren 2008 i FYS2130: Svingninger i en elektrisk RCL-krets med og uten påtrykt vekselspenning. Vi har på forelesninger i uke 19 vist hvordan vi kan løse den andre ordens
FFT. Prosessering i frekvensdomenet. Digital signalprosessering Øyvind Brandtsegg
FFT Prosessering i frekvensdomenet Digital signalprosessering Øyvind Brandtsegg Representasjonsmåter Tidsdomene: Amplityde over tid Frekvensdomene: Amplityde over frekvens Hvorfor? Prosessering i frekvensdomenet
FYS2130 Svingninger og bølger, Prosjektoppgave V2011. Kandidatnummer 49
FYS2130 Svingninger og bølger, Prosjektoppgave V2011 Kandidatnummer 49 Prosjektoppgave FYS2130 V2011 Oppgave 1 a) Vi skal aller først se på beregninger av elektromagnetiske bølger ( stråling ) fra mobiltelefoniantenner.
Kan vi lære litt kvantefysikk ved å lytte til noen lydprøver? Arnt Inge Vistnes Fysisk institutt, UiO
Kan vi lære litt kvantefysikk ved å lytte til noen lydprøver? Arnt Inge Vistnes Fysisk institutt, UiO La oss starte med lyttingen... Vi spiller fire ulike lydprøver. Oppgaven er å bestemme tonehøyden.
Eksamen R2 høst 2011, løsning
Eksamen R høst 0, løsning Oppgave (4 poeng) a) Deriver funksjonene f e ) Bruker produktregelen for derivasjon, uv uv uv f e e e e ) g sin Bruker kjerneregelen på uttrykket cos der u og g u sinu Vi har
Verden. Introduksjon. Skrevet av: Kine Gjerstad Eide og Ruben Gjerstad Eide
Verden Skrevet av: Kine Gjerstad Eide og Ruben Gjerstad Eide Kurs: Processing Tema: Tekstbasert Fag: Matematikk, Programmering, Samfunnsfag Klassetrinn: 8.-10. klasse, Videregående skole Introduksjon Velkommen
( x+ π 2) Bakgrunn: Sinus og cosinus. Bakgrunn: Samplet sinus i 1D. Bakgrunn: Samplet sinus i 2D. Bakgrunn: Sinus i 2D. sin( x)=cos.
Bakgrunn: Samplet sinus i 1D Bakgrunn: Sinus og cosinus En generell samplet sinusfunksjon kan skrives som: y(t) = A sin(2πut/n + φ) t : tid; 0, 1,..., N-1 A : amplitude u : antall hele perioder* N : antall
Forelesning nr.13 INF 1410
Forelesning nr.3 INF 4 Komplekse frekvenser og Laplace-transform Oversikt dagens temaer Me Mer om sinusformede signaler om komplekse frekvenser Introduksjon til Laplace-transform Løsning av kretsligninger
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i MAT-INF 00 Modellering og beregninger. Eksamensdag: Torsdag 6. desember 202. Tid for eksamen: 9:00 3:00. Oppgavesettet er på 8
Småtriks med integraler
Småtriks med integraler Carl Inge C. Nilsen (carlingn), UiO 28. februar 26 1 Hvordan vise effekten av tidsskift på Fourier koeffisientene. Gitt et signalx(t) med periodet og kjente Fourier koeffisientera
Kapittel 13. Wavelettransformasjon. Dummy tekst for å spenne ut et åpent felt for et førsteside-opplegg. c 1. Sqrt(Wavelet Power Spectrum)
Kapittel 13 Wavelettransformasjon Dummy tekst for å spenne ut et åpent felt for et førsteside-opplegg. c 1 2.9 Sqrt(Wavelet Power Spectrum) Log10(frekvens i Hz) 2.8 2.7 2.6 0.0 0.5 1.0 1.5 Tid (s) 2.0
INF 1040 Løsningsforslag til kapittel
INF 040 Løsningsforslag til kapittel 8 Oppgave : Huffmankoding med kjente sannsynligheter Gitt en sekvens av symboler som er tilstrekkelig lang, og som inneholder de 6 symbolene A, B, C, D, E, F. Symbolene
Kapittel august Institutt for geofag Universitetet i Oslo. GEO En Introduksjon til MatLab. Kapittel 2.
Institutt for geofag Universitetet i Oslo 28. august 2012 Kommandovinduet Det er gjennom kommandovinduet du først og fremst interagerer med MatLab ved å gi datamaskinen kommandoer når >> (kalles prompten
Matematikk Øvingsoppgaver i numerikk leksjon 6 Løsningsforslag
Matematikk 1000 Øvingsoppgaver i numerikk leksjon 6 Løsningsforslag Oppgave 1 Summer og for-løkker a) 10 i=1 i 2 = 1 2 + 2 2 + 3 2 + 4 2 + 5 2 + 6 2 + 7 2 + 8 2 + 9 2 + 10 2 = 1 + 4 + 9 + 16 + 25 + 36
Matematikk 1000. Øvingsoppgaver i numerikk leksjon 3. Løsningsforslag
Matematikk 1000 Øvingsoppgaver i numerikk leksjon 3 Løsningsforslag Oppgave 1 Flo og fjære a) >> x=0:.1:24; >> y=3.2*sin(pi/6*(x-3)); Disse linjene burde vel være forståelige nå. >> plot(x,y,'linewidth',3)
Løsningsforslag. Innlevering i BYFE/EMFE 1000 Oppgavesett 1 Innleveringsfrist: 14. september klokka 14:00 Antall oppgaver: 3.
Innlevering i BYFE/EMFE 1000 Oppgavesett 1 Innleveringsfrist: 14. september klokka 14:00 Antall oppgaver: 3 Løsningsforslag Oppgave 1 a) ln a ln 3 a+ln 4 a = ln a 1/2 ln a 1/3 +ln a 1/4 = 1 2 ln a 1 3
Inf109 Programmering for realister Uke 5. I denne leksjonen skal vi se på hvordan vi kan lage våre egne vinduer og hvordan vi bruker disse.
Inf109 Programmering for realister Uke 5 I denne leksjonen skal vi se på hvordan vi kan lage våre egne vinduer og hvordan vi bruker disse. Før du starter må du kopiere filen graphics.py fra http://www.ii.uib.no/~matthew/inf1092014
Kapittel 13. Wavelettransformasjon. Sqrt(Wavelet Power Spectrum) Log10(frekvens i Hz)
Kapittel 13 Wavelettransformasjon Dummy tekst for å spenne ut et åpent felt for et førsteside-opplegg. c 1 2.9 Sqrt(Wavelet Power Spectrum) Log10(frekvens i Hz) 2.8 2.7 2.6 0.0 0.5 1.0 1.5 Tid (s) 2.0
Utkast til: Løsningsforslag til eksamen i. Ingeniørfaglig yrkesutøvelse og arbeidsmetoder. 18.des for oppgave 1, 2 og 3
Utkast til: Løsningsforslag til eksamen i Ingeniørfaglig yrkesutøvelse og arbeidsmetoder 18.des 2013 for oppgave 1, 2 og 3 Oppgave 1 (15%) Anta vi har en matrise: A = 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
Obligatorisk oppgave 1
Obligatorisk oppgave 1 a) Oppgaveteksten oppgir et vektorfelt f(x, y) F x, y = g x, y der f og g er oppgitt ved f x, y = x 3 3xy 1 og g x, y = y 3 + 3x y. Vi kan med dette regne ut Jacobimatrisen F x,
Svingninger og Bølger Oblig1 Matthew Terje Aadne
Svingninger og Bølger Oblig1 Matthew Terje Aadne Oppgave 1) Ved å ha den initielle frekvensen f0 = 3000, og en ny nærliggende frekvens f1, fant jeg at ejg kunne høre forskjell mellom dem når f1=3002. Så
Obligatorisk oppgave nr 4 FYS-2130. Lars Kristian Henriksen UiO
Obligatorisk oppgave nr 4 FYS-2130 Lars Kristian Henriksen UiO 23. februar 2015 Diskusjonsoppgaver: 3 Ved tordenvær ser vi oftest lynet før vi hører tordenen. Forklar dette. Det finnes en enkel regel
TDT4105 IT Grunnkurs Høst 2014
TDT4105 IT Grunnkurs Høst 2014 Norges teknisknaturvitenskapelige universitet Institutt for datateknikk og informasjonsvitenskap Øving 6 1 Teori a) Hva er 2-komplement? b) Hva er en sample innen digital
