积分从入门到放弃<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 ...
随机推荐
- angular 中自己常用的下拉框获取值方法
方法一 HTML页中 <select name="" id="if02" data-first-option="true" (chan ...
- 网络编程基础【day09】:堡垒机前戏(十一)
本节内容 1.堡垒机前戏 2.SSHClient 3.SFTPClient 一.堡垒机前戏 开发堡垒机之前,先来学习Python的paramiko模块,该模块机遇SSH用于连接远程服务器并执行相关操作 ...
- 【1】【leetcode-77】 组合
(典型,做过似曾相识但不熟悉,基本知道怎么做但调试了一个多小时各种错) 给定两个整数 n 和 k,返回 1 ... n 中所有可能的 k 个数的组合. 示例: 输入: n = 4, k = 2 输出: ...
- linux_网易云音乐安装
使用命令安装一些基本包$ sudo apt install devscripts equivs git
- C#中连接MySQL数据
小结一下MySQL在C#中是如何连接的,并做一些简单的选择(SELECT).插入( INSERT).更新( UPDATE).删除(DELETE ) (一)连接 a) Firstly, you shou ...
- ext.net gridlist选择内部元素时自动选择所在行
function changeSelection(id) { var index = 0; for (var i = 0; i < mcp_liststore.data.length; i++) ...
- DevExpress 之 GridControl 自定义列
Ø 前言 DevExpress 控件大家应该都有所了解,使用这个框架实现B/S或C/S的,都是非常出色的.本文主要讨论下 GridControl 中如何[自定义列]或[计算列],可使用以下两种方法实 ...
- JavaSE回顾及巩固的自学之路(二)——————进入JavaSE
好的.今天接着上一篇文章对JavaSE的历程初步介绍,开始对JavaSE的技术性知识进行探讨. 首先,选择编程,成为一名程序员,应该会了解一些计算机的相关基础知识,毕竟,以后就是和计算机打交道了嘛.s ...
- 随机生成10元素数组并找出最大元素(Java)
package day01; import java.util.Arrays; import java.util.Random; public class MaxOfArray { public st ...
- 遍历页面上的checkbox
$("#Button1").click(function () { $("input[type='checkbox']").each(function () { ...