अजगर का उपयोग कर रेखापुंज से लैट / लंबे समय तक ऊंचाई प्राप्त करना?


10

मैं सोच रहा था कि अगर किसी को आरकेजीआईएस का उपयोग किए बिना एक रैस्टर से ऊंचाई डेटा प्राप्त करने का कुछ अनुभव है , बल्कि एक अजगर के रूप में जानकारी प्राप्त करें listया dict?

मुझे अपना XY डेटा टुपल्स की सूची के रूप में मिलता है:

xy34 =[perp_obj[j].CalcPnts(float(i.dist), orientation) for j in range (len(perp_obj))]

मैं सूची के माध्यम से लूप करना चाहता हूं या xy- जोड़े के लिए संबंधित ऊंचाई प्राप्त करने के लिए इसे फ़ंक्शन या क्लास-विधि में पास करना चाहता हूं।

मैंने इस विषय पर कुछ शोध किया और गदल एपीआई आशाजनक लगता है। क्या कोई मुझे सलाह दे सकता है कि चीजों, नुकसान, नमूना कोड के बारे में कैसे जाना जाए?


GDAL एक विकल्प नहीं है क्योंकि मैं जिस मशीन पर काम कर रहा हूं उस पर सिस्टम पथ चर को संपादित नहीं कर सकता!

क्या कोई अलग दृष्टिकोण के बारे में जानता है?


2
दुर्भाग्य से, आपको वास्तव में पायथन में एक रेखापुंज के साथ कुछ भी करने के लिए अपने सिस्टम पर GDAL चलाने की आवश्यकता है। "मशीन पर सिस्टम पथ चर को संपादित नहीं कर सकते हैं", क्या आप इन निर्देशों का उल्लेख कर रहे हैं ? मुझे यह स्थापना विधि बहुत खराब लगती है, और मैं इसका उपयोग नहीं करता और न ही इसकी सिफारिश करता हूं। यदि आप विंडोज का उपयोग कर रहे हैं, तो GDAL / Python को सरल तरीके से इंस्टॉल करें ।
माइक टी।

हां, मैं वास्तव में था। मैं अभी काम पर नहीं हूं, लेकिन आपके द्वारा पोस्ट किए गए लिंक की जांच करूंगा। उम्मीद तो दिखती है! मेरे सवाल पर वापस आने के लिए धन्यवाद!
लार्सविगास

मैंने कई काम कंप्यूटरों पर क्रिस्टोफ गोहलके (ऊपर लिंक) द्वारा इंस्टॉलर का उपयोग किया है, और यह वास्तव में सरल है। आपको केवल यह सुनिश्चित करने की आवश्यकता है कि आप पायथन के संस्करण से मेल खाते हैं और 32- या 64-बिट विंडोज। जब आप इस पर होते हैं, तो आपको उसी जगह से NumPy प्राप्त करना चाहिए, क्योंकि GDAL को इसकी आवश्यकता है, जैसा कि नीचे दिए गए उत्तरों में दिखाया गया है।
माइक टी।

जवाबों:


15

यहाँ @ आरागॉन के उत्तर की तुलना में GDAL का उपयोग करने का एक अधिक प्रोग्रामेटिक तरीका है। मैंने इसका परीक्षण नहीं किया है, लेकिन यह ज्यादातर बॉयलर-प्लेट कोड है जो अतीत में मेरे लिए काम कर चुका है। यह Numpy और GDAL बाइंडिंग पर निर्भर करता है, लेकिन यह इसके बारे में है।

import osgeo.gdal as gdal
import osgeo.osr as osr
import numpy as np
from numpy import ma

