Creating NDVI using Python, rasterio producing grey imageCalculating NDVI with Rasteriopython rasterio errorReading S3 Sentinel-2 image files with rasterioNDVI image processingUnable to create NDVI image using Python gdal packagebad results NDVI in rasterio with jp2 sentinel-2 bandsRasterio: tool for creating mosaic?Planet NDVI calculation: ModuleNotFoundError: No module named 'rasterio'Rasterio write_band output has no CRSNDVI Python image showing inverse

Why is Minecraft giving an OpenGL error?

Can an x86 CPU running in real mode be considered to be basically an 8086 CPU?

Why can't I see bouncing of switch on oscilloscope screen?

When a company launches a new product do they "come out" with a new product or do they "come up" with a new product?

RSA: Danger of using p to create q

Can a monk's single staff be considered dual wielded, as per the Dual Wielder feat?

Is it possible to run Internet Explorer on OS X El Capitan?

Languages that we cannot (dis)prove to be Context-Free

Why is consensus so controversial in Britain?

How much RAM could one put in a typical 80386 setup?

Can a vampire attack twice with their claws using Multiattack?

What's that red-plus icon near a text?

Does detail obscure or enhance action?

Is it possible to do 50 km distance without any previous training?

Important Resources for Dark Age Civilizations?

How can I prevent hyper evolved versions of regular creatures from wiping out their cousins?

Revoked SSL certificate

How do I deal with an unproductive colleague in a small company?

Is it unprofessional to ask if a job posting on GlassDoor is real?

How much of data wrangling is a data scientist's job?

expand `ifthenelse` immediately

Alternative to sending password over mail?

Replacing matching entries in one column of a file by another column from a different file

Filter any system log file by date or date range



Creating NDVI using Python, rasterio producing grey image


Calculating NDVI with Rasteriopython rasterio errorReading S3 Sentinel-2 image files with rasterioNDVI image processingUnable to create NDVI image using Python gdal packagebad results NDVI in rasterio with jp2 sentinel-2 bandsRasterio: tool for creating mosaic?Planet NDVI calculation: ModuleNotFoundError: No module named 'rasterio'Rasterio write_band output has no CRSNDVI Python image showing inverse






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








0















Using Sentinel data I am creating an NDVI image using the below Python code. The output is a grey image.



import rasterio
from rasterio import plot
import matplotlib.pyplot as plt
import numpy as np
import subprocess
import os

os.listdir('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/')

band4 = rasterio.open('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/GRANULE/L1C_T43PGQ_A010341_20190228T051623/IMG_DATA/T43PGQ_20190228T050739_B04.jp2')
band5 = rasterio.open('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/GRANULE/L1C_T43PGQ_A010341_20190228T051623/IMG_DATA/T43PGQ_20190228T050739_B08.jp2')

bandRed = band4.read(1)
print(os.getcwd())


resize = np.empty(shape=(1,5490*2,5490*2),dtype=np.uint16)

bandNIR = band5.read(1,out=resize)

bandRed = bandRed.astype('float32')
bandNIR = bandNIR.astype('float32')


ndvi = np.zeros(band4.shape, dtype=rasterio.float32)

ndvi_upper = bandNIR + bandRed
ndvi_lower = bandNIR - bandRed

ndvi = ndvi_lower / ndvi_upper

kwargs = band4.meta
kwargs.update(
dtype=rasterio.float32,
count=1,
compress='lzw')

ndviImage = rasterio.open('/Users/abc/ndviImage.tiff','w',driver='Gtiff',
width=band4.width,
height = band4.height,
count=1, crs=band4.crs,
transform=band4.transform,
dtype='float32')


ndviImage.write(ndvi,1)









share|improve this question



















  • 2





    Why not? NDVI is just a single number, in your code ndvi = ndvi_lower / ndvi_upper. It is up to you to apply a color palette when you view the image.

    – user30184
    Apr 2 at 12:03


















0















Using Sentinel data I am creating an NDVI image using the below Python code. The output is a grey image.



import rasterio
from rasterio import plot
import matplotlib.pyplot as plt
import numpy as np
import subprocess
import os

os.listdir('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/')

band4 = rasterio.open('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/GRANULE/L1C_T43PGQ_A010341_20190228T051623/IMG_DATA/T43PGQ_20190228T050739_B04.jp2')
band5 = rasterio.open('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/GRANULE/L1C_T43PGQ_A010341_20190228T051623/IMG_DATA/T43PGQ_20190228T050739_B08.jp2')

bandRed = band4.read(1)
print(os.getcwd())


resize = np.empty(shape=(1,5490*2,5490*2),dtype=np.uint16)

