连续2个三次样条曲线操作出现问题

时间:2019-06-06 07:21:56

标签: python divide-by-zero cubic-spline

我在2个数据列上执行第一个三次样条曲线(总共对301个文件)。一切正常,值的范围等于预期的值。

问题来自三次样条插值的第二次操作,该操作是在使用os.system从python源执行程序之后执行的(生成了我加载到kh, pk的其他301个文件)

实际上,在第二次三次样条曲线操作中出现以下错误,这是错误:

Traceback (most recent call last):
File "Exe_launcher.py", line 323, in <module>
P_m = CubicSpline(np.log10(kh[ppp]),np.log10(pk[ppp]))
File "/Users/fab/Library/Python/2.7/lib/python/site-packages/scipy   /interpolate/_cubic.py", line 527, in __init__
axis = axis % y.ndim
ZeroDivisionError: integer division or modulo by zero

我找不到零除的来源。我在下面给出产生问题的代码段。

我试图通过打印2个数据列的值及其大小来查找错误,这一切似乎都是正确的,但实际上并非如此,因为我遇到了上述错误。

zrange = range(300)
while paramo < len(fid)+1:

   ## First cubic spline interpolation (paramo = 0)
  print('paramo_final1 = ', paramo)

  if paramo == 0:
   # Test_matterpower
   FPA = fold_path_fid
   aaa = len(zrange)
   while aaa >= 0:
       if aaa == len(zrange):
       kh, pk = np.loadtxt("test_matterpower"+str(aaa)+".dat", usecols=(0,1,), unpack=True)
       elif aaa > 0:
       kh1, pk1 = np.loadtxt("test_matterpower"+str(aaa)+".dat", usecols=(0,1,), unpack=True)
       kh = np.vstack((kh,kh1))
       pk = np.vstack((pk,pk1))
       else:
       kh1, pk1 = np.loadtxt("test_matterpower"+str(len(zrange)+1)+".dat", usecols=(0,1,), unpack=True)
       kh = np.vstack((kh,kh1))
       pk = np.vstack((pk,pk1))
       aaa = aaa-1

   ooo,ppp = 0,0
   integrale = np.zeros((len(pk)))
   print('1) len(kh) = ', len(kh))
   print('len(pk) = ', len(pk))
   print('len(integrale) = ', len(integrale))
   print('kh = ', kh)
   print('kh[0] = ', kh[0])
   print('np.log10(kh[ppp] = ', np.log10(kh[ppp]))
   print('np.log10(pk[ppp] = ', np.log10(pk[ppp]))
   print('pk = ', pk)
   while ppp < len(integrale):
       P_m = CubicSpline(np.log10(kh[ppp]),np.log10(pk[ppp]))
       while ooo < len(kh[0])-1:
       integrale[ppp] = integrale[ppp] + 1./(2*np.pi**2) * (kh[ppp][ooo+1]-kh[ppp][ooo])/6. * ( (kh[ppp][ooo]**2*(3*(np.sin(8*kh[ppp][ooo]) - 8*kh[ppp][ooo]*np.cos(8*kh[ppp][ooo]))/(8*kh[ppp][ooo])**3)**2*pk[ppp][ooo]) + (kh[ppp][ooo+1]**2*(3*(np.sin(8*kh[ppp][ooo+1]) - 8*kh[ppp][ooo+1]*np.cos(8*kh[ppp][ooo+1]))/(8*kh[ppp][ooo+1])**3)**2*pk[ppp][ooo+1]) + 4.*( ((kh[ppp][ooo+1]+kh[ppp][ooo])/2.)**2*(3*(np.sin(8*(kh[ppp][ooo+1]+kh[ppp][ooo])/2.) - 8*(kh[ppp][ooo+1]+kh[ppp][ooo])/2*np.cos(8*(kh[ppp][ooo+1]+kh[ppp][ooo])/2.))/(8*(kh[ppp][ooo+1]+kh[ppp][ooo])/2.)**3)**2*10**P_m(np.log10((kh[ppp][ooo]+kh[ppp][ooo+1])/2))) )
       ooo=ooo+1
       ooo=0
       ppp=ppp+1

   print('1) kh[0] = ', kh[0])
   kh = np.delete(kh, len(kh)-1, axis=0)
   pk = np.delete(pk, len(pk)-1, axis=0)
   print('2) kh[0] = ', kh[0])

  # for paramo > 0 
  else: 

   ## Second cubic spline interpolation (paramo > 0)

     os.system('./camb Exe_launcher_modified.ini')   

     aaa = len(zrange)
     while aaa >= 0:
      if aaa == len(zrange):
          kh, pk = np.loadtxt("test_matterpower"+str(aaa)+".dat", usecols=(0,1,), unpack=True)
      elif aaa > 0:
          kh1, pk1 = np.loadtxt("test_matterpower"+str(aaa)+".dat", usecols=(0,1,), unpack=True)
          kh = np.vstack((kh,kh1))
          pk = np.vstack((pk,pk1))
      else:
          kh1, pk1 = np.loadtxt("test_matterpower"+str(len(zrange)+1)+".dat", usecols=(0,1,), unpack=True)
          kh = np.vstack((kh,kh1))
          pk = np.vstack((pk,pk1))
      aaa = aaa-1

      ooo,ppp = 0,0
      integrale = np.zeros((len(pk)))
      print('2) len(kh) = ', len(kh))
      print('len(pk) = ', len(pk))
      print('len(integrale) = ', len(integrale))
      print('kh = ', kh)
      print('kh[0] = ', kh[0])
      print('np.log10(kh[ppp] = ', np.log10(kh[ppp]))
      print('np.log10(pk[ppp] = ', np.log10(pk[ppp]))
      print('pk = ', pk)
      while ppp < len(integrale):
          P_m = CubicSpline(np.log10(kh[ppp]),np.log10(pk[ppp]))
          while ooo < len(kh[0])-1:
          integrale[ppp] = integrale[ppp] + 1./(2*np.pi**2) * (kh[ppp][ooo+1]-kh[ppp][ooo])/6. * ( (kh[ppp][ooo]**2*(3*(np.sin(8*kh[ppp][ooo]) - 8*kh[ppp][ooo]*np.cos(8*kh[ppp][ooo]))/(8*kh[ppp][ooo])**3)**2*pk[ppp][ooo]) + (kh[ppp][ooo+1]**2*(3*(np.sin(8*kh[ppp][ooo+1]) - 8*kh[ppp][ooo+1]*np.cos(8*kh[ppp][ooo+1]))/(8*kh[ppp][ooo+1])**3)**2*pk[ppp][ooo+1]) + 4.*( ((kh[ppp][ooo+1]+kh[ppp][ooo])/2.)**2*(3*(np.sin(8*(kh[ppp][ooo+1]+kh[ppp][ooo])/2.) - 8*(kh[ppp][ooo+1]+kh[ppp][ooo])/2*np.cos(8*(kh[ppp][ooo+1]+kh[ppp][ooo])/2.))/(8*(kh[ppp][ooo+1]+kh[ppp][ooo])/2.)**3)**2*10**P_m(np.log10((kh[ppp][ooo]+kh[ppp][ooo+1])/2))) )
          ooo=ooo+1
          ooo=0
          ppp=ppp+1

     print('3) kh[0] = ', kh[0])
     kh = np.delete(kh, len(kh)-1, axis=0)
     pk = np.delete(pk, len(pk)-1, axis=0)

     print('4) kh[0] = ', kh[0])

在执行时,实现了第一次三次插值,但没有实现第二次:

Traceback (most recent call last):
File "Exe_launcher.py", line 323, in <module>
P_m = CubicSpline(np.log10(kh[ppp]),np.log10(pk[ppp]))
File "/Users/fab/Library/Python/2.7/lib/python/site-packages/scipy   /interpolate/_cubic.py", line 527, in __init__
axis = axis % y.ndim
ZeroDivisionError: integer division or modulo by zero

更新1::已解决问题,抱歉,缩进不好。

致谢

0 个答案:

没有答案