import numpy as np
import matplotlib.pyplot as plt
np.random.seed(0)
def f(x): # 求f(x)在2-3之間的定積分
return x ** 2
def f0():
def intf(x): # 原函數
return x ** 3 / 3.0
exactVal = intf(2) - intf(0)
return exactVal
def f1():
def g(x):
return 1 / 2
def z(x): # f(x)/g(x)
return f(x) / g(x)
a = 0
b = 2
N = 10000 # 一萬次實驗
X = np.random.uniform(low=a, high=b, size=N) # 利用均勻分布隨機生成N個區間為【a,b】的數
Y = z(X) # 帶入函數f(x)計算對應y值
return np.sum(Y) / N # 計算N次結果的均值
def f2():
def g(x):
return x / 2.0
def z(x): # f(x)/g(x)
return f(x) / g(x)
a = 0
b = 2
N = 10000 # 一萬次實驗
X = np.random.uniform(low=a, high=b, size=N) # 利用均勻分布隨機生成N個區間為【a,b】的數
Y = z(X) # 帶入函數f(x)計算對應y值
return np.sum(Y) / N # 計算N次結果的均值
def f3():
def g(x):
return 3 * x * x / 8.0
def z(x): # f(x)/g(x)
return f(x) / g(x)
a = 0
b = 2
N = 10000 # 一萬次實驗
X = np.random.uniform(low=a, high=b, size=N) # 利用均勻分布隨機生成N個區間為【a,b】的數
Y = z(X) # 帶入函數f(x)計算對應y值
return np.sum(Y) / N # 計算N次結果的均值
print(f0())
print(f1())
print(f2())
print(f3())
"""
2.6666666666666665
2.642675506081223
1.980958484741736
2.666666666666666
問題: f2() 為什么會比 f1() 差一些呢? 如何痕量選擇最佳的 q(x) 函數
"""