Brovey图像融合方法+Python代码

Brovey图像融合方法+Python代码

1、方法原理

原理:Brovey变换融合又叫做比值变换融合,通过对多光谱数据进行归一化后,与高分辨率影像进行乘积来增加影像信息;

                                           

2、实现代码

# coding=utf-8
'''
Created on 2020-6-1
@author: jiangao
Project: Brovey图像融合方法
'''
import numpy as np
import cv2
import scipy.misc as smi
from osgeo import gdal
from PIL import Image
def gdal_open(path):
    """
    读取图像函数
    输入:图像路径
    返回:np.ndArray格式的三维数组
    """
    data = gdal.Open(path)
    col = data.RasterXSize#读取图像长度
    row = data.RasterYSize#读取图像宽度
    data_array_r = data.GetRasterBand(1).ReadAsArray(0,0,col,row).astype(np.float)#读取图像第一波段并转换为数组
    data_array_g = data.GetRa
  • 3
    点赞
  • 52
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
全色多光谱图像融合是将全色图像和多光谱图像进行融合,以获得更高质量的图像。在Python中,可以使用OpenCV和NumPy库来实现全色多光谱图像融合。 首先,使用OpenCV库加载全色图像和多光谱图像,并将它们转换为RGB格式。可以使用cv2.imread函数加载图像,并使用cv2.cvtColor函数将图像转换为RGB格式。例如,可以使用以下代码加载和显示全色图像: ```python import cv2 as cv import matplotlib.pyplot as plt img1 = cv.cvtColor(cv.imread('1.tif'), cv.COLOR_BGR2RGB) # 全色图像 plt.imshow(img1) plt.show() ``` 接下来,使用NumPy库将多光谱图像重塑为二维数组。可以使用np.reshape函数将多光谱图像的形状重塑为(像素数,波段数)。例如,可以使用以下代码将多光谱图像重塑为二维数组: ```python import numpy as np img2 = np.reshape(img2, (img2.shape\[0\] * img2.shape\[1\], img2.shape\[2\])) # 多光谱图像重塑为二维数组 ``` 然后,可以使用不同的融合方法对全色图像和多光谱图像进行融合。常用的融合方法包括Brovey、主成分分析(PCA)、FIHS(快速强度色相饱和度)等。可以使用相应的算法对图像进行融合,并将结果保存为新的图像。例如,可以使用以下代码使用PCA算法对图像进行融合: ```python from sklearn.decomposition import PCA pca = PCA(n_components=3) # 创建PCA对象 img3 = pca.fit_transform(img2) # 使用PCA算法对多光谱图像进行降维 ``` 最后,可以使用Matplotlib库将融合后的图像显示出来。例如,可以使用以下代码显示融合后的图像: ```python plt.imshow(np.reshape(img3, (img1.shape\[0\], img1.shape\[1\], img1.shape\[2\]))) # 显示融合后的图像 plt.show() ``` 通过以上步骤,可以实现全色多光谱图像融合Python代码。根据具体需求,可以选择不同的融合方法和参数来获得最佳的融合效果。 #### 引用[.reference_title] - *1* [全色和多光谱融合pansharpen的尝试](https://blog.csdn.net/qq_42121640/article/details/89305833)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [PCA 图像融合 matlab+ python](https://blog.csdn.net/qq_41730491/article/details/128933113)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值