繁体   English   中英

数值计算非均匀二维数据的一阶导数

[英]Numerically finding first derivative of non-uniform 2D data

我最初有 2 arrays p 和角度,并将它们代入方程 fh 以获得第三个数组 z。 获得这些数据后,我将 arrays p 和角度更改为 p_perpendicular 和 p_parallel,其中 p_perpendicular = p* sin(angle) 和 p_parallel = p*cos(angle)。

import numpy as np 
import matplotlib.pyplot as plt
import matplotlib.colors as colors
from numpy import histogram2d

def func(p,alpha):
   fh = (1/((1+((p**(1/2))))**(3/2)))*(1-np.tanh((np.cos(alpha*np.pi/180))**(1/2))+(1+np.tanh(alpha)**(1/2)))
return (fh)

p=[]
angle=[]
z=[]
for p_loop in np.arange(1e-23,4e-22,1e-23): 
    for alpha in np.arange(1,90,3): 
        p.append(p_loop)
        angle.append(alpha)
        z.append(func(p_loop,alpha))

p_parallel = (np.array(p)*np.cos(np.array(angle)*np.pi/180))   #array of parallel p
p_perpendicular = (np.array(p)*np.sin(np.array(angle)*np.pi/180))  #array of perpendicular p

我知道我可以从初始数据中找到 dz/dp 和 dz/d(angle) 的近似导数,但我不确定如何找到 dz/dp_parallel 或 dz/dp_perpendicular 的导数。

我的第一个想法是使用 2d 直方图进行分箱,但这会导致很大的不准确性。 是否有一些插值方法或极坐标合并方法或其他方法最好将数据放在 p_parallel 和 p_perpendicular 空间中? 在此处输入图像描述

在此处输入图像描述

您已经执行了变量更改 从链式法则:

  dz/dp = dz/dp_par dp_par/dp + dz/dp_perp dp_perp/dp
  dz/dangle = dz/dp_par dp_par/dangle + dz/dp_perp dp_perp/dangle

鉴于您的转变:

# the Jacobian of polar coordinates with respect to cartesian
# both `p` and `angle` are numpy arrays
J = np.array(
    [
        [np.cos(angle * np.pi / 180), -np.pi * p * np.sin(angle * np.pi / 180) / 180],
        [np.sin(angle * np.pi / 180), np.pi * p * np.cos(angle * np.pi / 180) / 180],
    ]
)

# J.shape = (2, 2, 1170).
# Transpose it such that the longest dim is first
J = np.transpose(J, axes=(2, 0, 1))

dz = <<your approximation of derivative [dz/dp, dz/dangle]>>
# dz.shape = (1170, 2)

然后通过求解给出 dz/dp_par、dz/dp_perp 的近似值

np.linalg.solve(J, dz)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM