- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图学习 Scipy,将其用于混合集成和微分,但在最初的步骤中我遇到了以下问题。
对于数值微分,似乎唯一适用于可调用函数的 Scipy 函数是 scipy.derivative() 如果我是对的!?但是,我无法使用它:
1st) 当我不打算指定要进行微分的点时,例如当微分在积分下时,积分应该将数值分配给其被积函数的变量,而不是我。作为一个简单的例子,我在 Sage 的笔记本中尝试了这段代码:
import scipy as sp
from scipy import integrate, derivative
var('y')
f=lambda x: 10^10*sin(x)
g=lambda x,y: f(x+y^2)
I=integrate.quad( sp.derivative(f(y),y, dx=0.00001, n=1, order=7) , 0, pi)[0]; show(I)
show( integral(diff(f(y),y),y,0,1).n() )
它还发出警告“警告:检测到舍入误差的发生,这会阻止达到要求的公差。误差可能被低估了。”而且我不知道这个警告代表什么,因为即使增加“dx”和减少“order”它仍然存在。
2nd) 当我想在上面的例子中找到像 g(x,y) 这样的多变量函数的导数和像 sp.derivative(g(x,y),(x ,0.5), dx=0.01, n=1, order=3) 给出了错误,这是很容易预料到的。
期待收到您的来信,了解如何使用数值微分解决上述问题。最好的问候
最佳答案
您的代码存在一些奇怪的问题,这表明您需要温习一些 python!我不知道你是怎么在 python 中定义这些定义的,因为它们不是合法的语法。
首先,我认为您使用的是旧版本的 scipy。在最近的版本中(至少从 0.12+ 开始)你需要 from scipy.misc import derivative
。 derivative
不在 scipy 全局命名空间中。
其次,var
未定义,尽管无论如何都没有必要(我认为您打算先导入 sympy 并使用 sympy.var('y')
) . sin
也没有从 math(或 numpy,如果您愿意)中导入。 show
在 sympy 或 scipy 中不是有效函数。
^ 不是 python 中的幂运算符。你是说**
您在这里似乎混淆了符号和数值微积分运算的概念。 scipy 不会在数字上区分涉及符号对象的表达式——导数的第二个参数应该是你希望求导的点(即一个数字)。正如您所说,您正在尝试进行数值微分,我会为此目的解决问题。
from scipy import integrate
from scipy.misc import derivative
from math import *
f = lambda x: 10**10*sin(x)
df = lambda x: derivative(f, x, dx=0.00001, n=1, order=7)
I = integrate.quad( df, 0, pi)[0]
现在,最后一个表达式生成了您提到的警告,并且返回的值在绝对值 -0.0731642869874073 处不是非常接近于零,尽管相对于 f
的规模来说这还不错。您必须了解有限差分中的舍入误差问题。您的函数 f
在 0 到 10^10 之间的区间内变化!这可能看起来很矛盾,但是使微分的 dx
值太小实际上会放大舍入误差并导致数值不稳定。请参阅此处的第二张图(“显示由于舍入误差和公式误差而难以选择 h 的示例”)以获取解释:http://en.wikipedia.org/wiki/Numerical_differentiation
事实上,在这种情况下,您需要增加它,比如 0.001:df = lambda x: derivative(f, x, dx=0.001, n=1, order =7)
然后,您可以安全地集成,而不会出现可怕的舍入。
I=integrate.quad( df, 0, pi)[0]
我不建议丢弃 quad
的第二个返回值。这是对发生的事情的重要验证,因为它是“对结果绝对误差的估计”。在这种情况下,I == 0.0012846582250212652 并且绝对误差为 ~ 0.00022,这还不错(暗示的区间仍然不包括零)。也许对四边形的 dx 和绝对公差进行更多调整会给您带来更好的解决方案,但希望您能理解。
对于你的第二个问题,你只需要创建一个合适的标量函数(称之为 gx
)来代表 g(x,y) 沿 y=0.5(这在计算机科学中被称为 Currying) .
g = lambda x, y: f(x+y**2)
gx = lambda x: g(x, 0.5)
derivative(gx, 0.2, dx=0.01, n=1, order=3)
为您提供 x=0.2 处的导数值。自然地,鉴于 f
的规模,其值(value)是巨大的。您可以像我上面展示的那样使用 quad 进行集成。
如果你想对 g 本身进行微分,你需要一个不同的数值微分函数。我认为 scipy 或 numpy 不支持这一点,尽管您可以通过制作 2D 精细网格(大小 dx)并使用 numpy.gradient 来破解中心差异计算。可能还有其他我不知道的库解决方案,但我知道我的 PyDSTool 软件包含一个函数 diff
可以做到这一点(如果你重写 g 以取一个数组参数)。它使用 Ridder 的方法,并受到 Numerical Recipes 伪代码的启发。
关于Scipy 的数值微分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12168676/
我正在开发一个 Java 脚本,为此我需要正则表达式来检查文本框中输入的文本是否应该是字母和数值的组合。 我尝试了 Java 脚本的 NaN 函数,但字符串的最小长度和最大长度应为 4,并以字母作为第
我给出了两个长方体,其中只有一个轴对齐(另外两个不需要对齐)和顶点坐标(在全局坐标系中),我知道它们相交。我正在寻找一种可以计算路口体积的算法。 为了检查交点,我使用了分离轴定理。 最佳答案 可以通过
我有一个类似这样的对象的 json 列表 [{ "something": "bla", "id": 2 }, { "something": "yes", "id": 1
这是一篇很长的文章,但请留在我身边... 我有一个字典,它将“PO”保存为Key,将“SO”保存为项目(在某些情况下,某个“PO”可能有多个“SO”) . 工作表中的我的 Excel 数据,字典在其中
我的问题是是否有办法使用 terms include在 numeric field在 elasticsearch aggregation . 我在 Elasticsearch 中对多个字段使用通用查询
我有一个 perl 代码片段 use JSON::XS; $a = {"john" => "123", "mary" => "456"}; print encode_json($a),"\n"; 输出
我想对 python 进行一个条件测试,以检查给定输入数字的值是否等于或小于 9,并且大于或等于 0。 number =input( "Please enter a number! :" ) Plea
我有一个这样的对象: var rock = { 5: 0.5, 0: 0.8, 10: 0.3, 2: 1.0, } 我有一个像 4.3 这样的数字,我需要前后数字的索引和值。在这个例子中我会
对于 iOS 中的 Objective-C: 如果我有一个字符串,如何读取单个字符的 unicode 数值? 例如,如果我的字符串是:“Δ”,unicode 字符是 U+0394,那么我如何读取该字符
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我有这样的数组 var arrayVal_Int = ["21", "53", "92", "79"]; var arrayVal_Alpha = ["John", "Christine", "L
就像标题暗示我需要做这样的事情...... $i++;//we all know this. $value = 'a'; increment($value);// i need this functi
我有一个文件,其中包含一些不同值的概率,例如: 1 0.1 2 0.05 3 0.05 4 0.2 5 0.4 6 0.2 我想使用此分布生成随机数。是否存在处理此问题的现有模块?自己编写代码相当简单
因此,我在从使用 RCPP 创建的函数返回值时遇到了一些问题。它只返回 NumericVector 的第一个值。问题是当我在自身内部调用函数并将 NumericVector 传递回 out 变量时。任
我有下面的数字 vector 模板类(用于数值计算的 vector )。我正在尝试使编写 D=A+B+C 成为可能,其中所有变量都是 Vector 对象。 A、B 和 C 不应修改。我的想法是使用 V
本文实例讲述了mysql常用函数。分享给大家供大家参考,具体如下: 本文内容: mysql函数的介绍 聚集函数 avg count max
我正在尝试使用 python(无关)为我的公司自动化一些事情,这就是我的问题。首先,我正在从邮箱中的特定文件夹创建数据框。(到这里没问题)” RangeIndex: 36 entries, 0 to
我在让 Angular ng-if 工作时遇到了一些麻烦。我希望我的 DOM 元素之一在 $scope.week = 1 时消失。 在我的 Controller 中我设置了 $scope.week =
我正在阅读 Ingersoll、Morton 和 Farris 撰写的 Taming Text,但我不明白 solr 的数字 trie 实现如何帮助搜索文本?我对 solr.TrieField fie
这个问题已经有答案了: What is the difference between client-side and server-side programming? (3 个回答) 已关闭 9 年前
我是一名优秀的程序员,十分优秀!