- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 fmin_l_bfgs_b 来近似函数的最小值。问题是没有界限的。我使用“approx_grad”来获得最小值。
weights_sp_new, func_val, info_dict = fmin_l_bfgs_b(func_to_minimize, self.w_vectors[si][pj],
args=(self.sigma_vector[si][pj], Y, X, E_step_results[si][pj]),
approx_grad=True, factr=10000000.0, pgtol=1e-05, epsilon=1e-04)
我在相同的目标函数上尝试了不同的初始猜测。输出的信息字典如下:
information dictionary: {'nit': 180, 'funcalls': 4480, 'warnflag': 0,
'task': b'CONVERGENCE: REL_REDUCTION_OF_F_<=_FACTR*EPSMCH',
'grad': array([ 1.69003327e+00, 2.29250366e+00, 1.55528930e+00,
9.84251656e-01, -1.10133624e-02, 1.83795773e+00,
6.44715933e-01, 2.01643592e+00, 8.71323232e-01,
9.93009353e-01, 1.34615338e+00, 4.20859578e-04,
-2.22691328e-01, -2.13318804e-01, -4.38475622e-01,
4.79004570e-01, -4.11879746e-01, 1.71003313e+00])}
information dictionary: {'nit': 0, 'funcalls': 20, 'warnflag': 0,
'task': b'CONVERGENCE: NORM_OF_PROJECTED_GRADIENT_<=_PGTOL',
'grad': array([ 1.84672949e-20, 1.49550746e-20, 1.11115003e-20,
2.73908962e-20, 0.00000000e+00, 2.62916240e-20,
0.00000000e+00, 4.95859400e-20, 4.70618521e-20,
4.77249742e-20, 2.80864703e-20, 0.00000000e+00,
1.84975333e-21, 7.63125358e-21, 1.35733459e-20,
6.34943656e-21, 1.02743864e-20, 5.31287405e-20])}
information dictionary: {'nit': 107, 'funcalls': 2460, 'warnflag': 0,
'task': b'CONVERGENCE: REL_REDUCTION_OF_F_<=_FACTR*EPSMCH',
'grad': array([ -3.09184019, -0.70217764, 0.72096009, -3.23745189,
-1.18111435, -4.13185742, 3.90762754, 2.28011806,
-3.02289147, -1.21219666, 1.80007832, -12.44630606,
-1.59126124, 1.59139978, -1.96677574, -0.50837465,
1.20439043, -1.58858602])}
information dictionary: {'nit': 132, 'funcalls': 2980, 'warnflag': 0,
'task': b'CONVERGENCE: REL_REDUCTION_OF_F_<=_FACTR*EPSMCH',
'grad': array([ -8.56568098, -9.39712794, -8.82591339, -8.61912864,
-0.53956945, -9.46679887, 0.89827947, -10.64991782,
-6.53652169, -7.34566878, -8.98861319, 1.28335021,
-2.39830071, -1.2056133 , -0.81190425, -1.3537686 ,
-1.65028498, -8.30791505])}
可以看到它成功收敛了。但最小值的梯度不为零。我知道这意味着我没有得到确切的最小值。还可以进一步下降。我现在应该怎么做?或者我可以接受这个“近似的”最小值吗?
最佳答案
提供的示例中有两种情况:
第二次运行算法收敛得很好,b'CONVERGENCE: NORM_OF_PROJECTED_GRADIENT_<=_PGTOL'
正如你所看到的
'grad': array([ 1.84672949e-20, 1.49550746e-20, 1.11115003e-20, 2.73908962e-20, 0.00000000e+00, 2.62916240e-20, 0.00000000e+00、4.95859400e-20、4.70618521e-20、 4.77249742e-20、2.80864703e-20、0.00000000e+00、 1.84975333e-21、7.63125358e-21、1.35733459e-20、 6.34943656e-21、1.02743864e-20、5.31287405e-20])
基本上为零(最多 20 位精度)。
其余案例因函数值没有显着变化而终止,b'CONVERGENCE: REL_REDUCTION_OF_F_<=_FACTR*EPSMCH'
,因此您可以执行以下一项(或多项)操作:
减少factr
fmin_l_bfgs_b
的参数,来自文档
factr : float
The iteration stops when (f^k - f^{k+1})/max{|f^k|,|f^{k+1}|,1} <= factr * eps, where eps is the machine precision, which is automatically generated by the code. Typical values for factr are: 1e12 for low accuracy; 1e7 for moderate accuracy; 10.0 for extremely high accuracy.
想想你的功能,也许可以简化一下?它是否存在平台问题(非常平坦的表面) - 如果是这样,也许您可以改变定义以尽量减少影响?
epsilon
因为您的数值近似可能不够关于python - fmin_l_bfgs_b 输出的最小值处的梯度不为零,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34547907/
我在使用 Android 时遇到了一点问题。 我有我的 GPS 位置,明确的经纬度,以及以米为单位的搜索射线(例如 100 米),可以吗? 想象一下我在射线形成的圆心的位置,我会知道如何在 Andro
深夜的编程之旅 这是一个深夜,街头灯光昏暗,大部分人都已陷入梦乡。但对于我来说,这却是一个灵感迸发的时刻。窗外的星空仿佛在诉说着某种宇宙的密码,而键盘下的代码则是我解密这个宇宙的工具。 一个突如其来的
我将数据集结构定义为 struct Dataset: Hashable { var x: Double var y: Double } 然后是数组 var dataset: [Data
我在 Excel 文件中有一个摘要选项卡,需要查看应计选项卡才能找到 Max和 Min .我遇到的问题是有许多不同的位置/商品组合,我需要找到 Max和 Min基于位置/商品组合。位置和商品位于两个单
我有一个 Excel 表,其中包含两列感兴趣的年份和捐款。年份值为 2008,2009,2010 等... 我想获得 2009 年所有捐款中的最低金额。我试过了 MIN(IF(Year="2009",
到现在为止,我刚刚找到了为列表中多个数据帧中的列获取最大值的解决方案。 我已经将数据帧 df1, df2, df3, ..., dfn 存储在列表 dfList 中,我想获取列 df_ 的最大值$a
假设我有一个列名列表作为向量: vec=c("C1" , "C2" ,"C3"). 我知道这些列名来自数据框 df: df: C1 C2 C3 C4 C5 1 2 3 4 5 1 4
我需要计算大数组的最小值/最大值。我知道Math.max.apply() ,但在大型数组上,它会因堆栈溢出异常而失败。有什么简单的解决方案吗? 最佳答案 使用 sort() 对数组进行排序方法它使用快
例如,我有一个像这样的模型: class Record(models.Model): name = CharField(...) price = IntegerField(...)
我正在编写一个用于测试听力的简单应用,并且正在使用Audiotrack生成纯音。因为它是用于测试听力的应用程序,所以我使用非常低的音量来播放这些音调。 要设置音量,我使用音轨的 setVolume(f
Example data set 对,上面是我的数据集子段图像的链接。它以 3 列为一组,第一个是浓度,第二个是限定值,最后一个是 MDL - 并持续最多 95 个 sample (因此总共 285
我想计算 df 的每 n 行的最小值/最大值,比如 10,但是使用 df.rolling(10).max() 给出第 0-9、1-10、2-11 行的值等。我想要 0-9、10-19、20-29 等
我被问到了关于 c# 的同样问题 here我发现通过使用 linq 你可以轻松地做到这一点。 但是既然 java 中的 linq 没有其他选择,我该如何简单地做到这一点呢? 最佳答案 如果您想要类似于
我曾经使用过数组,并且知道如何对使用数值(double 和 int)的数组进行排序,但我必须使用字符串数组制作相同的应用程序。我的教授不允许我发挥“创造力”,也不允许我与其他可能有助于完成这项工作的静
我想知道通过这样的回溯获得某些事实的最大值(最年长的人)是否是个好主意: data(MaxID, MaxName, MaxAge), \+ (data(ID, Name, Age), ID \= Ma
我想计算 df 的每 n 行的最小值/最大值,比如 10,但是使用 df.rolling(10).max() 给出第 0-9、1-10、2-11 行的值等。我想要 0-9、10-19、20-29 等
我的数据如下所示: df <- tribble( ~A, ~B, 0.2, 0.1, 0.2, 0.3, 0.5, 0.1, 0.7, 0.9,
我有以下数据集 Date Category 2014-01-01 A 2014-01-02 A 2014-01-03 A 2014-01-04
我是使用 Python 进行数据分析的初学者,并且坚持以下几点: 我想使用广播/矢量化方法从各个列 (pandas.dataframe) 中找到最大值(value)。 我的数据框的快照如下: 最佳答案
C99 中是否有一个标准函数来使用给定的比较函数获取给定数组中的最小/最大元素。 类似: void* get_min(void* start,size_t size,size_t elementSiz
我是一名优秀的程序员,十分优秀!