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;
Я продолжаю получать (исполнение) недопустимый индекс или индекс вне допустимого диапазона. Как решить эту задачу и получить правильный ответ? Я пробовал убрать -1 из x[1:N-1]; и y[1:N-1], но это дает мне неправильный ответ. Это потому, что мне нужно предполагать равные интервалы? Если да, то как бы я это сделал. Уравнение трапеции: (x-x0)*(y+y0)/2 или (xi - xi-1) * (yi + yi-1)/2.