bandNIR = band5.read(1,out=resize)

bandRed = bandRed.astype('float32')
bandNIR = bandNIR.astype('float32')


ndvi = np.zeros(band4.shape, dtype=rasterio.float32)

ndvi_upper = bandNIR + bandRed
ndvi_lower = bandNIR - bandRed

ndvi = ndvi_lower / ndvi_upper

kwargs = band4.meta
kwargs.update(
dtype=rasterio.float32,
count=1,
compress='lzw')

ndviImage = rasterio.open('/Users/abc/ndviImage.tiff','w',driver='Gtiff',
width=band4.width,
height = band4.height,
count=1, crs=band4.crs,
transform=band4.transform,
dtype='float32')


ndviImage.write(ndvi,1)









share|improve this question



















  • 2





    Why not? NDVI is just a single number, in your code ndvi = ndvi_lower / ndvi_upper. It is up to you to apply a color palette when you view the image.

    – user30184
    Apr 2 at 12:03














0












0








0








Using Sentinel data I am creating an NDVI image using the below Python code. The output is a grey image.



import rasterio
from rasterio import plot
import matplotlib.pyplot as plt
import numpy as np
import subprocess
import os

os.listdir('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/')

band4 = rasterio.open('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/GRANULE/L1C_T43PGQ_A010341_20190228T051623/IMG_DATA/T43PGQ_20190228T050739_B04.jp2')
band5 = rasterio.open('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/GRANULE/L1C_T43PGQ_A010341_20190228T051623/IMG_DATA/T43PGQ_20190228T050739_B08.jp2')

bandRed = band4.read(1)
print(os.getcwd())


resize = np.empty(shape=(1,5490*2,5490*2),dtype=np.uint16)

bandNIR = band5.read(1,out=resize)

bandRed = bandRed.astype('float32')
bandNIR = bandNIR.astype('float32')


ndvi = np.zeros(band4.shape, dtype=rasterio.float32)

ndvi_upper = bandNIR + bandRed
ndvi_lower = bandNIR - bandRed

ndvi = ndvi_lower / ndvi_upper

kwargs = band4.meta
kwargs.update(
dtype=rasterio.float32,
count=1,
compress='lzw')

ndviImage = rasterio.open('/Users/abc/ndviImage.tiff','w',driver='Gtiff',
width=band4.width,
height = band4.height,
count=1, crs=band4.crs,
transform=band4.transform,
dtype='float32')


ndviImage.write(ndvi,1)









share|improve this question
















Using Sentinel data I am creating an NDVI image using the below Python code. The output is a grey image.



import rasterio
from rasterio import plot
import matplotlib.pyplot as plt
import numpy as np
import subprocess
import os

os.listdir('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/')

band4 = rasterio.open('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/GRANULE/L1C_T43PGQ_A010341_20190228T051623/IMG_DATA/T43PGQ_20190228T050739_B04.jp2')
band5 = rasterio.open('/Users/abc/S2B_MSIL1C_20190228T050739_N0207_R019_T43PGQ_20190228T085706.SAFE/GRANULE/L1C_T43PGQ_A010341_20190228T051623/IMG_DATA/T43PGQ_20190228T050739_B08.jp2')

bandRed = band4.read(1)
print(os.getcwd())


resize = np.empty(shape=(1,5490*2,5490*2),dtype=np.uint16)

bandNIR = band5.read(1,out=resize)

bandRed = bandRed.astype('float32')
bandNIR = bandNIR.astype('float32')


ndvi = np.zeros(band4.shape, dtype=rasterio.float32)

ndvi_upper = bandNIR + bandRed
ndvi_lower = bandNIR - bandRed

ndvi = ndvi_lower / ndvi_upper

kwargs = band4.meta
kwargs.update(
dtype=rasterio.float32,
count=1,
compress='lzw')

ndviImage = rasterio.open('/Users/abc/ndviImage.tiff','w',driver='Gtiff',
width=band4.width,
height = band4.height,
count=1, crs=band4.crs,
transform=band4.transform,
dtype='float32')


ndviImage.write(ndvi,1)






python ndvi sentinel-2 rasterio






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Apr 2 at 12:25









Vince

14.8k32849




14.8k32849










asked Apr 2 at 11:46









hck3rhck3r

213




213







  • 2





    Why not? NDVI is just a single number, in your code ndvi = ndvi_lower / ndvi_upper. It is up to you to apply a color palette when you view the image.

    – user30184
    Apr 2 at 12:03













  • 2





    Why not? NDVI is just a single number, in your code ndvi = ndvi_lower / ndvi_upper. It is up to you to apply a color palette when you view the image.

    – user30184
    Apr 2 at 12:03








