<?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>FireTeam &#187; loop</title>
	<atom:link href="http://www.fireteam.it/tag/loop/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.fireteam.it</link>
	<description>#fuoco@AzzurraNet</description>
	<lastBuildDate>Tue, 16 Mar 2010 15:55:56 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.4</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Tecnica del Loop-Unrolling</title>
		<link>http://www.fireteam.it/2009/07/tecnica-del-loop-unrolling/</link>
		<comments>http://www.fireteam.it/2009/07/tecnica-del-loop-unrolling/#comments</comments>
		<pubDate>Fri, 10 Jul 2009 22:00:52 +0000</pubDate>
		<dc:creator>saverio</dc:creator>
				<category><![CDATA[Programmazione]]></category>
		<category><![CDATA[loop]]></category>

		<guid isPermaLink="false">http://www.fireteam.it/?p=503</guid>
		<description><![CDATA[Lo &#8220;srotolamento&#8221; del ciclo consistente nel modificare il controllo del ciclo
e nel replicare opportunamente le istruzioni all&#8217;interno del ciclo viene
detto &#8220;tecnica di LOOP UNROLLING&#8221;.
VANTAGGI DEL LOOP UNROLLING
- Utilizzo ottimale dei processori con architettura pipelined
- Riduzione dell&#8217;overhead del ciclo di iterazione
- Riduzione del numero di trasferimenti fra i vari livelli memoria
- Aumento delle operazioni concorrenti
L&#8217;overhead del [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.fireteam.it/wp-content/uploads/2009/07/rolled_liquorice.jpg"><img class="alignright size-full wp-image-512" title="rolled" src="http://www.fireteam.it/wp-content/uploads/2009/07/rolled_liquorice.jpg" alt="rolled" width="258" height="232" /></a>Lo &#8220;srotolamento&#8221; del ciclo consistente nel modificare il controllo del ciclo<br />
e nel replicare opportunamente le istruzioni all&#8217;interno del ciclo viene<br />
detto &#8220;tecnica di LOOP UNROLLING&#8221;.</p>
<h2>VANTAGGI DEL LOOP UNROLLING</h2>
<p>- Utilizzo ottimale dei processori con architettura pipelined<br />
- Riduzione dell&#8217;overhead del ciclo di iterazione<br />
- Riduzione del numero di trasferimenti fra i vari livelli memoria<br />
- Aumento delle operazioni concorrenti</p>
<p>L&#8217;overhead del programma e il numero di trasferimenti di dati dai livelli<br />
più bassi di memoria ai registri Si riducono di un fattore proporzionale alla<br />
nuova lunghezza del ciclo (profondità dell&#8217;unrolling).<br />
<span id="more-503"></span></p>
<h2>SVANTAGGI DEL LOOP UNROLLING</h2>
<p>- Aumento della memoria destinata al programma<br />
- Perdita della generalità del codice*</p>
<p>* se si effettua l&#8217;unrolling a mano, mentre se si usa un compilatore per queste<br />
tecniche se ne risente di meno; ad esempio, il compilatore gcc supporta<br />
l&#8217;opzione &#8220;-unroll-all-loops&#8221; per effettuare automaticamente il loop unrolling.</p>
<h2>ESEMPIO DI APPLICAZIONE 1</h2>
<p>I clicli:</p>
<p>for i=1 to n<br />
a[i] = x(i) + i<br />
endfor<br />
for i=1 to n<br />
b[i] = x(i) + i<br />
endfor</p>
<p>Si possono unificare in:</p>
<p>for i=1 to n<br />
a[i] = x(i) + i<br />
b[i] = x(i) + i<br />
endfor</p>
<h2>ESEMPIO DI APPLICAZIONE 2</h2>
<p>Il ciclo:</p>
<p>for i=1 to n<br />
if (i % 2) == 0<br />
y(i)++;<br />
else<br />
y(i)&#8211;;<br />
endfor</p>
<p>si puo&#8217; dividere in questo modo per evitare l&#8217;if:</p>
<p>for i=2 to n step 2<br />
y(i)++;<br />
endfor<br />
for i=1 to n step 2<br />
y(i)&#8211;;<br />
endfor</p>
<h2>ESEMPIO DI APPLICAZIONE 2</h2>
<p>Un ciclo del tipo:</p>
<p>for i=1 to n<br />
y(i)=0<br />
endfor</p>
<p>puo&#8217; essere modificato il passo del ciclo in questo modo:</p>
<p>for i=1 to n step 2<br />
y(i)=0<br />
y(i+1)=0<br />
endfor</p>
]]></content:encoded>
			<wfw:commentRss>http://www.fireteam.it/2009/07/tecnica-del-loop-unrolling/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
