Pyrite | Level 9

## NUMERICAL INTEGRATION: ERROR: (execution) Character argument should be numeric

Please, I wish to ask if any could help correct this error:

NOTE: Module FUNC defined.

47   interval = {A, B};

param must be numeric

ERROR: (execution) Character argument should be numeric

This is data set and code:

Data sim;

Input A B;

cards;

1   3

2   7

3   10

4   12

;

Run;

proc iml;

use sim;

read all  var{A B} into DM;

close;

A = DM[,1]; B = DM[,2];

n = nrow(DM);

start Func(x);

return(  exp(2-x)#cdf("Normal", x) );

finish;

interval = {A, B};

create kaplan1n var{A  B Answer };

append;

quit;

1 ACCEPTED SOLUTION

Accepted Solutions
SAS Super FREQ

## Re: NUMERICAL INTEGRATION: ERROR: (execution) Character argument should be numeric

You want to allocate a vector outside of the loop and fill it within the loop, as described in this article: Pre-allocate arrays to improve efficiency - The DO Loop

This and other efficiency tips that you've asked about are found in Chapter 2 of Statistical Programming with SAS/IML Software

do i = 1 to nrow(A);

end;

6 REPLIES 6
SAS Super FREQ

## Re: NUMERICAL INTEGRATION: ERROR: (execution) Character argument should be numeric

If you are trying to compute four integrals, use the i_th row of DM as the interval for the i_th computation:

do i = 1 to nrow(DM);

...

end;

Pyrite | Level 9

## Re: NUMERICAL INTEGRATION: ERROR: (execution) Character argument should be numeric

Hello Rick, My interval is A, B. The lower limit is A and upper limit is B, , the code does not specified the upper and lower limit. I have to pick the correct limit .

do i = 1 to nrow(DM);

...

end;

I modified my code as such:

Data sim;

Input A B;

cards;

1 3

2 7

3 10

4 12

;

Run;

proc iml;

use sim;

read all  var{A B} into DM;

close;

A = DM[,1]; B = DM[,2];

n = nrow(DM);

start Func(x);

return(  exp(2-x)#cdf("Normal", x) );

finish;

do i = 1 to nrow(DM);

end;

create kaplan1n var{A  B Answer };

append;

quit;

statement : CALL at line 8281 column 1

ERROR: (execution) Matrices do not conform to the operation.

operation : QUAD at line 8307 column 1

operands  : *LIT1007, _TEM1001

*LIT1007      1 row       1 col     (character, size 4)

Func

_TEM1001      1 row       1 col     (numeric)

3

statement : CALL at line 8307 column 1

SAS Super FREQ

## Re: NUMERICAL INTEGRATION: ERROR: (execution) Character argument should be numeric

Your error is that DM[1,2] is a scalar, whereas QUAD is expecting a vector with two elements, as in my code.  You could also use A || B, if you prefer.

Of course, you also will want to accumulate the results inside the loop. Currently you are just overwriting ANSWER four times, and the data set is only writing the answer to the last integration.

Pyrite | Level 9

## Re: NUMERICAL INTEGRATION: ERROR: (execution) Character argument should be numeric

Thanks a lot. Yes you are right,

This just give me one answer and I need a result for each row.

This code below gives me and answer. How ever, just as you said , it is not giving me the answer for each row.  How do I loop it from 1 to 4 so that each row has an answer. ?

Data sim;

Input A B;

cards;

1 3

2 7

3 10

4 12

;

Run;

proc iml;

use sim;

read all  var{A B} into DM;

close;

A = DM[,1]; B = DM[,2];

n = nrow(DM);

start Func(x);

return(  exp(2-x)#cdf("Normal", x) );

finish;

do i = 1 to nrow(DM);

end;

create kaplan1n var{A  B Answer };

append;

quit;

SAS Super FREQ

## Re: NUMERICAL INTEGRATION: ERROR: (execution) Character argument should be numeric

You want to allocate a vector outside of the loop and fill it within the loop, as described in this article: Pre-allocate arrays to improve efficiency - The DO Loop

This and other efficiency tips that you've asked about are found in Chapter 2 of Statistical Programming with SAS/IML Software

do i = 1 to nrow(A);

end;

Pyrite | Level 9

## Re: NUMERICAL INTEGRATION: ERROR: (execution) Character argument should be numeric

Data sim;

Input A B;

cards;

1 3

2 7

3 10

4 12

;

Run;

proc iml;

use sim;

read all  var{A B} into DM;

close;

A = DM[,1]; B = DM[,2];

n = nrow(DM);

start Func(x);

return(  exp(2-x)#cdf("Normal", x) );

finish;

do i = 1 to nrow(DM);

call quad(result, "Func", A || B,);

end;

create kaplan1n var{A  B Answer };

append;

quit;

From The DO Loop