This computes a generalisation of the $K$ function
  for inhomogeneous point patterns, proposed by
  Baddeley, Moller and Waagepetersen (2000).
  
  The ``ordinary'' $K$ function
  (variously known as the reduced second order moment function
  and Ripley's $K$ function), is
  described under Kest. It is defined only
  for stationary point processes.
  
  The inhomogeneous $K$ function
  $K_{\rm inhom}(r)$
  is a direct generalisation to nonstationary point processes.
  Suppose $x$ is a point process with non-constant intensity
  $\lambda(u)$ at each location $u$.
  Define $K_{\rm inhom}(r)$ to be the expected
  value, given that $u$ is a point of $x$,
  of the sum of all terms
  $1/\lambda(u)\lambda(x_j)$
  over all points $x_j$
  in the process separated from $u$ by a distance less than $r$.
  This reduces to the ordinary $K$ function if
  $\lambda()$ is constant.
  If $x$ is an inhomogeneous Poisson process with intensity
  function $\lambda(u)$, then
  $K_{\rm inhom}(r) = \pi r^2$.  This allows us to inspect a point pattern for evidence of 
  interpoint interactions after allowing for spatial inhomogeneity
  of the pattern. Values 
  $K_{\rm inhom}(r) > \pi r^2$
  are suggestive of clustering.
  The argument lambda should supply the
  (estimated) values of the intensity function $\lambda$.
  It may be either
  [object Object],[object Object],[object Object],[object Object]
  If lambda is a numeric vector, then its length should
  be equal to the number of points in the pattern X.
  The value lambda[i] is assumed to be the 
  the (estimated) value of the intensity
  $\lambda(x_i)$ for
  the point $x_i$ of the pattern $X$.
  Each value must be a positive number; NA's are not allowed.
  If lambda is a pixel image, the domain of the image should
  cover the entire window of the point pattern. If it does not (which
  may occur near the boundary because of discretisation error),
  then the missing pixel values 
  will be obtained by applying a Gaussian blur to lambda using
  blur, then looking up the values of this blurred image
  for the missing locations. 
  (A warning will be issued in this case.)
  If lambda is a function, then it will be evaluated in the
  form lambda(x,y) where x and y are vectors
  of coordinates of the points of X. It should return a numeric
  vector with length equal to the number of points in X.
  If lambda is omitted, then it will be estimated using
  a `leave-one-out' kernel smoother, as described in Baddeley, Moller
  and Waagepetersen (2000).  The estimate lambda[i] for the
  point X[i] is computed by removing X[i] from the
  point pattern, applying kernel smoothing to the remaining points using
  density.ppp, and evaluating the smoothed intensity
  at the point X[i]. The smoothing kernel bandwidth is controlled
  by the arguments sigma and varcov, which are passed to
  density.ppp along with any extra arguments.
  
  Edge corrections are used to correct bias in the estimation
  of $K_{\rm inhom}$.
  Each edge-corrected estimate of $K_{\rm inhom}(r)$ is
  of the form
  $$\widehat K_{\rm inhom}(r) = \sum_i \sum_j \frac{1{d_{ij} \le
      r} e(x_i,x_j,r)}{\lambda(x_i)\lambda(x_j)}$$
  where $d_{ij}$ is the distance between points
  $x_i$ and $x_j$, and
  $e(x_i,x_j,r)$ is
  an edge correction factor. For the `border' correction,
  $$e(x_i,x_j,r) =
    \frac{1(b_i > r)}{\sum_j 1(b_j > r)/\lambda(x_j)}$$
  where $b_i$ is the distance from $x_i$
  to the boundary of the window. For the `modified border'
  correction, 
  $$e(x_i,x_j,r) =
    \frac{1(b_i > r)}{\mbox{area}(W \ominus r)}$$
  where $W \ominus r$ is the eroded window obtained
  by trimming a margin of width $r$ from the border of the original
  window.
  For the `translation' correction,
  $$e(x_i,x_j,r) =
    \frac 1 {\mbox{area}(W \cap (W + (x_j - x_i)))}$$
  and for the `isotropic' correction,
  $$e(x_i,x_j,r) =
    \frac 1 {\mbox{area}(W) g(x_i,x_j)}$$
  where $g(x_i,x_j)$ is the fraction of the
  circumference of the circle with centre $x_i$ and radius
  $||x_i - x_j||$ which lies inside the window.
  If the point pattern X contains more than about 1000 points,
  the isotropic and translation edge corrections can be computationally
  prohibitive. The computations for the border method are much faster,
  and are statistically efficient when there are large numbers of
  points. Accordingly, if the number of points in X exceeds
  the threshold nlarge, then only the border correction will be
  computed. Setting nlarge=Inf will prevent this from happening.
  Setting nlarge=0 is equivalent to selecting only the border
  correction with correction="border".
  The pair correlation function can also be applied to the
  result of Kinhom; see pcf.