2

例如,

我的文件以00.dat、01.dat、02.dat ... 命名,每个文件包含多个列,我用来READCOL将它们读入变量。

for i = 0, n-1 do begin
    readcol, string(i, F='(I02)')+'.dat', F='D,D', a0, b0
    readcol, string(i, F='(I02)')+'.dat', F='D,D', a1, b1
    .
    .
    c1 = a1 / a0
    c2 = a2 / a0
    .
    .
    d1 = b1 / b0
    d2 = b2 / b0
    .
    .
endfor

这很好用,但如果有一百个变量,我不能一一键入所有变量。

因此,我想使用 for 循环来生成:a(i), b(i), c(i), d(i)。从这个意义上说,代码将如下所示:

for i = 0, n-1 do begin
    readcol, string(i, F='(I02)')+'.dat',F='D,D', a(i), b(i)
endfor

for i = 0, n-1 do begin
    c(i) = a(i) / a(0)
    d(i) = b(i) / b(0)
endfor

但这不起作用,是否有任何方法可以在 for 循环中声明变量并同时进行数学运算?

(我不是以英语为母语的人。如果我的问题有什么不清楚的地方,请告诉我。谢谢!)

4

1 回答 1

5

很高兴在 StackOverflow 上看到另一个 IDL 程序员!

我认为问题的一部分是READCOL它的输出期望简单的变量名,在你的第二个例子中你给它数组表达式,比如 a(i)andb(i)而不是aand b

如果我正确理解您的问题,您希望将 第一个示例中的一维数组a0, a1, b0,等替换为二维数组,等,其中每个数组都有维度(nfiles、samples_per_file)。因此,如果您事先知道将从每个文件中读取多少行,则可以执行以下操作:b1ab

a=dblarr(n,samples_per_file)
b=dblarr(n,samples_per_file)
; similarly for c, d, etc.

for i = 0, n-1 do begin
    readcol, string(i, F='(I02)')+'.dat',F='D,D', x, y
    a[i,*] = x
    b[i,*] = y
    c[i,*] = x/x[0]
    d[i,*] = y/y[0]
endfor

这个版本传递READCOL它所期望的简单变量名,然后将它们复制到二维变量的子数组中。

如果您事先不知道每个文件中有多少样本,您可以在第一次循环迭代期间分配二维数组:

for i = 0, n-1 do begin
    readcol, string(i, F='(I02)')+'.dat',F='D,D', x, y
    if (i EQ 0) then begin
       samples_per_file = n_elements(x)
       a = dblarr(n, samples_per_file)
       b = dblarr(n, samples_per_file)
       c = dblarr(n, samples_per_file)
       d = dblarr(n, samples_per_file)
    endif
    a[i,*] = x
    b[i,*] = y
    c[i,*] = x/x[0]
    d[i,*] = y/y[0]
endfor

当然,这一切都假设每个文件包含相同数量的样本。如果没有,您可能需要将abc和更改d为一维指针数组,然后PTR_NEW在读取每个文件的数据时使用它为每个文件的数据分配内存。

(请注意,我使用方括号[]表示法进行数组索引,我发现它比 等更容易阅读a(i)b(i)这可能与函数调用混淆。)

于 2010-01-24T22:03:52.453 回答