<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<style type="text/css" style="display:none;"> P {margin-top:0;margin-bottom:0;} </style>
</head>
<body dir="ltr">
<div style="" class="elementToProof"><span style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">I believe you didn't clear your environment and that's why df1 works. All should evaluate to "numeric(0) with the current
 code. You call df2$abs_diff, but you never defined that variable. You assigned that result to an object called diff2 which is not used anywhere else in your code. If you type in <span style="display: inline !important; background-color: rgb(255, 255, 255);" class="ContentPasted0">df2$abs_diff,
 you'll see it evaluates to NULL and that caries through the rest of your code. numeric(0) means that it's a variable of type numeric but it's empty (zero in length).</span></span></div>
<div style="" class="elementToProof"><span style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);"><span style="display: inline !important; background-color: rgb(255, 255, 255);" class="ContentPasted0"><br>
</span></span></div>
<div style="" class="elementToProof"><span style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);"><span style="display: inline !important; background-color: rgb(255, 255, 255);" class="ContentPasted0 ContentPasted1">
<div class="ContentPasted1">set.seed(5)</div>
<div class="ContentPasted1">df2<- data.frame(em= rnorm(10), pct=rnorm(10))</div>
<div class="ContentPasted1"><br>
</div>
<div class="ContentPasted1">diff2 <- abs(df2$em-1) #You defined diff2</div>
<div class="ContentPasted1">df2$abs_diff #This was never defined so it evalues to NULL</div>
<div class="ContentPasted1">#> NULL</div>
<div class="ContentPasted1"><br>
</div>
<div class="ContentPasted1">which.min(df2$abs_diff) #can't find position of min since
<span style="display: inline !important; background-color: rgb(255, 255, 255);" class="ContentPasted2">
df2$abs_diff was never defined</span></div>
<div class="ContentPasted1">#> integer(0)</div>
<div class="ContentPasted1"><br>
</div>
<div class="ContentPasted1">df2$pct[which.min(df2$abs_diff)] #cannot subset df2$pct since <span style="display: inline !important; background-color: rgb(255, 255, 255);" class="ContentPasted3">which.min(df2$abs_diff) evaluates to integer(0)</span></div>
<div class="ContentPasted1">#> numeric(0)</div>
<br>
</span></span></div>
<div id="appendonsend"></div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>From:</b> rain1290@aim.com <rain1290@aim.com><br>
<b>Sent:</b> Tuesday, May 16, 2023 8:29 PM<br>
<b>To:</b> Alexander Ilich <ailich@usf.edu>; r-sig-geo@r-project.org <r-sig-geo@r-project.org><br>
<b>Subject:</b> Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R</font>
<div> </div>
</div>
<div>
<div style="color:black; font:10pt arial">Hi Alexander,<br>
<br>
I am receiving that for my real data, which is, indeed, odd. It works just fine with my very first dataframe, but for all other dataframes, it returns "numeric(0)". I did the following to organize each dataframe accordingly (note that I renamed my dataframes
 to "df1" through to "df10" for simplicity):
