Take the calculation of NDVI as an example:
NDVI=(NIR-RED)/(NIR+RED)
where NIR is band 3 and RED is band 2
The programming points are as follows:
1. Read band 3 into the array data3, read band 2 into the array data2
2. The calculation formula is:
3. When data3 and data2 are both 0 (for example, 0 represents NODATA), a division by 0 error will occur, causing the program to crash. You need to use mask with choose to remove the 0 value
The code is as follows, there are only 4 lines
data2 = band2.ReadAsArray(0, 0, cols,rows).astype(Numeric.Float16)
data3 = band3.ReadAsArray(0 , 0, cols,rows).astype(Numeric.Float16)
mask = Numeric.greater(data3 + data2, 0)
ndvi = Numeric.choose(mask, (-99, (data3 - data2) / (data3 + data2)))
Create a new raster dataset
Write the data just calculated into the new raster dataset
First, copy a data driver:
driver = inDataset.GetDriver()
Create a new data set afterwards
Create(
The default value of bands is 1, and the default value of GDALDataType is The default type is GDT_Byte, for example
outDataset = driver.Create(filename, cols, rows, 1, GDT_Float32)
During the execution of this statement, the storage space has been allocated to the hard disk
before writing , you also need to introduce the band object first
outBand = outDataset.GetRasterBand(1)
The band object supports direct writing to the matrix, the two parameters are x-direction offset and y-direction offset
outBand.WriteArray(ndvi, 0 , 0)
The following example summarizes the block-by-block writing method this time and last time
xBlockSize = 64
yBlockSize = 64
for i in range(0, rows, yBlockSize):
if i + yBlockSize
numRows = yBlockSize
else:
numRows = rowsnumRows = rows –– ii
for j in range(0, cols, xBlockSize) :
if j + xBlockSize
numCols = xBlockSize
outBand.WriteArray(outData, j, i)The band object can set the NoData valueoutBand.SetNoDataValue(-99)You can also read the NoData valueND = outBand.GetNoDataValue()Calculate the statistics of the bandFirst use FlushCache( )Write cached data to disk and then use GetStatistics(
geoTransform = inDataset.GetGeoTransform()outDataset.SetGeoTransform(geoTransform)proj = inDataset.GetProjection()outDataset.SetProjection(proj)Create pyramidsSet Imagine style pyramids
gdal.SetConfigOption ('HFA_USE_RRD', 'YES')Force to build pyramidsoutDataset.BuildOverviews(overviewlist=[2,4, 8,16,32,64,128])Stitching of images1. Read the number of rows and columns, origin (minX, maxY), pixel length, pixel width, and calculate the coordinate range maxX1 = minX1 + (cols1 * pixelWidth) minY1 = maxY1 + (rows1 * pixelHeight) 2 . Calculate the coordinate range of the output image: minX = min(minX1, minX2, …) maxX = max(maxX1, maxX2, …)minY = min(minY1, minY2, …) maxY = max(maxY1, maxY2, …)3. Calculate the number of rows and columns of the output image: cols = int((maxX – minX) / pixelWidth)rows = int((maxY – minY) / abs(pixelHeight)4. Create and initialize the output image5. For each image to be stitched: Calculate the offset valuexOffset1 = int((minX1 - minX) / pixelWidth)yOffset1 = int((maxY1 - maxY) / pixelHeight) Read the data and write it according to the offset calculated above6. For the output image: calculate statistics, set geotransform: [minX, pixelWidth, 0, maxY, 0, pixelHeight], set projection, and create pyramids
The above is the content of the python gdal tutorial: map algebra and raster data writing. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!

ToappendelementstoaPythonlist,usetheappend()methodforsingleelements,extend()formultipleelements,andinsert()forspecificpositions.1)Useappend()foraddingoneelementattheend.2)Useextend()toaddmultipleelementsefficiently.3)Useinsert()toaddanelementataspeci

TocreateaPythonlist,usesquarebrackets[]andseparateitemswithcommas.1)Listsaredynamicandcanholdmixeddatatypes.2)Useappend(),remove(),andslicingformanipulation.3)Listcomprehensionsareefficientforcreatinglists.4)Becautiouswithlistreferences;usecopy()orsl

In the fields of finance, scientific research, medical care and AI, it is crucial to efficiently store and process numerical data. 1) In finance, using memory mapped files and NumPy libraries can significantly improve data processing speed. 2) In the field of scientific research, HDF5 files are optimized for data storage and retrieval. 3) In medical care, database optimization technologies such as indexing and partitioning improve data query performance. 4) In AI, data sharding and distributed training accelerate model training. System performance and scalability can be significantly improved by choosing the right tools and technologies and weighing trade-offs between storage and processing speeds.

Pythonarraysarecreatedusingthearraymodule,notbuilt-inlikelists.1)Importthearraymodule.2)Specifythetypecode,e.g.,'i'forintegers.3)Initializewithvalues.Arraysofferbettermemoryefficiencyforhomogeneousdatabutlessflexibilitythanlists.

In addition to the shebang line, there are many ways to specify a Python interpreter: 1. Use python commands directly from the command line; 2. Use batch files or shell scripts; 3. Use build tools such as Make or CMake; 4. Use task runners such as Invoke. Each method has its advantages and disadvantages, and it is important to choose the method that suits the needs of the project.

ForhandlinglargedatasetsinPython,useNumPyarraysforbetterperformance.1)NumPyarraysarememory-efficientandfasterfornumericaloperations.2)Avoidunnecessarytypeconversions.3)Leveragevectorizationforreducedtimecomplexity.4)Managememoryusagewithefficientdata

InPython,listsusedynamicmemoryallocationwithover-allocation,whileNumPyarraysallocatefixedmemory.1)Listsallocatemorememorythanneededinitially,resizingwhennecessary.2)NumPyarraysallocateexactmemoryforelements,offeringpredictableusagebutlessflexibility.

InPython, YouCansSpectHedatatYPeyFeLeMeReModelerErnSpAnT.1) UsenPyNeRnRump.1) UsenPyNeRp.DLOATP.PLOATM64, Formor PrecisconTrolatatypes.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

Dreamweaver CS6
Visual web development tools

Dreamweaver Mac version
Visual web development tools

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft
