<html>
<body>
<div style="font-family: Verdana, Arial, Helvetica, Sans-Serif;">
<table bgcolor="#f9f3c9" width="100%" cellpadding="8" style="border: 1px #c9c399 solid;">
<tr>
<td>
This is an automatically generated e-mail. To reply, visit:
<a href="http://svn.reviewboard.kde.org/r/5825/">http://svn.reviewboard.kde.org/r/5825/</a>
</td>
</tr>
</table>
<br />
<blockquote style="margin-left: 1em; border-left: 2px solid #d0d0d0; padding-left: 10px;">
<p style="margin-top: 0;">On November 20th, 2010, 3:23 p.m., <b>Matias Kallio</b> wrote:</p>
<blockquote style="margin-left: 1em; border-left: 2px solid #d0d0d0; padding-left: 10px;">
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
<thead>
<tr>
<th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
<a href="http://svn.reviewboard.kde.org/r/5825/diff/1/?file=41107#file41107line160" style="color: black; font-weight: bold; text-decoration: underline;">/trunk/KDE/kdeedu/marble/tests/unittest_geodatacoordinates.cpp</a>
<span style="font-weight: normal;">
(Diff revision 1)
</span>
</th>
</tr>
</thead>
<tbody style="background-color: #e4d9cb; padding: 4px 8px; text-align: center;">
<tr>
<td colspan="2"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
<td colspan="2"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">void TestGeoDataCoordinates::testNormalize()</pre></td>
</tr>
</tbody>
<tbody>
<tr>
<th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
<td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
<th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">160</font></th>
<td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "> <span class="n">GeoDataCoordinates</span><span class="o">::</span><span class="n">normalizeLonLat</span><span class="p">(</span> <span class="n">normalized_longi</span><span class="p">,</span> <span class="n">normalized_latit</span><span class="p">,</span> <span class="n">GeoDataCoordinates</span><span class="o">::</span><span class="n">Degree</span><span class="p">);</span></pre></td>
</tr>
</tbody>
</table>
<pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;">Could you explain first of all what is the purpose of this normalize-methods? Where that functionality is needed? I have some difficulties to understand...
Then shouldn't normalizeLon and normalizeLat produce similar output as normalizeLonLat? Because now I'm getting different values. Or Am I just doing something wrong:
****
qreal lon = 200;
qreal lat = 130;
qDebug() << "lon" << GeoDataCoordinates::normalizeLon(lon, GeoDataCoordinates::Degree);
qDebug() << "lat" << GeoDataCoordinates::normalizeLat(lat, GeoDataCoordinates::Degree);
qreal normalized_lon = lon;
qreal normalized_lat = lat;
GeoDataCoordinates::normalizeLonLat( normalized_lon, normalized_lat, GeoDataCoordinates::Degree);
qDebug() << "Normalize_lon " << normalized_lon << "normalize_lat " << normalized_lat;
gives me:
lon -160
lat 50
Normalize_lon 20 normalize_lat 50
****</pre>
</blockquote>
<p>On November 21st, 2010, 3:07 p.m., <b>Torsten Rahn</b> wrote:</p>
<blockquote style="margin-left: 1em; border-left: 2px solid #d0d0d0; padding-left: 10px;">
<pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;">This looks correct to me.
GeoDataCoordinates::normalizeLon() "normalizes" whatever coordinates are provided to the range of [-180 (west) ... +180 (east)]. -180/180 marks the earths dateline. So if you go beyond that value (e.g. 200) then you end up on the other side of the dateline and get a value of -160.
The same applies with GeoDataCoordinates::normalizeLat(): The "valid" Latitude range goes from [-90 (south) ... +90 (north)]. So imagine you'd go from Tampere north: The latitude would rise until you reach the northpole (90). If you go beyond the pole you could argue that you e.g. reach 100 degrees latitude - which actually equals 80 degs north. So the normalized value would be 80.
Now imagine you do that for real: Tampere is at 24 degrees Longitude and 62 degrees latitude. You head north towards the northpole and once you cross it you are on the other side. So if you had a latitude of "100" that would certainly equal the "normalized" value "80". But since you are on the other side of the equator your longitude would be a different one: it would have shifted by 180 degs since you are on the other half of the globe. That's what GeoDataCoordinates::normalizeLonLat takes into account: Entering lon=200 and lat=130 would result in "50" for the latitude. But the longitude would at the same time change by 180: So we could either add those 180 or subtract them. And by subtracting we end up at lon=20.
So GeoDataCoordinates::normalizeLonLat takes both coordinates into account at the same time. GeoDataCoordinates::normalizeLon() and GeoDataCoordinates::normalizeLat() only take a single coordinate component into account. Therefore GeoDataCoordinates::normalizeLonLat() yields results that are different from what you get if you just execute GeoDataCoordinates::normalizeLon() and GeoDataCoordinates::normalizeLat() one after each other.
Got the idea? :-)
</pre>
</blockquote>
</blockquote>
<pre style="margin-left: 1em; white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;">I forgot to tell where this kind of stuff is needed: If you look at a certain point (e.g. close to the dateline or close to the poles and describe a movement of that point by a certain amount of degrees then your calculation might result in a value that is out of the -180/180 or -90/90 range. To avoid this situation you can apply the normalize methods.
Another example are different planets: For other planets a similar coordinate system as the one used for our earth is used. However some databases use ranges for the longitude between [0...360] (instead of [-180...180]). We normalize these values so that our painting methods still work accurately with flat map projections. </pre>
<br />
<p>- Torsten</p>
<br />
<p>On November 10th, 2010, 5:33 p.m., Matias Kallio wrote:</p>
<table bgcolor="#fefadf" width="100%" cellspacing="0" cellpadding="8" style="background-image: url('http://svn.reviewboard.kde.orgrb/images/review_request_box_top_bg.png'); background-position: left top; background-repeat: repeat-x; border: 1px black solid;">
<tr>
<td>
<div>Review request for marble.</div>
<div>By Matias Kallio.</div>
<p style="color: grey;"><i>Updated 2010-11-10 17:33:24</i></p>
<h1 style="color: #575012; font-size: 10pt; margin-top: 1.5em;">Description </h1>
<table width="100%" bgcolor="#ffffff" cellspacing="0" cellpadding="10" style="border: 1px solid #b8b5a0">
<tr>
<td>
<pre style="margin: 0; padding: 0; white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;">First version of unittest for GeoDataCoordinates-class. </pre>
</td>
</tr>
</table>
<h1 style="color: #575012; font-size: 10pt; margin-top: 1.5em;">Diffs</b> </h1>
<ul style="margin-left: 3em; padding-left: 0;">
<li>/trunk/KDE/kdeedu/marble/tests/CMakeLists.txt <span style="color: grey">(1194752)</span></li>
<li>/trunk/KDE/kdeedu/marble/tests/unittest_geodatacoordinates.cpp <span style="color: grey">(PRE-CREATION)</span></li>
</ul>
<p><a href="http://svn.reviewboard.kde.org/r/5825/diff/" style="margin-left: 3em;">View Diff</a></p>
</td>
</tr>
</table>
</div>
</body>
</html>