IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 第三单元 用python学习微积分(二十一)功、平均值、概率 -> 正文阅读

[游戏开发]第三单元 用python学习微积分(二十一)功、平均值、概率

本文内容来自于学习麻省理工学院公开课:单变量微积分-功、平均值、概率-网易公开课

一、平均值

?

由之前学过课知道,对上图中曲线函数 f(x )积分 \int_{a}^{b} f(x) dx 即是求取求取在 x \in (a,b)区间中 x 轴到曲线 f(x) 之间包围的面积。

所以当曲线被分为n ( n \rightarrow \infty) 个长方形时,它的面积为\sum_{i=1}^{n} f(x_i)dx 约等于\int_{a}^{b} f(x) dx, 而显然 \frac{f(x_1)+f(x_2)+...f(x_n)}{n}为所有分出的小矩形平均的高, 而平均的高*底边长为图形面积。所以有\frac{f(x_1)+f(x_2)+...f(x_n)}{n} *(b-a) = \int_{a}^{b} f(x) dx , 另一个看法是

(f(x_1)+f(x_2)+...f(x_n)) \frac{(b-a)}{n}把曲线下 a 到 b 间的图形分成n份,每份取一个f(x)值, 而每份的底边长为 \Delta x = \frac{(b-a)}{n}, ( \frac{\Delta x}{b-a} = \frac{1}{n} )所以有(f(x_1)+f(x_2)+...f(x_n)) \Delta x \rightarrow_{\Delta x\rightarrow 0} = \int_{a}^{b} f(x) dx

\frac{f(x_1)+f(x_2)+...f(x_n)}{n} =\frac{1}{(b-a)} \int_{a}^{b} f(x) dx (连续平均值) = AVE( f ) (f(x)在 (a,b)区间的平均值)

例1: 求f(x) = c 的定积分在a,b的平均值

\frac{1}{b-a}\int_{a}^{b} cdx = \frac{1}{b-a}cx|_{a}^{b} = \frac{1}{b-a}(cb -ca) = c当然AVE(c) = c

例2:单位半圆上(半径为1)的平均高度

from sympy import *
import numpy as np 

import matplotlib.pyplot as plt 

fig = plt.figure()
ax = fig.add_subplot(1, 1, 1)
ax.spines['left'].set_position('zero')
ax.spines['bottom'].set_position('zero')
ax.spines['right'].set_color('none')
ax.spines['top'].set_color('none')
ax.xaxis.set_ticks_position('bottom')
ax.yaxis.set_ticks_position('left')
ax.set_aspect(1) 

def DrawXY(xFrom,xTo,steps,expr,color,label,plt):
    yarr = []
    xarr = np.linspace(xFrom ,xTo, steps) 
    for xval in xarr:
        yval = expr.subs(x,xval)
        yarr.append(yval)
    y_nparr = np.array(yarr) 
    plt.plot(xarr, y_nparr, c=color, label=label)    

def DrawInt(xFrom,xTo,steps,expr,color,plt, label=''):
    if(xFrom < 0 and xTo < 0):
        DrawIntNegative(xFrom,xTo,steps,expr,color,plt, label)
    else:
        if(xFrom > 0 and xTo > 0):
            DrawIntPostive(xFrom,xTo,steps,expr,color,plt, label)
        else:
            DrawIntNegative(xFrom,0,steps,expr,color,plt, label)
            DrawIntPostive(0,xTo,steps,expr,color,plt, label)
    
def DrawIntNegative(xFrom1,xTo1,steps,expr,color,plt, label=''):
    xFrom = 0 - xTo1
    xTo = 0 - xFrom1
    width = (xTo - xFrom)/steps
    xarr = []
    yarr = []
    area = 0
    xprev = xFrom
    yvalAll =  0
    xarr.append(0)
    yarr.append(0)
    for step in range(steps):
        yval = expr.subs(x,xprev)
        area += width * yval
        xarr.append(0-xprev)
        yarr.append(0-area)
        xprev= xprev + width
    plt.plot(xarr, yarr, c=color, label =label)
    
def DrawIntPostive(xFrom,xTo,steps,expr,color,plt, label=''):
    width = (xTo - xFrom)/steps
    xarr = []
    yarr = []
    area = 0
    xprev = xFrom
    yvalAll =  0
    xarr.append(0)
    yarr.append(0)
    for step in range(steps):
        yval = expr.subs(x,xprev)
        area += width * yval
        xarr.append(xprev)
        yarr.append(area)
        xprev= xprev + width
    plt.plot(xarr, yarr, c=color, label =label)    
        