def maFromGDAL(filename):
    dataset = gdal.Open(filename, gdal.GA_ReadOnly)

    if dataset is None:
        raise Exception()

    # Get the georeferencing metadata.
    # We don't need to know the CRS unless we want to specify coordinates
    # in a different CRS.
    #projection = dataset.GetProjection()
    geotransform = dataset.GetGeoTransform()

    # We need to know the geographic bounds and resolution of our dataset.
    if geotransform is None:
        dataset = None
        raise Exception()

    # Get the first band.
    band = dataset.GetRasterBand(1)
    # We need to nodata value for our MaskedArray later.
    nodata = band.GetNoDataValue()
    # Load the entire dataset into one numpy array.
    image = band.ReadAsArray(0, 0, band.XSize, band.YSize)
    # Close the dataset.
    dataset = None

    # Create a numpy MaskedArray from our regular numpy array.
    # If we want to be really clever, we could subclass MaskedArray to hold
    # our georeference metadata as well.
    # see here: http://docs.scipy.org/doc/numpy/user/basics.subclassing.html
    # For details.
    masked_image = ma.masked_values(image, nodata, copy=False)
    masked_image.fill_value = nodata

    return masked_image, geotransform

def pixelToMap(gt, pos):
    return (gt[0] + pos[0] * gt[1] + pos[1] * gt[2],
            gt[3] + pos[0] * gt[4] + pos[1] * gt[5])

# Reverses the operation of pixelToMap(), according to:
# https://en.wikipedia.org/wiki/World_file because GDAL's Affine GeoTransform
# uses the same values in the same order as an ESRI world file.
# See: http://www.gdal.org/gdal_datamodel.html
def mapToPixel(gt, pos):
    s = gt[0] * gt[4] - gt[3] * gt[1]
    x = (gt[4] * pos[0] - gt[1] * pos[1] + gt[1] * gt[5] - gt[4] * gt[2]) / s
    y = (-gt[3] * pos[0] + gt[0] * pos[1] + gt[3] * gt[2] - gt[0] * gt[5]) / s
    return (x, y)

def valueAtMapPos(image, gt, pos):
    pp = mapToPixel(gt, pos)
    x = int(pp[0])
    y = int(pp[1])

    if x < 0 or y < 0 or x >= image.shape[1] or y >= image.shape[0]:
        raise Exception()

    # Note how we reference the y column first. This is the way numpy arrays
    # work by default. But GDAL assumes x first.
    return image[y, x]

try:
    image, geotransform = maFromGDAL('myimage.tif')
    val = valueAtMapPos(image, geotransform, (434323.0, 2984745.0))
    print val
except:
    print('Something went wrong.')

1
मेरे प्रश्न को संपादित देखें ... वैसे भी पोस्ट करने के लिए धन्यवाद! मैंने इसे उकेरा।
लार्सविगास

1
आह लानत है! अच्छी तरह से कम से कम यह यहाँ पोस्टर के लिए है। टीबीएच, में गणित mapToPixel()और pixelToMap()महत्वपूर्ण बिट हैं, जब तक आप एक संख्यात्मक सरणी (या एक नियमित पायथन एक बना सकते हैं, लेकिन वे आम तौर पर इस तरह की चीज के लिए कुशल नहीं होते हैं), और सरणी का भौगोलिक बाउंडिंग बॉक्स प्राप्त करते हैं।
MerseyViking

1
+1 (और कोड) टिप्पणी के लिए मापदंडों को सुन्न सरणी में बदलने के बारे में। मैं अपने कोड में एक बग के लिए हर जगह खोज रहा था, और इस स्वैप ने इसे तय किया!
एल्डो

1
फिर मैं सुझाव देता हूं कि आपका मैट्रिक्स ( gtउदाहरण में) गलत है। सीजीएएल में इस्तेमाल की जाने वाली एक एफाइन मैट्रिक्स (देखें: gdal.org/gdal_datamodel.html ) आमतौर पर उलटी है (अन्यथा आपके पास कुछ फंकी स्केलिंग वैल्यू चल रही है)। इसलिए जहां हमारे पास है g = p.Aहम p = g.A^-1Numpy.linalg भी अपने उद्देश्यों के लिए थोड़ा भारी है - हम सब कुछ कम कर सकते हैं दो प्रारंभिक समायोजन।
मर्सीवैकिंग

