Skip to main content
Logo image

Chapter 23 Function limits

Section 23.1 Concept and definition

Subsection 23.1.1 Motivation

Our motivation to create the concept of limit of a sequence was to help investigate trends in summing up more and more terms in a summation pattern that could extend indefinitely, and we will begin investigating such sums in the next chapter. But we can also use sequences to help us investigate trends in functions and understand continuity of functions a little more deeply.
Example 23.1.1. A removable discontinuity.
The function
f(t)=t3+2t2t2t1
is undefined at t=1. But what is the output trend for t1? If we investigate numerically by evaluating f(t) for inputs that are very close to 1, we would find that the closer t is to 1, the closer f(t) will be to 6.
t f(t)
0.99 5.9501
0.9999 5.99950001
0.999999 5.999995000001
t f(t)
1.01 6.0501
1.0001 6.00050001
1.000001 6.000005000001
The conflicting trends of Example 23.1.2 now put the conclusion of Example 23.1.1 in doubt: how can we be sure that outputs of the function from that example trend toward 6, if it is possible that different input patterns might exhibit different output trend behaviour. The only way to be sure is to check every possible input pattern. We can do this with sequences of input values.

Subsection 23.1.2 Limit points

To investigate output trends of a function, we need to ensure that the pattern of input values we use are all in the domain of the function. While in the examples in Subsection 23.1.1 involved investigating the behaviour of function outputs for inputs near some t-value that itself was not in the domain of the function, our investigation would not have been possible if there weren’t at least some domain values near that t-value.
Definition 23.1.3. Limit point.
Given a domain set D, a number c is called a limit point of D when there is at least one example of a sequence (tn) that satisfies:
  • (tn) is entirely contained in D
  • no term of (tn) is equal to c
  • (tn)c
The idea here is that c is a limit point of D when it is possible to “tiptoe” arbitrarily close to c from within D via an example sequence (tn)c.
Warning 23.1.4.
It is not necessary for the limit point c itself to be contained in the domain set D.
Example 23.1.5. Limit points of intervals.
  1. The number c=2 is a limit point of both the closed interval D1=[0,2] and the open interval D2=(0,2). In both cases, we can use the sequence (21n)n>0 as our example. This sequence converges to 2 but the terms of this sequence are all strictly less than 2, and so are all contained within both D1 and D2. Observe that 2 is a limit point of D1 that is itself contained in that domain, but on the other hand 2 is a limit point of D2 that is not itself contained in that domain. Also be careful that in the case of D1, which contains the limit point 2, the constant sequence (cn) with cn=2 for all n would not be an appropriate example to use to demonstrate that 2 is indeed a limit point, as it does not satisfy the second condition of the definition.
  2. The number c=1 is a limit point of both the closed interval D1=[0,2] and the open interval D2=(0,2). (Can you come up with an example sequence that satisfies the three conditions of the definition in both cases?)
  3. The number c=2.001 is not a limit point of either D1=[0,2] or D2=(0,2). Every sequence with (tn)2.001 would eventually have to contain a tail (tn)nN that is entirely contained in the open range (2.0005,2.0015). But then the terms of that tail would not be contained in either of these domains, and so no sequence converging to 2.001 satisfies the requirements to demonstrate that this number is a limit point of either of those domains.

Subsection 23.1.3 Definition and examples

As mentioned before, because function outputs can only be produced by valid input values (in other words, from the domain of the function), we can only investigate a possible trend in output values f(t) for tc if it is possible to create a pattern of domain values that trend toward c. That is, we require c to be a limit point of the domain set of function f. Then we can consider domain-value sequences (tn) that converge to c and investigate the corresponding sequence of output values (f(tn)).
Definition 23.1.6. Limit of a function.
Suppose f is a function and let D represent the domain set of f. For limit point t=c of D, we say that f(t) approaches L as t approaches c and write
f(t)Lastc
when every possible sequence (tn) that satisifies the three conditions of Limit point for c (and D) creates a corresponding output sequence (f(tn)) that converges to L. Alternatively, we may say that L is the limit of f(t) as t approaches c and write
limtcf(t)=L.
If there is no value L so that the above holds, then we say that the limit of f(t) as t approaches c does not exist.
Remark 23.1.7.
Because a limit point of a set does not itself need to be contained in that set, in the definition above the point t=c does not need to be in the domain of f for the notion of a limit of f(t) as tc to be meaningful. In fact, this is one of the main scenarios where a limit is useful: even if f(c) is undefined, what can we say about output values f(t) for tc?
And because we only consider input sequences (tn) for which tn is never equal to the limit point c, we can make an even stronger remark: a function limit value is independent of the value of the function at the limit point.
Example 23.1.8. Verifying the definition.
Let’s return to Example 23.1.1, where we investigated output trends for t1 of the function
f(t)=t3+2t2t2t1.
In that example we only considered two input sequences that converge to 1:
tn=1±102n2.
But in both cases we observed that the corresponding output sequence (f(tn)) appeared to be converging toward 6. Let’s attempt to confirm that f(t)6 as t1.
So suppose (tn) is an arbitrary sequence with (tn)1 but tn1 for all n. The corresponding output sequence will have terms
f(tn)=tn3+2tn2tn2tn1.
It is possible to factor the numerator:
f(tn)=(tn1)(tn2+3tn+2)tn1.
Since we assume tn1 we may cancel the common factor in numerator and denominator:
f(tn)=(tn1)(tn2+3tn+2)tn1=tn2+3tn+2.
Now we may apply the patterns of Pattern 22.3.35 to conclude that since (tn)1, we must have
(f(tn))12+31+2=6.
Since our analysis holds for every input sequence that converges to 1 (but with no terms equal to 1), the definition of function limit says that
limt1t3+2t2t2t1=6.
In practice, to compute a function limit value we are usually less formal than the example above, and we only investigate numerically (as in Example 23.1.1) as a last resort, because it is too easy to be deceived by numerical trends (as we observed in Example 23.1.2).
Example 23.1.9. Practical computation of a function limit.
Our analysis in the previous example really only depended on considering input values close to but not equal to 1. So if we were not concerned with confirming the limit value rigorously using the formal definition, we could arrive at the actual result
limt1t3+2t2t2t1=6
via the same algebra but without the input sequence:
f(t)=t3+2t2t2t1=(t1)(t2+3t+2)t1(only valid for t1)=t2+3t+2.
So for t1 (but t1), we have
f(t)=t2+3t+212+31+2=6.
From this analysis we can be fairly certain that f(t)6 as t1, and if we needed to be completely certain we would then turn to the formal verification presented in Example 23.1.8.
Example 23.1.10. A limit that doesn’t exist.
Consider
f(t)=t+1t1.
The domain of f is all values t1. But we may wish to investigate if there are any trends as t1. An input sequence (tn) in the domain of the function creates an output sequence (sn) where
sn=f(tn)=tn+1tn1.
We can consider this output sequence as being made up of a numerator sequence (tn+1) and a denominator sequence (tn1). In the case that (tn)1 (but with tn1 for all n), then
(tn+1)2,(tn1)0,
and so Statement 6 of Pattern 22.3.35 says that (sn) must diverge. So no matter what potential limit value L we try, (f(tn))L is impossible.
Remark 23.1.11.
Effectively, the limit in Example 23.1.10 doesn’t exist because the function exhibits singular behaviour at t=1. We will be more precise about how this type of limit diverges in Subsection 23.5.2.