def DrawRects(xFrom,xTo,steps,expr,color,plt, label=''):
    width = (xTo - xFrom)/steps
    xarrRect = []
    yarrRect = []
    area = 0
    xprev = xFrom
    yvalAll =  0
    for step in range(steps):
        yval = expr.subs(x,xprev + width)
        xarrRect.append(xprev)
        xarrRect.append(xprev)
        xarrRect.append(xprev + width)
        xarrRect.append(xprev + width)
        xarrRect.append(xprev)
        yarrRect.append(0)
        yarrRect.append(yval)
        yarrRect.append(yval)
        yarrRect.append(0)
        yarrRect.append(0)
        area += width * yval
        plt.plot(xarrRect, yarrRect, c=color)    
        xprev= xprev + width
        yvalAll += yval
    print('============================')    
    if len(label)!=0:
        print(label)    
    print('============================')
    print('width = ', width)
    print('ave = ', yvalAll / steps)
    print('area = ',area)
    areaFinal = (integrate(expr, (x,xFrom,xTo)))
    print ('area final = ',areaFinal)
    print ('ave final = ', areaFinal / (xTo - xFrom))

def TangentLine(exprY,x0Val,xVal):
    diffExpr = diff(exprY)
    x1,y1,xo,yo = symbols('x1 y1 xo yo')
    expr = (y1-yo)/(x1-xo) - diffExpr.subs(x,x0Val)
    eq = expr.subs(xo,x0Val).subs(x1,xVal).subs(yo,exprY.subs(x,x0Val))
    eq1 = Eq(eq,0)
    solveY = solve(eq1)
    return xVal,solveY

def DrawTangentLine(exprY, x0Val,xVal1, xVal2, clr, txt):
    x1,y1 = TangentLine(exprY, x0Val, xVal1)
    x2,y2 = TangentLine(exprY, x0Val, xVal2)
    plt.plot([x1,x2],[y1,y2], color = clr, label=txt)
    
def Newton(expr, x0):
    ret = x0 - expr.subs(x, x0)/ expr.diff().subs(x,x0)
    return ret

   
x = symbols('x')
expr = (1 - x**2)**0.5

DrawXY(-1,1,100,expr,'blue','y = (1-x^2)^0.5',plt)

expr = -((1 - x**2)**0.5)
DrawXY(-1,1,100,expr,'green','y = -(x^2-1)^0.5',plt)

plt.legend(loc='lower right')
plt.show()

?

图1

问题是求上图中蓝色的上半圆的平均 y 是多少?

带入公式:

\frac{1}{b-a}\int_{a}^{b} f(x)dx = \frac{1}{1-(-1)}\int_{-1}^{1} \sqrt {1-x^2}dx ........(a = -1, b=1)

这里注意 \int_{-1}^{1} \sqrt {1-x^2}dx 是上图蓝色半圆的面积,

半径为1, S半圆= \frac{ \pi r}{2} = \frac{ \pi }{2}

AVE(y) = \frac{1}{1-(-1)}\int_{-1}^{1} \sqrt {1-x^2}dx = \frac{\pi}{4}

例3:求上图中蓝色半圆中弧上的点对应弧长 \theta 的平均高度

?

图2

因为这个是个单位圆, 所以我们知道半径为1, 所以半圆的长度为 \pi, 而弧长的变化等于弧度的变化

所以 y = sin\theta ,这时如果把角度换到x轴,则面积等于\int_{0}^{\pi}sin\theta d\thetasin\theta的平均值为

\frac{1}{b-a}\int_{a}^{b} f(x)dx = \frac{1}{\pi}\int_{0}^{\pi}sin\theta d\theta = -\frac{1}{\pi}\cos\theta|_{0}^{\pi}= \frac{(-cos\pi +cos0)}{\pi} = \frac{2}{\pi}

x = symbols('x')
expr = sin(x)

DrawXY(0,np.pi,100,expr,'blue','y = sin(x)',plt)

plt.legend(loc='lower right')
plt.show()

?

图3

由 图3 可知这个图形平均的y值应该是小于半圆的,也就是说在 图1 中, 从半圆的弧上随机取一个点所对应的y值(y1),比在x轴上随机取一个点所对应的y值(y2) , y1<y2 的概率大于 y1 \geq y2

检查

print(2/np.pi>= np.pi/4)

False

二、带权重的平均值

公式: \frac{\int_{a}^{b}f(x)w(x)dx}{\int_{a}^{b}w(x)dx}

