<?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>David Gustafsson &#187; matlab</title>
	<atom:link href="http://www.techonomics.se/tag/matlab/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.techonomics.se</link>
	<description>&#62; Det viktiga samspelet mellan teknik och ekonomi</description>
	<lastBuildDate>Sun, 23 Oct 2011 21:24:36 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Hitta ett optimalt polygon som omsluter slumpmässiga komplexa punkter &#8211; Konvext hölje</title>
		<link>http://www.techonomics.se/teknik/hitta-ett-optimalt-polygon-som-omsluter-slumpmassiga-komplexa-punkter-konvext-holje/</link>
		<comments>http://www.techonomics.se/teknik/hitta-ett-optimalt-polygon-som-omsluter-slumpmassiga-komplexa-punkter-konvext-holje/#comments</comments>
		<pubDate>Tue, 27 Jul 2010 20:27:10 +0000</pubDate>
		<dc:creator>David Gustafsson</dc:creator>
				<category><![CDATA[Programmering]]></category>
		<category><![CDATA[Teknik]]></category>
		<category><![CDATA[Convex Hull]]></category>
		<category><![CDATA[Konvext hölje]]></category>
		<category><![CDATA[matlab]]></category>
		<category><![CDATA[Polygon]]></category>

		<guid isPermaLink="false">http://www.techonomics.se/?p=599</guid>
		<description><![CDATA[Inledning
I sommar jobbar jag på en teknikavdelning i Västerås. Jag har jobbat på samma företag och på ungefär samma kontor under tre raka somrar. Arbetet är väldigt tekniskt, roligt och utmanande. Till skillnad från många andra sommarjobb på kontor har jag hittat ett där jag får ansvar och får jobba med vanliga arbetsuppgifter. Konkret så [...]]]></description>
			<content:encoded><![CDATA[<h2>Inledning</h2>
<p>I sommar jobbar jag på en teknikavdelning i Västerås. Jag har jobbat på samma företag och på ungefär samma kontor under tre raka somrar. Arbetet är väldigt tekniskt, roligt och utmanande. Till skillnad från många andra sommarjobb på kontor har jag hittat ett där jag får ansvar och får jobba med vanliga arbetsuppgifter. Konkret så jobbar jag med att utveckla verktyg för att förenkla beräkningsarbete med hjälp av till största delen MatLab, GUI-programmering och Java. Den nya objektorienterade stilen i MatLab gör koden betydligt mer tydlig än för några år sedan.</p>
<h2>Problemet</h2>
<p>Här om dagen ställdes jag inför en liten utmaning. Förenklat gick det ut på att hitta ett polygon som omsluter en samling med komplexa punkter som ligger spridda i planet. Till en början hittade jag inte funktionen som gör detta i MatLab, vilket förstås var konstigt. Jag bestämde mig därför för att hitta en egen algoritm. I detta inlägg skall jag beskriva min algoritm.</p>
<div id="attachment_602" class="wp-caption aligncenter" style="width: 592px"><a href="http://www.techonomics.se/upLoads/2010/07/Brevbilaga.png"><img class="size-full wp-image-602  " title="Konvext hölje" src="http://www.techonomics.se/upLoads/2010/07/Brevbilaga.png" alt="Konvext hölje" width="582" height="527" /></a><p class="wp-caption-text">Figur 1. Exempel på konvext hölje.</p></div>
<h2>Min Alogritm</h2>
<p>Jag ska beskriva min algoritm med hjälp av figur 2. Till att börja med skall jag förklara svårigheten med att hitta höljet. Grejen är att alla punkter ligger osorterade i en struktur. Om punkterna sorteras kring en centrumpunkt kan man använda deras ordning och avståndet från centrum för att lösa problemet. Det tar dock minst O(n log(n)) att göra en linjär sortering. Min algoritm jobbar på den osorterade listan och tar säkert ännu mer tid; jag har inte härlett något bevis.</p>
<p>Tanken är i alla fall att börja med min punkten i x-led och därefter hitta den punkt till vilken k värdet blir maximalt. dvs räkna ut:</p>
<p><strong>max(k_i) = (y_min &#8211; y_i)/(x_min &#8211; x_i) för i = [alla punkter]. </strong>Detta ger dig punkten p_2.</p>
<p>Alla punkter med mindre y-värde än X_min kan uteslutas. Alla punkter med mindre x-värde än p_2 kan också uteslutas för vidare genomläsning.</p>
<p>k_2 hittas sedan genom att hitta den punkt som minimerar:</p>
<p><strong>k_1 &#8211; </strong><strong>(y_1 &#8211; y_i)/(x_1 &#8211; x_i) för i = [alla icke uteslutna punkter]</strong></p>
<p>På samma sätt hittas k_a generellt genom:</p>
<p><strong>min(k_a-1 &#8211; </strong><strong>(y_a-1 &#8211; y_i)/(x_a-1 &#8211; x_i)) för i = [alla icke uteslutna punkter]</strong></p>
<p>Uträkningen görs för övre halvan av polygonen tills man kommer till punkten som är maximal i x-led. Därefter görs samma algoritm för den undre halvan av polygonen.</p>
<div id="attachment_603" class="wp-caption aligncenter" style="width: 564px"><a href="http://www.techonomics.se/upLoads/2010/07/Fit-polygon-fig2.png"><img class="size-full wp-image-603 " title="Fit polygon fig2" src="http://www.techonomics.se/upLoads/2010/07/Fit-polygon-fig2.png" alt="Algoritm för konvext hölje" width="554" height="394" /></a><p class="wp-caption-text">Figur 2. Algoritm för konvext hölje.</p></div>
<h3>Prestanda</h3>
<p>Prestandan av algoritmen beror på hur många punkter som hamnar i polygonet. Jag gör lika många linjärsök i listan som det blir punkter i polygonet. Det innebär att komplexiteten är O(N*antalet sök). Antalet punkter i det optimala polygonet blir mellan 10 och 25 beroende på dina slumppunkter. Algoritmen är alltså relativt snabb.</p>
<h3>Kod</h3>
<p>Koden är inte publik.</p>
<h2>MatLabs lösning &#8211; convex hull</h2>
<p>Min algoritm gör samma sak som MatLabs funktion <strong><a title="Convex hull" href="http://www.mathworks.com/access/helpdesk/help/techdoc/ref/delaunaytri.convexhull.html">convhull</a>. Convex hull </strong>är alltså det Engelska ordet för en omslutande polygon eller ett konvext hölje. En annan bra resurs är <a href="http://en.wikipedia.org/wiki/Convex_hull_algorithms">http://en.wikipedia.org/wiki/Convex_hull_algorithms</a> som förklarar att den teoretiska minimum tiden för att hitta ett konvext hölje är av storleksordningen O(n log(n)).</p>
]]></content:encoded>
			<wfw:commentRss>http://www.techonomics.se/teknik/hitta-ett-optimalt-polygon-som-omsluter-slumpmassiga-komplexa-punkter-konvext-holje/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Matlab Image Resizer</title>
		<link>http://www.techonomics.se/teknik/programmering/matlab-image-resizer/</link>
		<comments>http://www.techonomics.se/teknik/programmering/matlab-image-resizer/#comments</comments>
		<pubDate>Tue, 14 Jul 2009 10:29:59 +0000</pubDate>
		<dc:creator>David Gustafsson</dc:creator>
				<category><![CDATA[Programmering]]></category>
		<category><![CDATA[applikation]]></category>
		<category><![CDATA[förminska bilder]]></category>
		<category><![CDATA[matlab]]></category>
		<category><![CDATA[resize images]]></category>

		<guid isPermaLink="false">http://www.techonomics.se/?p=562</guid>
		<description><![CDATA[Jag har skrivit ett litet program för matlab som förminskar bilder. Detta eftersom jag inte hittade den funktionen på något enkelt sätt någonstans. Det bör bli ganska många bilder i Sydney/Australien under utbytesåret som måste laddas upp. Vi har begränsningar på vår uppkoppling där vi bor så det går inte att ha bilder på 5 [...]]]></description>
			<content:encoded><![CDATA[<p>Jag har skrivit ett litet program för matlab som förminskar bilder. Detta eftersom jag inte hittade den funktionen på något enkelt sätt någonstans. Det bör bli ganska många bilder i Sydney/Australien under utbytesåret som måste laddas upp. Vi har begränsningar på vår uppkoppling där vi bor så det går inte att ha bilder på 5 Mb per styck. Efter att jag blivit klar med programmet i det utförande det nu har såg jag dock att det går smidigt att redigera många bilder samtidigt med ett officeprogram. Hur som helst så fungerar programmet bra.</p>
<h2>Syfte</h2>
<p>Programmet syftat till att enkelt förminska alla bilder i en mapp.</p>
<h2>Varför?</h2>
<p>Eftersom det är jobbigt att editera och förminska var bild för sig när många bilder skall fixas.</p>
<h2>Vad krävs för att köra programmet?</h2>
<p>Det krävs att du har en licens på matlab runtime. Är du student som jag skall det inte vara några problem, annars är det tyvärr nog inte gratis.</p>
<h2>Användning</h2>
<p>WYSIWYG.</p>
<h2>Ansvar</h2>
<p>Jag tar inget ansvar för att någonting fungerar.</p>
<p><a href='http://www.techonomics.se/upLoads/2009/07/imageresizer.rar'><br />
<h2>Ladda ner ImageResizer</h2>
<p></a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.techonomics.se/teknik/programmering/matlab-image-resizer/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Matlab Gui med guihandles</title>
		<link>http://www.techonomics.se/teknik/programmering/matlab-gui-med-guihandles/</link>
		<comments>http://www.techonomics.se/teknik/programmering/matlab-gui-med-guihandles/#comments</comments>
		<pubDate>Sun, 28 Jun 2009 16:54:06 +0000</pubDate>
		<dc:creator>David Gustafsson</dc:creator>
				<category><![CDATA[Programmering]]></category>
		<category><![CDATA[gui]]></category>
		<category><![CDATA[guide]]></category>
		<category><![CDATA[guihandles]]></category>
		<category><![CDATA[matlab]]></category>

		<guid isPermaLink="false">http://www.techonomics.se/?p=550</guid>
		<description><![CDATA[Jag har jobbat med ett beräkningsprogram i Matlab. Tanken med detta är att det skall vara användarvänligt och effektivt att göra vanliga beräkningar för vissa typer av anläggningar. I detta program har jag använt mig av en hel del grafiska komponenter som uipanel, uitree och uicontrol.
Många författare av tutorials för Matlab GUI rekommenderar att använda [...]]]></description>
			<content:encoded><![CDATA[<p>Jag har jobbat med ett beräkningsprogram i Matlab. Tanken med detta är att det skall vara användarvänligt och effektivt att göra vanliga beräkningar för vissa typer av anläggningar. I detta program har jag använt mig av en hel del grafiska komponenter som <strong>uipanel</strong>, <strong>uitree</strong> och <strong>uicontrol.</strong></p>
<p>Många författare av tutorials för Matlab GUI rekommenderar att använda Matlabs inbyggda funktion (eller jag kanske ska kalla det för toolbox (?)) som heter guide. Skriv:</p>
<blockquote><p>&gt;&gt;guide</p></blockquote>
<p>I kommandofönstret och du får upp ett fönster där det går att placera och konfigurera komponenter i en figur. Detta har sina fördelar för enkla snabba applikationer. Dock har det stora problem om du vill skriva seriösa program. Detta eftersom det är svårt att ha kontroll på dina grafiska objekt. De bakas in i den exporterade figuren med ändelsen fig.</p>
<h2>Placera dina komponenter själv</h2>
<p>Jag har skrivit mitt program utan att använda <strong>guide</strong>. Det är lätt att skapa och placera ut komponenter. Som ni kan se nedan, krävs en bit kommando en massa kodning. Föreställa sig hur biffiga koderna för spel som <a href="http://www.pokerstars.se/">poker</a> och andra tillämpningar där det finns en mångfald av verksamheter. Anyway, tillbaka till att skriva program utan att använda <strong>guide</strong>. Detta görs genom att ange hantag till fönstret figuren skall skapas i samt positionen i fönstret. Givetvis kan även andra parametrar som färg eller callback konfigureras, precis som inifrån guide. Jag har skrivit mina program som Matlab objekt och använt strategin att lägga ut komponenterna i konstruktorn genom att anropa en utläggningsfunktion, förslagsvis med namnet init gui. Jag sparar mina objekt internt i klassen i en struktur som har tag i alla handtag till komponenterna. Denna struktur initierar jag när jag lägger ut komponenterna. </p>
<blockquote>
<pre>classdef aClassName &lt; handle
   properties
      handleToGui;
   end
   methods
      function obj = aClassName(varargin)
         ...
         obj.initGui();
         ...
      end
      ...
      function fig = initGui(Obj)
         Obj.handleToGui.fig = figure(...);
         Obj.handleToGui.otherComponentName = ...
         ...
      end
   end
end % classdef</pre>
</blockquote>
<h2>Matlabs function guihandles</h2>
<p>Matlab har en funktion som heter guihandles. Den är ganska smidig på många sätt och jag ska förklara varför. Anledningen är att du inte behöver bry dig om att lägga dina komponenter direkt i en struktur när du placerar ut dem eftersom guihandles(parent), ger en struktur med handtag till alla barn (children) som finns i figuren. Genom att kalla på denna kan du initiera <strong>handleToGui</strong> efter att alla komponenter lagts ut. Denna blir då en struktur med fieldnames givet till de taggnamn (<strong>Tag</strong>) komponenterna har givits.</p>
<h2>Problem med Matlabs function guihandles</h2>
<p>Det finns dock en risk med detta som jag tror att Matlab inte har tänkt på. Alternativt är det så att jag och andra har använt funktionen alltför oförsiktigt. Det är nämligen så att gui handles ger handtag till alla grafiska komponenter i figuren. Om du har olika klasser för olika delar av ditt program, t.ex. en separat klass som hanterar en viss typ av plottyta i en del av programmet och en annan klass som gör en liknande uppgift på ett annat ställe kan dessa förstöra för varandra om båda använder guihandles. Guihandles i en subkomponent ger handtagen till hela huvudfiguren (inklusive andra subkomponenter som ligger i den). Om den andra subkomponenten har samma taggnamn på någon komponent kommer dessa att sammanblandas när den aktuella komponenten anropar vad den tror är sin komponent.</p>
<h2>Använd inte Matlabs function guihandles</h2>
<p>Objektorienterad programmering är för mig en programmeringsmetod för att skapa god struktur. Detta genom att låta varje objekt (klass) sköta sina uppgifter internt och endast kommunicera genom bestämda gränssnitt med omgivningen. Globala variabler som <strong>guihandles</strong> ger är livsfarligt. I begreppsvärlden strävar man med andra ord efter låg <strong>coupling</strong>, hög <strong>cohesion </strong>och väl avgränsade<strong> moduler</strong>.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.techonomics.se/teknik/programmering/matlab-gui-med-guihandles/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Matlab programmering</title>
		<link>http://www.techonomics.se/teknik/programmering/matlab-programmering/</link>
		<comments>http://www.techonomics.se/teknik/programmering/matlab-programmering/#comments</comments>
		<pubDate>Fri, 19 Jun 2009 11:35:29 +0000</pubDate>
		<dc:creator>David Gustafsson</dc:creator>
				<category><![CDATA[Programmering]]></category>
		<category><![CDATA[david gustafsson]]></category>
		<category><![CDATA[matlab]]></category>
		<category><![CDATA[matlabprogrammerare]]></category>

		<guid isPermaLink="false">http://www.techonomics.se/?p=538</guid>
		<description><![CDATA[Jag har arbetat med ett Matlab-program under mitt sommarjobb. Styrkan med Matlab är att det är ett väldigt enkelt språk som håller en högre abstraktionsnivå än till exempel java. Till det skall läggas att språket är mycket enkelt när det gäller att utföra beräkningar, lösa differentialekvationer, numeriska räkningar, simuleringar osv. En nackdel, som följer av [...]]]></description>
			<content:encoded><![CDATA[<p>Jag har arbetat med ett Matlab-program under mitt sommarjobb. Styrkan med Matlab är att det är ett väldigt enkelt språk som håller en högre abstraktionsnivå än till exempel java. Till det skall läggas att språket är mycket enkelt när det gäller att utföra beräkningar, lösa differentialekvationer, numeriska räkningar, simuleringar osv. En nackdel, som följer av den höga abstraktionsnivån, är dock att det går ganska långsamt. Det gäller att noga tänka sig för när man kodar.</p>
<p>Matlab bygger från och med version 2008a på java. Det går att köra de flesta funktioner i java genom Matlabfunktionen (det finns även andra funktioner i samma genre):</p>
<blockquote>
<pre>javaMethodEDT('Class or object of class', 'method name', ..., Params)</pre>
</blockquote>
<p>Från och med Matlabs 2008 version går det också att skapa klasser och objekt, vilket förenklar väldigt och skapar struktur. Syntaxen är ganska långt ifrån java och mycket är ärvt från tidigare Matlabversioner, vilket till en början gör det lite krångligt. Jag skall i en artikelserie presentera lite tips och trix vid Matlabprogrammering.</p>
<ul class="unIndentedList">
<li> Jag kommer att gå igenom GUI i form av bland annat träd och kontroller. Dessa hanteras genom Matlabfunktionerna uicontrol och uitree, vilka är en omskrivning av javas komponenter <strong>JTree</strong> och <strong>JButton</strong>, <strong>JTextField</strong> osv. I samband med detta tar jag också upp utläggning av komponenter, som kan ske manuellt och med Matlabs inbyggda programvara <strong>Guide</strong>.</li>
<li> Jag kommer att ta upp matlabs <strong>get och set metoder</strong>, som är lite krångliga men mycket bra vid arbete med objekt.</li>
<li> Jag går igenom Matlabs funktioner för att <strong>spara objekt</strong> och förklarar varför det är klokare att spara data i from av datastrukturer.</li>
<li> Slutligen tänkte jag också ta upp så kallade <strong>Callbacks </strong>och funktionen <strong>ode45</strong>, som är bra vid lösning av differentialekvationer. Ode45 kan bland annat användas för att simulera dynamiska system av olika slag. Ett exempel är kraftnätets beteende vid olika förhållanden.</li>
</ul>
<p>Jag ser mig nu som en <strong>duktig Matlabprogrammerare</strong> med erfarenhet från två projekt. För mer information om mig och mina uppdrag, vänligen ta kontakt vid <a href="mailto:david@techonomics.se">david@techonomics.se</a>. Jag har f-skatt och fakturerar per uppdrag eller tar betalt per timme.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.techonomics.se/teknik/programmering/matlab-programmering/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

