PROC IML трапециевидное правило

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

1 ответ

Подстрочная проблема возникает из-за того, что x рассматривается как вектор строки, а не вектор столбца, поэтому nrow(x) = 1, Это означает, что вы определили n = 1поэтому, когда индекс n-1фактически равен 0. Это вызывает ошибку индексации, поскольку векторы SAS IML индексируются с 1, а не с 0. Чтобы исправить это, используйте n = ncol(x),

Кроме того, как в стороне, вы можете сократить свой модуль tr если ты хотел:

proc iml;
    start tr(x, y);
        i = 2:ncol(x);
        return( (x[i] - x[i-1])` * (y[i] + y[i-1]) / 2 );
    finish tr;

    x = do(-2, 5, 0.01);

    print 'The integral of a over x is' (tr(x, 0#x+1)) 'and should be 7.';
quit;
Другие вопросы по тегам