解释一、

首先是常数的带权重平均值

\frac{\int_{a}^{b}cw(x)dx}{\int_{a}^{b}w(x)dx} =\frac{c\int_{a}^{b}w(x)dx}{\int_{a}^{b}w(x)dx} = c 这个结果符合预期,毕竟常数的权重应该是一样的,所以带权重的常数的平均值还是常数

另, 老师举了个例子, 假如一个人先后以每股10刀 / 20刀/ 30刀买入某支股票,计算买入这支股票的平均购买价格的公式为(这里的这个权重就是数量):

\frac{10\times w_{10} + 20\times w_{20} + 30\times w_{30}}{w_{10} + w_{20} + w_{30}}

三、上一讲中女巫的坩埚问题:

?

这个锅是由一个抛物线 y=x^2旋转构成,顶部直径是2m, 高1m, 锅里装满水,共1600L,锅里面的水的初始温度为0摄氏度,当锅底100摄氏度时,锅的顶部温度为70摄氏度,并遵循公式 T = 100 - 30y ,问题时需要多少能量(能量=体积*温度<摄氏度>)来把锅底部加热到100摄氏度?

老师给的提示是,在锅里每一个平面(y=c)它的温度是个常数。

由于当锅的底部是100摄氏度,顶部是70摄氏度时,可以看出对于不同的高度,温度都不一样,所以只有用积分(圆盘法)来计算这个体积x温度

(上图代码请参考:https://zhuanlan.zhihu.com/p/479575377)

圆盘法体积:

老师的解法: \int_{0}^{1} T(\pi y)dy = \int_{0}^{1}(100-30y)\pi ydy = (50\pi y -10\pi y^2)|_{0}^{1} = 40\pi

换元到x: y = x^2; dy = 2xdx; 1>x>0

\int_{0}^{1}(100-30x^2)\pi x^2 *2x dx = \int_{0}^{1}2\pi x^3(100 - 30x^2)dx = 50\pi x^4 - 10\pi x^3|_{0}^{1}

= 40\pi ( deg * m^3 )(\frac{1cal}{deg*cm^3})(\frac{100cm}{m})^3

= 40\pi*10^6 cal

= 40\pi*10^3 kcal\approx125 \times 1000kcal

?

1块士力架大约250kcal , 所以大概需要500块士力架来加热这个坩埚

注意:温度是以y=?平面为常数,所以要对y做积分

计算坩埚底部加热到100摄氏度时的平均温度,这里需要考虑到水的体积的权重,

注意锅越靠近顶部面积越大(也就是权重越大)

AVE(T) = \frac{\int_{0}^{1}T \pi ydy}{\int_{0}^{1}\pi ydy} = \frac{40\pi}{\frac{\pi}{2}} = 80 deg.....w(y) = \pi y

四、概率

x = symbols('x')
expr = 1-x**2

DrawXY(-1,1,100,expr,'blue','y = 1 - x^2',plt)
DrawRects(0.5,1,100,expr,'b',plt, label='')
plt.legend(loc='lower right')
plt.show()

?

在区域 0<y < 1-x^2(上图蓝色曲线和 y=0 包围的部分) 随机取一个点 x,y), 求 P(x>0.5) ?(x>0.5的概率是多少)?这个其实就是算上面蓝色实心面积和总包围面积的比 ......

概率 = 部分/总体 ( probability = \frac{part}{whole} )

P(x>\frac{1}{2})=\frac{\int_{0.5}^{1} (1-x^2)dx}{\int_{-1}^{1} (1-x^2)dx} = \frac{(x-\frac{x^3}{3})|_{0.5}^{1}}{(x-\frac{x^3}{3})|_{-1}^{1}} = \frac{5}{32}

这里 w(x) = 1-x^2

老师的计算结果为 \frac{5}{18} ,和我的\frac{5}{32}不一样,python算下:

x = symbols('x')
expr = 1-x**2
print(integrate(expr, (x,0.5,1))/integrate(expr, (x,-1,1)))
print(5/32)

0.156250000000000

0.15625

我算的结果应该是对的....

求概率的一般公式:

a \leq x1 < x_2 \leq b

?

P(x_1<x<x_2) = \frac{\int_{x1}^{x2}w(x)dx}{\int_{a}^{b}w(x)dx} = \frac{PART}{WHOLE}

下节课将介绍更多概率的问题,比如一个人打靶,靶子旁边有另一个人,那他有多大的概率会打到那个人....?

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 21:25:47  更:2022-03-21 21:26:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 18:47:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码