Python 中的二维优化(最小化)(使用 scipy.optimize)

2023-12-12

我正在尝试优化(最小化)二维函数E(n,k)定义如下:

error=lambda x,y,w: (math.log(abs(Tformulated(x,y,w))) - math.log(abs(Tw[w])))**2 + (math.atan2(Tformulated(x,y,w).imag,Tformulated(x,y,w).real) - math.atan2(Tw[w].imag,Tw[w].real))**2

where Tformulated得到如下:

def Tformulated(n,k,w):
    z=1j
    L=1
    C=0.1
    RC=(w*L)/C
    n1=complex(1,0)
    n3=complex(1,0)
    n2=complex(n,k)
    FP=1/(1-(((n2-n1)/(n2+n1))*((n2-n3)/(n2+n3))*math.exp(-2*z*n2*RC)))
    Tform=((2*n2*(n1+n3))/((n2+n1)*(n2+n3)))*(math.exp(-z*(n2-n1)*RC))*FP
    return Tform

and Tw是先前计算的具有复值元素的列表。 我真正想做的是对于每个值w(用于“错误 x,y,w ....”)我想最小化函数“错误”的值x & y. w范围从 1 到 2048。所以,它基本上是一个 2D 最小化问题。我已经尝试过编程(尽管我陷入了使用什么方法以及如何使用它的困境);我的代码如下:

temp=[]
i=range(5)
retval = fmin_powell(error , x ,y, args=(i) , maxiter=100 ,maxfun=100)
temp.append(retval)

我不确定即使fmin_powell是正确的方法。


这是一个最简单的例子:

from scipy.optimize import fmin

def minf(x):
  return x[0]**2 + (x[1]-1.)**2

print fmin(minf,[1,2])

[out]:

Optimization terminated successfully.
         Current function value: 0.000000
         Iterations: 44
         Function evaluations: 82
[ -1.61979362e-05   9.99980073e-01]

这里可能存在的问题是最小化例程需要一个列表作为参数。看the docs对于所有血淋淋的细节。不确定是否可以直接最小化复值函数,您可能需要分别考虑实部和虚部。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Python 中的二维优化(最小化)(使用 scipy.optimize) 的相关文章

