批量求解基于电导率的植物半致死温度

2023-12-29 22:10

本文主要是介绍批量求解基于电导率的植物半致死温度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 问题的提出

问题:一批植物材料,设定了不同梯度的温度,每个处理重复3次,并测定了相对电导率,想计算各种基因型的半致死温度。
方法:采用文献《应用Logistic方程确定植物组织低温半致死温度的研究》的方法进行计算。

前言:很遗憾,R语言自带的nls函数(nls(ddl ~ SSlogis(temp, a, b, c))无法运行,主要缘故是数据问题。因此,根据查询的文献,从手动开始计算,到编程一次性完成。

2 文献所述求解方法

文献涉及的Logistic方程如下:
y = k / ( 1 + a ∗ e ( − b ∗ x ) ) y=k/(1+a*e^{(-b*x)}) y=k/(1+ae(bx))
问题改为涉及对参数 k , a 和 b k,a和b kab的求解,半致死温度的求解公式如下:
L t 50 = l n a / b Lt_{50}=ln{a}/b Lt50=lna/b

关键步:参考文献需要对原始的电导率作如下转换:
y ′ = ( k − y ) / y = a ∗ e ( − b ∗ x ) y'=(k-y)/y=a*e^{(-b*x)} y=(ky)/y=ae(bx)
上述方程进行对数转换:
l n y ′ = l n a − b ∗ x ln{y'}=ln{a}-b*x lny=lnabx
进一步
l n y ′ = l n ( k − y ) / y ln{y'}=ln{(k-y)/y} lny=ln(ky)/y
式中, y y y是原始的相对电导率(去掉%的值), k = 100 k=100 k=100
通过 l n y ′ ln{y'} lny即可对 x x x做普通的线性回归,获得 l n a 和 b ln{a}和b lnab的值。
最后要求解 k k k,采用等距离的3个 y y y值求解,方法如下:
k = ( y 2 2 ∗ ( y 1 + y 3 ) − 2 ∗ y 1 ∗ y 2 ∗ y 3 ) / ( y 2 2 − y 1 ∗ y 3 ) k=(y_{2}^2*(y_{1}+y_{3})-2*y_{1}*y_{2}*y_{3})/(y_{2}^2-y_{1}*y_{3}) k=(y22(y1+y3)2y1y2y3)/(y22y1y3)

通过上述的步骤,即可获得Logistic方程的各项参数值。之后就是利用R语言编程的事了,以及如何实现批量分析的目的。

3 R语言编程求解

3.1 数据读取和变换

对原始的电导率数据做所需的对数转换和均值计算:

df2<-readxl::read_excel('抗逆性.xls',sheet=1,skip=1)
df2$y<-log((100-df2$ddl)/df2$ddl)
df2a<-df2 %>% select(Clone,y,ddl,temp) %>% group_by(Clone,temp) %>% summarise(dm=mean(ddl),ym=mean(y))

3.2 批量求解的函数

lgssf <- function(dat,mod=ym~temp,x=temp,y0=dm,tn=3:5,ts=3) {# mod: line regression# x: temperature, for plot# y0: orginal leakage, for plot# tn: used orginal leakage data, 3 points position# ts: orginal leakage variablex=deparse(substitute(x))y0=deparse(substitute(y0))m2<-lm(mod,data=dat)tt<-summary(m2)r2<-tt$r.squaredFv<-tt$fstatisticpv<-1-pf(Fv[1],df1=Fv[2],df2=Fv[3])fit<-list()fit$r2<-r2;fit$Fv<-Fv;fit$pv<-pvln.a<-coef(m2)[1];a<-exp(ln.a)b<--coef(m2)[2]Lt50<-ln.a/b y1=dat[tn[1],ts];y2=dat[tn[2],ts];y3=dat[tn[3],ts]k=(y2^2*(y1+y3)-2*y1*y2*y3)/(y2^2-y1*y3)lgss.cof<-c(k,a,b,Lt50)lgss.cof<-unlist(lgss.cof)names(lgss.cof)<-c('k','a','b','Lt50')lc<-lgss.cof<-round(lgss.cof,3) equat<-paste0('y=',lc[1],'/','(1+',lc[2],'*exp^','(',lc[3],'*x))')fig<-ggplot(dat, aes_string(x=x,y=y0))+geom_point()+geom_smooth(method='auto',se=F)res<-list(equat,lc[4],lgss.cof,fit)names(res)<-c('equat','Lt50','coef','fit')res$fig<-figreturn(res)
}

3.3 运行程序和查看结果

res2a <- plyr::dlply(df2a,"Clone",lgssf)
> names(res2a) # 各植物材料的基因型代码
[1] "1" "2" "3" "4" "5" "6" "7" "8" "9"# 第一个基因型的结果
> res2a$`1`[c('equat','Lt50','fit')]
$`equat`
[1] "y=21.713/(1+1.148*exp^(-0.127*x))"$Lt50Lt50 
-1.089 $fit
$fit$`r2`
[1] 0.8356973
$fit$Fvvalue    numdf    dendf 
20.34531  1.00000  4.00000
$fit$pvvalue 
0.01073532

图形查看res2a$`1`$fig
在这里插入图片描述
到此,所有求解和批量运算都结束了。

这篇关于批量求解基于电导率的植物半致死温度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python脚本:对文件进行批量重命名

字符替换:批量对文件名中指定字符进行替换添加前缀:批量向原文件名添加前缀添加后缀:批量向原文件名添加后缀 import osdef Rename_CharReplace():#对文件名中某字符进行替换(已完结)re_dir = os.getcwd()re_list = os.listdir(re_dir)original_char = input('请输入你要替换的字符:')replace_ch

Python脚本:批量解压RAR文件

所需模块: os.getcwd() #获取脚本文件路径os.system() #执行系统命令 import os#source_dir = input("Please input in source_dir:")#unzip_dir = input("Please input in unzip_dir:") source_dir = os.

vcpkg子包路径批量获取

获取vcpkg 子包的路径,并拼接为set(CMAKE_PREFIX_PATH “拼接路径” ) import osdef find_directories_with_subdirs(root_dir):# 构建根目录下的 "packages" 文件夹路径root_packages_dir = os.path.join(root_dir, "packages")# 如果 "packages"

Python批量读取身份证信息录入系统和重命名

前言 大家好, 如果你对自动化处理身份证图片感兴趣,可以尝试以下操作:从身份证图片中快速提取信息,填入表格并提交到网页系统。如果你无法完成这个任务,我们将在“Python自动化办公2.0”课程中详细讲解实现整个过程。 实现过程概述: 模块与功能: re 模块:用于从 OCR 识别出的文本中提取所需的信息。 日期模块:计算年龄。 pandas:处理和操作表格数据。 PaddleOCR:百度的

分享MSSQL、MySql、Oracle的大数据批量导入方法及编程手法细节

1:MSSQL SQL语法篇: BULK INSERT      [ database_name . [ schema_name ] . | schema_name . ] [ table_name | view_name ]         FROM 'data_file'        [ WITH       (      [ [ , ] BATCHSIZE = batch_siz

2024 年高教社杯全国大学生数学建模竞赛题目——2024 年高教社杯全国大学生数学建模竞赛题目的求解

2024 年高教社杯全国大学生数学建模竞赛题目 (请先阅读“ 全国大学生数学建模竞赛论文格式规范 ”) 2024 年高教社杯全国大学生数学建模竞赛题目 随着城市化进程的加快、机动车的快速普及, 以及人们活动范围的不断扩大,城市道 路交通拥堵问题日渐严重,即使在一些非中心城市,道路交通拥堵问题也成为影响地方经 济发展和百姓幸福感的一个“痛点”,是相关部门的棘手难题之一。 考虑一个拥有知名景区

C语言批量数据到动态二维数组

上一篇文章将文件读取放到静态创建的二维数组中,但是结合网络上感觉到今天的DT时代,这样批量大量读取一个上百行的数据,分配的内存是否可能因为大量的数据而产生溢出呢,最近一直研究里malloc函数,通过它来动态建立所需的二维数组,因此,通过文件操作和动态创建二维数组结合起来,将大量的数据动态的放入矩阵中,不知道这样的思想是否正确,下午把程序运行出来了,将程序贴上来,欢迎大家一起探讨:对于有规律的大数据

Mybatis Plus快速重构真批量sql入库操作

Mybatis快速重构真批量sql入库操作 基本思路 重构mybatis默认方法saveBatch和saveOrUpdateBatch的实现 基本步骤 真批量保存实现类InsertBatchMethod真批量更新实现类MysqlInsertOrUpdateBath注册InsertBatchMethod和MysqlInsertOrUpdateBath到EasySqlInjector注册Eas

批量生成编号(A~Z+3位流水编号)

/*** 批量生成编号* @param num* @param warehouseId* @return*/public synchronized List<String> generatCodeList(int num,long warehouseId){MesRack rack = this.getCurrentRack(warehouseId);String oldRackCode;Lis

基于SA模拟退火算法的多车辆TSP问题求解matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述        基于SA模拟退火算法的多车辆TSP问题求解matlab仿真,三个车辆分别搜索其对应的最短路径,仿真后得到路线规划图和SA收敛曲线。 2.测试软件版本以及运行结果展示 MATLAB2022A版本运行 (完整程序运行后无水印)