一个相当简单的方法是在函数空间中选择一个基础并将积分变换转换为矩阵。然后,您可以将矩阵求逆。
从数学上讲,这是这样工作的:您需要一些正交基函数。(你可以逃脱,没有他们被归过,但它更容易解释这种方式。)正交手段内积⟨ 牛逼我,牛逼Ĵ ⟩ = δ 我Ĵ,其中Ti(x)⟨Ti,Tj⟩=δij
⟨Ti,Tj⟩≡∫baW(x)Ti(x)Tj(x)dx=δij(1)
这里是一些权重函数。那和极限a和b与您对T i的选择有关。一旦选择了要使用的一组基础函数,就可以将极限和权重函数硬编码到程序中。W(x)abTi
使用正交性,您可以将任何函数(例如和F (y ))表示为这些基本函数的线性组合:f(x)F(y)
f(x)=∑iciTi(x)F(y)=∑jCjTj(y)(2)
系数计算为
ciCj=⟨f,Ti⟩=∫baW(x)f(x)Ti(x)dx=⟨F,Tj⟩=∫baW(y)F(y)Tj(y)dy(3)(4)
您可以验证这些表达式与系数eq的定义是否一致。(2),以及正交性,等式。(1)。
现在,计算每个基本函数的转换;让我们叫它。T~i(y)
T~i(y)≡∫∞0yexp[−12(y2+x2)]I0(xy)Ti(x)dx
是一个函数,所以你可以表达它的,就像我们做了与基函数的线性组合˚F(X)和˚F(ÿ):T~i(y)f(x)F(y)
T~i(y)=∑kAikTk(y)
矩阵元素的确定方法与上述c i和C j相同:AikciCj
Aik=⟨T~i,Tk⟩=∫baW(y)T~i(y)Tk(y)dy(5)
实际上,这是一个相当棘手的双积分,但是对于和k的每个组合,您只需(一次)执行一次。您可以对数字进行积分,然后在程序中对结果值进行硬编码。(旁注:通过明智地选择T i(x )和W (x ),您可能能够做到这一点,从而可以象征性地完成积分。是否可行取决于您的变换。您可以使用傅里叶变换,但我倾向于认为您在这里询问的变换是不可能的。)ikTi(x)W(x)
根据矩阵元素以及系数c i和C j,f (x )和F (y )之间的关系简化为线性系统AikciCjf(x)F(y)
∑jCjTj(y)F(y)=∫∞0yexp[−12(y2+x2)]I0(xy)∑iciTi(x)f(x)dx=∑ici∫∞0yexp[−12(y2+x2)]I0(xy)Ti(x)dx=∑ici∑kAikTk(y)
给定的基函数的正交性,可以隔离任何特定系数通过取两侧的内积Ť ℓ:CℓTℓ
⟨(∑jCjTj),Tℓ⟩∫baW(y)∑jCjTj(y)Tℓ(y)dy∑jCj∫baW(y)Tj(y)Tℓ(y)dy∑jCjδjℓCℓ=⟨(∑ici∑kAikTk),Tℓ⟩=∫baW(y)∑ici∑jAikTk(y)Tℓ(y)dy=∑ici∑kAik∫baW(y)Tk(y)Tℓ(y)dy=∑ici∑kAikδkℓ=∑iciAiℓ
当然只是一个虚拟索引,因此我将回到它的名称C j。ℓCj
这只是线性代数问题。是向量的一个分量,c i也是,而A i j是一个矩阵的分量。您可以从要使用eq转换的函数中计算c i。(3),并且从您为该特定积分变换(等式)所做的一次性计算中知道A i j。(5),因此您可以通过执行矩阵乘法(这是非常擅长的计算机)来获得C j s,然后从使用等式的那些中重建函数F (y )。(2)。CjciAijciAijCjF(y)
相反,要进行逆变换,请从函数,使用等式从中计算C j s。(4),然后您需要求解线性系统F(y)Cj
Cj=∑iciAij
这可以通过将两边都乘以矩阵的逆来完成,但是实际上有更有效的方法可以做到这一点。使用您拥有的任何线性代数库的线性系统求解器。A
请注意,到目前为止,我所写的所有内容都未指定,j等上的和的限制。实际上,您将需要选择一些限制,例如1到N(您选择N),以便可以通过T 1(x ),… ,T的线性组合充分地逼近您可能遇到的任何f (x )。N(x )以及1到M之类的范围,使得任何F (y )ij1NNf(x)T1(x),…,TN(x)1MF(y)通过的线性组合可以很好地近似。选择M = N可能是最简单的。在这里,“足够好”的意思取决于您。通常,您使M和N越大,您的近似值就会越好,但是您需要更多的内存(和时间)来进行计算。请记住,您需要计算N个系数c i,对于矩阵A,您需要具有M × NT1(y),…,TM(y)M=NMNNciAM×N系数来计算,从到甲Ñ 中号。A11ANM
用于在有限的时间间隔,其可以是线性重新调整为定义函数中,切比雪夫多项式是一个常见的选择Ť 我。从某种意义上说,切比雪夫多项式使用固定数量的项产生给定函数的最精确近似,这使得它们特别适合于此类应用。如果可以截断概率分布的域,则可以使用它们。它们与权重W (x )= 1相关[−1,1]TiW(x)=11−x2√a=−1b=1⟨Ti,Tj⟩=δijπ/2i=j≠0⟨T0,T0⟩=π