PCA主成分分析遥感影像融合

融合目的

多光谱影像具有高光谱分辨率低空间分辨率,全色影像具有高空间分辨率低光谱分辨率,将这两种影像进行融合就可以得到同时具有高空间分辨率高光谱分辨率的影像

PCA主成分变换影像融合

PCA主成分分析原理

参考博客:主成分分析(PCA)原理详解

融合步骤

image-20220606200125599

pca

代码

from osgeo import gdal, gdalconst, gdal_array
import numpy as np
from score import *

if __name__ == '__main__':
    pantif = './sub_image/SV1-03_20180407_L2A0001046618_1012102060010001_01-PAN.tif' # 全色影像
    muxtif = './sub_image/SV1-03_20180407_L2A0001046618_1012102060010001_01-MUX.tif' # 多光谱影像
    # 读取全色波段影像
    gdal.AllRegister()
    pands = gdal.Open(pantif, gdalconst.GA_ReadOnly)
    # 宽高
    panX = pands.RasterXSize
    panY = pands.RasterYSize
    # 坐标系
    pansrs = gdal.Dataset.GetSpatialRef(pands)
    # 读取多光谱影像
    muxds = gdal.Open(muxtif, gdalconst.GA_ReadOnly)
    muxsrs = gdal.Dataset.GetSpatialRef(muxds)
    # 数据类型
    muxBand = gdal.Dataset.GetRasterBand(muxds, 1)
    muxType = muxBand.DataType
    # 重采样
    options = gdal.WarpOptions(width=panX, height=panY, srcSRS=muxsrs,
                               dstSRS=pansrs, outputType=gdalconst.GDT_Int32, resampleAlg=gdalconst.GRIORA_Bilinear, creationOptions=['COMPRESS=LZW'])
    gdal.Warp("./pca.tif", muxds, options=options)
    # 主成分分析影像融合
    rsData = gdal_array.LoadFile("./pca.tif")
    nBands, xSzie, ySize = rsData.shape
    rsArray = None
    for i in range(nBands):
        bArray = rsData[i]
        bArray = np.reshape(bArray, (-1, 1))
        if i == 0:
            rsArray = bArray
        else:
            rsArray = np.hstack((rsArray, bArray))
    rsArrayAvg = np.mean(rsArray, axis=0)
    rsArray = rsArray - rsArrayAvg
    u, s, v = np.linalg.svd(rsArray, full_matrices=False)
    rsPCA = rsArray@v.T
    rsPCA1 = rsPCA[:, 0]
    rsPCA1Avg = np.mean(rsPCA1)
    rsPCA1Std = np.std(rsPCA1)
    # 计算全色波段的均值和标准差
    panBand = gdal.Dataset.GetRasterBand(pands, 1)
    panArray = gdal.Band.ReadAsArray(panBand)
    panArray = np.reshape(panArray, (-1, 1))
    panStd = np.std(panArray)
    panAvg = np.mean(panArray)
    # 计算变换系数k1,k2
    k1 = rsPCA1Std/panStd
    k2 = rsPCA1Avg-k1*panAvg
    # 对全色波段进行变换使其与第一主成分的标准差和均值一直
    panArray = panArray*k1+k2
    # 替换第一主成分
    rsPCA[:, 0] = panArray[:, 0]
    # 主成分逆变换
    rsArray = rsPCA@v+rsArrayAvg
    rsds = gdal.Open("./pca.tif", gdalconst.GA_Update)
    for i in range(nBands):
        bArray = rsArray[:, i]
        bArray = np.reshape(bArray, (ySize, xSzie))
        iBand = gdal.Dataset.GetRasterBand(rsds, i+1)
        gdal.Band.WriteArray(iBand, bArray)
    del rsds, pands, muxds
    print('ok!')

融合效果

多光谱影像

多光谱

全色影像

全色

融合影像

融合

细节对比

道路

融合前后道路

农田

融合前后农田田埂
  • 2
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值