积分从入门到放弃<2>
这部分重新从定积分学了
1,lnx 的导数就是x^(-1) = 1/x
那么求∫(1/x)dx = ln|x|+C
2,初值问题.就是求∫f(x)dx = F(x) + C 求C
.
3,Houdini体积映射:
#define PI 3.1415926 vector gmin ;
vector gmax ;
getbbox(,gmin,gmax); // get sphere radius
float R = gmax.x - gmin.x;
//printf("gmax.x / gmaxmin : %f,%f \n", gmax.x, gmin.x);
float r = R / 2.000f; vector center = (gmax + gmin)/;
int segments = ;
float dx = R / segments; function float cylinder_volume(float r ; float h)
{
return PI * r *r * h;
} float v = 0.0f;
for(int i=;i<segments;i++)
{
float ci = lerp(-r, r ,1.0f/segments * i);
float cylinder_r = sqrt(r*r - ci*ci);
//printf("r/ci/cylinder_r %f/%f/%f \n" ,r, ci , cylinder_r);
float cl_volume = cylinder_volume(cylinder_r, dx);
v += cl_volume;
}
//printf("volume is %f \n" , v);
setdetailattrib(geoself(),"volume",v);
下图可以看到体积小的是黑色.虽然方法积的是圆柱形,最终为球,为了学习积分,没用球的方程
两条曲线之间的面积:
A = ∫ [f(x)-g(x) ] dx 积分上限b,下限a
数值积分:
有时候不知道反导数怎么求?梯形法,simpson法
曲线积分:求曲线长度:
求普通曲线的长度:
L = ∫ [sqrt(1+dx/dy)^2 ] dy 或者 L=∫ [sqrt(1+dy/dx)^2] dx
求参数方程如图:
x= cos^3t
y = sin^3t
0<= t <= 2π
解方法就是:
√ [(dx/dt)^2 + (dy/dt)^2]
float pi = 3.141596;
float t = fit(@ptnum,,@numpt-,,) * * pi;
@P.x = cos(t) * cos(t) * cos(t);
@P.y = sin(t) * sin(t) * sin(t);
HoudiniCode
蒙特卡洛求PI
曲线下的面积/矩形面积 = 曲线下的总点数/随机点的总数
<1>求PI
import random,math import numpy as np
import matplotlib.pyplot as plt N = 100000
distance = lambda x, y: math.sqrt(x * x + y * y) np.random.seed(100)
x = np.random.uniform(-1,1,N)
np.random.seed(200)
y = np.random.uniform(-1,1,N) def Monte_carlo_PI():
hitNum = 0
for index in xrange(0,N,1):
if distance(x[index],y[index]) <=1 :
hitNum += 1
proportion_seed = float(hitNum)/float(N)
return proportion_seed * 4 if __name__ == "__main__":
print Monte_carlo_PI() fig = plt.figure(figsize=(10,10)) ax = fig.add_subplot(111)
ax.spines['top'].set_color('none')
ax.spines['right'].set_color('none')
ax.xaxis.set_ticks_position('bottom')
ax.spines['bottom'].set_position(('data', 0))
ax.yaxis.set_ticks_position('left')
ax.spines['left'].set_position(('data', 0)) #plt.plot(xs,ys,'r')
#plt.scatter(0, 0, s=100000)
circle2 = plt.Circle((0, 0), 1, color='r',alpha = 0.5)
ax.add_patch(circle2) plt.scatter(x, y,s=1,c="black")
plt.grid(True)
plt.show()
python_mente_claro
功:
弹簧做功:弹簧的积分区域一定是变化了多少,从0开始积分变化了多少。如下
1,弹簧系数: 把弹簧从自然长度2米拉到5米做功为1800焦耳,求弹簧的弹力系数.
弹簧力是:F = kx (系数*变化的距离)
弹簧做功:∫F(x)dx 积分阈为[0,变化长度]
所以W ∫F(x)dx = k/2 * x^2 [0,3]
W(3) - W(0) = 1800 ,k = 400牛顿/米
抽水做功:
第一步(薄片体积) : ΔV = PI * r^2 Δy 这里薄片体积表示为圆柱
第二步(薄片力) : F(y) = ΔV * 比重
第三步(薄片需要的功) : ΔW = 力 X 力的作用距离 = F(y) * (距离-y)
第四步(黎曼和总功) : w =Σ ΔW
矩和质心
....
积分从入门到放弃<2>的更多相关文章
- CYQ.Data 从入门到放弃ORM系列:开篇:自动化框架编程思维
前言: 随着CYQ.Data 开始回归免费使用之后,发现用户的情绪越来越激动,为了保持这持续的激动性,让我有了开源的念头. 同时,由于框架经过这5-6年来的不断演进,以前发的早期教程已经太落后了,包括 ...
- [精品书单] C#/.NET 学习之路——从入门到放弃
C#/.NET 学习之路--从入门到放弃 此系列只包含 C#/CLR 学习,不包含应用框架(ASP.NET , WPF , WCF 等)及架构设计学习书籍和资料. C# 入门 <C# 本质论&g ...
- OpenStack从入门到放弃
OpenStack从入门到放弃 目录: 为何选择云计算/云计算之前遇到的问题 什么是云计算 云服务模式 云应用形式 传统应用与云感知应用 openstack及其相关组件介绍 flat/vlan/gre ...
- 绕过校园网的共享限制 win10搭建VPN服务器实现--从入门到放弃
一.开篇立论= =.. 上次说到博主在电脑上搭建了代理服务器来绕过天翼客户端的共享限制,然而经过实际测试还不够完美,所以本着生命不息,折腾不止的精神,我又开始研究搭建vpn服务器= =... (上次的 ...
- 《区块链:从入门到放弃》之obc安装步骤
obc安装步骤 朋友们可能会好奇,厨师不研究菜谱怎么改研究兵法了,哈哈,我原本是app出身,最近被安排去预研区块链和比特币技术,2个月下来,颇有斩获.期间得到IBM的CC同学指导我一步一步安装obc的 ...
- win10搭建代理服务器实现绕过校园网的共享限制--从入门到放弃
博主所在学校特别坑爹,校园网被电信一家垄断了,而且最恶心的还是电信要求一条网线只能供一台电脑上网,不许接路由器共享网络= =- (还有电信2M价格是380+每年,20m是500每年,而且网速都很慢= ...
- WPF从入门到放弃系列第二章 XAML
本文是作者学习WPF从入门到放弃过程中的一些总结,主要内容都是对学习过程中拜读的文章的整理归纳. 参考资料 XAML 概述 (WPF):https://msdn.microsoft.com/zh-cn ...
- Android -- 带你从源码角度领悟Dagger2入门到放弃
1,以前的博客也写了两篇关于Dagger2,但是感觉自己使用的时候还是云里雾里的,更不谈各位来看博客的同学了,所以今天打算和大家再一次的入坑试试,最后一次了,保证最后一次了. 2,接入项目 在项目的G ...
- Android -- 带你从源码角度领悟Dagger2入门到放弃(二)
1,接着我们上一篇继续介绍,在上一篇我们介绍了简单的@Inject和@Component的结合使用,现在我们继续以老师和学生的例子,我们知道学生上课的时候都会有书籍来辅助听课,先来看看我们之前的Stu ...
随机推荐
- 列举一些 MacBook Pro 必需的外设和应用程序推荐
来源:知乎 文章收录于:风云社区SCOEE,提供上千款mac软件下载 基于从事Apps设计或开发者,使用 MacBook Pro,以下罗列一些必需的外设和应用程序推荐. Retina 256GB SS ...
- Mac 软件专题:教学参考工具软件-外语/医学/天文/地理/数学等
今天和大家分享mac软件专题:教学参考工具软件,在这个专题中,主要向大家推荐一些Mac上优秀的教育教学.知识参考类的软件,包含外语.医学.天文.地址.数学.音乐等方面,学生.老师以及相关的工作者不要错 ...
- Java基础构造方法和this关键字整理
构造方法 8.1构造方法介绍 构造方法的格式: 修饰符 构造方法名(参数列表) { } l 构造方法的体现: n 构造方法没有返回值类型.也不需要写返回值.因为它是为构建对象的,对象创建完,方法就 ...
- java类的编译、加载和执行
一.java类的编译流程 这里主要讲的是从java文件到class文件 下图是java类编译的详细步骤: 1.词法分析:将java源代码的字符流转变为标记(Token)的集合,Token是编译过程中的 ...
- Java Bean的规范
什么是Java Bean? Java Bean就是遵循了某种规范的类,所以Java Bean就是一个类,只不过遵循了某种规范而已. Java Bean的规范 就是这么简单,下面就是一个标准的Java ...
- synchronized和volatile的区别
但是volatile不适合做计数器使用,即使他具有可见性,但是它不具有原子性.不能保证数据的一致性. 但是volatile适合哪种场景呢? 比较适合做一些标示.比如说两个线程,线程B必须得等线程A执行 ...
- Shell编程(四)Shell变量
1. 自定义变量(仅在当前shell生效) 1.1 定义变量 #!/usr/bin/bash ip=115.239.210.27 if ping -c1 $ip &>/dev/null ...
- API(Scanner、Random、ArrayList、String、Arrays、Math)
Scanner import java.util.Scanner; /* public int nextInt(): to get a integer from keyboard public Str ...
- CSS 快速学习
[快速学习让我不再思考太多,更多专注在一个 box 当中,上下文朝着正交方向前进~] [Think small,]https://learnxinyminutes.com/docs/zh-cn/css ...
- 【解题报告】SRM-08
A Description 给一个 01 串设为其 S,询问是否存在只出现两次的 01 串 T. 这里的出现定义为存在一串下标 ,满足 且 . Input 一行,一个 01 串 Output 一行, ...