<?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>Business Analyst: Ryan Kirgan's Blog</title>
	<atom:link href="http://blog.kirgs.com/feed/" rel="self" type="application/rss+xml" />
	<link>http://blog.kirgs.com</link>
	<description></description>
	<lastBuildDate>Thu, 15 Oct 2009 09:22:39 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.3</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Increasing your virtual memory (paging file) with Windows XP</title>
		<link>http://blog.kirgs.com/2009/04/14/increasing-your-virtual-memory-paging-file-with-windows-xp/</link>
		<comments>http://blog.kirgs.com/2009/04/14/increasing-your-virtual-memory-paging-file-with-windows-xp/#comments</comments>
		<pubDate>Tue, 14 Apr 2009 00:44:35 +0000</pubDate>
		<dc:creator>ryankirgan</dc:creator>
				<category><![CDATA[Windows XP]]></category>
		<category><![CDATA[paging file]]></category>
		<category><![CDATA[virtual memory]]></category>

		<guid isPermaLink="false">http://blog.kirgs.com/?p=131</guid>
		<description><![CDATA[





In many operating systems you can use free disk space (which is typically in a abundance) to emulate RAM.  It&#8217;s obviously not as beneficial as physically adding more RAM to your machine, however here is a brief guide to customising your virtual memory configuration using Windows XP.
- Press the Windows Key + Pause&#124;Break key [...]]]></description>
			<content:encoded><![CDATA[<p><!--[endif]--><!--[if gte mso 9]><xml><br />
<w:WordDocument><br />
<w:View>Normal</w:View><br />
<w:Zoom>0</w:Zoom><br />
<w:DoNotOptimizeForBrowser /><br />
</w:WordDocument><br />
</xml><![endif]--><!-- /* Font Definitions */ @font-face {font-family:Wingdings; panose-1:5 0 0 0 0 0 0 0 0 0; mso-font-charset:2; mso-generic-font-family:auto; mso-font-pitch:variable; mso-font-signature:0 268435456 0 0 -2147483648 0;} @font-face {font-family:Verdana; panose-1:2 11 6 4 3 5 4 4 2 4; mso-font-charset:0; mso-generic-font-family:swiss; mso-font-pitch:variable; mso-font-signature:536871559 0 0 0 415 0;} /* Style Definitions */ p.MsoNormal, li.MsoNormal, div.MsoNormal {mso-style-parent:""; margin-top:4.0pt; margin-right:0cm; margin-bottom:4.0pt; margin-left:0cm; text-align:justify; mso-pagination:widow-orphan; font-size:11.0pt; mso-bidi-font-size:10.0pt; font-family:Arial; mso-fareast-font-family:"Times New Roman"; mso-bidi-font-family:"Times New Roman";} @page Section1 {size:612.0pt 792.0pt; margin:72.0pt 90.0pt 72.0pt 90.0pt; mso-header-margin:36.0pt; mso-footer-margin:36.0pt; mso-paper-source:0;} div.Section1 {page:Section1;} /* List Definitions */ @list l0 {mso-list-id:1742556194; mso-list-type:hybrid; mso-list-template-ids:-1203760546 -1242637504 67698691 67698693 67698689 67698691 67698693 67698689 67698691 67698693;} @list l0:level1 {mso-level-start-at:0; mso-level-number-format:bullet; mso-level-text:-; mso-level-tab-stop:36.0pt; mso-level-number-position:left; text-indent:-18.0pt; font-family:"Times New Roman"; mso-fareast-font-family:"Times New Roman";} ol {margin-bottom:0cm;} ul {margin-bottom:0cm;} --><br />
In many operating systems you can use free disk space (which is typically in a abundance) to emulate RAM.  It&#8217;s obviously not as beneficial as physically adding more RAM to your machine, however here is a brief guide to customising your virtual memory configuration using Windows XP.<br />
<span style='font-family:Courier New;'>- Press the <strong>Windows Key</strong> + <strong>Pause|Break</strong> key to open the <strong>System Properties</strong> windows (there are many ways to do this!)</span><br />
<div id="attachment_134" class="wp-caption alignnone" style="width: 429px"><img class="size-full wp-image-134" title="system-properties" src="http://blog.kirgs.com/wp-content/uploads/2009/04/system-properties.png" alt="System Properties" width="419" height="479" /><p class="wp-caption-text">System Properties</p></div><br />
<span style='font-family:Courier New;'>- Click on the <strong>Advanced</strong> tab.<br />
- Click on the <strong>Settings</strong> button (under the <strong>Performance</strong> section).</span><br />
<div id="attachment_135" class="wp-caption alignnone" style="width: 429px"><img class="size-full wp-image-135" title="system-properties-advanced" src="http://blog.kirgs.com/wp-content/uploads/2009/04/system-properties-advanced.png" alt="System Properties - Advanced Tab" width="419" height="479" /><p class="wp-caption-text">System Properties - Advanced Tab</p></div><br />
<span style='font-family:Courier New;'>- Click on the <strong>Advanced</strong> tab.</span><br />
<div id="attachment_136" class="wp-caption alignnone" style="width: 377px"><img class="size-full wp-image-136" title="performance-options" src="http://blog.kirgs.com/wp-content/uploads/2009/04/performance-options.png" alt="Performance Options" width="367" height="528" /><p class="wp-caption-text">Performance Options</p></div><br />
<span style='font-family:Courier New;'>- Under the <strong>Virtual memory</strong> section, click on the <strong>Change</strong> button.</span><br />
You might like to change the <strong>Processor scheduling</strong> and/or <strong>Memory usage</strong> to suit your needs.</p>
<div id="attachment_137" class="wp-caption alignnone" style="width: 377px"><img class="size-full wp-image-137" title="performance-options-advanced" src="http://blog.kirgs.com/wp-content/uploads/2009/04/performance-options-advanced.png" alt="Performance Options - Advanced Tab" width="367" height="528" /><p class="wp-caption-text">Performance Options - Advanced Tab</p></div><br />
<span style='font-family:Courier New;'>- Select the <strong>Custom size</strong> radio button.</span><br />
A good rule of thumb (well, my rule of thumb) is to set the <strong>Initial size (MB)</strong> to one-and-a-half times (1.5x) your actual RAM, the <strong>Maximum size (MB)</strong> to twice (2x.)  This can be determined from the initial <strong>System Properties</strong> section.</p>
<p>In my case, I have 3.49Gb of reported RAM.  Assuming 1024Mb == 1Gb then this is equivalent to approx. 3574Mb.  Multiplying this by one-and-a-half (1.5x) equals 5361Mb (which is approx. equal to the Windows recommended 5359Mb.)  Similarly, twice (2x) this value is 7148Mb (which is approx. equal to the used value of 3.5Gb x 1024Mb x 2 = 7168Mb).<br />
<span style='font-family:Courier New;'>- Click the <strong>Set</strong> button.<br />
- Click the <strong>OK</strong> button.</span><br />
<div id="attachment_138" class="wp-caption alignnone" style="width: 354px"><img class="size-full wp-image-138" title="virtual-memory-c-drive" src="http://blog.kirgs.com/wp-content/uploads/2009/04/virtual-memory-c-drive.png" alt="Virtual Memory - Primary (C:\) Drive" width="344" height="431" /><p class="wp-caption-text">Virtual Memory - Primary (C:) Drive</p></div>
<p>You can set the swap or virtual memory paging file on as many drives as you like – perhaps one that is not written to often in case this results in resource competition.  This is an assumption I&#8217;ve made, so may not actually make a difference.</p>
<div id="attachment_139" class="wp-caption alignnone" style="width: 354px"><img class="size-full wp-image-139" title="virtual-memory-d-drive" src="http://blog.kirgs.com/wp-content/uploads/2009/04/virtual-memory-d-drive.png" alt="Virtual Memory - Secondary (D:\) Drive" width="344" height="431" /><p class="wp-caption-text">Virtual Memory - Secondary (D:) Drive</p></div><br />
<span style='font-family:Courier New;'>- Continue clicking the <strong>OK</strong> button until you have exited all windows.</span><br />
You will be notified that the changes will not take affect until you restart your computer.</p>
<p><div id="attachment_141" class="wp-caption alignnone" style="width: 543px"><img class="size-full wp-image-141" title="system-control-panel-applet" src="http://blog.kirgs.com/wp-content/uploads/2009/04/system-control-panel-applet.png" alt="System Control Panel Applet" width="533" height="119" /><p class="wp-caption-text">System Control Panel Applet</p></div>
<p>You can restart now, or defer restarting until later.</p>
<div id="attachment_140" class="wp-caption alignnone" style="width: 433px"><img class="size-full wp-image-140" title="system-settings-change" src="http://blog.kirgs.com/wp-content/uploads/2009/04/system-settings-change.png" alt="Systems Settings Change" width="423" height="126" /><p class="wp-caption-text">Systems Settings Change</p></div>
<p>I believe that there are physical RAM limits (4Gb?) with 32-bit Operating Systems like Windows XP, however admit that I don&#8217;t know enough about the mechanics of this to be certain how/if it applies here.  It might be pointless having a 7Gb paging file (let alone two!) as described above.  Comments clarifying this are more than welcome.</p>
<hr />Feel free to add any comments.  If you require further clarification on any part of this how-to guide, please leave a comment, or you can email me at: <a href="mailto:ryan@kirgs.com">ryan@kirgs.com</a> or simply visit my website: <a href="http://businessanalyst.kirgs.com/">http://businessanalyst.kirgs.com/</a> and complete the feedback form on the &#8220;contact&#8221; section.  <em> </em></p>
<p><em>Ryan Kirgan is a Business Analyst who operates out of Sydney, Australia.</em></p>
<div class="wp-caption alignnone" style="width: 80px"><a href="http://businessanalyst.kirgs.com/about/"><img title="Business Analyst: Ryan Kirgan" src="http://businessanalyst.kirgs.com/images/mugshot_70x120.png" alt="Business Analyst: Ryan Kirgan" width="70" height="120" /></a><p class="wp-caption-text">Business Analyst: Ryan Kirgan</p></div>
<a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save?linkurl=http%3A%2F%2Fblog.kirgs.com%2F2009%2F04%2F14%2Fincreasing-your-virtual-memory-paging-file-with-windows-xp%2F&amp;linkname=Increasing%20your%20virtual%20memory%20%28paging%20file%29%20with%20Windows%20XP"><img src="http://blog.kirgs.com/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a>]]></content:encoded>
			<wfw:commentRss>http://blog.kirgs.com/2009/04/14/increasing-your-virtual-memory-paging-file-with-windows-xp/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Viigo has installed itself!  Or did it?  Optus are at it again.</title>
		<link>http://blog.kirgs.com/2009/03/12/viigo-has-installed-itself-or-did-it-optus-are-at-it-again/</link>
		<comments>http://blog.kirgs.com/2009/03/12/viigo-has-installed-itself-or-did-it-optus-are-at-it-again/#comments</comments>
		<pubDate>Thu, 12 Mar 2009 01:28:54 +0000</pubDate>
		<dc:creator>ryankirgan</dc:creator>
				<category><![CDATA[Blackberry]]></category>
		<category><![CDATA[optus]]></category>
		<category><![CDATA[uninstall viigo]]></category>
		<category><![CDATA[viigo]]></category>

		<guid isPermaLink="false">http://blog.kirgs.com/?p=126</guid>
		<description><![CDATA[Looking at the Application icons on my Blackberry I&#8217;ve noticed something that wasn&#8217;t there before: Viigo RSS Reader.  Having no idea what this was (and knowing that I hadn&#8217;t installed it myself) I did a quick google search to discover this is an extremely popular RSS reader (as the name suggests) for Blackberry devices.
I [...]]]></description>
			<content:encoded><![CDATA[<p>Looking at the Application icons on my Blackberry I&#8217;ve noticed something that wasn&#8217;t there before: <strong>Viigo RSS Reader</strong>.  Having no idea what this was (and knowing that I hadn&#8217;t installed it myself) I did a quick google search to discover this is an extremely popular RSS reader (as the name suggests) for Blackberry devices.</p>
<p>I didn&#8217;t ask for it, so no matter how good it is isn&#8217;t really the point.  The problem quickly became that I couldn&#8217;t seem to uninstall it!  <strong>Options-&gt;Advanced Options-&gt;Applications</strong> didn&#8217;t contain anything that even slightly resembled <strong>Viigo RSS Reader</strong>.  Similarly, pressing the <strong>Menu Key</strong> and selecting <strong>Modules</strong> in this section does not show anything.</p>
<p>I then delved into the <strong>Service Book </strong>(also found in <strong>Options-&gt;Advanced Options</strong>) to find that <strong>Viigo VPL [Browser Config]</strong> was present and active.  Viewing the properties of this service book showed:</p>
<pre>Description: Viigo Virtual preload for Optus AU</pre>
<p>Pressing the <strong>Menu Key</strong> and <strong>Delete</strong> seems to have solved the problem, but with carriers such as Optus being able to deploy potentially unwanted software, who knows for how long it will remain off my phone.</p>
<hr />Feel free to add any comments.  If you require further clarification on any part of this article, please leave a comment, or you can email me at: <a href="mailto:ryan@kirgs.com">ryan@kirgs.com</a> or simply visit my website: <a href="http://businessanalyst.kirgs.com/">http://businessanalyst.kirgs.com/</a> and complete the feedback form on the &#8220;contact&#8221; section.  <em>Ryan Kirgan is a Business Analyst who operates out of Sydney, Australia.</em></p>
<div class="wp-caption alignnone" style="width: 80px"><a href="http://businessanalyst.kirgs.com/about/"><img title="Business Analyst: Ryan Kirgan" src="http://businessanalyst.kirgs.com/images/mugshot_70x120.png" alt="Business Analyst: Ryan Kirgan" width="70" height="120" /></a><p class="wp-caption-text">Business Analyst: Ryan Kirgan</p></div>
<a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save?linkurl=http%3A%2F%2Fblog.kirgs.com%2F2009%2F03%2F12%2Fviigo-has-installed-itself-or-did-it-optus-are-at-it-again%2F&amp;linkname=Viigo%20has%20installed%20itself%21%20%20Or%20did%20it%3F%20%20Optus%20are%20at%20it%20again."><img src="http://blog.kirgs.com/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a>]]></content:encoded>
			<wfw:commentRss>http://blog.kirgs.com/2009/03/12/viigo-has-installed-itself-or-did-it-optus-are-at-it-again/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>A comprehensive how-to set up a wireless network (securely) with Windows XP guide</title>
		<link>http://blog.kirgs.com/2009/02/26/a-comprehensive-how-to-set-up-a-wireless-network-securely-guide/</link>
		<comments>http://blog.kirgs.com/2009/02/26/a-comprehensive-how-to-set-up-a-wireless-network-securely-guide/#comments</comments>
		<pubDate>Wed, 25 Feb 2009 23:44:43 +0000</pubDate>
		<dc:creator>ryankirgan</dc:creator>
				<category><![CDATA[Wireless Networking]]></category>
		<category><![CDATA[ssid]]></category>
		<category><![CDATA[wireless]]></category>
		<category><![CDATA[wireless security]]></category>
		<category><![CDATA[wpa]]></category>

		<guid isPermaLink="false">http://blog.kirgs.com/?p=60</guid>
		<description><![CDATA[I wrote this how-to guide a while back, however thought I would publish it on my blog in response to: Stop Internet Poachers from Stealing Your Wi-Fi by Rick Broida.  My advice to people is diametrically opposed to Rick&#8217;s, so hopefully between the two there&#8217;s a solution that best meets your requirements  
Disclaimer: [...]]]></description>
			<content:encoded><![CDATA[<p>I wrote this how-to guide a while back, however thought I would publish it on my blog in response to: <a href="http://www.pcworld.com/article/158356/article.html">Stop Internet Poachers from Stealing Your Wi-Fi by Rick Broida</a>.  My advice to people is diametrically opposed to Rick&#8217;s, so hopefully between the two there&#8217;s a solution that best meets your requirements <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p><span style="font-style:italic">Disclaimer: This is how I set up wireless networks, however I am sure that there are a lot of different ways to do this.  Apart from any references to upgrading firmware (in short, don&#8217;t do it unless you have to!) there shouldn&#8217;t be anything in here that breaks your equipment and ends up costing you lots of money!</span></p>
<p>In the examples provided I have used:</p>
<p style="font-family:courier new">- Intel(&reg;) PRO/Wireless 3945ABG Network Connection wireless adapter<br />
- Linksys WRT54G wireless router</p>
<p>This document is aimed at enabling secure, wireless access to a wired network that is already operational.  While setting up a home network from scratch is beyond the scope of this document, I will say briefly that there are two main ways (that I know of) to get things working: either the modem does the authentication/DHCP etc. or the router does (and the modem is set to &#8220;full bridge&#8221; mode.)  The following instructions should work irrespective of the method adopted.</p>
<p>First we need to gather some information about your network&#8230;</p>
<p>There are countless combinations of ISPs/modems/routers/wireless cards/PCs that are used when setting up a wireless network, however there are a number of basic principals that are common to all.  This first thing to find out is the IP address of the router (also known in this context as the gateway).  Almost all new routers will have a web interface that lets you configure your network.  Also, keep in mind that it&#8217;s a lot easier to configure the router via the wired network than the wireless network (as there is no encryption, a permanent link etc.)</p>
<p>To do this and to find out the IP address of your router&#8230;</p>
<p style="font-family:courier new">- Connect your computer to one of the wired ports on the router (i.e. not the uplink port) using a UTP cable (usually blue with a clear 8-pin RJ-45 connector on the end &#8211; kind of like a telephone connector but bigger.)  Most home routers have 4 or 5 of these ports.<br />
- Click on the <strong>Start Menu</strong>.<br />
- Click on <strong>Run&#8230;.</strong><br />
- Type <strong>cmd</strong> (or <strong>command</strong> for pre-Windows 2000 machines) and click OK.</p>
<div id="attachment_76" class="wp-caption alignnone" style="width: 357px"><img class="size-full wp-image-76" title="The &quot;run&quot; dialog box" src="http://blog.kirgs.com/wp-content/uploads/2009/02/run-dialog-box.png" alt="Enter &quot;cmd&quot; in the &quot;run&quot; dialog box" width="347" height="186" /><p class="wp-caption-text">Enter &quot;cmd&quot; in the &quot;run&quot; dialog box</p></div>
<p>The command prompt should open.</p>
<div id="attachment_77" class="wp-caption alignnone" style="width: 510px"><img class="size-full wp-image-77" title="Command Prompt" src="http://blog.kirgs.com/wp-content/uploads/2009/02/command-prompt.png" alt="Command Prompt" width="500" height="253" /><p class="wp-caption-text">Command Prompt</p></div>
<p style="font-family:courier new">- Enter <strong>ipconfig</strong> and press the Enter key.</p>
<div id="attachment_78" class="wp-caption alignnone" style="width: 510px"><img class="size-full wp-image-78" title="ipconfig" src="http://blog.kirgs.com/wp-content/uploads/2009/02/ipconfig.png" alt="ipconfig" width="500" height="253" /><p class="wp-caption-text">ipconfig</p></div>
<p>You&#8217;ll notice that there are three Ethernet adapters listed above (you may have more or less).  These correspond to the number of ethernet  network interfaces on the computer; here, two are for wired networks and one is for wireless networks.</p>
<p>As we are connected using the wired Local Area Connection adapter, we need to look at the information listed for that particular device. The default gateway (here, <strong>192.168.1.1</strong>) is the IP address of the router.</p>
<p style="font-family:courier new">- Record this number.</p>
<p>Now&#8230;</p>
<p style="font-family:courier new">- Open your web browser (e.g. Internet Explorer, Mozilla Firefox, Safari, Opera)<br />
- Enter in the address bar http:// followed by the IP address obtained earlier.  Using the previous example you would enter <strong>http://192.168.1.1</strong></p>
<div id="attachment_79" class="wp-caption alignnone" style="width: 503px"><img class="size-medium wp-image-79" title="router-web-interface" src="http://blog.kirgs.com/wp-content/uploads/2009/02/192.168.1.1.png" alt="Access the router's web interface" width="493" height="238" /><p class="wp-caption-text">Access the router&#39;s web interface</p></div>
<p>This is where things become different for different arrangements.  You will (hopefully) most likely be prompted for a username and password.  This will usually be <strong>admin</strong> and <strong>admin</strong> or <strong>admin</strong> and <strong>no password</strong> at all.  Sometimes you are solely prompted for a password (maybe simply try <strong>password</strong>?)</p>
<div id="attachment_104" class="wp-caption alignnone" style="width: 510px"><img class="size-full wp-image-104" title="router-credentials" src="http://blog.kirgs.com/wp-content/uploads/2009/02/router-credentials.png" alt="Router Credentials" width="500" height="149" /><p class="wp-caption-text">Router Credentials</p></div>
<p>The default password will almost always come with any documentation that came with your router &#8211; otherwise, you&#8217;re router&#8217;s vendor will most certainly have it (so try their website or Google search your router model.)  If the password has been set to something that you don&#8217;t know and can&#8217;t find out, you will have to reset the router (which is usually done by pressing a reset button on the router for around 10 seconds, however be warned that this will restore the factory default settings &#8211; except the firmware &#8211; and you will lose any changes you have previously made to your router.)</p>
<p>Once connected, you can use the web interface to configure your router for wireless access.</p>
<p>The first thing that you need to do is ensure that the Wireless radio (or similar) option is enabled.  Once this has been confirmed, you need to decide upon, set and record the SSID (think of this as the name of your wireless access point).  At home, mine is called <strong>rabbit</strong>.  This is arbitrary, but you will need to enter this name when you set up the computers/printers for use in your wireless network (hereafter known as devices) so make it something you can remember.</p>
<p>**DON&#8217;T MAKE IT ANY OF YOUR PASSWORDS!**</p>
<p>Also, for reasons outlined later, it is good to set this to something other than the default factory setting (e.g. NETGEAR or WRT54G).</p>
<p>Now for the important information&#8230;</p>
<p>The four main components to wireless network security that I find most important (in order) are:</p>
<p>1. Using WPA (or greater) encryption<br />
2. Changing the router&#8217;s admin password<br />
3. Enabling access control<br />
4. Not broadcasting the SSID</p>
<p>The first of these is an absolute must &#8211; the second and third strongly recommended preferable and the fourth, nice if you have time provided you can sustain good connectivity with its implementation <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<h2 style="text-decoration: underline;">Using WPA (or greater) encryption</h2>
<p>I would suggest using <a title="Wi-Fi Protected Access (Wiki)" href="http://en.wikipedia.org/wiki/Wi-Fi_Protected_Access" target="_blank">WPA</a> (as the mode of encryption (or WPA2 if your wireless card and router support it.)   It is based on an algorithm (AES) that has not been broken (yet or as least not as far as I know!)</p>
<p>DO NOT use WEP.  WEP is based on a weaker algorithm and if enough packets are collected can be broken.</p>
<p style="font-style:italic">Anecdotal: I have been told that there were competitions for breaking WEP encryption schemes that resulted in the password being discovered within 6 minutes!</p>
<p>DO NOT use nothing!  (This kind of goes without saying <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />  &#8211; or does it? See: <a href="http://www.pcworld.com/article/158356/article.html">Stop Internet Poachers from Stealing Your Wi-Fi by Rick Broida</a>)</p>
<p>If your wireless card or router don&#8217;t support WPA (although if it was bought in the last 5 years it should!) you may have to upgrade the firmware of the device in question.  This is like a software update for your hardware, but can be extremely dangerous and render your equipment useless.  If your equipment is this old, you&#8217;re probably better off buying new equipment, although be absolutely sure that your equipment doesn&#8217;t permit this before spending money needlessly.  For legal reasons I am not going to write any instructions on upgrading firmware <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_razz.gif' alt=':P' class='wp-smiley' />   Also, it should be noted that anything before Windows XP with Service Pack 2 may have limited WPA capabilities.  To check if you have Service Pack 2 (or above) installed&#8230;</p>
<p style="font-family:courier new">- Right-click on My Computer.  This may be on your Desktop or in the Start Menu.<br />
- Click on Properties.</p>
<div id="attachment_92" class="wp-caption alignnone" style="width: 429px"><img class="size-full wp-image-92" title="system-properties" src="http://blog.kirgs.com/wp-content/uploads/2009/02/system-properties.png" alt="Windows System Properties" width="419" height="486" /><p class="wp-caption-text">Windows System Properties</p></div>
<p>The information should be listed under System: under the General tab.</p>
<p>Back to the web interface of the router&#8230;</p>
<p>When using WPA you want to look for something on the web interface of the router that says WPA-PSK, WPA shared key or WPA passphrase.</p>
<p>Once you set this passphrase, record it as this will be what you use to set up the devices on your network.  I generally get Windows to handle my wireless connections.  Using Windows to do something is probably a first, but from experience the software utilities that come with most network cards seem to provide intermittent connectivity.</p>
<p>Once this information has been set, we need to configure the device.  The instructions below are for setting up a Windows XP machine (with Service Pack 2).</p>
<p style="font-family:courier new">- Click on the Start Menu.<br />
- Click on the Control Panel.</p>
<div id="attachment_80" class="wp-caption alignnone" style="width: 361px"><img class="size-full wp-image-80" title="cp-in-start-menu" src="http://blog.kirgs.com/wp-content/uploads/2009/02/cp-in-start-menu.png" alt="Control Panel in the Start Menu" width="351" height="727" /><p class="wp-caption-text">Control Panel in the Start Menu</p></div>
<p style="font-family:courier new">- Double-click on Network Connections.  If you can&#8217;t see this icon, click on the Switch to Classic View link in the top-left hand corner under Control Panel.</p>
<div id="attachment_81" class="wp-caption alignnone" style="width: 306px"><img class="size-full wp-image-81" title="network-connections-in-cp" src="http://blog.kirgs.com/wp-content/uploads/2009/02/network-connections-in-cp.png" alt="Network Connections in the Control Panel" width="296" height="18" /><p class="wp-caption-text">Network Connections in the Control Panel</p></div>
<div id="attachment_94" class="wp-caption alignnone" style="width: 216px"><img class="size-full wp-image-94" title="switch-to-classic-view-cp" src="http://blog.kirgs.com/wp-content/uploads/2009/02/switch-to-classic-view-cp.png" alt="Switch to Classic View" width="206" height="82" /><p class="wp-caption-text">Switch to Classic View</p></div>
<div id="attachment_82" class="wp-caption alignnone" style="width: 510px"><img class="size-full wp-image-82" title="network-connections-cp" src="http://blog.kirgs.com/wp-content/uploads/2009/02/network-connections-cp.png" alt="Network Connections Control Panel" width="500" height="375" /><p class="wp-caption-text">Network Connections Control Panel</p></div>
<p style="font-family:courier new">- Right-click on the Wireless Network Connection icon and click on Properties.</p>
<div id="attachment_95" class="wp-caption alignnone" style="width: 350px"><img class="size-full wp-image-95" title="wlan-right-click-menu" src="http://blog.kirgs.com/wp-content/uploads/2009/02/wlan-right-click-menu.png" alt="Wireless Network Properties" width="340" height="213" /><p class="wp-caption-text">Wireless Network Properties</p></div>
<p style="font-family:courier new">- Click on the Wireless Networks tab.<br />
- Ensure that the Use Windows to configure my wireless network settings checkbox is checked.<br />
- Under Preferred networks click on the Add&#8230; button.</p>
<div id="attachment_96" class="wp-caption alignnone" style="width: 377px"><img class="size-full wp-image-96" title="wireless-networks-tab" src="http://blog.kirgs.com/wp-content/uploads/2009/02/wireless-networks-tab.png" alt="Wireless Networks Tab" width="367" height="450" /><p class="wp-caption-text">Wireless Networks Tab</p></div>
<p style="font-family:courier new">- Enter the SSID set when configuring the router.<br />
- Change the Network Authentication to WPA-PSK.<br />
- Change the Data encryption to TKIP.<br />
- Enter your WPA passphrase as the Network key.<br />
- Confirm network key.</p>
<div id="attachment_98" class="wp-caption alignnone" style="width: 378px"><img class="size-full wp-image-98" title="wireless-networks-add" src="http://blog.kirgs.com/wp-content/uploads/2009/02/wireless-networks-add.png" alt="Add Wireless Network" width="368" height="450" /><p class="wp-caption-text">Add Wireless Network</p></div>
<p style="font-family:courier new">- Click the OK button to confirm.</p>
<p>You should now be connected via your wireless adapter.</p>
<div id="attachment_100" class="wp-caption alignnone" style="width: 344px"><img class="size-full wp-image-100" title="wireless-network-is-now-connected" src="http://blog.kirgs.com/wp-content/uploads/2009/02/wireless-network-is-now-connected.png" alt="Wireless Network is now connected" width="334" height="85" /><p class="wp-caption-text">Wireless Network is now connected</p></div>
<div id="attachment_101" class="wp-caption alignnone" style="width: 201px"><img class="size-full wp-image-101" title="wireless-connected" src="http://blog.kirgs.com/wp-content/uploads/2009/02/wireless-connected.png" alt="Wireless Connected (mouseover)" width="191" height="87" /><p class="wp-caption-text">Wireless Connected (mouseover)</p></div>
<p>You may need to restart the machine to get the computer to connect to your router.  Alternatively, you may need to repair your wireless connection&#8230;</p>
<h2 style="text-decoration: underline;">Repairing the connection</h2>
<p>It has been my experience that sometimes the wireless connection won&#8217;t be active immediately, so repairing the connection is a way to give things a bit of a kick-start without having to restart.</p>
<div id="attachment_99" class="wp-caption alignnone" style="width: 254px"><img class="size-full wp-image-99" title="wireless-connection-not-connected" src="http://blog.kirgs.com/wp-content/uploads/2009/02/wireless-connection-not-connected.png" alt="Wireless Connection Not Connected" width="244" height="51" /><p class="wp-caption-text">Wireless Connection Not Connected</p></div>
<p style="font-family:courier new">- Right-click on the wireless icon (with the three (3) yellow waves emanating out) in the system tray.<br />
- Left-click on <strong>Repair</strong>.</p>
<div id="attachment_106" class="wp-caption alignnone" style="width: 214px"><img class="size-full wp-image-106" title="right-click-repair" src="http://blog.kirgs.com/wp-content/uploads/2009/02/right-click-repair.png" alt="Repair broken Wireless Connection" width="204" height="133" /><p class="wp-caption-text">Repair broken Wireless Connection</p></div>
<p>This will initiate Windows running through the &#8220;wireless repair&#8221; motions.  You should see dialog boxes indicating that the network adapter is being disabled, then enabled.  This is followed by the adapter connecting to the wireless network, the wireless network adapters ip address being renewed, the NetBT being cleared and refreshed and the same for the DNS cache.</p>
<p>Example:</p>
<div id="attachment_107" class="wp-caption alignnone" style="width: 391px"><img class="size-full wp-image-107" title="enabling-your-wireless-adapter" src="http://blog.kirgs.com/wp-content/uploads/2009/02/enabling-your-wireless-adapter.png" alt="Enabling your Wireless Adapter" width="381" height="169" /><p class="wp-caption-text">Enabling your Wireless Adapter</p></div>
<div id="attachment_108" class="wp-caption alignnone" style="width: 391px"><img class="size-full wp-image-108" title="refreshing-netbt" src="http://blog.kirgs.com/wp-content/uploads/2009/02/refreshing-netbt.png" alt="Refreshing NetBT" width="381" height="169" /><p class="wp-caption-text">Refreshing NetBT</p></div>
<p>Hopefully you&#8217;ll now see our happy friend, the<strong> Windows Network Connection is now connected</strong> speech bubble.</p>
<div id="attachment_100" class="wp-caption alignnone" style="width: 344px"><img class="size-full wp-image-100" title="wireless-network-is-now-connected" src="http://blog.kirgs.com/wp-content/uploads/2009/02/wireless-network-is-now-connected.png" alt="Wireless Network is now connected" width="334" height="85" /><p class="wp-caption-text">Wireless Network is now connected</p></div>
<h2 style="text-decoration: underline;">Still not connected?!?</h2>
<p>There could be many reasons why this hasn&#8217;t worked.  Some common problems:</p>
<ul>
<li><strong style="font-style:italic;">The adapter is disabled.</strong>  With laptops, there is often a physical switch located that disables (usu. Bluetooth and) wireless network devices.  Ensure that this is switched on (mine has a light that turns blue when on, orange when off.)  These switches can also be controlled using function keys.  Look for icons (also, usually blue) above some of your function keys.  It will generally look like the wireless icon (with the &#8220;radio waves&#8221;) in the system tray.  Hold down the &#8220;function&#8221; key on your keyboard and press this button &#8211; continually pressing this button should cycle through the different adapter enabled/disabled modes.  The adapter may also be disabled under Windows.</li>
</ul>
<p>(I&#8217;ll update this list as best I can)</p>
<h2 style="text-decoration: underline;">Changing the router&#8217;s admin password</h2>
<p>Almost every router has this in a different place in it web interface, but in all of the router&#8217;s I&#8217;ve configured it&#8217;s in there somewhere.  You may need to enter the old password (as mentioned above, usually admin or nothing at all!) beforehand.  Record this, or you won&#8217;t be able to make changes to your router without having to resort to reset the router and starting all over again.  This is the username and password that you will use to connect to your router via the web interface.</p>
<h2 style="text-decoration: underline;">Enabling access control</h2>
<p>Each network adapter (wireless and wired) has a unique hardware address.  You might have heard of this as a MAC address or physical address.  We want to limit wireless network access to only those devices you own.  To find this address using Windows&#8230;</p>
<p style="font-family:courier new">- Click on the <strong>Start Menu</strong>.<br />
- Click on <strong>Run&#8230;</strong>.<br />
- Type <strong>cmd</strong> and click OK.</p>
<div id="attachment_76" class="wp-caption alignnone" style="width: 357px"><img class="size-full wp-image-76" title="The &quot;run&quot; dialog box" src="http://blog.kirgs.com/wp-content/uploads/2009/02/run-dialog-box.png" alt="Enter &quot;cmd&quot; in the &quot;run&quot; dialog box" width="347" height="186" /><p class="wp-caption-text">Enter &quot;cmd&quot; in the &quot;run&quot; dialog box</p></div>
<p>The command prompt should open.</p>
<p style="font-family:courier new">- Enter <strong>ipconfig/all</strong> and press the Enter key.</p>
<div id="attachment_109" class="wp-caption alignnone" style="width: 510px"><img class="size-full wp-image-109" title="wireless-adapter-mac-address" src="http://blog.kirgs.com/wp-content/uploads/2009/02/wireless-adapter-mac-address.png" alt="Wireless Adapter MAC address" width="500" height="253" /><p class="wp-caption-text">Wireless Adapter MAC address</p></div>
<p style="font-family:courier new">- Under <strong>Ethernet adapter Wireless Network Connection:</strong> look for the value of the Physical Address.</p>
<p>This is the MAC or Hardware address mentioned earlier.  The address needs to be entered in to an Access List or Access Control List of permitted  MAC addresses using the web interface for the router.  Another phrase to look for is MAC address filtering or Hardware address filtering.</p>
<p>In this example, the address is 00-18-DE-20-C2-E7.  The format that your router requires may be different, although this is usually given.  You may need to separate the address pairs by using colons (:) (e.g. 00:18:DE:20:C2:E7) or nothing at all (e.g. 0018DE20C2E7).  This should be case insensitive, but some routers might be more picky than others <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<h2 style="text-decoration: underline;">Not broadcasting the SSID</h2>
<p>Generally there is an option using the web interface of the router to disable the broadcast of the SSID.  The idea behind this is that if people can&#8217;t find your router then they won&#8217;t be able to connect to it.  This is also why I mentioned earlier that changing the SSID from the default is a good idea.  Despite this, pretty much all modern network cards will be able to connect to a router without the SSID and furthermore, if someone is looking to hack your network then the notion that &#8220;security by obscurity&#8221; not working rings true.  Another upshot of this is that occasionally your network card might not be very good at remembering what wireless access point it should be connecting to and you will experience intermittent connectivity.</p>
<p style="font-style:italic">Anecdotal: In the last dozen or so wireless networks that I&#8217;ve set up there have been a number of physical impediments between the wireless adapters and the router.  All of these were initially set to use the wireless utility that came with the network card (c.f. letting Windows handle wireless networking) and also, were on networks where the SSID was not broadcast.  Removing the vendor&#8217;s wireless utility, letting Windows handle the wireless network and setting the SSID to broadcast solved the problem in every instance.</p>
<p>Do not worry too much about any security risks that might be associated with broadcasting the SSID &#8211; even if a person can &#8220;see&#8221; your wireless access point, they will still need the WPA passphrase and their wireless card&#8217;s MAC address won&#8217;t be in your access control list.</p>
<p>More often than not, after making changes such as this you will be required to reboot or restart the router.  Note that this is different to resetting the router.</p>
<h2>Final words</h2>
<p>I&#8217;ll finish by saying that I don&#8217;t think <strong>security by obscurity</strong> works (to use a catchphrase of doyen, mentor and networking guru, <a title="JohnD's Home Page" href="http://www.physiol.usyd.edu.au/~johnd/index.html" target="_blank">John Dodson</a>.)  Be it for closed-source software (did someone say Microsoft?) or by hiding your wireless network&#8217;s SSID.  This is not to say that using Linux and OpenOffice will save you from security breaches, nor will there never be an occurence that broadcasting your SSID was solely responsible for someone stealing your Wi-Fi.  It&#8217;s all about probability and taking sensible measures.  It&#8217;s also about acceptance that if you couldn&#8217;t be bothered taking measures then you should live with the consequences.</p>
<p>MAC address spoofing will bypass any MAC address filtering measures and I&#8217;m sure there are encryption specialists who will talk down the imperviousness of WPA (sequential IVs?  Or is that WEP?)  For my mind, it&#8217;s all about maintaining the balance between what is easy to implement <em>for your average user</em>, yet secure enough that people won&#8217;t connect to your wireless network (sometimes even unintentionally via connect-automatically-to-wireless-networks-in-range-happy Windows!)</p>
<p>Fingers crossed after all of this you’re in business <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />  and a little bit more secure.</p>
<hr />
Feel free to add any comments.  If you require further clarification on any part of this how-to guide, please leave a comment, or you can email me at: <a href="mailto:ryan@kirgs.com">ryan@kirgs.com</a> or simply visit my website: <a href="http://businessanalyst.kirgs.com/">http://businessanalyst.kirgs.com/</a> and complete the feedback form on the &#8220;contact&#8221; section.  <em>Ryan Kirgan is a Business Analyst who operates out of Sydney, Australia.</em></p>
<div class="wp-caption alignnone" style="width: 80px"><a href="http://businessanalyst.kirgs.com/about/"><img title="Business Analyst: Ryan Kirgan" src="http://businessanalyst.kirgs.com/images/mugshot_70x120.png" alt="Business Analyst: Ryan Kirgan" width="70" height="120" /></a><p class="wp-caption-text">Business Analyst: Ryan Kirgan</p></div>
<a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save?linkurl=http%3A%2F%2Fblog.kirgs.com%2F2009%2F02%2F26%2Fa-comprehensive-how-to-set-up-a-wireless-network-securely-guide%2F&amp;linkname=A%20comprehensive%20how-to%20set%20up%20a%20wireless%20network%20%28securely%29%20with%20Windows%20XP%20guide"><img src="http://blog.kirgs.com/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a>]]></content:encoded>
			<wfw:commentRss>http://blog.kirgs.com/2009/02/26/a-comprehensive-how-to-set-up-a-wireless-network-securely-guide/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Google Earth Update Review [v5.0.11337.1968 (beta)]</title>
		<link>http://blog.kirgs.com/2009/02/17/google-earth-update-review-v50113371968-beta/</link>
		<comments>http://blog.kirgs.com/2009/02/17/google-earth-update-review-v50113371968-beta/#comments</comments>
		<pubDate>Tue, 17 Feb 2009 04:09:55 +0000</pubDate>
		<dc:creator>ryankirgan</dc:creator>
				<category><![CDATA[Geocoding]]></category>
		<category><![CDATA[google]]></category>
		<category><![CDATA[google earth]]></category>

		<guid isPermaLink="false">http://blog.kirgs.com/?p=39</guid>
		<description><![CDATA[The other day I updated my Google Earth installation to 5.0.11337.1968 (beta) and was happy to see some new functionality:  
Flight Simulator 
Fly a F16 (a.k.a. &#8220;Viper&#8221;) or old-school  SR22 over your house.  As far as I know, this function was previously available to Google Earth Pro users only.  Not advisable for those who [...]]]></description>
			<content:encoded><![CDATA[<p>The other day I updated my Google Earth installation to 5.0.11337.1968 (beta) and was happy to see some new functionality:  <span style="text-decoration: underline;"><strong></strong></span></p>
<p><span style="text-decoration: underline;"><strong>Flight Simulator</strong></span> <span style="text-decoration: underline;"><strong></strong></span></p>
<p>Fly a F16 (a.k.a. &#8220;Viper&#8221;) or old-school  SR22 over your house.  As far as I know, this function was previously available to Google Earth Pro users only.  Not advisable for those who already have a fear of flying as you realise just how b****y hard it is to fly a plane <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>You can do this by clicking on <strong>Tools</strong> -&gt; <strong>Enter Flight Simulator&#8230;</strong> <span style="text-decoration: underline;"><strong></strong></span></p>
<p><span style="text-decoration: underline;"><strong>Record a Tour</strong></span> <span style="text-decoration: underline;"><strong></strong></span></p>
<p>This function is really cool.  It basically captures and records your movements in Google Earth, i.e. what you see on your screen can be saved and replayed.</p>
<p>The file size is small because it is the movements (rather than the actual images) that are captured.  It is for this reason that the file size is contingent on the number of events rather than the duration of the tour.  I recorded a 30-second tour with 5 or 6 events resulting in a 4kB (tiny) file.</p>
<p>The tour can be saved as a KML (unencrypted) or KMZ (encrypted) file and emailed to others to open with Google Earth.  It also permits audio recordings, however, this will no doubt add to the file size (with audio being continuous data rather than the discrete events mentioned previously.)  <span style="text-decoration: underline;"><strong></strong></span></p>
<p><span style="text-decoration: underline;"><strong>Historical Imagery</strong></span></p>
<p>This doesn&#8217;t seem to be implemented yet, however, it looks as though you can use a slider to look at the aerial shots over time.  It didn&#8217;t work at all when I started writing this blog entry, but now (some 5 minutes later) it is allowing me to select dates between July, 2001 and today.  The fact that it is killing Google Earth every time I move the slider should be ignored as I&#8217;m sure those clever ducks at Google are on the case <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />   (Might be why it is &#8220;beta&#8221;?)</p>
<div id="attachment_41" class="wp-caption aligncenter" style="width: 421px"><img class="size-full wp-image-41" title="Google Earth Historical Imagery slider" src="http://blog.kirgs.com/images/google-earth-slider.gif" alt="Google Earth Historical Imagery slider" width="411" height="90" /><p class="wp-caption-text">Google Earth Historical Imagery slider</p></div>
<p><em>I just tried it again and it works, however, you need to be patient.  The aforementioned crash *might* have been due to me violently sliding the slider up and down.  Also, there are limited samples (only 4 between Feb 2006 and now, Feb 2009, for a 1255ft view of the Sydney Harbour Bridge; only 1 over my house.) </em></p>
<p><span style="text-decoration: underline;"><strong>Bouncing icons </strong></span></p>
<p>Place your mouse over a placemark icon and it bounces.  Very exciting.  <span style="text-decoration: underline;"><strong></strong></span></p>
<p><span style="text-decoration: underline;"><strong>New Splash Page</strong></span></p>
<p>A different Google Earth image is shown on start up.  All I can say is: &#8220;Wow.&#8221;  <span style="text-decoration: underline;"><strong></strong></span></p>
<p><span style="text-decoration: underline;"><strong>Ocean</strong></span></p>
<p>Go under the sea (apparently).  I entered in &#8220;Great Barrier Reef&#8221; as a location, however couldn&#8217;t see any streetview-camera-like icons.  I&#8217;m sure this is a great feature for those who are interested in that kind of thing.</p>
<p><span style="text-decoration: underline;"><strong>Mars!!!</strong></span></p>
<p>Find your prospective plot of land on Mars for 2032.  Street-view doesn&#8217;t work either which was a bit disappointing.  <em>What are we paying Google for? (oh, that&#8217;s right, we&#8217;re not <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />  )</em></p>
<p>My existing KML files loaded when I changed from Earth to Mars, so it looked a bit strange to have the overlay on the red planet.</p>
<div id="attachment_42" class="wp-caption aligncenter" style="width: 510px"><img class="size-medium wp-image-42" title="Customers &amp; Zones on Mars(?!?)" src="http://blog.kirgs.com/images/customer-zones-on-mars.gif" alt="Customers &amp; Zones on Mars(?!?)" width="500" height="481" /><p class="wp-caption-text">Customers &amp; Zones on Mars(?!?)</p></div>
<p><span style="text-decoration: underline;"><strong>COLLADA models</strong></span></p>
<p>I&#8217;m not too sure what these are, but it appears that you can link to *.dae files<strong>. </strong> A quick Google search suggests this is some kind of 3d modelling format.</p>
<p>All in all, great work, Google Earth.</p>
<p>You can download both the Free and Pro versions of Google Earth from: <a title="Google Earth Download" href="http://earth.google.com" target="_blank">http://earth.google.com/</a></p>
<hr />Feel free to add any comments.  If you require further clarification on any part of this review, please leave a comment, or you can email me at: <a href="mailto:ryan@kirgs.com">ryan@kirgs.com</a> or simply visit my website: <a title="Business Analyst: Ryan Kirgan" href="http://businessanalyst.kirgs.com/">http://businessanalyst.kirgs.com/</a> and complete the feedback form on the &#8220;contact&#8221; section.  <em>Ryan Kirgan is a Business Analyst who operates out of Sydney, Australia.</em></p>
<div class="wp-caption alignnone" style="width: 80px"><a title="About Business Analyst: Ryan Kirgan" href="http://businessanalyst.kirgs.com/about/"><img title="Business Analyst: Ryan Kirgan" src="http://businessanalyst.kirgs.com/images/mugshot_70x120.png" alt="Business Analyst: Ryan Kirgan" width="70" height="120" /></a><p class="wp-caption-text">Business Analyst: Ryan Kirgan</p></div>
<a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save?linkurl=http%3A%2F%2Fblog.kirgs.com%2F2009%2F02%2F17%2Fgoogle-earth-update-review-v50113371968-beta%2F&amp;linkname=Google%20Earth%20Update%20Review%20%5Bv5.0.11337.1968%20%28beta%29%5D"><img src="http://blog.kirgs.com/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a>]]></content:encoded>
			<wfw:commentRss>http://blog.kirgs.com/2009/02/17/google-earth-update-review-v50113371968-beta/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>The weighing twelve (12) balls riddle &#8211; which one is a different weight?</title>
		<link>http://blog.kirgs.com/2009/02/13/the-weighing-twelve-12-balls-riddle-which-one-is-a-different-weight/</link>
		<comments>http://blog.kirgs.com/2009/02/13/the-weighing-twelve-12-balls-riddle-which-one-is-a-different-weight/#comments</comments>
		<pubDate>Fri, 13 Feb 2009 02:40:40 +0000</pubDate>
		<dc:creator>ryankirgan</dc:creator>
				<category><![CDATA[Mathematics]]></category>
		<category><![CDATA[riddle]]></category>

		<guid isPermaLink="false">http://blog.kirgs.com/?p=25</guid>
		<description><![CDATA[This is a riddle that a friend (Carl &#8220;Chunky&#8221; Benson) put to me a few years back.  A few A4 pages of scribblings and I had accounted for an &#8220;answer&#8221; for almost all possible outcomes (almost), however, I never arrived at a complete solution.
There&#8217;s every chance that I&#8217;m just b****y hopeless at Maths, so [...]]]></description>
			<content:encoded><![CDATA[<p>This is a riddle that a friend (Carl &#8220;Chunky&#8221; Benson) put to me a few years back.  A few A4 pages of scribblings and I had accounted for an &#8220;answer&#8221; for <em>almost</em> all possible outcomes (almost), however, I never arrived at a complete solution.</p>
<p>There&#8217;s every chance that I&#8217;m just b****y hopeless at Maths, so prove me wrong people and make me look like a dill <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p><span style="text-decoration: underline;">Premise</span></p>
<ol>
<li>You have <strong>twelve (12)</strong> balls and a set of balance scales.</li>
<li><strong>One</strong> <strong>(1)</strong> of the balls is a <em>different</em> weight to the other <strong>eleven (11)</strong> balls.</li>
<li>You are allowed to use the balance scales <strong>three (3) </strong>times.</li>
<li>You need to determine which ball is the &#8220;odd one out&#8221; and whether it is heavier or lighter than the other balls.</li>
</ol>
<p>Now these are <em>balance</em> scales I&#8217;m talking about.  While a solution involving electronic scales would be effective, I don&#8217;t think it&#8217;s what the riddle&#8217;s architect had in mind <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<div id="attachment_31" class="wp-caption aligncenter" style="width: 377px"><img class="size-medium wp-image-31" title="balance_scales" src="http://blog.kirgs.com/images/balance_scales.jpg" alt="Balance Scales" width="367" height="327" /><p class="wp-caption-text">Balance Scales</p></div>
<p style="text-align: center;">
<p>I&#8217;ve seen a few similar riddles such as this posted elsewhere on the Internet, however, several state that the ball is either <em>heavier</em> or <em>lighter</em>; a far easier problem to solve.  Maybe it should be called something different than &#8220;weighing twelve&#8230;&#8221; as your solution mightn&#8217;t necessarily involve weighing all the balls.</p>
<p>Good luck (and no posts to other sites please!)</p>
<p>Feel free to add any comments.  If you require further clarification on any part of this riddle, please leave a comment, or you can email me at: <a href="mailto:ryan@kirgs.com">ryan@kirgs.com</a> or simply visit my website: <a href="http://businessanalyst.kirgs.com/">http://businessanalyst.kirgs.com/</a> and complete the feedback form on the &#8220;contact&#8221; section.  <em>Ryan Kirgan is a Business Analyst who operates out of Sydney, Australia.</em></p>
<div class="wp-caption alignnone" style="width: 80px"><a href="http://businessanalyst.kirgs.com/about/"><img title="Business Analyst: Ryan Kirgan" src="http://businessanalyst.kirgs.com/images/mugshot_70x120.png" alt="Business Analyst: Ryan Kirgan" width="70" height="120" /></a><p class="wp-caption-text">Business Analyst: Ryan Kirgan</p></div>
<p>P.S &#8211; Any hate mail you want to write (after obsessing over this problem) can be sent to carl@mytrade.com.au <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save?linkurl=http%3A%2F%2Fblog.kirgs.com%2F2009%2F02%2F13%2Fthe-weighing-twelve-12-balls-riddle-which-one-is-a-different-weight%2F&amp;linkname=The%20weighing%20twelve%20%2812%29%20balls%20riddle%20%26%238211%3B%20which%20one%20is%20a%20different%20weight%3F"><img src="http://blog.kirgs.com/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a>]]></content:encoded>
			<wfw:commentRss>http://blog.kirgs.com/2009/02/13/the-weighing-twelve-12-balls-riddle-which-one-is-a-different-weight/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>Matching data in a table in Excel® using INDEX and MATCH (- a VLOOKUP alternative)</title>
		<link>http://blog.kirgs.com/2009/02/02/matching-data-in-a-table-in-excel%c2%ae-using-index-and-match-a-vlookup-alternative/</link>
		<comments>http://blog.kirgs.com/2009/02/02/matching-data-in-a-table-in-excel%c2%ae-using-index-and-match-a-vlookup-alternative/#comments</comments>
		<pubDate>Mon, 02 Feb 2009 04:12:40 +0000</pubDate>
		<dc:creator>ryankirgan</dc:creator>
				<category><![CDATA[Excel Tips]]></category>
		<category><![CDATA[excel]]></category>

		<guid isPermaLink="false">http://blog.kirgs.com/?p=3</guid>
		<description><![CDATA[This article describes an extremely basic Excel® function (well, two functions actually) and is more a test of my new Wordpress installation than anything else  
It describes how you can use the INDEX() and MATCH() functions to look up data in a matrix.
Background to VLOOKUP()
Many users are familar with the VLOOKUP() (vertical lookup) function [...]]]></description>
			<content:encoded><![CDATA[<p>This article describes an extremely basic Excel® function (well, two functions actually) and is more a test of my new Wordpress installation than anything else <img src='http://blog.kirgs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>It describes how you can use the <strong>INDEX</strong>() and <strong>MATCH</strong>() functions to look up data in a matrix.</p>
<p><span style="text-decoration: underline;">Background to <strong>VLOOKUP</strong>()</span></p>
<p>Many users are familar with the <strong>VLOOKUP</strong>() (vertical lookup) function that simply looks up a value in the leading column of a table and returns the value in another specified column of the same table.  The required parameters are:</p>
<p><strong>VLOOKUP</strong>(<strong>Lookup_value</strong>,<strong>Table_array</strong>,<strong>Col_index_num</strong>,<strong>Range_lookup</strong>) where <strong>Range_lookup</strong> is optional.</p>
<p><em>For example:</em></p>
<p>With the data in the table below&#8230;</p>
<table style="text-align: center;" border="0">
<tbody>
<tr>
<td></td>
<td style="color:silver;text-align:center;">A</td>
<td style="color:silver;text-align:center;">B</td>
</tr>
<tr style="font-weight:bold;">
<td style="color:silver;font-weight:normal;">1</td>
<td style="border:solid black 1px;">Fruit</td>
<td style="border:solid black 1px;">Colour</td>
</tr>
<tr>
<td style="color:silver;">2</td>
<td style="border:solid black 1px;">Apple</td>
<td style="border:solid black 1px;">Red</td>
</tr>
<tr>
<td style="color:silver;">3</td>
<td style="border:solid black 1px;">Banana</td>
<td style="border:solid black 1px;">Yellow</td>
</tr>
<tr>
<td style="color:silver;">4</td>
<td style="border:solid black 1px;">Orange</td>
<td style="border:solid black 1px;">Orange (what else!)</td>
</tr>
</tbody>
</table>
<p>&#8230;the formula</p>
<p>=<strong>VLOOKUP</strong>(<strong>&#8220;Banana&#8221;</strong>,<strong>$A$2:$B$4</strong>,<strong>2</strong>)</p>
<p><em>Result<strong>: Yellow<br />
</strong></em></p>
<p>will search for &#8220;<strong>Banana</strong>&#8221; (1st parameter) in the leftmost column of the table (<strong>$A$2:$B$4</strong>) (2nd parameter) and return the value that is in the <strong>2</strong>nd (3rd-parameter-th) column.</p>
<p>It should be noted that the 1st parameter (the value of which, here, is &#8220;<strong>Banana</strong>&#8220;) can also be a cell reference (e.g.<strong> $D$1</strong>) rather than statically entered into the result cell formula.</p>
<p><span style="text-decoration: underline;">Problems with <strong>VLOOKUP</strong>()</span></p>
<p>I&#8217;ve never like this function for several reasons:</p>
<ol>
<li>Any changes to the structure of the table (such as the insertion of a new column) may result in the incorrect field value for that row entry being returned.</li>
<li>You need to determine what column number the information you want return resides in.  (<em>This is obviously fine for small tables, but you shouldn&#8217;t have to waste time determining this in the first place!</em>)</li>
<li>The table needs to be (ascendingly?) sorted by the first column to work correctly.</li>
<li>It takes longer than it ought to replicate the query to return the value for a different column.</li>
</ol>
<p>So what are our alternatives?  I prefer to use the <strong>INDEX</strong>() and <strong>MATCH</strong>()<strong> </strong>functions.  For my mind this approach is not only more flexible, but it&#8217;s also more intuitive.</p>
<p>The premise is much the same, however, instead of matching only the leftmost column, you can also match a row and column to determine the coordinates of the value you want returned.  It&#8217;s effectively a combination of the <strong>VLOOKUP</strong>() (vertical lookup) and <strong>HLOOKUP</strong>()<strong>*</strong> (horizontal lookup) functions.</p>
<p>*<em> <strong>HLOOKUP</strong>() simply matches a value to the first <strong>row</strong> (cf. column) of the table, returning the value in a corresponding <strong>column</strong> (cf. row)</em></p>
<p><span style="text-decoration: underline;">Using <strong>INDEX</strong>() and <strong>MATCH</strong>()</span></p>
<p>I&#8217;ll describe the <strong>INDEX</strong>() and <strong>MATCH</strong>() functions separately.  There are two permutations of the <strong>INDEX</strong>() function: <em>array</em> and <em>reference</em>.   For the purposes of this post, I&#8217;ll use <em>array</em>.  The <strong>INDEX</strong>()<strong> </strong>function is described as:</p>
<p>=<strong>INDEX</strong>(<strong>array,row_num,column_num)</strong></p>
<p><em>For example:</em></p>
<p>Using the same data from the previous example, we designate the <strong>array</strong> parameter as the table that contains the data we wish to return.</p>
<table style="text-align: center;" border="0">
<tbody>
<tr>
<td></td>
<td style="color:silver;text-align:center;">A</td>
<td style="color:silver;text-align:center;">B</td>
</tr>
<tr style="font-weight:bold;">
<td style="color:silver;font-weight:normal;">1</td>
<td style="border:solid black 1px;">Fruit</td>
<td style="border:solid black 1px;">Colour</td>
</tr>
<tr>
<td style="color:silver;">2</td>
<td style="border:solid black 1px;">Apple</td>
<td style="border:solid black 1px;">Red</td>
</tr>
<tr>
<td style="color:silver;">3</td>
<td style="border:solid black 1px;">Banana</td>
<td style="border:solid black 1px;">Yellow</td>
</tr>
<tr>
<td style="color:silver;">4</td>
<td style="border:solid black 1px;">Orange</td>
<td style="border:solid black 1px;">Orange (what else!)</td>
</tr>
</tbody>
</table>
<p>To retrieve the same result from the first example, we can use the formula:</p>
<p>=<strong>INDEX</strong>(<strong>$A$2:$B$4</strong>,<strong>2</strong>,<strong>2</strong>)</p>
<p><em>Result<strong>: Yellow<br />
</strong></em></p>
<p>This returns the value from the array (<strong>$A$2:$B$4</strong> &#8211; 1st parameter) that is in the <strong>2</strong>nd row (2nd parameter) and the <strong>2</strong>nd column (3rd parameter).  Using the function in this way <strong>INDEX</strong>() is certainly no better than using <strong>VLOOKUP</strong>() (in fact, it&#8217;s worse, because there is no dynamic functionality &#8211; that is, there is no &#8220;searching&#8221; involved.)</p>
<p>So, how do we dynamically determine the row and column numbers based on certain criteria?  We can use the <strong>MATCH</strong>() function, which can be described as:</p>
<p>=<strong>MATCH</strong>(<strong>Lookup_value</strong>,<strong>Lookup_array</strong>,<strong>Match_type</strong>)</p>
<p>To determine the row we are interested in (here, row <strong>2</strong> &#8211; the &#8220;<strong>Banana</strong>&#8221; row) we can use the formula:</p>
<p><strong>=MATCH(</strong>&#8220;<strong>Banana</strong>&#8220;,<strong>$A$2:$A$4</strong>,<strong>0)</strong></p>
<p>This searches the data array (<strong>$A$2:$A$4</strong> &#8211; the 2nd parameter) for the lookup value (&#8221;<strong>Banana</strong>&#8221; &#8211; the 1st parameter) and ensures that it matches exactly (<strong>Match_type</strong> &#8211; the 3rd parameter &#8211; equals <strong>0</strong>; returns #N/A if there is no match.)</p>
<p><em>Result<strong>: 2</strong></em></p>
<p>Similarly, we use this function to determine our required column number (here, column <strong>2</strong> &#8211; the &#8220;<strong>Colour</strong>&#8221; column) we can use:</p>
<p><strong>=MATCH(</strong>&#8220;<strong>Colour</strong>&#8220;,<strong>$A$1:$B$1</strong>,<strong>0)</strong></p>
<p>This searches the data array (<strong>$A$1:$B$1</strong> &#8211; the 2nd parameter) for the lookup value (&#8221;<strong>Colour</strong>&#8221; &#8211; the 1st parameter) and ensures that it matches exactly (<strong>Match_type</strong> &#8211; the 3rd parameter &#8211; equals <strong>0</strong>; returns #N/A if there is no match.)</p>
<p><em>Result<strong>: 2</strong></em></p>
<p>It should be easy to recognise from this point that for a much larger table, this takes a lot of the guess work out of determining the appropriate column number.</p>
<p>=<strong>INDEX</strong>(<strong>$A$2:$B$4</strong>,<strong>MATCH</strong>(<strong>&#8220;Banana&#8221;</strong>,<strong>$A$2:$A$4,0</strong>),<strong>MATCH</strong>(<strong>&#8220;Colour&#8221;</strong>,<strong>$A$1:$B$1,0</strong>))</p>
<p><em>Result<strong>: Yellow<br />
</strong></em></p>
<p><span style="text-decoration: underline;">Accomodating changes to the table structure</span><em> </em></p>
<p>As mentioned, one of the advantages of using the <strong>INDEX</strong>() and <strong>MATCH</strong>() functions is its ability to adapt when changes are made to the table structure.</p>
<table style="text-align: center;" border="0">
<tbody>
<tr>
<td></td>
<td style="color:silver;text-align:center;">A</td>
<td style="color:silver;text-align:center;">B</td>
<td style="color:silver;text-align:center;">C</td>
<td style="color:silver;text-align:center;">D</td>
</tr>
<tr style="font-weight:bold;">
<td style="color:silver;font-weight:normal;">1</td>
<td style="border:solid black 1px;">Fruit</td>
<td style="border:solid black 1px;">Price</td>
<td style="border:solid black 1px;">Colour</td>
<td style="border:solid black 1px;">Qty</td>
</tr>
<tr>
<td style="color:silver;">2</td>
<td style="border:solid black 1px;">Apple</td>
<td style="border:solid black 1px;">$1.50</td>
<td style="border:solid black 1px;">Red</td>
<td style="border:solid black 1px;">2</td>
</tr>
<tr>
<td style="color:silver;">3</td>
<td style="border:solid black 1px;">Banana</td>
<td style="border:solid black 1px;">$2.50</td>
<td style="border:solid black 1px;">Yellow</td>
<td style="border:solid black 1px;">7</td>
</tr>
<tr>
<td style="color:silver;">4</td>
<td style="border:solid black 1px;">Orange</td>
<td style="border:solid black 1px;">$0.80</td>
<td style="border:solid black 1px;">Orange (what else!)</td>
<td style="border:solid black 1px;">8</td>
</tr>
</tbody>
</table>
<p>=<strong>INDEX</strong>(<strong>$A$2:$D$4</strong>,<strong>MATCH</strong>(<strong>&#8220;Banana&#8221;</strong>,<strong>$A$2:$A$4,0</strong>),<strong>MATCH</strong>(<strong>&#8220;Colour&#8221;</strong>,<strong>$A$1:$D$1,0</strong>))<strong> </strong>will still return &#8220;<strong>Yellow</strong>&#8221; (once columns <strong>C</strong> and <strong>D</strong> are accounted for) as the 3rd parameter of the <strong>INDEX</strong>() function is now <strong>3</strong>, while&#8230;</p>
<p>=<strong>VLOOKUP</strong>(<strong>&#8220;Banana&#8221;</strong>,<strong>$A$2:$D$4</strong>,<strong>2</strong>)<strong> </strong>will now return <strong>$2.50</strong> as this is the value in the <strong>2</strong>nd column of the &#8220;<strong>Banana</strong>&#8221; row, that is, it hasn&#8217;t adapted to the change in table structure.</p>
<p><span style="text-decoration: underline;">Using named ranges</span></p>
<p>I love named ranges (as much as one can love an Excel® function) and using them can simplify even the most complicated formula.  I will describe named ranges in more detail in another article, but for the sake of this piece, simply put, named ranges are names that refer to a cell or cell range.  Using the above example, you could define or &#8220;name&#8221; the <strong>$A$2:$D$4</strong> cell range as &#8220;<strong>Data</strong>&#8220;, <strong>$A$1:$D$1</strong> as &#8220;<strong>Fields</strong>&#8220;, <strong>$A$2:$A$4</strong> as <strong>&#8220;Fruits</strong>&#8220;, <strong>$B$2:$B$4</strong> as &#8220;<strong>Prices</strong>&#8221; and so on.  You can name ranges by selecting <strong>Insert</strong> -&gt; <strong>Name</strong> -&gt; <strong>Define</strong> from the Excel® file menu.  Once this has been done, your formula simplifies to:</p>
<p>=<strong>INDEX</strong>(<strong>Data</strong>,<strong>MATCH</strong>(<strong>&#8220;Banana&#8221;</strong>,<strong>Fruits,0</strong>),<strong>MATCH</strong>(<strong>&#8220;Colour&#8221;</strong>,<strong>Fields,0</strong>))</p>
<p><em>Result: <strong>Yellow</strong></em></p>
<p><span style="text-decoration: underline;">An additional example &#8211; the best use of <strong>INDEX</strong>() and <strong>MATCH</strong>()</span></p>
<p>This combination of functions is probably best utilised when using 2-dimensional matrices that have column and row headings.</p>
<p><em>For example:</em></p>
<div><em></em></div>
<div><em></em></div>
<table style="text-align: center;" border="0">
<tbody>
<tr>
<td></td>
<td style="color:silver;text-align:center;">A</td>
<td style="color:silver;text-align:center;">B</td>
<td style="color:silver;text-align:center;">C</td>
<td style="color:silver;text-align:center;">D</td>
</tr>
<tr>
<td style="color:silver;">1</td>
<td style="border:solid black 1px;font-weight:bold;">Origin/Destination</td>
<td style="border:solid black 1px;">Sydney</td>
<td style="border:solid black 1px;">Melbourne</td>
<td style="border:solid black 1px;">Brisbane</td>
</tr>
<tr>
<td style="color:silver;">2</td>
<td style="border:solid black 1px;">Sydney</td>
<td style="border:solid black 1px;">0</td>
<td style="border:solid black 1px;">885</td>
<td style="border:solid black 1px;">926</td>
</tr>
<tr>
<td style="color:silver;">3</td>
<td style="border:solid black 1px;">Melbourne</td>
<td style="border:solid black 1px;">885</td>
<td style="border:solid black 1px;">0</td>
<td style="border:solid black 1px;">1697</td>
</tr>
<tr>
<td style="color:silver;">4</td>
<td style="border:solid black 1px;">Brisbane</td>
<td style="border:solid black 1px;">926</td>
<td style="border:solid black 1px;">1697</td>
<td style="border:solid black 1px;">0</td>
</tr>
</tbody>
</table>
<p><em></em>With the appropriate named ranges, your formula to determine the distance between two given points could be:</p>
<p>=<strong>INDEX</strong>(<strong>Distances</strong>,<strong>MATCH</strong>(<strong>&#8220;Brisbane&#8221;</strong>,<strong>Origins,0</strong>),<strong>MATCH</strong>(<strong>&#8220;Sydney&#8221;</strong>,<strong>Destinations,0</strong>))</p>
<p><em>Results: <strong>926</strong></em></p>
<p><span style="text-decoration: underline;">Other points</span></p>
<ul>
<li>As mentioned with the <strong>VLOOKUP</strong>() example, &#8220;<strong>Banana</strong>&#8221; and &#8220;<strong>Colour</strong>&#8221; could both be cell references (you could even use a drop-down menu!)</li>
<li>You could use <strong>VLOOKUP</strong>() and <strong>MATCH</strong>() (e.g. <strong>VLOOKUP</strong>(<strong>&#8220;Banana&#8221;</strong>,<strong>$A$2:$B$4</strong>,<strong>MATCH</strong>(<strong>&#8220;Colour&#8221;</strong>,<strong>$A$1:$B$1</strong>,<strong>0</strong>)) but you are still limited to your &#8220;row&#8221; search term being in the first row and that the list is sorted by the first row.</li>
<li>Complications can arise if there are not unique values in a column or row (e.g. &#8220;<strong>Apples</strong>&#8221; can be &#8220;<strong>Red&#8221;</strong> or &#8220;<strong>Green</strong>&#8220;, so could have two entries in the table.)  There are ways in which you can handle this (sometimes using <strong>SMALL</strong>() and <strong>BIG</strong>() that are beyond the scope of this article.)</li>
</ul>
<p>Othewise, I&#8217;ve found this to be a good alternative to the <strong>VLOOKUP</strong>() function; one that&#8217;s easier to use and more powerful.</p>
<p>There are certainly aspects of the functions that I have omitted.  I&#8217;d welcome any comments or criticism, so please feel free to add any comments.  If you require further clarification on any part of this article, please leave a comment, or you can email me at: <a href="mailto:ryan@kirgs.com">ryan@kirgs.com</a> or simply visit my website: <a href="http://businessanalyst.kirgs.com/">http://businessanalyst.kirgs.com/</a> and complete the feedback form on the &#8220;contact&#8221; section.</p>
<p><em>Ryan Kirgan is a Business Analyst who operates out of Sydney, Australia.</em></p>
<div class="wp-caption alignnone" style="width: 80px"><a href="http://businessanalyst.kirgs.com/about/"><img title="Business Analyst: Ryan Kirgan" src="http://businessanalyst.kirgs.com/images/mugshot_70x120.png" alt="Business Analyst: Ryan Kirgan" width="70" height="120" /></a><p class="wp-caption-text">Business Analyst: Ryan Kirgan</p></div>
<a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save?linkurl=http%3A%2F%2Fblog.kirgs.com%2F2009%2F02%2F02%2Fmatching-data-in-a-table-in-excel%25c2%25ae-using-index-and-match-a-vlookup-alternative%2F&amp;linkname=Matching%20data%20in%20a%20table%20in%20Excel%C2%AE%20using%20INDEX%20and%20MATCH%20%28-%20a%20VLOOKUP%20alternative%29"><img src="http://blog.kirgs.com/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a>]]></content:encoded>
			<wfw:commentRss>http://blog.kirgs.com/2009/02/02/matching-data-in-a-table-in-excel%c2%ae-using-index-and-match-a-vlookup-alternative/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
	</channel>
</rss>