随机推荐

  • 如何读取cakephp视图文件中的cookie值

    在此我将 cookie 值写入控制器文件中 我想读取视图文件中的 cookie 值 而不是如何可能 您必须在控制器中读取它并设置该值以使其可用于视图 this gt set myValue this gt Cookie gt read co
  • Azure SQL 使用 PowerShell 和 ServicePrincipal 为 AD 用户授予访问权限

    我尝试为 Azure SQL Server 创建用户 我想使用 AzureAD 用户 这是代码 accessToken az account get access token resource https database windows
  • 我需要使用 VBA 将数据从 Excel 导入到 SQL Server

    我正在尝试将数据从我的 PC 上的另一个 Excel 工作簿导入到 SQL Server 我尝试使用这段代码 但它不起作用 Sub insertion Dim conn As ADODB Connection Dim rs As ADODB
  • 以二进制形式设置权限

    我在学校看到一个使用二进制字符串设置权限的系统 假设 101001 41 So 1可以是第1页的权限 2 可以是第2页的权限 4 可以是第3页的权限 8可以是第4页的权限 16可以是第5页的权限 32可以是第6页的权限 假设我得到了上面的二
  • 阿卡。安卓。 NoSuchMethodException:

    当我在 Android 上运行使用 Akka 的应用程序时 我收到以下异常 04 29 16 13 06 235 E AndroidRuntime 8968 java lang RuntimeException Unable to star
  • 仅从字符串中提取数字

    据说我有一个包含以下内容的字符串 hello 14 12 现在我只想提取数字 并在两个变量中有两个单独的值 如下所示 first num值应该是int 即first num 14 第二个变量应该存储冒号后面的数字 即 Second num
  • 如何在 Swift 中制作可设计的 UIImage

    我是初学者 我想制作一个 swift 文件 其中包含制作可设计 UIImage 的代码 因此我不会通过编码来编辑 UI 元素显示 只需在界面构建器中将此 swift 文件分配给 UI 类即可 我可以在 UIButton 中做类似的事情 例如
  • 每个key必须是一个数字字符串;得到未定义的量角器

    我正在尝试从 json 文件读取数据 但遇到了一些问题 如何将 json 文件中的项目获取到单个项目 我的 json 文件 UserName email protected Password tests123 我的方法 element by
  • 无法从 http 端点消费

    下面给出了我的路线 我正在尝试使用 HTTP 组件交换数据 URI 包含提交数据并获取响应应该获取数据 但它不起作用
  • 如何减去年份?

    我在 R 中有一个约会 例如 dt as Date 2010 03 17 我想从此日期减去 2 年 而不用担心闰年和此类问题 得到as Date 2008 03 17 我该怎么做呢 With lubridate library lubrid
  • 如何使用 Notepad++ Compare 作为 git bash/命令行中的 diff 工具?

    有什么方法可以更改 gitbash 中的默认 diff 工具吗 这篇文章似乎表明这是可能的 但他们没有提供命令行示例 关联 从命令行运行 NotePad 并使用比较插件显示比较结果 由于 Notepad 的官方 diff 插件似乎是uph0
  • Drools 6.4 KieScanner:如何在 Maven 中创建和添加带有规则的 Jar?

    我是 Drools 和 Maven 的初学者 我面临着使用 KieScanner 加载规则的问题 该项目的目标是能够在永久 KieSession 中动态加载规则 我想知道是否可以使用 KieFileSystem 管理规则 不确定是否可以在不
  • 如何解决Odoo中不存在列res_partner.

    例如 reonp 很好地添加到了模型中 但是当我尝试添加 gradjanin 时 Odoo 10 会引发错误 我试图重新启动服务器 py class komPartnerrReon models Model inherit res part
  • 使用带有像素后备的 rems

    我正在研究移动优先框架 该项目有广泛的需求 需要满足不同地点的大量浏览器和设备 我的主要目标地点之一是印度 那里的浏览器和设备使用趋势与英国或美 国有很大不同 印度浏览器使用情况http gs statcounter com all bro
  • 如果使用autowidth:true,如何删除免费的jqgrid自己的水平滚动条

    使用以下设置将免费 jqgrid 宽度设置为至少占据整个窗口宽度jqGrid 和自动宽度选项 它是如何工作的 answer autowidth true shrinkToFit false 使用以下答案中的样式使顶级工具栏图标变得更大 如果
  • Django 继承和永久链接

    我正在 django 中创建一个简单的 CMS 其中包含多个 模块 每个模块都是一个 django 应用程序 我设置了以下模型 class FooObject models Model id models SlugField primary
  • 如何在 C# 中存储之前验证 .csv 文件?

    我有一些 csv 文件 在存储到数据库之前我正在解析这些文件 我想让应用程序更加健壮 并在保存到数据库之前对 csv 文件执行验证 所以我问你们是否有一些好的链接 代码示例 模式或关于如何做到这一点的建议 我将在下面粘贴我的 csv 文件的
  • Swing:将事件委托给转换后的父组件的子组件

    我有一个自定义组件GameViewCanvas extends JPanel将容纳许多图块 800x800 纹理 现在在 GameViewCanvas 中我已经覆盖了paint 方法 以便它将在变换后的画布上绘制子项 缩放 平移和旋转 我现
  • 我应该在android服务的onDestroy方法中调用onCreate方法吗?

    我想在它被破坏时再次启动服务 Override public void onDestroy super onDestroy onCreate 你不应该这样做 这不会做任何事 要重新启动服务 您应该重新启动它onTaskRemove 像下面这
  • Python 中的二维优化(最小化)(使用 scipy.optimize)

    我正在尝试优化 最小化 二维函数E n k 定义如下 error lambda x y w math log abs Tformulated x y w math log abs Tw w 2 math atan2 Tformulated