* The first targrows sample rows are simply copied into the
* reservoir. Then we start replacing tuples in the sample
* until we reach the end of the relation. This algorithm is
- * from Jeff Vitter's paper (see full citation below). It
- * works by repeatedly computing the number of tuples to skip
- * before selecting a tuple, which replaces a randomly chosen
- * element of the reservoir (current set of tuples). At all
- * times the reservoir is a true random sample of the tuples
- * we've passed over so far, so when we fall off the end of
- * the relation we're done.
+ * from Jeff Vitter's paper (see full citation in
+ * utils/misc/sampling.c). It works by repeatedly computing
+ * the number of tuples to skip before selecting a tuple,
+ * which replaces a randomly chosen element of the reservoir
+ * (current set of tuples). At all times the reservoir is a
+ * true random sample of the tuples we've passed over so far,
+ * so when we fall off the end of the relation we're done.
*/
if (numrows < targrows)
rows[numrows++] = heap_copytuple(&targtuple);