1
मैंने सुन्न एलिनाग के बजाय सरल बीजगणित का उपयोग करने के लिए कोड को फिर से संपादित किया है। यदि गणित गलत है, तो विकिपीडिया पृष्ठ को ठीक करें।
16

3

मेरा जवाब यहां देखें ... और कुछ जानकारी के लिए यहां पढ़ें । निम्नलिखित जानकारी Geotips से ली गई थी:

Gdallocationinfo के साथ , हम एक बिंदु पर ऊंचाई को क्वेरी कर सकते हैं:

$ gdallocationinfo gmted/all075.vrt -geoloc 87360 19679

उपरोक्त कमांड के आउटपुट में फॉर्म है:

Report:
   Location: (87360P,19679L)
Band 1:
   Value: 1418

इसका मतलब है, कि प्रदान किए गए जियोलोकेशन में ऊंचाई का मान 1418 है।


बस मुझे पता चला कि मैं GDAL का उपयोग नहीं कर सकता क्योंकि मैं जिस मशीन पर काम कर रहा हूं, उस पर अपना सिस्टम वैरिएबल संपादित नहीं कर पा रहा हूं। वैसे, इनपुट के लिए धन्यवाद।
LarsVegas

0

उदाहरण देखें यह कोड जो GDAL (और पायथन, कोई सुन्न आवश्यक) पर आधारित है: https://github.com/geometalab/retrieve-height-service


यह दुर्भाग्यपूर्ण है कि कोड को ओपन सोर्स लाइसेंस नहीं लगता है।
बेन क्रॉउल

अब यह :-) है।
स्टीफन

-1

प्रदान की गई अजगर कोड दिए गए x, y coords के आधार पर एक रेखापुंज सेल का मान डेटा निकालता है। यह इस उत्कृष्ट स्रोत से एक उदाहरण का थोड़ा बदल संस्करण है । यह पर आधारित है GDALऔर numpyजो मानक अजगर वितरण का हिस्सा नहीं हैं। स्थापना और त्वरित और आसान उपयोग करने के लिए पायथन एक्सटेंशन पैकेज के लिए अनधिकृत विंडोज बायनेरिज़ को इंगित करने के लिए @ माइक टोज़ के लिए धन्यवाद ।

import os, sys, time, gdal
from gdalconst import *


# coordinates to get pixel values for
xValues = [122588.008]
yValues = [484475.146]

# set directory
os.chdir(r'D:\\temp\\AHN2_060')

# register all of the drivers
gdal.AllRegister()
# open the image
ds = gdal.Open('i25gn1_131.img', GA_ReadOnly)

if ds is None:
    print 'Could not open image'
    sys.exit(1)

# get image size
rows = ds.RasterYSize
cols = ds.RasterXSize
bands = ds.RasterCount

# get georeference info
transform = ds.GetGeoTransform()
xOrigin = transform[0]
yOrigin = transform[3]
pixelWidth = transform[1]
pixelHeight = transform[5]

# loop through the coordinates
for xValue,yValue in zip(xValues,yValues):
    # get x,y
    x = xValue
    y = yValue

    # compute pixel offset
    xOffset = int((x - xOrigin) / pixelWidth)
    yOffset = int((y - yOrigin) / pixelHeight)
    # create a string to print out
    s = "%s %s %s %s " % (x, y, xOffset, yOffset)

    # loop through the bands
    for i in xrange(1,bands):
        band = ds.GetRasterBand(i) # 1-based index
        # read data and add the value to the string
        data = band.ReadAsArray(xOffset, yOffset, 1, 1)
        value = data[0,0]
        s = "%s%s " % (s, value) 
    # print out the data string
    print s
    # figure out how long the script took to run

ऐसा लगता है कि यह केवल एक कम जेनेरिक, कम लचीला संस्करण है जो ऊपर दिए गए MerseyViking की पेशकश करता है?
विलेबी
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.