usage: vol = gquad2d(fun,xlow,xhigh,ylow,yhigh,bpx,bpy,wfxy) or vol = gquad2d(fun,xlow,xhigh,ylow,yhigh,nquadx,nquady) This function evaluates the integral of an externally defined function fun(x,y) between limits xlow and xhigh and ylow and yhigh. The numerical integration is performed using a Gauss integration rule. The integration is done with an nquadx by nquady Gauss formula which involves base point matrices bpx and bpy and weight factor matrix wfxy. The normalized interval of integration for the bpx, bpy and wfxy constants is -1 to +1 (in x) and -1 to +1 (in y). The algorithm is described by the summation relation x=b j=nx k=ny integral( f(x)*dx ) = J*sum sum( wfxy(j,k)*fun( x(j), y(k) ) ) x=a j=1 k=1 where wfxy are weight factors, nx = nquadx = number of Gauss points in the x-direction, ny = nquady = number of Gauss points in the y-direction, x = (xhigh-xlow)/2 * bpx + (xhigh+xlow)/2 = mapping function in x, y = (yhigh-ylow)/2 * bpy + (yhigh+ylow)/2 = mapping function in y, and J = (xhigh-xlow)*(yhigh-ylow)/4 = Jacobian of the mapping. The base points and weight factors must first be generated by a call to grule of the form [bpx,bpy,wfxy] = grule2d(nquadx,nquady) The first form of gquad2d is faster when used several times, because the points and weights are only calculated once. The second form of gquad2d is usefull if it is only called once (or a few times).