<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<!--[if !mso]><style>v\:* {behavior:url(#default#VML);}
o\:* {behavior:url(#default#VML);}
w\:* {behavior:url(#default#VML);}
.shape {behavior:url(#default#VML);}
</style><![endif]--><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
span.Shkpostityyli19
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        mso-ligatures:none;
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 2.0cm 70.85pt 2.0cm;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="FI" link="blue" vlink="purple" style="word-wrap:break-word">
<div class="WordSection1">
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">Hi,<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US">Thank you everybody for the good and working suggestions.<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US">-Jukka Rahkonen-<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b>Lähettäjä:</b> gdal-dev <gdal-dev-bounces@lists.osgeo.org>
<b>Puolesta </b>Ujaval Gandhi via gdal-dev<br>
<b>Lähetetty:</b> keskiviikko 30. lokakuuta 2024 8.44<br>
<b>Vastaanottaja:</b> Scott <public@postholer.com><br>
<b>Kopio:</b> gdal-dev@lists.osgeo.org<br>
<b>Aihe:</b> Re: [gdal-dev] How to locate where the raster min and max values are?<o:p></o:p></p>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">Another approach using rasterio<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">import rasterio<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">import numpy as np<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">dataset = rasterio.open('P3412A.tif')<br>
band1 = dataset.read(1)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">rows, cols = np.where(band1 == np.max(band1))<o:p></o:p></p>
<div>
<div>
<div>
<p class="MsoNormal">lon, lat = rasterio.transform.xy(dataset.transform, row[0], col[0])<br>
print(lat, lon)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">---<o:p></o:p></p>
<div>
<p class="MsoNormal">Ujaval Gandhi<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">Spatial Thoughts<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><a href="https://mailtrack.io/l/79bb80f67e4a9e655cddd40fc6a12779870dac63?w=Z2RhbC1kZXZAbGlzdHMub3NnZW8ub3Jn&url=http%3A%2F%2Fwww.spatialthoughts.com&u=8747767&signature=198a984b1b993e73" target="_blank">www.spatialthoughts.com</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</div>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</div>
<p class="MsoNormal"><br>
<img border="0" width="1" height="1" style="width:.0104in;height:.0104in" id="_x0000_i1025" src="https://mailtrack.io/trace/mail/w/Z2RhbC1kZXZAbGlzdHMub3NnZW8ub3Jn/534810d4c31014abe1126883ab1899f775f7c9e0.png?u=8747767"><o:p></o:p></p>
<div>
<div>
<p class="MsoNormal">On Wed, Oct 30, 2024 at 8:06 AM Scott via gdal-dev <<a href="mailto:gdal-dev@lists.osgeo.org">gdal-dev@lists.osgeo.org</a>> wrote:<o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0cm 0cm 0cm 6.0pt;margin-left:4.8pt;margin-right:0cm">
<p class="MsoNormal">It ain't pretty or efficient, but it's cheap. Here's min value. Remove
<br>
'r' from sort for max value:<br>
<br>
gdal2xyz.py -csv -skipnodata source.tif /dev/stdout | grep -v done | <br>
sort -rnk 3,3 -t "," | tail -1<br>
<br>
result:<br>
-116.9916667,36.54166667,46<br>
<br>
On 10/29/24 17:31, Rahkonen Jukka via gdal-dev wrote:<br>
> Hi,<br>
> <br>
> I would like to know the georeferenced coordinates of the min and max <br>
> values of a DEM file. Even better if I could forward them into a vector <br>
> file. If the minimum or maximum happens to be on a flat area like seabed <br>
> I would be happy with the first pixel at the moment.<br>
> <br>
> By copy-pasting from How do I open geotiff images with GDAL in Python? - <br>
> Stack Overflow <br>
> <<a href="https://stackoverflow.com/questions/41996079/how-do-i-open-geotiff-images-with-gdal-in-python" target="_blank">https://stackoverflow.com/questions/41996079/how-do-i-open-geotiff-images-with-gdal-in-python</a>> and How to find the indexes of the
 minimum or maximum value(s) in a matrix using python ? <<a href="https://en.moonbooks.org/Articles/How-to-find-the-indexes-of-the-minimum-or-maximum-values-in-a-matrix-using-python-/" target="_blank">https://en.moonbooks.org/Articles/How-to-find-the-indexes-of-the-minimum-or-maximum-values-in-a-matrix-using-python-/</a>>
 I think I managed to get the correct points as numpy indexes<br>
> <br>
>>>> import numpy as np<br>
> <br>
>>>> from osgeo import gdal<br>
> <br>
>>>> ds = gdal.Open('P3412A.tif', gdal.GA_ReadOnly)<br>
> <br>
>>>> rb = ds.GetRasterBand(1)<br>
> <br>
>>>> img_array = rb.ReadAsArray()<br>
> <br>
>>>> vmin = img_array.min()<br>
> <br>
>>>> vmax = img_array.max()<br>
> <br>
>>>> vmin<br>
> <br>
> -0.929<br>
> <br>
>>>> vmax<br>
> <br>
> 17.246<br>
> <br>
>>>><br>
> <br>
>>>> np.where(img_array==vmin)<br>
> <br>
> (array([1504], dtype=intg64), array([1189], dtype=int64))<br>
> <br>
>>>> np.where(img_array==vmax)<br>
> <br>
> (array([1545], dtype=int64), array([2423], dtype=int64))<br>
> <br>
>>>><br>
> <br>
> But now I have no idea about how to get the georeferenced coordinates.<br>
> <br>
> The task feels rather simple and I was sure that someone has already <br>
> made an utility or a QGIS plugin, but all I have found yet is for R. I <br>
> was thinking that perhaps some of the gdaldem modes could be misused for <br>
> this purpose, but I believe they cannot. For QGIS I found advice to use <br>
> an obvious but  clumsy method of polygonising the raster and finding the <br>
> extremes from the vector data. And one OpenJUMP developer took the <br>
> challenge and wrote a prototype with Java but it is not complete yet.<br>
> <br>
> -Jukka Rahkonen-<br>
> <br>
> <br>
> _______________________________________________<br>
> gdal-dev mailing list<br>
> <a href="mailto:gdal-dev@lists.osgeo.org" target="_blank">gdal-dev@lists.osgeo.org</a><br>
> <a href="https://lists.osgeo.org/mailman/listinfo/gdal-dev" target="_blank">https://lists.osgeo.org/mailman/listinfo/gdal-dev</a><br>
_______________________________________________<br>
gdal-dev mailing list<br>
<a href="mailto:gdal-dev@lists.osgeo.org" target="_blank">gdal-dev@lists.osgeo.org</a><br>
<a href="https://lists.osgeo.org/mailman/listinfo/gdal-dev" target="_blank">https://lists.osgeo.org/mailman/listinfo/gdal-dev</a><o:p></o:p></p>
</blockquote>
</div>
</div>
</body>
</html>