<div><br>
</div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff1 <- abs(df1$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">w1 <- df1$pct[which.min(df1$abs_diff)]</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><br>
</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff2</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">abs(df2$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">w2</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><- df2$pct[which.min(df2$abs_diff)]</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><br>
</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff3 <-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">abs(df3$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">w3</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><- df3$pct[which.min(df3$abs_diff)]</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><br>
</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff4</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">abs(df4$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">w4 <- df4$pct[which.min(df4$abs_diff)]</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><br>
</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff5</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">abs(df5$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">w5 <-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">df5$pct[which.min(df5$abs_diff)]</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><br>
</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff6 <-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">abs(df6$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">w6 <- df6$pct[which.min(df6$abs_diff)]</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><br>
</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff7 <- abs(df7$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">w7 <-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">df7$pct[which.min(df7$abs_diff)]</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><br>
</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff8</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">abs(df8$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">w8 <-</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">
</span><span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">df8$pct[which.min(df8$abs_diff)]</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue"><br>
</span></div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; line-height:11.25pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; word-break:break-all">
<span style="font-size:10.0pt; font-family:"Lucida Console"; color:blue">diff9 <- abs(df9$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div><span style="color:blue; font-family:"Lucida Console"; font-size:10pt; background-color:transparent">w9</span><span style="color:blue; font-size:10pt; background-color:transparent; font-family:Arial,Helvetica,sans-serif">
</span><span style="color:blue; font-family:"Lucida Console"; font-size:10pt; background-color:transparent"><- df9$pct[which.min(df9$abs_diff)]</span> </div>
<div><br>
</div>
<div>
<div class="x_MsoNormal" style="margin-bottom:0.0001pt; background-image:initial; background-position:initial; background-size:initial; background-repeat:initial; background-attachment:initial; background-origin:initial; background-clip:initial; line-height:11.25pt; word-break:break-all">
<span style="font-size:10pt; font-family:"Lucida Console"; color:blue">diff10 <- abs(df1</span><span style="font-size:10pt; color:blue; font-family:Arial,Helvetica,sans-serif">0</span><span style="font-size:10pt; font-family:"Lucida Console"; color:blue">$em-1)</span><span style="font-size:10pt; font-family:"Lucida Console""></span></div>
<div><span style="color:blue; font-family:"Lucida Console"; font-size:10pt; background-color:transparent">w10</span><span style="color:blue; font-size:10pt; background-color:transparent; font-family:Arial,Helvetica,sans-serif"> </span><span style="color:blue; font-family:"Lucida Console"; font-size:10pt; background-color:transparent"><-
 df1</span><span style="color:blue; font-size:10pt; background-color:transparent; font-family:Arial,Helvetica,sans-serif">0</span><span style="color:blue; font-family:"Lucida Console"; font-size:10pt; background-color:transparent">$pct[which.min(df</span><span style="color:blue; font-size:10pt; background-color:transparent; font-family:Arial,Helvetica,sans-serif">10</span><span style="color:blue; font-family:"Lucida Console"; font-size:10pt; background-color:transparent">$abs_diff)]</span> </div>
<br>
This is what object "df2" looks like (the first 21 rows are displayed - there are 140 rows in total). All dataframes are structured the same way, including "df1" (which, as mentioned previously, worked just fine). All begin with "0.000000000" in the first row. <span style="background-color:transparent; font-size:10pt">"em"
 is my x-column name, and "pct" is my y-column name, as shown in the image below:</span></div>
<div><br>
<div class="x_envelope" align="left" style="float:none"><img width="275" id="x_TIE.7809330" alt="df2.jpg" class="x_AOLInlineImage" title="df2.jpg" style="margin:5px; vertical-align:middle" data-outlook-trace="F:1|T:1" src="cid:8wjyPsqjj09pxXReEpT8"></div>
<div></div>
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><br>
</div>
<div style="font-family:arial,helvetica; font-size:10pt; color:black">What could make the other dataframes so different from "df1" to cause "numeric(0)"? Essentially, why would "df1" be fine, and not the other 9 dataframes? Unless my code for the other dataframes
 is flawed somehow?</div>
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><br>
</div>
<div style="font-family:arial,helvetica; font-size:10pt; color:black">Thanks, again,</div>
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><font size="2"><br>
</font></div>
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><font size="2">-----Original Message-----<br>
From: Alexander Ilich <ailich@usf.edu><br>
To: rain1290@aim.com <rain1290@aim.com>; r-sig-geo@r-project.org <r-sig-geo@r-project.org><br>
Sent: Tue, May 16, 2023 7:38 pm<br>
Subject: Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R<br>
<br>
<div id="x_yiv1880419194">
<div>
<div>It's not clear to me why that would be happening. Are you getting that with your real data or the example data generated in the code I sent? The only reasons I can think of for that happening is if you're trying to access the zeroeth element of a vector
 which would require <span style="color:rgb(0,0,0); font-family:Calibri,arial,Helvetica,sans-serif; display:inline!important">which.min(df2$abs_diff) to somehow evaluating to zero (which I don't see how it could) or if your dataframe is zero rows.</span><span></span></div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="x_yiv1880419194yqt45190" class="x_yiv1880419194yqt9896070411">
<div dir="ltr" id="x_yiv1880419194divRplyFwdMsg"><font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> rain1290@aim.com <rain1290@aim.com><br clear="none">
<b>Sent:</b> Tuesday, May 16, 2023 5:58:22 PM<br clear="none">
<b>To:</b> Alexander Ilich <ailich@usf.edu>; r-sig-geo@r-project.org <r-sig-geo@r-project.org><br clear="none">
<b>Subject:</b> Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R</font>
<div> </div>
</div>
<div>
<div style="color:black; font:10pt arial">
<div class="x_yiv1880419194x_yiv1290385850x_yiv1957706691ContentPasted4" style="font-size:16px">
<span style="background-color:transparent; font-size:10pt">Hi Alexander,</span><br clear="none">
</div>
<div>Thank you so much, once again! Very, very helpful explanations. </div>
<div><br clear="none">
</div>
<div>I experimented with this method:</div>
<div><br clear="none">
</div>
<div>
<div class="x_yiv1880419194x_yiv1290385850x_yiv1957706691ContentPasted4" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
df1$abs_diff<- abs(df1$x-1)</div>
<div class="x_yiv1880419194x_yiv1290385850x_yiv1957706691ContentPasted4" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
min_rate[1]<- df1$y[which.min(df1$abs_diff)]</div>
<div style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px"><br clear="none" class="x_yiv1880419194x_yiv1290385850x_yiv1957706691ContentPasted4">
</div>
<div class="x_yiv1880419194x_yiv1290385850x_yiv1957706691ContentPasted4" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
df2$abs_diff<- abs(df2$x-1)</div>
<div class="x_yiv1880419194x_yiv1290385850x_yiv1957706691ContentPasted4" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
min_rate[2]<- df2$y[which.min(df2$abs_diff)]</div>
</div>
<div><br clear="none">
</div>
<div><span style="background-color:transparent; font-size:10pt"><br clear="none">
</span></div>
<div><span style="background-color:transparent; font-size:10pt">For the first dataframe, it correctly returned the first y-value where x = ~1. However, for dataframe2 to dataframe9, I strangely received: "numeric(0)".  Everything is correctly placed. It does
 not appear to be an error per se, but is there a way around that to avoid that message and see the correct value?</span><br clear="none">
</div>
<div><br clear="none">
</div>
<div>Thanks, again,<span style="background-color:transparent; font-size:10pt"> </span></div>
<div><br clear="none">
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><font size="2">-----Original Message-----<br clear="none">
From: Alexander Ilich <ailich@usf.edu><br clear="none">
To: r-sig-geo@r-project.org <r-sig-geo@r-project.org>; rain1290@aim.com <rain1290@aim.com><br clear="none">
Sent: Tue, May 16, 2023 2:03 pm<br clear="none">
Subject: Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R<br clear="none">
<br clear="none">
</font>
<div id="x_yiv1880419194x_yiv1079392194"><style type="text/css">
<!--
#x_yiv1880419194 #x_yiv1880419194x_yiv1079392194 p
        {margin-top:0;
        margin-bottom:0}
-->
</style>
<div dir="ltr">
<div class="x_yiv1880419194x_yiv1079392194elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
sapply goes element by element in your list, where each element is one of your dataframes. So mydata starts out as dataframe1, then dataframe2, then dataframe3, etc. It is never all of them at once. It goes through the list sequentially. So, at the end of the
 sapply call, you have a vector of length 10 where the first element corresponds to the rate closest to x=1 in dataframe 1, and the tenth element corresponds to the <span class="x_yiv1880419194x_yiv1079392194ContentPasted0" style="display:inline!important; background-color:rgb(255,255,255)">rate
 closest to x=1 in dataframe 10. If your columns are not named x and y, then the function should be edited accordingly based on the names. It does assume the "x" and "y" have the same name across dataframes. For example, if x was actually "Time" and y was "Rate",
 you could use</span></div>
<div class="x_yiv1880419194x_yiv1079392194elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<span class="x_yiv1880419194x_yiv1079392194ContentPasted0" style="display:inline!important; background-color:rgb(255,255,255)"><br clear="none">
</span></div>
<div class="x_yiv1880419194x_yiv1079392194elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<span class="x_yiv1880419194x_yiv1079392194ContentPasted0 x_yiv1880419194x_yiv1079392194ContentPasted1" style="display:inline!important; background-color:rgb(255,255,255)">#Generate data
</span>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">set.seed(5)</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">for (i in 1:10) {</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">  assign(x = paste0("df", i),</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">         value = data.frame(Time = sort(rnorm(n = 10, mean = 1, sd = 0.1)),</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">                            Rate= rnorm(n = 10, mean = 30, sd = 1)))</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">} # Create 10 Data Frames</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194ContentPasted1">
</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1"># Define Functions (two versions based on how you want to deal with ties)</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">ExtractFirstMin<- function(df){</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">  df$abs_diff<- abs(df$Time-1)</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">  min_rate<- df$Rate[which.min(df$abs_diff)]</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">  return(min_rate)</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">}</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194ContentPasted1">
</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1"># Put all dataframes into a list</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1">df_list<- list(df1,df2,df3,df4,df5,df6,df7,df8,df9,df10)</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194ContentPasted1">
</div>
<div class="x_yiv1880419194x_yiv1079392194ContentPasted1"># Apply function across list</div>
sapply(df_list, ExtractFirstMin)<br clear="none">
</div>
<div id="x_yiv1880419194x_yiv1079392194appendonsend"></div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="x_yiv1880419194x_yiv1079392194yqt18356" class="x_yiv1880419194x_yiv1079392194yqt7570492759">
<div dir="ltr" id="x_yiv1880419194x_yiv1079392194divRplyFwdMsg"><font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> rain1290@aim.com <rain1290@aim.com><br clear="none">
<b>Sent:</b> Tuesday, May 16, 2023 12:46 PM<br clear="none">
<b>To:</b> Alexander Ilich <ailich@usf.edu>; r-sig-geo@r-project.org <r-sig-geo@r-project.org><br clear="none">
<b>Subject:</b> Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R</font>
<div> </div>
</div>
<div>
<div style="color:black; font:10pt arial">Hi Alexander,
<div><br clear="none">
</div>
<div>Wow, thank you so very much for taking the time to articulate this answer! It really gives a good understanding of what is going on at each stage in the coding! </div>
<div><br clear="none">
</div>
<div>And sorry if I missed this previously, but the object "mydata" is defined based on the incorporation of all dataframes? Since it is designed to swiftly obtain the first minimum at y = ~1 across each dataframe, "mydata" must take into account "dataframe1"
 to dataframe10", correct?    </div>
<div><br clear="none">
</div>
<div>Also, the "x" is simply replaced with the name of the x-column and the "y" with the y-column name, if I understand correctly?</div>
<div><br clear="none">
</div>
<div>Again, sorry if I overlooked this, but that would be all, and thank you so very much, once again for your help and time with this! Much appreciated!</div>
<div><br clear="none">
</div>
<div>~Trav.~<br clear="none">
<br clear="none">
<br clear="none">
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><font size="2">-----Original Message-----<br clear="none">
From: Alexander Ilich <ailich@usf.edu><br clear="none">
To: r-sig-geo@r-project.org <r-sig-geo@r-project.org>; rain1290@aim.com <rain1290@aim.com><br clear="none">
Sent: Tue, May 16, 2023 11:42 am<br clear="none">
Subject: Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R<br clear="none">
<br clear="none">
</font>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691"><style type="text/css">
<!--
#x_yiv1880419194 #x_yiv1880419194x_yiv1079392194 #x_yiv1880419194x_yiv1079392194x_yiv1957706691 p
        {margin-top:0;
        margin-bottom:0}
-->
</style>
<div dir="ltr">
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691elementToProof x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0 x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted2 x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted3 x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">The only spot you'll need to change the names for is when putting all of your dataframes in a list as that is based on the names you gave them in your script when reading in the data.
 In the function, you don't need to change the input to "dataframe1", and naming it that way could be confusing since you are applying the function to more than just dataframe1 (you're applying it to all 10 of your dataframes). I named the argument df to indicate
 that you should supply your dataframe as the input to the function, but you could name it anything you want. For example, you could call it "mydata" and define the function this way if you wanted to.</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">ExtractFirstMin<- function(mydata){</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">  mydata$abs_diff<- abs(mydata$x-1)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">  min_rate<- mydata$y[which.min(mydata$abs_diff)]</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">  return(min_rate)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">}</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#The function has its own environment of variables that is separate from the global environment of variables you've defined in your script.</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#When we supply one of your dataframes to the function, we are assigning that information to a variable in the function's environment called "mydata". Functions allow you to generalize
 your code so that you're not required to name your variables a certain way. Note here, we do assume that "mydata" has a "$x" and "$y" slot though.<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0"><br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#Without generalizing the code using a function, we'd need to copy and paste the code over and over again and make sure to change the name of the dataframe each time. This is very time
 consuming and error prone. Here's an example for the first 3 dataframes.</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0"></div>
<div><br clear="none">
</div>
<div></div>
<div>min_rate<- rep(NA_real_, 10) #initialize empty vector<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">df1$abs_diff<- abs(df1$x-1)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">min_rate[1]<- df1$y[which.min(df1$abs_diff)]</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">df2$abs_diff<- abs(df2$x-1)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">min_rate[2]<- df2$y[which.min(df2$abs_diff)]</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">df3$abs_diff<- abs(df3$x-1)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">min_rate[3]<- df3$y[which.min(df3$abs_diff)]</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">print(min_rate)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">#>  [1] 29.40269 32.21546 30.75330       NA       NA       NA       NA       NA</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4">#>  [9]       NA       NA</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted4"><br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#With the function defined we can run that it for each individual dataframe, which is less error prone than copying and pasting but still fairly repetitive</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">ExtractFirstMin(mydata = df1) # You can explicitly say "mydata ="</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#> [1] 29.40269</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">ExtractFirstMin(df2) # Or equivalently it will be based on the order arguments when you defined the function. Since there is just one argument, then what you supply is assigned to "mydata"</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#> [1] 32.21546</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">ExtractFirstMin(df3)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#> [1] 30.7533</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0"># Rather than manually typing out to tun the function on eeach dataframe and bringing it together, we can instead use sapply.</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#<span class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0 x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted5" style="margin:0px"> Sapply takes a list of inputs
 and a function as arguments. It then applies the function to every element in the list and returns a vector (i.e. goes through each dataframe in your list, applies the function to each one individually, and then records the result for each one in a single
 variable).</span><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted5">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0"><span class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0" style="margin:0px"></span></div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">sapply(df_list, ExtractFirstMin)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#>  [1] 29.40269 32.21546 30.75330 30.12109 30.38361 28.64928 30.45568 29.66190</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0">#>  [9] 31.57229 31.33907</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0"><br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691ContentPasted0"><br clear="none">
</div>
</div>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691appendonsend"></div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691yqt92173" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691yqt2582161532">
<div dir="ltr" id="x_yiv1880419194x_yiv1079392194x_yiv1957706691divRplyFwdMsg"><font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> rain1290@aim.com <rain1290@aim.com><br clear="none">
<b>Sent:</b> Monday, May 15, 2023 4:44 PM<br clear="none">
<b>To:</b> Alexander Ilich <ailich@usf.edu>; r-sig-geo@r-project.org <r-sig-geo@r-project.org><br clear="none">
<b>Subject:</b> Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R</font>
<div> </div>
</div>
<div>
<div style="color:black; font:10pt arial">Hi Alexander and everyone,
<div><br clear="none">
</div>
<div>I hope that all is well! Just to follow up with this, I recently was able to try the following code that you had kindly previously shared:</div>
<div><br clear="none">
</div>
<div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
ExtractFirstMin<- function(df){</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
  df$abs_diff<- abs(df$x-1)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
  min_rate<- df$y[which.min(df$abs_diff)]</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
  return(min_rate)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
} #Get first y value of closest to x=1</div>
<div><br clear="none">
</div>
Just to be clear, do I simply replace the "df" in that code with the name of my individual dataframes? For example, here is the name of my 10 dataframes, which are successfully placed in a list (i.e. df_list), as you showed previously:</div>
<div><br clear="none">
</div>
<div>dataframe1<br clear="none">
dataframe2</div>
<div>dataframe3</div>
<div>dataframe4</div>
<div>dataframe5</div>
<div>dataframe6</div>
<div>dataframe7</div>
<div>dataframe8</div>
<div>dataframe9</div>
<div>dataframe10</div>
<div><br clear="none">
</div>
<div>Thus, using your example above, using the first dataframe listed there, would this become:</div>
<div><br clear="none">
</div>
<div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-size:16px">
<span style="font-family:Calibri,Arial,Helvetica,sans-serif">ExtractFirstMin<- function(</span><span style="background-color:transparent; font-size:10pt">dataframe1</span><span style="font-family:Calibri,Arial,Helvetica,sans-serif; background-color:transparent">){</span></div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
  <span style="background-color:transparent; font-family:arial; font-size:10pt">dataframe1</span><span style="background-color:transparent">$abs_diff<- abs(</span><span style="background-color:transparent; font-family:arial; font-size:10pt">dataframe1</span><span style="background-color:transparent">$x-1)</span></div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
  min_rate<- <span style="background-color:transparent; font-family:arial; font-size:10pt">dataframe1</span><span style="background-color:transparent">$y[which.min(</span><span style="background-color:transparent; font-family:arial; font-size:10pt">dataframe1</span><span style="background-color:transparent">$abs_diff)]</span></div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
  return(min_rate)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
} #Get first y value of closest to x=1</div>
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-size:16px">
<span style="font-family:Calibri,Arial,Helvetica,sans-serif">df_list<- list(</span><span style="background-color:transparent; font-size:10pt">dataframe</span><span style="font-family:Calibri,Arial,Helvetica,sans-serif; background-color:transparent">1,</span><span style="background-color:transparent; font-family:Arial,Helvetica,sans-serif"> </span><span style="background-color:transparent; font-size:10pt">dataframe2</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">,</span><span style="background-color:transparent; font-family:Arial,Helvetica,sans-serif"> </span><span style="background-color:transparent; font-size:10pt">dataframe3</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">, </span><span style="background-color:transparent; font-size:10pt">dataframe4</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">, </span><span style="background-color:transparent; font-size:10pt">dataframe5</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">, </span><span style="background-color:transparent; font-size:10pt">dataframe6</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">, </span><span style="background-color:transparent; font-size:10pt">dataframe7</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">, </span><span style="background-color:transparent; font-size:10pt">dataframe8</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">,</span><span style="background-color:transparent; font-family:Arial,Helvetica,sans-serif"> </span><span style="background-color:transparent; font-size:10pt">dataframe9</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">,</span><span style="background-color:transparent; font-family:Arial,Helvetica,sans-serif"> </span><span style="background-color:transparent; font-size:10pt">dataframe10</span><span style="background-color:transparent; font-family:Calibri,Arial,Helvetica,sans-serif">)</span></div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0">
# Apply function across list</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0">
sapply(df_list, ExtractFirstMin)</div>
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5233821364ContentPasted0" style="font-size:16px">
<br clear="none">
</div>
<div><br clear="none">
</div>
<div>Am I doing this correctly?</div>
<div><br clear="none">
</div>
<div>Thanks, again!</div>
<br clear="none">
<br clear="none">
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><font size="2">-----Original Message-----<br clear="none">
From: Alexander Ilich <ailich@usf.edu><br clear="none">
To: rain1290@aim.com <rain1290@aim.com><br clear="none">
Sent: Thu, May 11, 2023 1:48 am<br clear="none">
Subject: Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R<br clear="none">
<br clear="none">
</font>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421">
<div>
<div>Sure thing. Glad I could help!</div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421yqt55671" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421yqt2367370053">
<div dir="ltr" id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421divRplyFwdMsg">
<font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> rain1290@aim.com <rain1290@aim.com><br clear="none">
<b>Sent:</b> Thursday, May 11, 2023 12:17:12 AM<br clear="none">
<b>To:</b> Alexander Ilich <ailich@usf.edu><br clear="none">
<b>Subject:</b> Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R</font>
<div> </div>
</div>
<div>
<div style="color:black; font:10pt arial">Hi Alexander,
<div><br clear="none">
</div>
<div>Many thanks for sharing this! It was really helpful!</div>
<div><br clear="none">
<br clear="none">
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><font size="2">-----Original Message-----<br clear="none">
From: Alexander Ilich <ailich@usf.edu><br clear="none">
To: rain1290@aim.com <rain1290@aim.com><br clear="none">
Sent: Wed, May 10, 2023 2:05 pm<br clear="none">
Subject: Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R<br clear="none">
<br clear="none">
</font>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444">
<style type="text/css">
<!--
#x_yiv1880419194 #x_yiv1880419194x_yiv1079392194 #x_yiv1880419194x_yiv1079392194x_yiv1957706691 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444 p
        {margin-top:0;
        margin-bottom:0}
-->
</style>
<div dir="ltr">
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
One way to do this would be to put all your dataframes in a list, make one of the code implementation I put earlier into a function, and then use sapply to apply it across all the data frames. </div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444elementToProof x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
#Generate data</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
set.seed(5)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
for (i in 1:10) {</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
  assign(x = paste0("df", i), </div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
         value = data.frame(x = sort(rnorm(n = 10, mean = 1, sd = 0.1)),</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
                            y= rnorm(n = 10, mean = 30, sd = 1)))</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
  } # Create 10 Data Frames</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
# Define Functions (two versions based on how you want to deal with ties)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
ExtractFirstMin<- function(df){</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
  df$abs_diff<- abs(df$x-1)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
  min_rate<- df$y[which.min(df$abs_diff)] </div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
  return(min_rate)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
} #Get first y value of closest to x=1</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
ExtractAvgMin<- function(df){</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
  df$abs_diff<- abs(df$x-1)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
  min_rate<- mean(df$y[df$abs_diff==min(df$abs_diff)]) </div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
  return(min_rate)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
} #Average all y values that are closest to x=1</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
# Put all dataframes into a list</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
df_list<- list(df1,df2,df3,df4,df5,df6,df7,df8,df9,df10)</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
# Apply function across list</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
sapply(df_list, ExtractFirstMin)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
#>  [1] 29.40269 32.21546 30.75330 30.12109 30.38361 28.64928 30.45568 29.66190</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
#>  [9] 31.57229 31.33907</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
sapply(df_list, ExtractAvgMin)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
#>  [1] 29.40269 32.21546 30.75330 30.12109 30.38361 28.64928 30.45568 29.66190</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444ContentPasted0">
#>  [9] 31.57229 31.33907</div>
</div>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444appendonsend">
</div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444yqt49985" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444yqt5404633998">
<div dir="ltr" id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444divRplyFwdMsg">
<font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> rain1290@aim.com <rain1290@aim.com><br clear="none">
<b>Sent:</b> Wednesday, May 10, 2023 1:40 PM<br clear="none">
<b>To:</b> Alexander Ilich <ailich@usf.edu>; r-sig-geo@r-project.org <r-sig-geo@r-project.org><br clear="none">
<b>Subject:</b> Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R</font>
<div> </div>
</div>
<div>
<div style="color:black; font:10pt arial">Hi Alexander,<br clear="none">
<br clear="none">
Thank you so much for taking the time to outline these suggestions! 
<div><br clear="none">
</div>
<div>What if I wanted to only isolate the y-value at x = 1.0 across all of my 10 dataframes? That way, I could quickly see what the highest and lowest y-value is at x = 1.0? That said, in reality, not all x values are precisely 1.0 (it can be something like
 0.99 to 1.02), but the idea is to target the y-value at x = ~1.0. Is that at all possible? </div>
<div><br clear="none">
</div>
<div>Thanks, again!</div>
<div><br clear="none">
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><font size="2">-----Original Message-----<br clear="none">
From: Alexander Ilich <ailich@usf.edu><br clear="none">
To: r-sig-geo@r-project.org <r-sig-geo@r-project.org>; rain1290@aim.com <rain1290@aim.com><br clear="none">
Sent: Wed, May 10, 2023 10:31 am<br clear="none">
Subject: Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R<br clear="none">
<br clear="none">
</font>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727">
<style type="text/css">
<!--
#x_yiv1880419194 #x_yiv1880419194x_yiv1079392194 #x_yiv1880419194x_yiv1079392194x_yiv1957706691 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727 p
        {margin-top:0;
        margin-bottom:0}
-->
</style>
<div dir="ltr">
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
So using your data but removing x=1, 0.8 and 1.2 would be equally close. Two potential options are to choose the y value corresponding to the first minimum difference (in this case x=0.8, y=39), or average the y values for all that are equally close (in this
 case average the y values for x=0.8 and x=1.2). I think the easiest wayodo that would to first calculate a column of the absolute value of differences between x and 1 and then subset the dataframe to the minimum of that column to extract the y values. Here's
 a base R and tidyverse implementation to do that.</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727elementToProof x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
#Base R</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
df<- data.frame(x=c(0,0.2,0.4,0.6,0.8,1.2,1.4),</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
                y= c(0,27,31,32,39,34,25))</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
df$abs_diff<- abs(df$x-1)</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
df$y[which.min(df$abs_diff)] #Get first y value of closest to x=1</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
#> [1] 39</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
mean(df$y[df$abs_diff==min(df$abs_diff)]) #Average all y values that are closest to x=1</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
#> [1] 36.5</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
</div>
<div>#tidyverse<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
rm(list=ls())</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
library(dplyr)</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
df<- data.frame(x=c(0,0.2,0.4,0.6,0.8,1.2,1.4),</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
                y= c(0,27,31,32,39,34,25))</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
df<- df %>% mutate(abs_diff = abs(x-1))</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
df %>% filter(abs_diff==min(abs_diff)) %>% pull(y) %>% head(1) #Get first y value of closest to x=1</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
#> [1] 39</div>
<div><br clear="none" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
df %>% filter(abs_diff==min(abs_diff)) %>% pull(y) %>% mean() #Average all y values that are closest to x=1</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ContentPasted0">
#> [1] 36.5</div>
</div>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727appendonsend">
</div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727yqt58754" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727yqt3960461884">
<div dir="ltr" id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727divRplyFwdMsg">
<font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> rain1290@aim.com <rain1290@aim.com><br clear="none">
<b>Sent:</b> Wednesday, May 10, 2023 8:13 AM<br clear="none">
<b>To:</b> Alexander Ilich <ailich@usf.edu>; r-sig-geo@r-project.org <r-sig-geo@r-project.org><br clear="none">
<b>Subject:</b> Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R</font>
<div> </div>
</div>
<div>
<div style="color:black; font:10pt arial">Hi Alex and everyone,
<div><br clear="none">
</div>
<div>My apologies for the confusion and this double message (I just noticed that the example dataset appeared distorted)! Let me try to simplify here again.<br clear="none">
<br clear="none">
My dataframes are structured in the following way: an x column and y column, like this:
<div><br clear="none">
</div>
<div><img alt="" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727ycb1458053211"><br clear="none">
</div>
<div><br clear="none">
</div>
<div><br clear="none">
</div>
<div>Now, let's say that I want to determine the rate of increase at about x = 1.0, relative to the beginning of the period (i.e. 0 at the beginning). We can see clearly here that the answer would be y = 43. My question is would it be possible to quickly determine
 the value at around x = 1.0 across the 10 dataframes that I have like this without having to manually check them? The idea is to determine the range of values for y at around x = 1.0 across all dataframes. Note that it's not perfectly x = 1.0 in all dataframes
 - some could be 0.99 or 1.01.  </div>
<div><br clear="none">
</div>
<div>I hope that this is clearer!</div>
<div><br clear="none">
</div>
<div>Thanks,</div>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv6508739839yqt23439" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv6508739839yqt5648016678">
</div>
</div>
<br clear="none">
<br clear="none">
<div style="font-family:arial,helvetica; font-size:10pt; color:black"><font size="2">-----Original Message-----<br clear="none">
From: Alexander Ilich <ailich@usf.edu><br clear="none">
To: r-sig-geo@r-project.org <r-sig-geo@r-project.org>; rain1290@aim.com <rain1290@aim.com><br clear="none">
Sent: Tue, May 9, 2023 2:23 pm<br clear="none">
Subject: Re: [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R<br clear="none">
<br clear="none">
</font>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370">
<style type="text/css">
<!--
#x_yiv1880419194 #x_yiv1880419194x_yiv1079392194 #x_yiv1880419194x_yiv1079392194x_yiv1957706691 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727 #x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370 p
        {margin-top:0;
        margin-bottom:0}
-->
</style>
<div dir="ltr">
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
I'm currently having a bit of difficultly following. Rather than using your actual data, perhaps you could include code to generate a smaller dataset with the same structure with clear definitions of what is contained within each (<a rel="nofollow noopener noreferrer" shape="rect" target="_blank" href="https://stackoverflow.com/questions/5963269/how-to-make-a-great-r-reproducible-example" originalsrc="https://stackoverflow.com/questions/5963269/how-to-make-a-great-r-reproducible-example" shash="vSHz2ugoRpQtOfXDwBkn0ZCvzCGb77kjGjdzwT+riTg9LJWIS3QqL6sIMJ0LT7l5ce7Aca7fCWYV/cqh6OaHuXZRTydtp7o6X/Y+GjW+hYYrpcaGDnXbyWG86mbnNT3am5uYQig2nfhT25vwLtehl/xTSyq2YiAC5psO9k5alEk=" class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370ContentPasted0">r
 faq - How to make a great R reproducible example - Stack Overflow</a>). You can design that dataset to be small with a known answer and the describe how you got to that answer and then others could help determine some code to accomplish that task.</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370_Entity x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370_EType_OWALinkPreview x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370_EId_OWALinkPreview x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370_EReadonly_1">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<br clear="none">
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
Best Regards,</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370elementToProof" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
Alex</div>
<div id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370appendonsend">
</div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div dir="ltr" id="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370divRplyFwdMsg">
<font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> R-sig-Geo <r-sig-geo-bounces@r-project.org> on behalf of rain1290--- via R-sig-Geo <r-sig-geo@r-project.org><br clear="none">
<b>Sent:</b> Tuesday, May 9, 2023 1:01 PM<br clear="none">
<b>To:</b> r-sig-geo@r-project.org <r-sig-geo@r-project.org><br clear="none">
<b>Subject:</b> [R-sig-Geo] Finding the highest and lowest rates of increase at specific x value across several time series in R</font>
<div> </div>
</div>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370BodyFragment">
<font size="2"><span style="font-size:11pt"></span></font>
<div class="x_yiv1880419194x_yiv1079392194x_yiv1957706691x_yiv5116260421x_yiv4839490444x_yiv9338178727x_yiv7769615370PlainText">
I would like to attempt to determine the difference between the highest and lowest rates of increase across a series of dataframes at a specified x value. As shown below, the dataframes have basic x and y columns, with emissions values in the x column, and
 precipitation values in the y column. Among the dataframes, the idea would be to determine the highest and lowest rates of precipitation increase at "approximately" 1 Terratons of emissions (TtC) relative to the first value of each time series. For example,
 I want to figure out which dataframe has the highest increase at 1 TtC, and which dataframe has the lowest increase at 1 TtC. at However, I am not sure if there is a way to quickly achieve this? Here are the dataframes that I created, followed by an example
 of how each dataframe is structured:<br clear="none">
#Dataframe objects created:<br clear="none">
    CanESMRCP8.5PL<-data.frame(get3.teratons, pland20)     IPSLLRRCP8.5PL<-data.frame(get6.teratons, pland21)    IPSLMRRCP8.5PL<-data.frame(get9.teratons, pland22)    IPSLLRBRCP8.5PL<-data.frame(get12.teratons, pland23)    MIROCRCP8.5PL<-data.frame(get15.teratons,
 pland24)    HadGEMRCP8.5PL<-data.frame(get18.teratons, pland25)    MPILRRCP8.5PL<-data.frame(get21.teratons, pland26)    GFDLGRCP8.5PL<-data.frame(get27.teratons, pland27)    GFDLMRCP8.5PL<-data.frame(get30.teratons, pland28)<br clear="none">
#Example of what each of these look like:<br clear="none">
    >CanESMRCP8.5PL<br clear="none">
        get3.teratons   pland20    X1      0.4542249 13.252426    X2      0.4626662  3.766658    X3      0.4715780  2.220986    X4      0.4809204  8.495072    X5      0.4901427 10.206458    X6      0.4993126 10.942797    X7      0.5088599  6.592956    X8     
 0.5187588  2.435796    X9      0.5286758  2.275836    X10     0.5389284  5.051706    X11     0.5496212  8.313389    X12     0.5600628  9.007722    X13     0.5708608 11.905644    X14     0.5819234  6.126022    X15     0.5926283  9.883264    X16     0.6042306 
 7.699696    X17     0.6159752  5.614193    X18     0.6274483  6.681527    X19     0.6394011 10.112812    X20     0.6519496  8.721810    X21     0.6646344 10.315931    X22     0.6773436 11.372490    X23     0.6903203  8.662169    X24     0.7036479 10.106109   
 X25     0.7180955 10.990867    X26     0.7322746 13.491778    X27     0.7459771 17.256650    X28     0.7604589 12.040960    X29     0.7753096 10.638796    X30     0.7898374  7.889500    X31     0.8047258 11.757174    X32     0.8204160 15.060151    X33    
 0.8359387  9.822078    X34     0.8510721 11.388695    X35     0.8661237 10.271567    X36     0.8815913 13.224285    X37     0.8984146 15.584782    X38     0.9154501  9.320024    X39     0.9324529  9.187128    X40     0.9497379 12.919805    X41     0.9672824
 15.190318    X42     0.9854439 12.098606    X43     1.0041460 16.758629    X44     1.0241779 17.435182    X45     1.0451656 15.323428    X46     1.0663605 18.292109    X47     1.0868977 12.625429    X48     1.1079376 17.318583    X49     1.1295719 14.056624   
 X50     1.1516720 18.239445    X51     1.1736696 16.312087    X52     1.1963065 18.683315    X53     1.2195753 20.364835    X54     1.2425277 14.337167    X55     1.2653873 16.072449    X56     1.2888002 14.870248    X57     1.3126799 18.431717    X58    
 1.3362459 19.873449    X59     1.3593610 17.278361    X60     1.3833589 18.532887    X61     1.4083234 16.178170    X62     1.4328881 17.689810    X63     1.4572568 21.395131    X64     1.4821021 20.154886    X65     1.5072721 15.655971    X66     1.5325393
 21.692028    X67     1.5581797 23.258303    X68     1.5842384 23.802459    X69     1.6108635 15.824673    X70     1.6365393 19.016228    X71     1.6618322 20.957593    X72     1.6876948 19.105363    X73     1.7134712 19.759288    X74     1.7392598 27.315595   
 X75     1.7652725 24.882263    X76     1.7913807 25.813408    X77     1.8173818 23.658997    X78     1.8434211 24.223432    X79     1.8695911 23.560818    X80     1.8960611 28.057708    X81     1.9228969 26.996265    X82     1.9493552 26.659719    X83    
 1.9759324 22.723687    X84     2.0026666 30.977267    X85     2.0290137 29.384326    X86     2.0549359 24.840383    X87     2.0811679 26.952620    X88     2.1081763 29.894790    X89     2.1349227 25.224040    X90     2.1613017 27.722623<br clear="none">
    >IPSLLRRCP8.5PL<br clear="none">
        get6.teratons   pland21    X1      0.5300411  8.128827    X2      0.5401701  6.683660    X3      0.5503503 12.344974    X4      0.5607762 11.322411    X5      0.5714146 14.250646    X6      0.5825357 10.013592    X7      0.5937966  9.437394    X8     
 0.6051673  8.138396    X9      0.6168960  9.767765    X10     0.6290367  8.166579    X11     0.6413864 12.307348    X12     0.6539184 12.623931    X13     0.6667360 11.182448    X14     0.6800060 12.585040    X15     0.6935350 13.408614    X16     0.7071757 
 9.352335    X17     0.7211951 12.743725    X18     0.7356089 11.625612    X19     0.7502665 10.240418    X20     0.7650959 12.394282    X21     0.7800845 16.963066    X22     0.7953119 16.380090    X23     0.8107459 10.510501    X24     0.8260236 12.645911   
 X25     0.8414439 14.134851    X26     0.8572960 18.924963    X27     0.8732313 17.849050    X28     0.8892344 10.941533    X29     0.9057380 12.034925    X30     0.9223530 15.897904    X31     0.9391578 19.707692    X32     0.9563358 16.690375    X33    
 0.9738711 18.098571    X34     0.9916517 16.588447    X35     1.0096934 16.125172    X36     1.0279473 19.108647    X37     1.0463864 16.972994    X38     1.0653421 22.869403    X39     1.0842487 21.228874    X40     1.1035309 25.509754    X41     1.1230403
 15.579367    X42     1.1426743 21.259726    X43     1.1626806 26.061262    X44     1.1833831 21.918530    X45     1.2045888 22.369094    X46     1.2262981 21.480456    X47     1.2481395 20.503543    X48     1.2703019 27.717028    X49     1.2929382 26.295449   
 X50     1.3157745 28.271455    X51     1.3390449 31.595651    X52     1.3626052 26.188018    X53     1.3863833 26.326999    X54     1.4102701 26.902272    X55     1.4343871 25.308764    X56     1.4584666 23.789699    X57     1.4831504 26.916504    X58    
 1.5080384 32.921638    X59     1.5331210 29.753267    X60     1.5582794 29.567720    X61     1.5832585 31.454097    X62     1.6085002 26.602191    X63     1.6339502 35.873728    X64     1.6594560 34.222654    X65     1.6851070 36.290959    X66     1.7109757
 31.623912    X67     1.7368503 31.965520    X68     1.7626750 41.490310    X69     1.7883216 35.645934    X70     1.8141292 35.639422    X71     1.8405670 37.085608    X72     1.8672313 44.812777    X73     1.8939987 40.044602    X74     1.9208222 37.834526   
 X75     1.9478806 44.497335    X76     1.9750195 39.839740    X77     2.0024118 38.300529    X78     2.0302205 52.116649    X79     2.0581589 59.189047    X80     2.0861536 51.559857    X81     2.1141780 43.305779    X82     2.1421791 47.950074    X83    
 2.1703249 46.252149    X84     2.1985953 47.536605    X85     2.2266540 49.422466    X86     2.2547762 44.577399    X87     2.2827062 49.720523    X88     2.3102098 47.138244    X89     2.3379090 51.882832    X90     2.3656370 51.413472<br clear="none">
Etc...<br clear="none">
Any help with this would be greatly appreciated!<br clear="none">
Thanks,<br clear="none">
        [[alternative HTML version deleted]]<br clear="none">
<br clear="none">
_______________________________________________<br clear="none">
R-sig-Geo mailing list<br clear="none">
R-sig-Geo@r-project.org<br clear="none">
<a rel="nofollow noopener noreferrer" shape="rect" target="_blank" href="https://stat.ethz.ch/mailman/listinfo/r-sig-geo" originalsrc="https://stat.ethz.ch/mailman/listinfo/r-sig-geo" shash="KdV/OtmeWuXAgESIsvLVnnutzzLEqK40oreKTMMFaP8xLFHzkJae6Gt9rFa1DztoUrYQBHANeb3xQnu8jjs3orPnUTyBkRGgza/K6bo58yaQLWBg7+QQGGStxa4sUZB2hkV3b9eRVeEmry+ecOTiS+99DkAbcUoiD/dS9tLlh48=">https://nam04.safelinks.protection.outlook.com/?url=https%3A%2F%2Fstat.ethz.ch%2Fmailman%2Flistinfo%2Fr-sig-geo&data=05%7C01%7Cailich%40usf.edu%7Cb59e2f81076143e9b0a408db50af0b78%7C741bf7dee2e546df8d6782607df9deaa%7C0%7C0%7C638192484981183656%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=iwGeEZIJDfmhJ5TkfQxq5htErTGihLIrl7T5nJ6fIC0%3D&reserved=0</a><br clear="none">
[EXTERNAL EMAIL] DO NOT CLICK links or attachments unless you recognize the sender and know the content is safe.<br clear="none">
</div>
</div>
</div>
</div>
</div>
</div>
<div style="border:1px; border-style:solid; border-color:#FFCACA; background-color:#FFCACA; padding:1em">
<span style="font-size:12.0pt; color:black"><b>[EXTERNAL EMAIL]</b></span> <span style="font-size:10.0pt; color:black">
DO NOT CLICK links or attachments unless you recognize the sender and know the content is safe.</span></div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div style="border:1px; border-style:solid; border-color:#FFCACA; background-color:#FFCACA; padding:1em">
<span style="font-size:12.0pt; color:black"><b>[EXTERNAL EMAIL]</b></span> <span style="font-size:10.0pt; color:black">
DO NOT CLICK links or attachments unless you recognize the sender and know the content is safe.</span></div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div style="border:1px; border-style:solid; border-color:#FFCACA; background-color:#FFCACA; padding:1em">
<span style="font-size:12.0pt; color:black"><b>[EXTERNAL EMAIL]</b></span> <span style="font-size:10.0pt; color:black">
DO NOT CLICK links or attachments unless you recognize the sender and know the content is safe.</span></div>
</div>
</div>
</div>
</div>
</div>
</div>
<div style="border:1px; border-style:solid; border-color:#FFCACA; background-color:#FFCACA; padding:1em">
<span style="font-size:12.0pt; color:black"><b>[EXTERNAL EMAIL]</b></span> <span style="font-size:10.0pt; color:black">
DO NOT CLICK links or attachments unless you recognize the sender and know the content is safe.</span></div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div style="border:1px; border-style:solid; border-color:#FFCACA; background-color:#FFCACA; padding:1em">
<span style="font-size:12.0pt; color:black"><b>[EXTERNAL EMAIL]</b></span> <span style="font-size:10.0pt; color:black">
DO NOT CLICK links or attachments unless you recognize the sender and know the content is safe.</span></div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div style="border:1px; border-style:solid; border-color:#FFCACA; background-color:#FFCACA; padding:1em">
<span style="font-size:12.0pt; color:black"><b>[EXTERNAL EMAIL]</b></span> <span style="font-size:10.0pt; color:black">
DO NOT CLICK links or attachments unless you recognize the sender and know the content is safe.</span></div>
</div>
</div>
</div>
</div>
</font></div>
</div>
</div>
<p style="border:1px; border-style:solid; border-color:#FFCACA; background-color:#FFCACA; padding:1em">
<span style="font-size:12.0pt; color:black"><b>[EXTERNAL EMAIL]</span></b> <span style="font-size:10.0pt; color:black">
DO NOT CLICK links or attachments unless you recognize the sender and know the content is safe.</span></p>
</div>
</body>
</html>