proc iml;
start tr(x,y); * create function called tr;
N = nrow(x);
dx = x[2:N] - x[1:N-1];
ymean = (y[2:N] + y[1:N-1]) / 2;
return(dx` * ymean );
finish tr;
x = do(-2,5,0.01);
print "Integral of a over x is" ( tr(x,0#x+1) ); *Answer is 7;
我不断收到(执行)无效下标或下标超出范围。我该如何解决这个问题并得到正确的答案?我试过取出 x[1:N-1] 中的 -1; 和 y[1:N-1],但它给了我错误的答案。是因为我需要假设等距间隔吗?如果是这样,我会怎么做。梯形方程:(x-x0)*(y+y0)/2 或 (xi - xi-1) * (yi + yi-1) / 2。