In this part, I will work through several numerical examples of decisions by an exponential discounter.
23.1 Example 1: $100 today or $110 next week
Alison is an exponential discounter with discount factor \delta=0.95 and utility each period of u(x_n)=x_n. She is offered two choices.
Choice 1: Would she prefer $100 today (t=0) or $110 next week (t=1)?
To determine this, we calculate the discounted utility of each option. Alison will prefer the option with the highest discounted utility.
We write the discounted utility of the $100 today as U_0(0,\$100). The subscript 0 indicates that the utility is calculated at time t=0. The first number in the brackets indicates the time the payment is received. In this case, the $100 is received at t=0, today. The second number in the brackets is the value of the payment.
The discounted utility of the $100 today, U_0(0,\$100), is:
There is no discount \delta applied to the $100 as it is received immediately.
We write the discounted utility of the $110 next week as U_0(1,\$110). The subscript 0 again indicates that the utility is calculated at time t=0. The first number in the brackets, 1, indicates the time the payment is received, t=1. The second number in the brackets is the value of the payment.
In this case, a discount of \delta=0.95 is applied to the $110 as it is received in one week.
We can now compare the discounted utility of each option. U_0(0,\$100)=100<104.5=U_0(1,\$110). Alison would prefer to receive $110 next week as it leads to higher discounted utility.
Figure 23.1 visualises the effect of discounting in Choice 1.
The two bars represent the options: $100 at t=0 and $110 at t=1. The line from the $110 option represents the discounted utility of that option at each time. At t=0 the discounted utility of the $110 received at t=1 is 104.5. At t=0 we can see that the $110 is preferred as the line indicating discounted utility is higher than the utility of the $100 received immediately.
Code
# Create a function to create the discounted bar chartlibrary(ggplot2)# Helper function to create discounted valuescreate_discount_data <-function(value, time, discount_rate, start) { times <-seq(start, time, by =1)data.frame(t = times,group =as.character(time),value = value * discount_rate^(time - times) )}# Main function to create the discounted bar chartcreate_discounted_bar_chart <-function(smaller, t_s, larger, t_l, discount_rate, starting_at =0, y_spacing =20, x_spacing =1) {# Create the data data <-data.frame(t =c(t_s, t_l),U_t =c(smaller, larger) )# Create the discounted values, starting from 'starting_at' discounted_data <-rbind(create_discount_data(smaller, t_s, discount_rate, starting_at),create_discount_data(larger, t_l, discount_rate, starting_at) )# Shift t values based on starting_at data$t_plot <- data$t - starting_at discounted_data$t_plot <- discounted_data$t - starting_at# Filter out any data points before the starting point data <- data[data$t >= starting_at, ] discounted_data <- discounted_data[discounted_data$t >= starting_at, ]# Determine x-axis and y-axis limits x_min <-0 x_max <-max(max(data$t_plot), max(discounted_data$t_plot)) y_max <-max(max(data$U_t), max(discounted_data$value)) *1.1# 10% buffer# Create the plotggplot() +# Add the barsgeom_rect(data = data, aes(xmin =ifelse(t_plot ==0, 0, t_plot -0.15),xmax =ifelse(t_plot ==0, 0.15, t_plot +0.15),ymin =0, ymax = U_t),fill ="white", color ="black") +# Add the discount linesgeom_line(data = discounted_data, aes(x = t_plot, y = value, group = group), color ="black", linewidth =1) +# Customize the plotscale_x_continuous(breaks =seq(x_min, x_max +1, by = x_spacing), limits =c(x_min, x_max +1),expand =c(0, 0),labels =function(x) x + starting_at) +scale_y_continuous(breaks =seq(0, y_max, by = y_spacing), limits =c(0, y_max),expand =c(0, 0)) +geom_vline(xintercept =0, linewidth =0.25) +geom_hline(yintercept =0, linewidth =0.25) +labs(x ="t",y =expression(U[t])) +theme_minimal() +theme(axis.title.y =element_text(angle =0, vjust =0.5),panel.grid.major =element_blank(),panel.grid.minor =element_blank() )}
Code
create_discounted_bar_chart(100, 0, 110, 1, 0.95)
Choice 2: Would Alison prefer $100 next week (t=1) or $110 in two weeks (t=2)?
Again, we calculate the discounted utility of each option. Alison will prefer the option with the highest discounted utility.
We can now compare the discounted utility of each option. U_0(1,\$100)=95<99.275=U_0(2,\$110). Alison would prefer to receive $110 in two weeks.
The set of decisions across Choice 1 and Choice 2 are time consistent. If Alison selected $110 in two weeks for Choice 2 and was given a chance to change her choice after one week (which is effectively Choice 1), she would not change her decision.
Figure 23.2 visualises the effect of discounting in Choice 2.
The two bars represent the options: $100 at t=1 and $110 at t=2. The line from each represents the discounted utility of that option at each time.
Code
create_discounted_bar_chart(100, 1, 110, 2, 0.95)
For example, at t=1 the discounted utility of the $100 received at t=1 is 100 and the discounted utility of the $110 received at t=2 is 104.50. We can read those values from the line. For any time t we can determine which option would be preferred by seeing which line is higher.
Code
# First, create the plot using the existing functionp <-create_discounted_bar_chart(100, 1, 110, 2, 0.95)# Calculate the y-intercept for the dashed liney_intercept <-110*0.95# 104.5# Add the dashed line and the label to the existing plotp_with_line_and_label <- p +geom_segment(aes(x =0, y = y_intercept, xend =1, yend = y_intercept),linetype ="dashed", color ="black") +geom_text(aes(x =0.2, y = y_intercept, label =sprintf("%.1f", y_intercept)),hjust =1, vjust =-0.2, size =3)# Display the modified plotprint(p_with_line_and_label)
You will note that the two lines do not cross. For an exponential discounter, if one line is higher at any particular time t, it is higher at all times.
Figure 23.4 visualises Choice 2 reconsidered at t=1, which as noted earlier, is effectively Choice 1. The discounted utility of the $100 received immediately is less than the discounted utility of $110 in one week. The preference for the higher-value option remains.
Brenda would be willing to wait a year for payment if she was paid more than $1440.03.
Figure 23.5 visualises this problem. The bar at t=52 represents the $1440.03 Brenda would need to be paid (at minimum) to prefer that payment to $100 today. The line extended from that bar back to t=0 indicates the discounted utility of that payment at any time t. At t=0 the discounted utility of the $1440.03 is equal to the utility of $100.
The discount factor \delta is applied 10 times as the payment is received in 10 days.
We can now compare the discounted utility of each option. U_0(5,\$10)=2.37>1.13=U_0(10,\$20). The discounted utility is higher for the $10 in five days. As a result, Chelsea will prefer to receive $10 in five days.
Dorothy is an exponential discounter with discount factor \delta=0.95 and utility each period of u(x_n)=x_n. Dorothy has a larger discount factor than Chelsea, meaning that she applies a smaller discount to future outcomes.
Would Dorothy prefer $10 in five days (t=5) or $20 in 10 days (t=10)?
The discounted utility of the $10 in five days is:
The discounted utility is higher for the $20 in 10 days. Dorothy will prefer to receive $20 in 10 days.
Figure 23.6 visualises the choices and Chelsea and Dorothy’s discounting of the payoffs.
In both charts, vertical bars represent the $10 in five days and $20 in 10 days. The lines projecting back to t=0 represent the discounted utility of those payoffs at each time.
When \delta=0.75, the heavy discount to the more distant payoff means that it has a lower discounted utility than the smaller, sooner payment of $10. When \delta=0.95, the discount is less severe and the $20 in 10 days has a higher discounted utility than the $10 in five days.