Section 23.2 Function limit laws

First we establish two fundamental limits for the foundations on which every function is built.
Most of the laws below follow immediately from the facts and laws discussed in Chapter 22.
Repeated application of these laws and the two fundamental limits in Pattern 23.2.1 allow us to handle limits of power functions, polynomial functions, and most rational functions of polynomials.

Warning 23.2.5.

A limit of a quotient function may or may not exist in the case that both the numerator and denominator limits are 0. For example, in Example 23.1.8 we verified that
limt1t3+2t2t2t1=6,
yet separately we have
limt1(t3+2t2t2)=0,limt1(t1)=0.
As another example, the quotient limit
limt1t3+2t2t2(t1)2
also has both numerator and denominator trending toward 0. But for t1 we have
t3+2t2t2(t1)2=t2+3t+2t1,
and this simplified ratio has numerator trending toward 6 as t1, while the denominator trends to 0, and so the limit as t1 does not exist.
The patterns of the Order Limit Theorem apply to function limits as well.

Justification.

For each of the statements, apply the corresponding statement from Pattern 22.3.37 to the output sequence (f(tn)) (and the output sequence (g(tn)) for the third statement), for arbitrary input sequence (tn) that converges to c from within D.
We can also squeeze function limits.

Justification.

Apply the Pattern 22.3.26 to the output sequences (f(tn)),(g(tn)),(h(tn)) for arbitrary input sequence (tn) that converges to c from within D.

Section 23.3 One-sided limits

Recall that we have only defined a Limit of a function for tc in the case that c is a Limit point of the domain of the function. Sometimes we we wish to analyze output trends on a restricted domain.

Example 23.3.1. Limits of a piecewise-defined function.

