1 回答

TA貢獻(xiàn)1951條經(jīng)驗(yàn) 獲得超3個(gè)贊
如果raster
是一個(gè)數(shù)組,
raster == x
給出一個(gè)布爾掩碼,其形狀與 相同raster
,指示 的哪些元素(在您的情況下為像素)raster
等于x
np.where(arr)
arr
給出計(jì)算結(jié)果為 true的數(shù)組元素的索引.np.where(raster == x)
, 因此, 給出像素的索引raster
等于x
.np.any(arr)
當(dāng)且僅當(dāng) 的至少一個(gè)元素的arr
計(jì)算結(jié)果為 true 時(shí)才返回 True。np.any(raster == x)
,因此,告訴您是否至少有一個(gè)像素raster
是 x。
假設(shè)fvc
和toaRef_red
具有相同的形狀并且您想創(chuàng)建一個(gè)新emiss
的發(fā)射數(shù)組,如果fvc
為 1,則將其設(shè)置為 0.99,0.979 - 0.046 * toaRef_red
如果fvc
為 0,0.971 * (1 - fvc) + 0.987 * fvc
如果 0 < fvc
< 1,否則為 NaN,您可以執(zhí)行以下操作:
emiss = np.full(ndvi.shape, np.nan) # create new array filled with nan
emiss[fvc == 1] = 0.99
mask = fvc == 0
emiss[mask] = 0.979 - 0.046 * toaRef_red[mask]
mask = (fvc > 0) & (fvc < 1)
emiss[mask] = 0.971 * (1 - fvc[mask]) + 0.987 * fvc[mask]
這與以下內(nèi)容相同:
emiss = np.full(ndvi.shape, np.nan) # create new array filled with nan
emiss[np.where(fvc == 1)] = 0.99
idx = np.where(fvc == 0)
emiss[idx] = 0.979 - 0.046 * toaRef_red[idx]
idx = np.where((fvc > 0) & (fvc < 1))
emiss[idx] = 0.971 * (1 - fvc[idx]) + 0.987 * fvc[idx]
后者顯然是多余的。你不需要np.where這里。
添加回答
舉報(bào)