2




2





Why not? NDVI is just a single number, in your code ndvi = ndvi_lower / ndvi_upper. It is up to you to apply a color palette when you view the image.

– user30184
Apr 2 at 12:03






Why not? NDVI is just a single number, in your code ndvi = ndvi_lower / ndvi_upper. It is up to you to apply a color palette when you view the image.

– user30184
Apr 2 at 12:03











0






active

oldest

votes












Your Answer








StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "79"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fgis.stackexchange.com%2fquestions%2f317485%2fcreating-ndvi-using-python-rasterio-producing-grey-image%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes















draft saved

draft discarded
















































Thanks for contributing an answer to Geographic Information Systems Stack Exchange!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fgis.stackexchange.com%2fquestions%2f317485%2fcreating-ndvi-using-python-rasterio-producing-grey-image%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

រឿង រ៉ូមេអូ និង ហ្ស៊ុយលីយេ សង្ខេបរឿង តួអង្គ បញ្ជីណែនាំ

Crop image to path created in TikZ? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)Crop an inserted image?TikZ pictures does not appear in posterImage behind and beyond crop marks?Tikz picture as large as possible on A4 PageTransparency vs image compression dilemmaHow to crop background from image automatically?Image does not cropTikzexternal capturing crop marks when externalizing pgfplots?How to include image path that contains a dollar signCrop image with left size given

Romeo and Juliet ContentsCharactersSynopsisSourcesDate and textThemes and motifsCriticism and interpretationLegacyScene by sceneSee alsoNotes and referencesSourcesExternal linksNavigation menu"Consumer Price Index (estimate) 1800–"10.2307/28710160037-3222287101610.1093/res/II.5.31910.2307/45967845967810.2307/2869925286992510.1525/jams.1982.35.3.03a00050"Dada Masilo: South African dancer who breaks the rules"10.1093/res/os-XV.57.1610.2307/28680942868094"Sweet Sorrow: Mann-Korman's Romeo and Juliet Closes Sept. 5 at MN's Ordway"the original10.2307/45957745957710.1017/CCOL0521570476.009"Ram Leela box office collections hit massive Rs 100 crore, pulverises prediction"Archived"Broadway Revival of Romeo and Juliet, Starring Orlando Bloom and Condola Rashad, Will Close Dec. 8"Archived10.1075/jhp.7.1.04hon"Wherefore art thou, Romeo? To make us laugh at Navy Pier"the original10.1093/gmo/9781561592630.article.O006772"Ram-leela Review Roundup: Critics Hail Film as Best Adaptation of Romeo and Juliet"Archived10.2307/31946310047-77293194631"Romeo and Juliet get Twitter treatment""Juliet's Nurse by Lois Leveen""Romeo and Juliet: Orlando Bloom's Broadway Debut Released in Theaters for Valentine's Day"Archived"Romeo and Juliet Has No Balcony"10.1093/gmo/9781561592630.article.O00778110.2307/2867423286742310.1076/enst.82.2.115.959510.1080/00138380601042675"A plague o' both your houses: error in GCSE exam paper forces apology""Juliet of the Five O'Clock Shadow, and Other Wonders"10.2307/33912430027-4321339124310.2307/28487440038-7134284874410.2307/29123140149-661129123144728341M"Weekender Guide: Shakespeare on The Drive""balcony"UK public library membership"romeo"UK public library membership10.1017/CCOL9780521844291"Post-Zionist Critique on Israel and the Palestinians Part III: Popular Culture"10.2307/25379071533-86140377-919X2537907"Capulets and Montagues: UK exam board admit mixing names up in Romeo and Juliet paper"Istoria Novellamente Ritrovata di Due Nobili Amanti2027/mdp.390150822329610820-750X"GCSE exam error: Board accidentally rewrites Shakespeare"10.2307/29176390149-66112917639"Exam board apologises after error in English GCSE paper which confused characters in Shakespeare's Romeo and Juliet""From Mariotto and Ganozza to Romeo and Guilietta: Metamorphoses of a Renaissance Tale"10.2307/37323537323510.2307/2867455286745510.2307/28678912867891"10 Questions for Taylor Swift"10.2307/28680922868092"Haymarket Theatre""The Zeffirelli Way: Revealing Talk by Florentine Director""Michael Smuin: 1938-2007 / Prolific dance director had showy career"The Life and Art of Edwin BoothRomeo and JulietRomeo and JulietRomeo and JulietRomeo and JulietEasy Read Romeo and JulietRomeo and Julieteeecb12003684p(data)4099369-3n8211610759dbe00d-a9e2-41a3-b2c1-977dd692899302814385X313670221313670221