Consider the function below.
f(t)={2t2t<1t1t>1
Graph of a discontinuous piecewise function.
The value t=1 is not in the domain of this function, but it is a limit point of the domain. The sequence (tn) with
tn=1+(1)n10n
converges to 1, but the corresponding output sequence (f(tn)) oscillates between two subsequences:
f(tn)={2(1110n)2n odd110nn even.
The odd-index subsequence converges to 2, while the even-index subsequence converges to 0. Therefore, it’s impossible for the full output sequence (f(tn)) to converge, as that would violate Pattern 22.3.13. However, the fact that these two subsequences converge provides useful information about output trends of this function for t1.
If we temporarily restrict the domain of our function to t<1, then any input sequence (tn) that converges to 1 from within this restricted domain will necessarily satisfy tn<1 for all n. In this case, the corresponding output sequence is (2tn2), which converges to 2 if (tn)1.
On the other hand, if we temporarily restrict the domain of our function to t>1, then any input sequence (tn) that converges to 1 from within this restricted domain will necessarily satisfy tn>1 for all n. In this case, the corresponding output sequence is (tn1), which converges to 0 if (tn)1.
It would be nice to have notation and terminology to capture the patterns of the previous example in general.

Definition 23.3.2. One-sided limits.

Let D represent the domain of a function f and suppose c is a limit point of D. Let D represent only those values in D that satisfy t<c, and let D+ represent only those values in D that satisfy t>c.
  1. If c is a limit point of D, then we write f(t)L as tc to mean that f(t)L as tc from within the restricted domain D. In this case, we say f(t) approaches L as t approaches c from the left. In limit notation, we write
    limtcf(t)=L,
    and say that L is the left-hand limit of f at c.
  2. If c is a limit point of D+, then we write f(t)L as tc+ to mean that f(t)L as tc from within the restricted domain D+. In this case, we say f(t) approaches L as t approaches c from the right. In limit notation, we write
    limtc+f(t)=L,
    and say that L is the right-hand limit of f at c.

Justification for Statement 1.

(⇒) 
If f(t)L as tc, then f(tn)L for every input sequence (tn) within D with (tn)c. In particular, f(tn)L both when (tn)c from within D and from within D+.
(⇐) 
We assume f(t)L for both tc and tc+, and wish to verify that the same is true for tc. So suppose (tn)c from within D. Let (an) be the subsequence of those terms tn that satisfy tn<c (reindexed to have indices progress consecutively from n=0), and similarly let (bn) be the subsequence of terms that satisfy tn>c. Since we assume that tnc for all n, the two subsequences together account for all terms of (tn), and so it is also true that the two subsequences (f(an)) and (f(bn)) together account for all terms of the output sequence (f(tn)). Furthermore, since we assume f(t)L as both tc and tc+, the two output subsequences (f(an)) and (f(bn)) both converge to L. Therefore, we may apply Fact 22.3.20 to conclude that (f(tn))L.

Justification for Statement 2.

The definition of f(t)L as tc requires that (f(tn))L for every input sequence (tn)c, whether (tn)c+ or (tn)c.

Example 23.3.5. More limits of a piecewise-defined function.

Here is a slightly modified version of Example 23.3.1.
f(t)={2t2t<1t+1t>1
Graph of a continuous piecewise function.
Consider the “pieces” of f as separate functions without restricted domains. Applying various Function limit laws, we see that both 2t22 and t+12 as t1, and so Fact 23.3.4 tells us that
limt12t2=2,limt1+t+1=2.
Now taking the domain restrictions in the defintion of f into account, the above one-side limits say that
limt1f(t)=2,limt1+f(t)=2.
Combining these two and applying Fact 23.3.4 again, we have f(t)2 as t1. This says that the trend result of output values of f(t) for t1 is consistent at 2, even though those output values will trend toward 2 in different ways on each side of input value 1 due to the piecewise nature of f.
In the example above, it wasn’t really necessary to consider the “pieces” of f as having unrestricted domains — the Function limit laws are equally valid for one-sided limits.

Section 23.4 An alternative characterization

It is often useful in proofs to have a characterization of the concept of function limit value that does not explicitly refer to sequences.

Justification.

(⇒) 
We would like to prove that if f(t)L as tc, then values of f(t) can be restricted to arbitrary open ranges around L by restricting tc (but tc). We will instead prove the contrapositive statement: if values of f(t) cannot always be restricted to arbitrary open ranges around L, then f(t)L as tc is impossible. For this, we will construct an input sequence (tn)c for which the corresponding output sequence (f(tn)) does not converge to L.
So assume that values of f(t) cannot always be restricted to arbitrary open ranges around L. This means that there must be at least one example of an open range (A,B) containing L that does not contain all output values of f(t), no matter how closely around c we restrict the input values t. For example, the domain (c1,c+1) must contain at least one value t0c for which f(t0) is not within (A,B). Similarly, the domain (c1/2,c+1/2) must also contain at least one value t1c for which f(t1) is not within (A,B). Continuing in this fashion, each domain
(c1n+1,c+1n+1)
must contain at least one value tnc for which f(tn) is not within (A,B).
We leave it to the reader to verify that the sequence (tn) we have created converges to c. But clearly the corresponding output sequence (f(tn)) cannot converge to L, because the open range (A,B) contains L but contains none of the terms f(tn). So no tail of (f(tn)) is contained in that range, and the definition of sequence limit value cannot be confirmed.
Having shown that when values of f cannot be restricted to every arbitrary open range around L, then also f(t)L as tc must be false, we conclude that when f(t)L as tc is actually true, then it must always be possible to restrict values of f(t) to arbitrary ranges around L by restricting input values of t to open subdomains around c.
(⇐) 
Assume that values of f(t) can always be restricted to arbitrary open ranges around L by restricting input values t to open subdomains around c (but excluding c itself). We would like to verify that f(t)L as tc. So assume that input sequence (tn)c from within the domain of f (but, as always, tnc for all n). We need to verify that the corresponding output sequence (f(tn)) converges to L. So consider an open range (A,B) around L. From our assumption, it’s possible to specify a corresponding open domain (a,b) around c so that values of f(t) are always within (A,B) for t within (a,b) (but ignoring f(c)). As (tn)c and c lies within (a,b), there is a tail (tn)nN that is completely contained in (a,b). But within this subdomain all output values of f lie within range (A,B). In particular, the output values f(tn) all lie within (A,B) for the terms in the tail is contained in (a,b). That is, the corresponding tail (f(tn))nN of the output sequence is entirely contained within (A,B). Since such a tail of the output sequence can always be determined for every open range (A,B) around L, we conclude that (f(tn))L.

Section 23.5 Previous concepts as function limits

Many of the concepts we have considered previously can be expressed in terms of function limits.

Subsection 23.5.1 Continuity

Subsubsection Continuity in terms of limits
In Definition 2.4.1, we defined continuity at a point to mean that output values can always be restricted to an open range around a specific output value by restricting the inputs to an open domain around the corresponding specific input value. Through Pattern 23.4.1 we may now connect this to limits.
Fact 23.5.1 effectively says that a function is continuous precisely when computing a limit value coincides with evaluating the function. We can use this to help us compute limit values for compositions of functions involving a continuous function.
Effectively, this pattern says that we may interchange order of computing a limit and evaluating a function:
limtcg(f(t))=g(limtcf(t)).
Example 23.5.3.
To compute
limt1ln(1t1t),
we can first compute
1t1t=1t1t1+t1+t=1t(1t)(1+t)=11+t12as t1.
Because ln is continuous on its domain, we have
limt1ln(1t1t)=ln(limt11t1t)=ln(12)=ln(2).
A power function is continuous on its domain, so we obtain a new limit law by applying Pattern 23.5.2 to limits of powers.
Subsubsection Continuity of combinations of functions
The Function limit laws says that we may reduce limit calculations to limits of the constituent parts of the function involved. Since continuity can be recast in terms of a limit, we can similarly reduce a question of continuity of a function to determining the continuity of the constituent parts of the function.
Justification.
We will only justify Statement 1; the others are similar. So suppose f(t) and g(t) are both continuous at t=c. Then by Fact 23.5.1 we can say that
limtcf(t)=f(c),limtcg(t)=g(c).
Applying Statement 2 of Pattern 23.2.2leads to
limtc[f(t)+g(t)]=limtcf(t)+limtcg(t)=f(c)+g(c),
which verifies that the sum function f+g is continuous at t=c (again by Fact 23.5.1).
Example 23.5.6. Analyzing continuity in parts.
Consider
f(t)=etln(t)+t.
Individually, all three of the functions
et,ln(t),t
are continuous at all points t>0. So etln(t) is a product of continuous functions, and therefore is continuous. Which makes f(t) a sum of continuous functions, and therefore is also continuous on domain t>0.
Subsubsection One-sided continuity
Example 23.5.7.
Consider the function below.
f(t)={t2t0t+1t>0
Graph of a discontinuous piecewise function.
The function is clearly discontinuous at t=0. However, examining the “flow” of the graph from left to right, the jump discontinuity is not evident until we move past t=0. Indeed, consider f restricted to the domain t0. Let g represent this restricted-domain version of f.
g(t)=t2t0
Graph of one half of a discontinuous piecewise function.
Note that c=0 is a limit point of the domain
D={t|t0}.
So considering the Limit formulation of continuity, as we clearly have g(t)g(0)=0 as t0 from within domain D, we may say that g is continuous at t=0.
Since g and f are effectively the same function for t0, we should be able to convert this to a statement about the continuity of f at t=0. But we must qualify this statement to include the domain D, because f is discontinuous at t=0 if we do not include such a qualification. So we will say that f is continuous from the left at t=0 because
limt0f(t)=f(0).
Definition 23.5.8. One-sided continuity.
Let D represent the domain of a function f and suppose c is a limit point of D.
  1. If c is a limit point of D and f(t)f(c) as tc, then we say that f is continuous at t=c from the left.
  2. If c is a limit point of D+ and f(t)f(c) as tc+, then we say that f is continuous at t=c from the right.
Notation.
When considering continuity on intervals, we will now include/exclude endpoints to indicate one-sided continuity/discontinuity at those endpoints.
Example 23.5.9.
Consider the function below.
f(t)={t2t1,1t211<t<0,t2t2+t6t0.
Graph of a discontinuous piecewise function with continuous pieces.
The parabolic portion of the graph is continuous, including from the left at the domain boundary t=1, so we may say that f is continuous on the closed interval t1. However, the next portion of the graph has a vertical asymptote from the right at t=1 and has a jump discontinuity at t=0, so we may only say that f is continuous on the open interval 1<t<0. Finally, the graph is continuous from the right at the jump discontinuity at t=0, but there is a removable discontinuity at t=2. So f is continuous on the half-open interval 0t<2 and again on the open interval t>2.

Subsection 23.5.2 Long-term and singular behaviour

In Chapter 3, we wrote “f(t) as t” to mean that output values of f eventually become and stay large and positive. Similar to Fact 23.5.1, we can make this more precise with sequences.
Justification.
We will only consider the case that L is finite; the arguments in the cases that L represents one of ± are similar.
(⇒) 
Assume that f(t)L as t, and suppose that (tn) is a sequence contained in the domain of f so that (tn). We would like to verify that (f(tn))L, so suppose (a,b) is an open range around L. Our assumption about the long-term behaviour of f means that values of f(t) eventually become and stay arbitrarily close to L, so there is some open domain (M,) where all values of f(t) land within (A,B) for t in (M,). But as (tn), there is a tail (tn)nN entirely contained within (M,), and therefore the corresponding tail (f(tn))nN is entirely contained within (a,b).
(⇐) 
Similarly to the justification of Pattern 23.4.1, one can instead demonstrate the contrapositive: if f(t)L as t, then it is not true that output sequences (f(tn)) will always converge to L for input sequences that diverge to infinity. We leave the details of constructing such an example input sequence (tn) to the reader.
Remark 23.5.11.
Fact 23.5.10 is similarly true about ancient behaviour by considering t versus sequences (tn) that diverge to negative infinity.
Singular behaviour is simply an inversion of long-term behaviour, and we can similarly take a limit point of view by considering output sequences diverging to infinity instead of input sequences diverging to infinity. The justification for the following fact is similar to arguments we’ve already made in this chapter, and will be omitted this time.
Remark 23.5.13.
Similarly to Fact 23.5.12, we may write
limtc+f(t)=±limtcf(t)=±
by only considering sequences contained in the domain t>c (for the limit tc+) or only considering sequences contained in the domain t<c (for the limit tc).

Subsection 23.5.3 Definite integrals

Recall that a definite integral value
abf(t)dt
represents the unique value (if it exists) that sits between every pair of upper and lower sum estimates:
L(P)abf(t)dtU(P)
for every partition P of the integration domain atb. If f is already known to be integrable (for example, if f is continuous on the integration domain), then it is sufficient to only consider regular partition (that is, creating a regular step function approximation to f(t) on that domain). Since the first “step” in creating a regular step function is to decide how many steps to use, in effect we create two sequences Riemann sum values indexed by n, the number of steps to use:
  • a sequence (Ln) where each term Ln represents the lower sum approximation value using a step function with n steps
  • a sequence (Un) where each term Un represents the upper sum approximation value using a step function with n steps.
Example 23.5.14.
For
01t22t+2dt,
the integrand function f(t)=t22t+2 is decreasing on the domain of integration, and so in this case lower sums will be right Riemann sums and upper sums will be left Riemann sums.
A graph depicting a right Riemann sum for a decreasing function creating a lower sum.
(a) Lower sum.
A graph depicting a left Riemann sum for a decreasing function creating an upper sum.
(b) Upper sum.
Figure 23.5.15.
Following Procedure 6.1.6 twice, choosing sample points to be right endpoints in the lower sum case and left endpoints in the upper sum case, we obtain
Ln=k=1nf(kn)1nUn=k=1nf(k1n)1n=k=1n(k2n22kn+2)1n,=k=1n((k1)2n22(k1)n+2)1n.
If we used the patterns of Subsection 5.3.2 to simplify these expressions, eventually we would be faced with having to calculate sums like
k=1nk2k=1nk
for which there are known formulas in n. Let’s get Sage to apply those patterns and formulas for us.
According to Sage, we have
Ln=8n23n+16n2,Un=8n2+3n+16n2.
With the only difference being a plus/minus sign switch between them, clearly the lower sum result is always less than the corresponding upper sum result, as expected, and the actual definite integral value will lie between these two values for every value of n.
We know that upper and lower sum values “squeeze” the exact definite integral value (Fact 6.2.1). We may now take a sequence perspective on this idea.
Notationally we can take the idea of these sequences “squeezing” down to the value of the definite integral further: if we let A represent the value of
abf(t)dt,
then we might write
(Ln)A,(Un)A+.
Example 23.5.17.
Continuing Example 23.5.14, for f(t)=t22t+2 on domain 0t1 we had
Ln=8n23n+16n2,Un=8n2+3n+16n2.
Using our strategy of “dominant terms”, we see that both of these sequences converge to 8/6 (or 4/3), which agrees with the result for the definite integral that we would obtain from Pattern 7.4.2:
01t22t+2dt=t332t22+2t|t=1=13212+2=43.
Example 23.5.18.
Analyzing
01t2t+1d
via upper and lower sums seems like it should be just as simple as our previous example, but in this case our integrand function f(t)=t2t+1 is sometimes decreasing and sometimes increasing, which means the sample points will not remain consistently at one endpoint or another, but instead will flip.
We could exploit the symmetry of the graph to simplify things, but instead let’s exercise our reasoning skills and exploit the symmetry of the positioning within the domain of the critical point at t=1/2, where the graph switches from decreasing to increasing. How the endpoints of our regular partition fall relative to this critical point depends on whether the number of steps n is even or odd, and so we will break our analysis up into those two cases.
Even number of steps.
In this case, the critical point at t=1/2 will always line up with a partition boundary, so we may split the domain in two: for the first half of the domain, lower sum sample points will be right endpoints and upper sum sample points will be left endpoints, and for the second half of the domain this will reverse.
A graph depicting a lower sum for an even number of partition cells.
(a) Lower sum for even n.
A graph depicting an upper sum for an even number of partition cells.
(b) Upper sum for even n.
Figure 23.5.19.
So when n is even we have
Ln=k=1n/2f(kn)1n+k=n/2+1nf(k1n)1n,Un=k=1n/2f(k1n)1n+k=n/2+1nf(kn)1n.
Odd number of steps.
In this case, the critical point at t=1/2 will always line up with a midpoint of a partition subdomain, and so this time we will split the domain in three: for the first “half” of the domain (excluding the “middle” parition subdomain), the second “half” of the domain, and the “middle” partition subdomain by itself. On the two “halves”, upper/lower sum sample points line up with left/right endpoints exactly as in the previous case. But on that middle partition subdomain that straddles the critical point, the lowest value occurs at t=1/2, while the highest value occurs symmetrically at the two endpoints.
A graph depicting a lower sum for an odd number of partition cells.
(a) Lower sum for odd n.
A graph depicting an upper sum for an odd number of partition cells.
(b) Upper sum for odd n.
Figure 23.5.20.
So when n is odd we have
Ln=k=1(n1)/2f(kn)1n+f(12)1n+k=(n+3)/2nf(k1n)1n,Un=k=1(n1)/2f(k1n)1n+k=(n+1)/2nf(kn)1n.
Note that the “middle” partition subdomain is indexed by k=(n+1)/2. For the upper sum we have chosen the right endpoint as the sample point for that subdomain, and so have absorbed that term into the sum for the second “half” of partition cells.
Effectively we are analyzing subsequences of the upper and lower sum sequences. Since in each case the even/odd-index subsequences cover all terms, if these subsequences all converge to the same value, we can be confident that the sequences themselves converge to the same value.
Convergence of lower sum even subsequence.
When n is even, we may assume that it is double another integer: n=2m. Substituting this into our previous expression for Ln in the even case, we have
Ln=k=1mf(k2m)12m+k=m+12mf(k12m)12m.
Let’s put this into Sage to simplify.
Analyzing dominant terms of the result
Lm=20m23m+124m2
we conclude (Lm)5/6, which agrees with the result of the definite integral that we could compute by other “shortcut” methods.
We leave the analysis of the other three cases to you, the reader.

Subsection 23.5.4 The derivative

Reviewing the definition of derivative value Definition 11.5.1, it attempts to describe the pattern of difference quotient values at a specific point t=t for Δt0. So it is not a limit of the function q whose derivative values we are computing, but instead a limit of a new function whose independent variable is Δt:
(✶)Qt(Δt)=ΔqΔt=q(t+Δt)q(t)Δt,
where t is a specific point in the domain of q.
Justification.
Re-reading the definition of Definition 11.5.1, interpret “arbitrarily close to d” to mean “restricted within some small open range around d”, and interpret “taking Δt sufficiently small” to mean “restricted within some small open domain around 0 (but Δt0).” Then the statement at hand is equivalent to Pattern 23.4.1 applied to Qt(Δt).
A difference quotient function Qt(Δt) always “evaluates” to an indeterminate 0/0 form, similar to many of the function limit examples we’ve considered in this chapter. In particular, you may have noticed a similarity between Example 23.1.9 and our algebraic approach to computing derivative values from the definition (Procedure 12.2.2). Fact 23.5.21 says that this is not a coincidence.
Example 23.5.22. Computing a derivative value using a limit.
Let’s repeat Example 12.2.1, but only for the specific derivative value at t=2. To maintain consistency with the notation used in this subsection, we’ll write q(t) for our position function instead of s(t):
q(t)=2t2+6t.
We would like to compute the value of q(2) using a limit. So form the associated difference quotient function
Q2(Δt)=q(2+Δt)q(2)Δt=(2(2+Δt)2+6(2+Δt))(222+62)Δt
and compute its limit as Δt0 through algebraic simplification of the difference quotient function Q2(Δt):
q(2)=limΔt0Q2(Δt)=limΔt0(2(2+Δt)2+6(2+Δt))(222+62)Δt=limΔt02Δt+(Δt)2Δt=limΔt02+Δt=2.
You may verify that this agrees with the value of q(2) that you might compute using other “shortcut” methods.

Section 23.6 L’Hopital’s rule

Subsection 23.6.1 0/0 forms

The Function limit laws say that a limit of a quotient
limtcf(t)g(t)
is 0 if the numerator function approaches 0 but the denominator function doesn’t, and doesn’t exist if the denominator function approaches 0 but the numerator function doesn’t. What if both f(t)0 and g(t)0 as tc?
Definition 23.6.1. Indeterminate form 0/0.
A limit of the form
limtcf(t)g(t)
where both f(t)0 and g(t)0 as tc.
Example 23.6.2.
  1. Consider
    f1(t)=t21,g1(t)=(t1)2.
    Both functions approach 0 as t1, but
    limt1f1(t)g1(t)
    does not exist.
  2. Consider
    f2(t)=(t1)2,g2(t)=t21.
    Again both functions approach 0 as t1, but
    limt1f2(t)g2(t)
    exists and is equal to 0.
  3. Consider
    f3(t)=t21,g3(t)=t1.
    Both functions approach 0 as t1, but
    limt1f3(t)g3(t)
    exists and is equal to 2.
Example 23.6.2 demonstrates that a limit of indeterminate form 0/0 may have any result. Though we already knew this, since every derivative calculation involves a 0/0 indeterminate form limit, and derivative values frequently exist and can take on many different values. In fact, known derivative formulas give us an alternative way to compute 0/0-form limits.
Example 23.6.3.
Consider
limt0et1t.
Since the numerator is a continuous function, we have et1e01=0. So the limit is a 0/0 indeterminate form. But using
Using Fact 23.5.21, we have
d(et)dt|t=0=limΔt0e(0+Δt)e0Δt=limΔt0eΔt1Δt.
Ignoring the difference in variables, this is exactly the limit we would like to compute. Since
d(et)dt=et,
we have
limt0et1t=limΔt0eΔt1Δt=d(et)dt|t=0=et|t=0=1.
Can derivatives help us compute other 0/0-form limits? Remember that a function limit measures how output-value sequences behave for all possible input-value sequences that converge to the limit point. So, similarly to Section 3.2, in some sense a 0/0-form limit is like a “race” to zero between the output-value sequences of the numerator function and the denominator function. In the first limit of Example 23.6.2, the denominator function was approaching zero faster and “won” the race, causing the limit of their ratio to diverge to infinity (though differently-signed infinities from different sides of the limit point). In the second limit of Example 23.6.2, the roles of numerator and denominator were reversed and the numerator function “won” the race, causing the limit of their ratio to converge to 0. And in the third limit of Example 23.6.2, both numerator and denominator functions were approaching zero at the same rate, and so these zeros “cancelled out” before they actually reached zero, leaving behind a constant ratio of 2.
A derivative measures a rate of variation, so we can use the derivatives of the numerator and denominator functions to compare how quickly they are trending toward zero near the limit point.
Warning 23.6.5.
  • Do not apply L’Hôpital’s Rule to limits to which it does not apply! The limit must be a 0/0-form (or another indeterminate form — see Subsection 23.6.2) for L’Hôpital’s Rule to apply.
  • If you have learned something called the “quotient rule” for computing derivatives in a previous calculus course, L’Hôpital’s Rule does not involve the “quotient rule.” The expression in L’Hôpital’s Rule is a quotient of derivatives, not a derivative of a quotient.
Notation.
We will use a “l’H” indicator over an equals sign between two limits when L’Hôpital’s Rule has been applied:
limtcf(t)g(t)=l'Hlimtcf(t)g(t).
Example 23.6.6.
In each of these, where L’Hôpital’s Rule has been applied you should verify that the preceding limit was a 0/0-form.
  1. We have
    limt1t21(t1)2=l'Hlimt12t2(t1)
    but this second limit does not exist because the denominator trends to 0 while the numerator does not.
  2. limt1(t1)2t21=l'Hlimt12(t1)2t=111=0
  3. limt1t21t1=l'Hlimt12t1=211=2
  4. limt0sin(t)t=l'Hlimt0cos(t)1=cos(0)1=1
Remark 23.6.7.
If the new limit you obtain after applying L’Hôpital’s Rule is still 0/0 form, you may apply the rule again. But if you apply it many times and still get 0/0 form every time, you might look for any patterns that might tell you whether you are actually making progress toward a final result.
Example 23.6.8. Applying L’Hôpital’s Rule multiple times.
In this example, the decreasing degree in the denominator as we repeatedly apply L’Hôpital’s Rule indicates that we will eventually come to a determinate form. Once again, where =l'H appears you should verify that the preceding limit was 0/0-form.
limt0tan(t)tt3=l'Hlimt0sec2(t)13t2=l'Hlimt02sec(t)(sec(t)tan(t))06t=limt02sec2(t)tan(t)6t=l'Hlimt0(2sec2(t))sec2(t)+(4sect(sec(t)tan(t)))tan(x)6=(2(1)2)(1)2+(41(10))06=13

Subsection 23.6.2 Other indeterminate forms

Recall that f(t)0 as tc means that for every input sequence (tn) that converges to c, the corresponding output sequence (f(tn)) converges to 0. So when we encounter a 0/0-form limit, it is (usually) not actually 0/0, it is a trend of f(tn)/g(tn) values with both f(tn)0 and g(tn)0. So instead of 0/0, it is better to think of this indeterminate form as “small over small”. And the reason this form is “indeterminate” is that we cannot reliably determine the result of “small over small”:
  • if the numerator becomes small faster than the denominator, then the ratio will become small
  • if the denominator becomes small faster than the numerator, then the ratio will become large
  • if the numerator and denominator become small at the same rate, then the ratio will be approximately constant.
Here are some other indeterminate limit forms.
Subsubsection / form
Definition 23.6.9. Indeterminate form /.
A limit of the form
limtcf(t)g(t)
where both f(t) and g(t) as tc.
Note 23.6.10.
We will also refer to a limit as / form if either or both of f and g trend to .
Similarly to the above discussion, we cannot reliably determine the result of “large over large” because there are multiple possible outcomes:
  • large ratio result if the numerator becomes large faster than the denominator
  • small ratio result if the denominator becomes large faster than the numerator
  • approximately constant ratio result if the numerator and denominator become large at the same rate.
We could apply L’Hôpital’s Rule for 0/0 form by first performing an algebraic manipulation: if
limtcf(t)g(t)
is / form, then
limtc1/g(t)1/f(t)
is 0/0 form, and the two limits are equivalent. Luckily, however, L’Hôpital’s Rule can be applied directly to an /-form limit.
Example 23.6.12.
Both et and t2 as t, so we may apply the /-form version of L’Hôpital’s Rule:
limtett2=l'Hlimtet2t=l'Hlimtet2=.
Warning 23.6.13.
We will repeat a previous warning: do not apply L’Hôpital’s Rule to limits to which it does not apply! For example, it would be incorrect to apply L’Hôpital’s Rule to the limit in Example 23.6.12 if it were for tinfty instead of t.
Subsubsection 0 form
Again this form of limit is indeterminate because we cannot reliably determine the result of “small times large”. (You are encouraged to run through the different possible outcomes on your own.)
Example 23.6.15.
The limit
limt0+tln(t)
is 0() form. So instead consider the equivalent limits
limt0+t1/ln(t)limt0+ln(t)1/t.
The first limit is now 0/0 form and the second is / form. If we applied L’Hôpital’s Rule to the first limit, the new limit would still have a logarithm in it because the derivative of 1/ln(t) would require a Chain Rule. However, the second limit will no longer have a logarithm after applying L’Hôpital’s Rule:
limt0+tln(t)=limt0+ln(t)1/t=limt0+ln(t)t1/2=l'Hlimt0+1/t(1/2)t3/2=limt0+2t1/2=0.
Subsubsection form
This is an indeterminate form because we cannot reliably determine the result of “large minus large”. (In this case, it is important that both “large” terms are “large and positive.”) Consider the possibilities:
  • large, positive difference result if the first term becomes large faster than the second
  • large, negative difference result if the second term becomes large faster than the first
  • approximately constant difference result if the two terms large at the same rate.
Example 23.6.17.
The limit
limtπ2tan(t)sec(t)
is an ()-form limit. We should not apply L’Hôpital’s Rule directly to this limit, because that rule does not apply. However, if we convert these trig functions into sines and cosines, we can manipulate the expression into a 0/0-form limit to which L’Hôpital’s Rule can be applied:
limtπ2tan(t)sec(t)=limtπ2sin(t)cost1cos(t)=limtπ2sin(t)1cost=l'Hlimtπ2cos(t)0sint=01=0.
Subsubsection Indeterminate forms involving exponents
Limits of the form
0001
are also indeterminate. (Remember: the “values” in these forms do not represent contant values, they represent results of output sequence trends.) For example, the output sequence values for the expression in a 1-form limit could be:
  • trending to 1 because the base values trend to 1, and 1a=1 for all values of a
  • becoming large if the base values trend to 1 from above, because the exponent is trending to large values, and a base greater than 1 raised to large exponent will create a large result
  • becoming small if the base values trend to 1 from below, because the exponent is trending to large values, and a base less than 1 raised to large exponent will create a small result.
As we have done in the past, we may exploit the algebraic properties of logarithms to help us deal with exponents.
Justification.
Because the exponential function is continuous, Pattern 23.5.2 tells us that
limtcg(t)=Llimtcexp(g(t))=exp(L).
Apply this pattern with g(t) replaced by ln(f(t)), noting that
exp(ln(f(t)))=f(t).
Example 23.6.19.
It seems like we should have
limt1tt=1,
but can we be sure? We don’t have any limit laws that directly address this situation. (Note that Pattern 23.5.4 does not apply here.)
Instead, let’s try to compute
limt1ln(tt)=limt1tln(t).
Since ln(t)0 as t1, we may apply the multiplicativity rule of Pattern 23.2.2 to determine
limt1tln(t)=10=0.
Therefore, Pattern 23.6.18 tells us that
limt1tt=e0=1.
Now we turn back to indeterminate forms involving exponents.
Example 23.6.21.
Consider
limx0+tt,
which is of 00 form. Applying Strategy 23.6.20, instead we compute
limt0+ln(tt)=limt0+tln(t).
This new limit is of 0() form, so we apply Strategy 23.6.14:
limt0+tln(t)=limt0+ln(t)1/t=l'Hlimt0+1/t1/t2=limt0+t=0.
Completing strategy Strategy 23.6.20, we have
limt0+tt=e0=1.
Example 23.6.22.
Consider
limt(1+t)1/t,
which is of 0 form. Applying Strategy 23.6.20, instead we compute
limtln((1+t)1/t)=limtln(1+t)t.
This new limit is of / form, so apply L’Hôpital’s Rule:
limtln(1+t)t=l'Hlimt1/(1+t)1=0.
Completing strategy Strategy 23.6.20, we have
limt(1+t)1/t=e0=1.
Example 23.6.23. Alternative characterization of Euler’s number.
Consider
limt0(1+t)1/t,
which is of 1 form. Applying Strategy 23.6.20, instead we compute
limt0ln((1+t)1/t)=limt0ln(1+t)t.
This limit is now of 0/0 form, but this time we don’t need to apply L’Hôpital’s Rule. Instead, let’s trade variable t for Δt:
limΔt0ln(1+Δt)Δt=limΔt0ln(1+Δt)0Δt=limΔt0ln(1+Δt)ln(1)Δt.
This last limit is precisely the limit form of the derivative of the logarithm function at t=1 (see Fact 23.5.21). Therefore,
limt0ln((1+t)1/t)=limΔt0ln(1+Δt)ln(1)Δt=d(ln(t))dt|t=1=1t|t=1=1.
From this we conclude
limt0(1+t)1/t=e1=e.
Remark 23.6.24.
The limit in the preceding example is sometimes taken as the definition of Euler’s number, and then Definition 9.3.1 is proved as a consequence.

Subsection 23.6.3 Justification

As is the case with many concepts in calculus, averages are the key. Recall that Mean Value Theorem says that a continuous function always achieves its average value at least once on a specific domain:
f(c)=favg=1baabf(t)dt
for at least one input c in the domain atb. If we apply this fact to a derivative function, then we obtain the following version of the Mean Value Theorem.
Justification.
For simplicity, we will justify this under the extra assumptions that the derivative function f(t) is defined and continuous on the closed interval atb. In that case the integral version of the Mean Value Theorem applies, and we can say that there is at least one input value t=c in the domain where
f(c)=1baabf(t)dt.
But f is an antiderivative of f, so we simply apply Pattern 13.6.2 to obtain
abf(t)dt=f(b)f(a).
Remark 23.6.26.
  • Note that the difference quotient
    f(b)f(a)ba
    is the average rate of variation of f over the domain atb (see Definition 1.3.3), and the derivative value f(c) represents the instantaneous rate of variation. So Theorem 23.6.25 really does represent the same information as the integral version of Mean Value Theorem: the differential form says that the rate-of-variation function f acheives its average value at least once.
  • It is not to difficult to justify Theorem 23.6.25 without making the extra assumptions that f(t) is defined and continuous on the closed interval atb. First one considers the special case that f(b)=f(a), and combines the Extreme Value Theorem with Pattern 18.2.10. Then, in the case f(b)f(a), one can reduce to the previous case by considering function d(t)=f(t)(t) where (t) represents the secant line between the points (a,f(a)) and (b,f(b)). We leave the details to you, the reader.
L’Hôpital’s Rule involves two functions in a ratio. If both the numerator function f and the denominator function g satisfy the hypotheses of the Differential form of the Mean Value Theorem, then there is some input t=c1 where f(c1) is equal to the average rate of f over the domain, and there is also some input t=c2 where g(c2) is equal to the average rate of g over the domain. Since f and g may be completely unrelated functions, there is no reason to think that these two input values are the same. But the following fact comes close to saying that we can take them to be the same input value.
Justification.
First we note that it is not possible for g(b)g(a)=0 to be true, which is important because if it were then our conclusion would be impossible. The Differential form of the Mean Value Theorem tells us that there is some input value t=d where
g(d)=g(b)g(a)ba.
If g(b)g(a)=0 were true, then the above would say that g(d)=0, but we have assumed that g(t) is never 0 on the domain in question.
We are looking for an input value t=c so that
f(c)g(c)=FG
for
F=f(b)f(a),G=g(b)g(a).
(Note that F and G are specific numbers, not functions.)
Now consider h(t)=Gf(t)Fg(t). Since f and g satisfy the hypotheses of the Differential form of the Mean Value Theorem, so does h, and so there is a input value t=c where
h(c)=h(b)h(a)ba.
But
h(b)h(a)=(Gf(b)Fg(b))(Gf(a)Fg(a))=G(f(b)f(a))F(g(b)g(a))=GFFG=0
So, in fact,
h(c)=0bah(c)=0Gf(c)Fg(c)=0Gf(c)=Fg(c)Gf(c)g(c)=FG
as desired.
Now we are in a position to justify L’Hôpital’s Rule.
Outline of justification of L’Hôpital’s Rule for 0/0 form.
Assume f and g are functions that satisfy the three conditions in Pattern 23.6.4. As discussed in Remark 23.1.7, the value of
limtcf(t)g(t)
does not depend on the values of f(c) and g(c), or even if these values are defined. So without loss of generality we may assume
f(c)=g(c)=0.
Using Fact 23.3.4, first let’s investigate the limit as tc+. So consider an input sequence (tn)c with tn>c for all n. Since this sequence approaches c, we may assume that it is contained within the domains of continuity and differentiability of f and g in the assumptions in the statement of L’Hôpital’s Rule. This means that Cauchy’s Mean Value Theorem applies to every domain cttn, and so for each n there exists an input value t=kn between c and tn for which
f(kn)g(kn)=f(tn)f(c)g(tn)g(c).
But recall that we have assumed f(c)=g(c)=0, so actually
f(kn)g(kn)=f(tn)g(tn).
So the sequences
(f(tn)g(tn))(f(kn)g(kn))
must both converge to the same limit or must both diverge in the same way. By the Sequence Squeeze Theorem, since ckntn and (tn)c, we also have (kn)c. So if
limtc+f(t)g(t)
exists, it must have the same limit value as the sequence (f(kn)/g(n)), which has the same limit value as the sequence (f(tn)/g(tn)), which has the same limit value as
limtc+f(t)g(t).
Having demonstrated that
limtc+f(t)g(t)=limtc+f(t)g(t),
and recognizing that a similar argument could be used to demonstrate the same for tc, we have our desired conclusion.