In this lecture we calculate the convexity for an annual-paying bond.

We do it first by building up an Excel grid, showing how each element of convexity is calculated.

Because Excel (rather strangely) does not have its own built-in CONVEXITY function (similar to DURATION or MDURATION), we also cover how to build your own personal convexity function within Excel’s VBA development environment.

The code for that demonstration function, for you to copy and paste, can be found below:

Public Function AndysAnnualConvexity(dYTM As Double, _
                                     dCouponRate As Double, _
                                     iBondMaturity As Integer, _
                                     dFaceValue As Double) As Double
Dim dConvexity As Double
Dim dAnnualPayment As Double
Dim dPresentValue As Double
Dim dTotalPVs As Double
Dim dTotalConvexity As Double

dConvexity = 0
dAnnualPayment = 0
dPresentValue = 0
dTotalPVs = 0
dTotalConvexity = 0

Dim dCouponPayment As Double

dCouponPayment = dCouponRate * dFaceValue

Dim dYearCounter As Double

dYearCounter = 1

Do While dYearCounter <= iBondMaturity

    dAnnualPayment = dCouponPayment
    If dYearCounter = iBondMaturity Then
        dAnnualPayment = dAnnualPayment + dFaceValue
    End If
    dPresentValue = dAnnualPayment / _
                    (Application.WorksheetFunction.Power(1 + dYTM, dYearCounter))
    dTotalPVs = dTotalPVs + dPresentValue
    dConvexity = (1 / (Application.WorksheetFunction.Power(1 + dYTM, 2))) * _
                 (dPresentValue) * _
                 (Application.WorksheetFunction.Power(dYearCounter, 2) + dYearCounter)
    dTotalConvexity = dTotalConvexity + dConvexity
    dYearCounter = dYearCounter + 1

AndysAnnualConvexity = (dTotalConvexity / dTotalPVs)

End Function

In our next lecture, we will implement convexity to predict future bond prices.

The full YouTube playlist of Securities Investment 101 lecture videos can be found by clicking here.

Please read our disclaimer.


In a non-mathematical way, and before our next lecture on actually calculating convexity, we try to explain why convexity has to be taken into account, particularly for large interest rate moves in either direction.

At the limit, interest rates moving down have a proportionally larger and larger effect on bond prices. Similarly, interest rates moving up have a proportionally smaller and smaller effect on bond prices.

Taken together at the limit of infinitely small interest rate moves, these two effects create convexity in the bond price, when measured against changing interest rates.

The flat-sloped tangential line of Modified Duration will then tend to underestimate price moves up, when interest rates move down, and will tend to overestimate price moves down, when interest rates move up.

This is the calculus principle behind convexity.

In our next lecture, we will actually calculate convexity.

The full YouTube playlist of Securities Investment 101 lecture videos can be found by clicking here.

Please read our disclaimer.


The Importance of Macaulay’s Duration, Lecture 022, Securities Investment 101

November 29, 2013

In this lecture we discuss the importance of Macaulay’s Duration, particularly to anyone holding large bond portfolios. In passing, we show how and why zero coupon bonds have a duration identical to their maturities, and why the anticipated directional moves of interest rates are so critical to bond traders and pension fund managers. We also […]

Read the full article →

Introducing Duration, Lecture 020, Securities Investment 101

November 22, 2013

In the first of a series of videos, we begin to delve into the complex subjects of bond duration and bond convexity. This first lecture begins to introduce the topic of duration and why we need it to anticipate bond price changes after expected (or unexpected) changes in required market interest rates. Previous video, Money […]

Read the full article →

The Time Value of Money, Lecture 010, Securities Investment 101

June 8, 2013

To help understand how bonds and many financial products are priced, we need to understand the ‘Time Value of Money’. We discuss the underlying axiom of human action behaviour and motivation which lies under this mechanism, and then explain how present values and future values of money are related, and how to calculate one from […]

Read the full article →

Free Float Stock, Lecture 007, Securities Investment 101

May 30, 2013

In this lecture we describe what is meant by ‘free float’ stock, how it is defined, why it is a useful measure, and where it is used by index construction companies and exchanges for different purposes. We explain why free float capitalisation is different from total market capitalisation and which three groups are placed into […]

Read the full article →