<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>KOMA.si, stari ... &#187; ifft</title>
	<atom:link href="http://www.koma.si/tag/ifft/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.koma.si</link>
	<description>... pa kak&#039; te tega ne razumeš?</description>
	<lastBuildDate>Mon, 08 Aug 2011 00:40:38 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<xhtml:meta xmlns:xhtml="http://www.w3.org/1999/xhtml" name="robots" content="noindex" />
		<item>
		<title>SIS: 5.vaja: Lastnosti DFT &#8211; Izgubno stiskanje podatkov s pomočjo DFT</title>
		<link>http://www.koma.si/2010/04/sis-5-vaja-lastnosti-dft-izgubno-stiskanje-podatkov-s-pomocjo-dft/</link>
		<comments>http://www.koma.si/2010/04/sis-5-vaja-lastnosti-dft-izgubno-stiskanje-podatkov-s-pomocjo-dft/#comments</comments>
		<pubDate>Mon, 12 Apr 2010 22:07:17 +0000</pubDate>
		<dc:creator>Sonicelo</dc:creator>
				<category><![CDATA[SIS]]></category>
		<category><![CDATA[dft]]></category>
		<category><![CDATA[fft]]></category>
		<category><![CDATA[ifft]]></category>
		<category><![CDATA[matlab]]></category>
		<category><![CDATA[stiskanje]]></category>

		<guid isPermaLink="false">http://www.koma.si/?p=459</guid>
		<description><![CDATA[<h3>Navodilo:</h3>
V primeru, da imamo signal, v katerem nastopa relativno malo frekvenc, lahko pretvorbo v frekvenčni prostor izkoristimo tudi za izgubno stiskanje podatkov  (za ta namen se pogosteje uporablja kosinusna in valčna transformacija). 

V našem primeru bomo poskusili stisniti tone, ki nastopajo pri prejšnji nalogi. Postopek stiskanja pa bo naslednji:
signal pretvorimo v frekvenčni prostor, delali bomo v pravokotnih koordinatah
obe amplitudi (kosinus in sinus) pri frekvencah, pri katerih je absolutna amplituda kosinusov manjša od podanega praga, postavimo na 0
podatke stisnemo z uporabo naslednjih pravil:
<ol><li>stiskati začnemo pri frekvenci 0 in nadaljujemo do Fvz/2 (torej od indeksa 1 do N/2+1)</li>
<li>najprej zapišemo amplitudo kosinusa, nato še sinusa</li>
<li>v kolikor je amplituda kosinusa 0, zapišemo najprej 0, nato pa še število, kolikokrat se ta ničla ponovi</li>
<li>postopek nato nadaljujemo pri prvi neničelni vrednosti</li></ol>

Primer: X=[9 3+2i 0 0 5+3i 0 8+9i....] bi stisnili v vektor [9 0 3 2 0 4 5 3 0 2 8 9].

Napišite še postopek za dekompresijo, ki bo ponovno razširil stisnjeni posnetek. Za pretvorbo iz frekvenčnega v časovni prostor uporabite funkcijo ifft.

Oddati morate postopek za kompresijo in dekompresijo, oddajte pa tudi tekstovno datoteko, v kateri opišite, kako se je kompresija obnesla (kakšen signal, prag, dosežena kvaliteta, razmerje velikosti) .


Zgradba vašega programa naj bo naslednja:
<ul><li><strong>function  izhod=kodiraj_podatke(podatki)</strong> - v tej funkciji stisnemo ničle po opisanem postopku ([9 3+2i 0 0 5+3i 0 8+9i] kodiramo v vektor [9 0 3 2 0 4 5 3 0 2 8 9]).</li>
<li><strong>function izhod=dekodiraj_podatke(podatki)</strong> - obratna funkcija od zgoraj opisane ([9 0 3 2 0 4 5 3 0 2 8 9] dekodiramo v [9 3+2i 0 0 5+3i 0 8+9i] )</li>
<li><strong>function izhod=stisni_signal(signal, prag)</strong> - v tej funkciji napravimo FFT, postavimo ustrezne amplitude na 0, odrežemo podatke, ki se podvajajo ter kličemo funkcijo kodiraj_podatke.</li>
<li><strong>function izhod=razsiri_signal(signal)</strong> - tu razširimo signal - kličemo funkcijo dekodiraj podatke, rekonstruiramo podatke, ki se podvojijo ter pokličemo funkcijo IFFT.</li></ul>
<strong>POZOR!</strong> Podatki, ki so zrcaljeni čez polovico so tudi konjugirani (imaginarnemu delu se spremeni predznak. npr. če X(2)=2+3i, potem X(end)=2-3i). Uporabite vgrajeno funkcijo conj.]]></description>
		<wfw:commentRss>http://www.koma.si/2010/04/sis-5-vaja-lastnosti-dft-izgubno-stiskanje-podatkov-s-pomocjo-dft/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

