迭代使用brentq功能在Python数组 [英] Iterating an Array in Python using the brentq Function

查看:1192
本文介绍了迭代使用brentq功能在Python数组的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我无法遍历使用 brentq 函数数组中的每个元素。 下面定义的函数是FITS文件数组,我们使用的每一个元素数组作为输入,通过了 brentq 为了解决 T 功能。

I am having trouble iterating every element of an array using the brentq function. q in the defined function below is a FITS file array, and we are using every element in this array as inputs to run through the brentqfunction in order to solve for T.

从本质上讲,我的问题就出在没有特别知道在哪里或如何实现相应的遍历①<的每个元素进行迭代函数/ code>。

Essentially, my problem lies in not particularly knowing where or how to implement the appropriate for loop to iterate the function over every element of q.

如何去对这个问题有什么建议?

Any suggestions on how to go about this problem?

def f(T,q,coeff1,coeff2,coeff3):
    return q*const3 - ((exp(const2/T)-1)/(exp(const/T)-1))

a = brentq(f, 10, 435.1, args=(q,4351.041,4262.570,0.206))
print a

newhdu = fits.PrimaryHDU(a)
newhdulist = fits.HDUList([newhdu])
newhdulist.writeto('Temp21DCOT.fits')

进一步的解释:的我试图做的是要使用的基础 brentq 使用的强度值求解温度值我们最初的阵列(FITS我们的文件)。

Further explanation: The basis of what I'm trying to do is to use brentq to solve for temperature values using the intensity values of our initial array (our FITS file).

等式是从普朗克公式的两个波长的比率计算出来,所以 Q = B_1 / B_2 如果我们想成为真正的物理学,其中每一个元素的强度值。 brentq 将解决 T (温度)为①<每个元素此解析无法解决方程/ code>,使同样大小的新的温度阵列。换句话说,我试图解决用普朗克公式在FITS文件中的每个像素的温度。

The equation is derived from a ratio of two wavelengths of Plank's Equation, so q = B_1/B_2 if we want to be true to physics, where every element in q are intensity values. brentq would solve this analytically insolvable equation for T (temperature) for every element in q, and make a new temperature array of the same size as q. In other words, I am trying to solve for the temperature of every pixel in a FITS file using Plank's Equation.

注意:我重新张贴这能够以更有效的方式阐明该问题

Note: I re-posted this to clarify the problem in a more efficient manner.

推荐答案

您有,或者与效率问题的迭代?

Are you having problems with iteration, or with efficiency?

该迭代为我的作品:

In [485]: from scipy import optimize

In [486]: def f(T,q,coeff1,coeff2,coeff3):
        return q*coeff3 - ((np.exp(coeff2/T)-1)/(np.exp(coeff1/T)-1))
        # corrected the coeff use

In [487]: q=np.linspace(1,3,10)
# q range chosen to avoid the different signs ValueError

In [488]: A=[optimize.brentq(f, 10, 435.1, args=(i,4351.041,4262.570,0.206),full_output=True) for i in q]

In [489]: A
Out[489]: 
[(55.99858839149886, <scipy.optimize.zeros.RootResults at 0xa861284c>),
 (64.14621536172528, <scipy.optimize.zeros.RootResults at 0xa861286c>),
 (72.98658083834341, <scipy.optimize.zeros.RootResults at 0xa861288c>),
 (82.75638321495505, <scipy.optimize.zeros.RootResults at 0xa86128ac>),
 (93.73016750496367, <scipy.optimize.zeros.RootResults at 0xa86128cc>),
 (106.25045004489637, <scipy.optimize.zeros.RootResults at 0xa86128ec>),
 (120.76612665626851, <scipy.optimize.zeros.RootResults at 0xa861290c>),
 (137.88917389176325, <scipy.optimize.zeros.RootResults at 0xa861292c>),
 (158.4854607193551, <scipy.optimize.zeros.RootResults at 0xa861294c>),
 (183.82941862839408, <scipy.optimize.zeros.RootResults at 0xa861296c>)]

In [490]: [a[1].iterations for a in A]
Out[490]: [8, 9, 10, 10, 10, 10, 10, 9, 8, 10]

brentq 文档˚F返回一个值,为一组参数数量。还有一些解算器,如颂歌的人,这让你定义一个函数,向量变量,并返回匹配的载体衍生物。它看起来并不像这样求根允许。所以,你被卡住遍历 ARGS 值,并求解每个案例。我写的迭代作为一个列表COM prehension。其他迭代格式是可能的(循环等)。我们甚至可以裹在可以通过 np.vectorize 传递函数这一 brentq 电话。但是,这仍然会是轻微节省时间一个迭代。

In the brentq docs f returns one value, for one set of args. There are some solvers, such as the ode ones, that let you define a function that takes a vector variable, and returns a matching vector derivative. It doesn't look like this root finder allows that. So you are stuck with iterating over the args values, and solving for each case. I wrote the iteration as a list comprehension. Other iteration formats are possible (for loop etc). We might even be able the wrap this brentq call in a function that could be passed through np.vectorize. But that is still going to be a iteration with minor time savings.

有处理多维数组的各种方法。一个简单的一个是扁平化输入,做1D迭代,然后重塑的结果。例如:

There are various ways of handling a multidimensional array. One simple one is to flatten the input, do the 1d iteration, and then reshape the result. For example:

In [517]: q1=q.reshape(2,5)

In [518]: q1
Out[518]: 
array([[ 1.        ,  1.22222222,  1.44444444,  1.66666667,  1.88888889],
       [ 2.11111111,  2.33333333,  2.55555556,  2.77777778,  3.        ]])

In [519]: np.array([optimize.brentq(f, 10, 435.1, args=(i,4351.041,4262.570,0.206)) for i in q1.flat]).reshape(q1.shape)
Out[519]: 
array([[  55.99858839,   64.14621536,   72.98658084,   82.75638321,
          93.7301675 ],
       [ 106.25045004,  120.76612666,  137.88917389,  158.48546072,
         183.82941863]])

我离开的 full_output 标记,因为这增加了复杂性。

I left off the full_output flag, since that adds complications.

这篇关于迭代使用brentq功能在Python数组的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