python实现土壤光谱曲线包络线去除

2023-10-08 22:50

本文主要是介绍python实现土壤光谱曲线包络线去除,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
#去除包络线
def ToEnvelope(x,data):data=np.array(data)LocMaxInd=np.where(np.diff(np.sign(np.diff(data)))<0)[0]+1#找到所有极大值的位置LocMax=data[LocMaxInd]#找到所有极大值#找到最大值的位置MaxInd=LocMaxInd[np.where(LocMax==LocMax.max())]output_x=[MaxInd[0]]#该数组记录包络线最大值在input_x中的索引output_y=[LocMax.max()]#该数组记录选取构成包络线的最大值# 计算最大值右边的包络线Ind_right = np.where(LocMax == LocMax.max())[0][0]  # 最大值在极大值列表中的位置while Ind_right != len(LocMax) - 1:JJ = Ind_rightk_arr = {}for i in np.arange(JJ + 1, len(LocMax)):k_arr[i] = (LocMax[i] - LocMax[JJ]) / (LocMaxInd[i] - LocMaxInd[JJ])  # 计算斜率Ind_right = list(k_arr.keys())[list(k_arr.values()).index(max(list(k_arr.values())))]output_x.append(LocMaxInd[Ind_right])output_y.append(LocMax[Ind_right])if len(x) not in output_x:#将终点加入output_x.append(len(x) - 1)output_y.append(data[-1])# 计算最大值左边的包络线Ind_left = np.where(LocMax == LocMax.max())[0][0]  # 最大值在极大值列表中的位置while Ind_left != 0:JJ = Ind_leftk_arr = {}for i in np.arange(JJ):k_arr[i] = (LocMax[i] - LocMax[JJ]) / (LocMaxInd[i] - LocMaxInd[JJ])  # 计算斜率Ind_left = list(k_arr.keys())[list(k_arr.values()).index(min(list(k_arr.values())))]output_x.insert(0, LocMaxInd[Ind_left])output_y.insert(0, LocMax[Ind_left])if 0 not in output_x:#将初始点加入output_x.insert(0, 0)output_y.insert(0, data[0])output_x = x[output_x]  # 找到包络线点的下标return output_x,output_y
Envelope_x,Envelope_y=ToEnvelope(band_length,SS)#去除包络线之后的点值
#包络线插值
from scipy.interpolate import interp1d
FF=interp1d(Envelope_x,Envelope_y,kind='slinear')#线性插值
Y_pred=FF(band_length)
plt.plot(band_length,SS,label='0')
plt.plot(band_length,Y_pred,label='02')#线性插值
plt.legend()

结果:
后面的就根据原光谱除以

这篇关于python实现土壤光谱曲线包络线去除的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/168546

相关文章

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

python中列表list切分的实现

《python中列表list切分的实现》列表是Python中最常用的数据结构之一,经常需要对列表进行切分操作,本文主要介绍了python中列表list切分的实现,文中通过示例代码介绍的非常详细,对大家... 目录一、列表切片的基本用法1.1 基本切片操作1.2 切片的负索引1.3 切片的省略二、列表切分的高

基于Python实现一个PDF特殊字体提取工具

《基于Python实现一个PDF特殊字体提取工具》在PDF文档处理场景中,我们常常需要针对特定格式的文本内容进行提取分析,本文介绍的PDF特殊字体提取器是一款基于Python开发的桌面应用程序感兴趣的... 目录一、应用背景与功能概述二、技术架构与核心组件2.1 技术选型2.2 系统架构三、核心功能实现解析

通过Python脚本批量复制并规范命名视频文件

《通过Python脚本批量复制并规范命名视频文件》本文介绍了如何通过Python脚本批量复制并规范命名视频文件,实现自动补齐数字编号、保留原始文件、智能识别有效文件等功能,听过代码示例介绍的非常详细,... 目录一、问题场景:杂乱的视频文件名二、完整解决方案三、关键技术解析1. 智能路径处理2. 精准文件名

基于Python开发PDF转Doc格式小程序

《基于Python开发PDF转Doc格式小程序》这篇文章主要为大家详细介绍了如何基于Python开发PDF转Doc格式小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用python实现PDF转Doc格式小程序以下是一个使用Python实现PDF转DOC格式的GUI程序,采用T

Python使用PIL库将PNG图片转换为ICO图标的示例代码

《Python使用PIL库将PNG图片转换为ICO图标的示例代码》在软件开发和网站设计中,ICO图标是一种常用的图像格式,特别适用于应用程序图标、网页收藏夹图标等场景,本文将介绍如何使用Python的... 目录引言准备工作代码解析实践操作结果展示结语引言在软件开发和网站设计中,ICO图标是一种常用的图像

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Python中如何控制小数点精度与对齐方式

《Python中如何控制小数点精度与对齐方式》在Python编程中,数据输出格式化是一个常见的需求,尤其是在涉及到小数点精度和对齐方式时,下面小编就来为大家介绍一下如何在Python中实现这些功能吧... 目录一、控制小数点精度1. 使用 round() 函数2. 使用字符串格式化二、控制对齐方式1. 使用