Integrate a function from 0 to 1 using the Sample Mean Monte Carlo algorithm
Sample Mean Monte Carlo integration can compute
\(I=\int_0^1 f(x) dx\)
by drawing random numbers \(x_i\) from Uniform(0, 1) distribution and
average the values of \(f(x_i)\). As \(n\) goes to infinity, the sample
mean will approach to the expectation of \(f(X)\) by Law of Large Numbers.
The height of the \(i\)-th rectangle in the animation is \(f(x_i)\) and
the width is \(1/n\), so the total area of all the rectangles is \(\sum_{i=1}^{n}\frac{1}{n}f(x_i)\), which is just the sample mean. We can compare the area of
rectangles to the curve to see how close is the area to the real integral.
library(animation)
ani.options(interval = 0.2, nmax = 50)
par(mar = c(4, 4, 1, 1))
## when the number of rectangles is large, use border = NA
MC.samplemean(border = NA)$est
## [1] 0.1638
integrate(function(x) x - x^2, 0, 1)
## 0.1667 with absolute error < 1.9e-15
## when adj.x = FALSE, use semi-transparent colors
MC.samplemean(adj.x = FALSE, col.rect = c(rgb(0, 0, 0, 0.3), rgb(1, 0, 0)), border = NA)
## another function to be integrated
MC.samplemean(FUN = function(x) x^3 - 0.5^3, border = NA)$est
## [1] 0.09573
integrate(function(x) x^3 - 0.5^3, 0, 1)
## 0.125 with absolute error < 2.4e-15
Donate
As a freelancer (currently working as a contractor) and a dad of three kids, I truly appreciate your donation to support my writing and open-source software development! Your contribution helps me cope with financial uncertainty better, so I can spend more time on producing high-quality content and software. You can make a donation through methods below.
-
Venmo:
@yihui_xie, or Zelle:xie@yihui.name -
Paypal
-
If you have a Paypal account, you can follow the link https://paypal.me/YihuiXie or find me on Paypal via my email
xie@yihui.name. Please choose the payment type as “Family and Friends” (instead of “Goods and Services”) to avoid extra fees. -
If you don’t have Paypal, you may donate through this link via your debit or credit card. Paypal will charge a fee on my side.
-
-
Other ways:
WeChat Pay (微信支付:谢益辉) Alipay (支付宝:谢益辉) 

When sending money, please be sure to add a note “gift” or “donation” if possible, so it won’t be treated as my taxable income but a genuine gift. Needless to say, donation is completely voluntary and I appreciate any amount you can give.
Please feel free to email me if you prefer a different way to give. Thank you very much!
I’ll give back a significant portion of the donations to the open-source community and charities. For the record, I received about $30,000 in total (before tax) in 2024-25, and gave back about $15,000 (after tax).