diff --git a/documentation/database.man b/documentation/database.man
index 60e54f60..70d45cc0 100644
--- a/documentation/database.man
+++ b/documentation/database.man
@@ -6,24 +6,63 @@ database \- builds a database
 
 .SH SYNOPSIS
 
-\fBdatabase\fP [--min-mag \fIminimum-magnitude\fP | --max-stars \fInum-stars\fP] [--kvector --kvector-min-distance \fImin\fP --kvector-max-distance \fImax\fP --kvector-distance-bins \fInum-bins\fP] [--output \fIoutput-path\fP]
+\fBdatabase\fP [CATALOG OPTIONS...] [[DATABASE SPECIFIC OPTIONS...]] [--output \fIoutput-path\fP] [--help]
 .br
 
 .SH DESCRIPTION
 
-\fBdatabase\fP generates a database (a subset of the star catalog), which is used to compare unidentified stars against. The greater star catalog contains about 9000 stars, which
-can be limited in the database by filtering the stars out with a \fImax-magnitude\fP or by getting the \fInum-stars\fP brightest stars in the catalog. There are several different methods of
-constructing a database. This database is then generated into the file \fIoutput-path\fP.
+First, some terminology:
+.IP \[bu] 2
+\fBCatalog\fP: A simple list of all stars we might want to ever identify, with basic information such as their position in the celestial sphere and magnitude.
+.IP \[bu] 2
+\fBDatabase\fP: A more complex data structure built from the catalog. Databases are optimized to
+answer certain types of queries quickly. Different star-id algorithms may need different databases.
+.LP
 
-.SS Options
+Every star-id algorithm needs the catalog, and all currently implemented algorithms also need a database.
+
+Databases generation can be somewhat slow, so database generation is usually performed on the
+ground. That being said, some types of databases aren't \fIthat\fP slow to build, so if you're
+worried about radiation corrupting the database, at least for some database types it may be
+acceptable to re-generate the database periodically during a mission.
+
+The LOST database file format is actually a "multi-database", which can store multiple databases as
+well as the catalog. The different database types contain a key which the star identification
+algorithms use to automatically select the correct sub-database in a multi-database. It's presently
+impossible to include two different databases of the same type in a multi-database.
+
+.SH STAR IDENTIFICATION ALGO <-> DATABASE TYPE
+
+Different star identification algorithms require different databases:
+.IP \[bu] 2
+\fBPyramid\fP: Catalog + Pair-distance KVector.
+.IP \[bu] 2
+\fBGeometric Voting\fP: Catalog + Pair-distance KVector.
+.LP
+
+.SH CATALOG NARROWING OPTIONS
+
+These options allow you to limit the stars that get added to the catalog. Generally you'll want to
+narrow down the catalog so that it only contains stars that your imaging system is likely to
+actually pick up, because any extra stars just slow down matching algorithms and increase the
+likelihood of a bad match.
 
 .TP
 \fB--min-mag\fP \fIminimum-magnitude\fP
-Limits database to stars with magnitude less than \minimum-magnitude\fP (brighter stars have lower magnitudes).
+Narrows catalog to stars with magnitude less than \minimum-magnitude\fP (brighter stars have lower magnitudes).
 
 .TP
 \fB--max-stars\fP \fInum-stars\fP
-Limits database to the \fInum-stars\fP brightest stars in the catalog.
+Limits catalog to the \fInum-stars\fP brightest stars in the catalog.
+
+.TP
+\fB--min-separation\fP \fIminimum-separation\fP
+Removes stars from the catalog that are within \fIminimum-separation\fP degrees of another catalog star. The default option is probably good enough for you.
+
+.SH PAIR-DISTANCE KVECTOR DATABASE OPTIONS
+
+The pair-distance KVector database allows fast (constant time) queries to find all pairs of stars
+with an angular distance between them being in a certain range.
 
 .TP
 \fB--kvector\fP
@@ -35,11 +74,13 @@ Sets the minimum distance bin in the kvector building method to \fImin\fP (degre
 
 .TP
 \fB--kvector-max-distance\fP \fImax\fP
-Sets the maximum distance bin in the kvector building method to \fImax\fP (degrees). Defaults to 15 if option is not selected.
+Sets the maximum distance \fImax\fP (degrees). Defaults to 15 if option is not selected. Should be set to no larger than your camera's FOV, otherwise you're just wasting time and space.
 
 .TP
 \fB--kvector-distance-bins\fP \fInum-bins\fP
-Sets the number of distance bins in the kvector building method to \fInum-bins\fP.  Defaults to 10000 if option is not selected.
+Sets the number of distance bins in the kvector building method to \fInum-bins\fP.  Defaults to 10000 if option is not selected, which is pretty reasonable for most cases.
+
+.SH OTHER OPTIONS
 
 .TP
 \fB--output\fP \fIoutput-path\fP
@@ -47,7 +88,7 @@ The file to output the database to. Defaults to stdout.
 
 .TP
 \fB--help\fP
-Prints the contents of the manual entry for the command to the terminal.
+Prints this page to the terminal.
 
 .SH SEE ALSO
 pipeline(3)
diff --git a/documentation/pipeline.man b/documentation/pipeline.man
index 2cf787d5..1fbbee99 100644
--- a/documentation/pipeline.man
+++ b/documentation/pipeline.man
@@ -6,24 +6,69 @@ pipeline \- builds a pipeline of the star identification process
 
 .SH SYNOPSIS
 
-\fBpipeline\fP --png \fIfilepath\fP (--focal-length \fIlength\fP --pixel-size \fIsize\fP) | --fov \fIdegrees\fP [--centroid-algo \fIalgo\fP [--centroid-dummy-stars \fInum-stars\fP]] [--centroid-mag-filter \fImin-mag\fP]
-[--database \fIfilename\fP] [--star-id-algo \fIalgo\fP (--angular-tolerance \fI[tolerance]\fP --false-stars \fInum\fP --max-mismatch-prob \fIprobability\fP)] [--attitude-algo \fIalgo\fP] [--print-attitude \fI[path]\fB] [--plot-output \fI[path]\fB]
+\fBpipeline\fP --png \fIfilepath\fP ((--focal-length \fIlength\fP --pixel-size \fIsize\fP) | --fov \fIdegrees\fP) [CENTROID OPTIONS...] [--centroid-mag-filter \fImin-mag\fP] [--database \fIfilename\fP] [STAR-ID OPTIONS...] [ATTITUDE DET OPTIONS...] [COMPARATORS...]
 .br
-\fBpipeline\fP --generate \fInum-images\fP [--generate-x-resolution \fIpixels\fP] [--generate-y-resolution \fIpixels\fP] [--fov \fIdegrees\fP] [--generate-reference-brightness \fImag\fP] [--generate-spread-stddev \fIstddev\fP] [--generate-read-noise-stddev \fIstddev\fP] [--generate-ra \fIdegrees\fP] [--generate-de \fIdegrees\fP] [--generate-roll \fIdegrees\fP]
-[--centroid-algo \fIalgo\fP [--centroid-dummy-stars \fInum-stars\fP]] [--centroid-mag-filter \fImin-mag\fP]
-[--database \fIfilename\fP] [--star-id-algo \fIalgo\fP (--angular-tolerance \fI[tolerance]\fP --false-stars \fInum\fP --max-mismatch-prob \fIprobability\fP)] [--attitude-algo \fIalgo\fP] [--plot-raw-input \fI[path]\fB] [--plot-input \fI[path]\fB]
+\fBpipeline\fP --generate \fInum-images\fP [(--focal-length \fIlength\fP --pixel-size \fIsize\fP) | --fov \fIdegrees\fP] [GENERATE OPTIONS...] [CENTROID OPTIONS...] [--centroid-mag-filter \fImin-mag\fP] [--database \fIfilename\fP] [STAR-ID OPTIONS...] [ATTITUDE DET OPTIONS...] [COMPARATORS...]
 
 .SH DESCRIPTION
 
-\fBpipeline\fP is the command to set the different stages of the star identification pipeline. An image can be
-taken in as input from \fIfilepath\fP, or image(s) can be generated according to various parameters. There are five main stages to the pipeline:
---centroid, --centroid-mag-filter, --id, --database, and --attitude. The --centroid option allows the user to
-choose which centroiding algorithm to use, while the --centroid-mag-filter option allows the user to filter out candidate
-centroids below a certain magnitude. The --database option allows the user to specificy which file to use as the database.
-The --id option runs the star identification algorithm, and the --attitude option determines the orientation of the
-cubesat in space.
-
-.SS Options
+\fBpipeline\fP is the command to set the different stages of the star identification pipeline. An
+image can be taken in as input from \fIfilepath\fP, or image(s) can be procedurally generated. The pipeline has
+the following stages:
+.IP \[bu] 2
+Centroiding: Determine star center positions.
+.IP \[bu] 8
+(Mini-stage after centroiding): Centroid magnitude filter: Remove centroids with too low of a magnitude.
+.IP \[bu] 2
+Star identification: Determine which star is which.
+.IP \[bu] 2
+Attitude determination: Use star identifiers to compute a best-fit orientation/attitude.
+.LP
+
+The command line specifies, mainly, three things: How input should be provided to the pipeline (from
+an image file or randomly generated?), how the different stages of the pipeline should be executed
+(which algorithms to use? What config options for those algorithms?), and what should be done with
+the output of the pipeline (Visualize the star-id? Figure out what percentage of stars were
+correctly identified?).
+
+.SS Pipeline Input
+
+Presently there are two ways to provide pipeline input:
+.IP \[bu] 2
+Image file on disk: Use the \fB--png\fP option to specify the file path to a png to read.
+.IP \[bu] 2
+Generated image: Use the \fB--generate\fP option to specify how many false images to generate.
+.LP
+
+For both input modes, you'll probably want to specify how "zoomed-in" the camera is; this can be
+done by providing both the \fB--focal-length\fP and \fB--pixel-size\fP options, or just the
+\fB--fov\fP option.
+
+When \fB--generate\fP is used, LOST keeps track of what the "true" centroids, star identifiers, and
+attitude are, since it has absolute knowledge of the generated image. These intermediate results can
+be compared against pipeline outputs later to evaluate individual pipeline stages.
+
+.SS Pipeline itself
+
+Options can be specified to select algorithms and configuration for each pipeline stage. When using
+a generated image, it is not necessary to specify every stage of the pipeline, because the generated
+image contains enough information to run each pipeline stage individually. For example, if only the
+attitude estimation algorithm is specified, the exact centroids and star identifiers that the image
+generator created will be used as input.
+
+.SS Pipeline Output (Comparators)
+
+Finally, information about the pipeline run can be printed. LOST can:
+.IP \[bu] 2
+Plot images visualizing star identification (\fB--plot-input\fP, \fB--plot-output\fP, and \fB--plot-raw-input\fP).
+.IP \[bu] 2
+Print the raw output of each stage (\fB--print-centroids\fP, \fB--print-attitude\fP).
+.IP \[bu] 2
+(Generated images only), compare the output of each stage with the expected output (\fB--compare-*\fP), making it easy to evaluate various algorithms for various parts of the pipeline.
+.LP
+
+
+.SH BASIC OPTIONS
 
 .TP
 \fB--png\fP \fIfilepath\fP
@@ -41,6 +86,22 @@ The pixel size of the camera that took the picture (in micrometers).
 \fB--fov\fP \fIdegrees\fP
 The field of view of the camera that took the picture (in degrees). Defaults to 20 deg if option is not selected.
 
+.SH MISC PIPELINE OPTIONS
+
+.TP
+\fB--centroid-mag-filter\fP \fImin-mag\fP
+Will not consider centroids with magnitude below \fImin-mag\fP.
+
+.TP
+\fB--database\fP \fIfilename\fP
+Chooses \fIfilename\fP as the database to use during star identification.
+
+.TP
+\fB--help\fI
+Prints the contents of the manual entry for the command to the terminal.
+
+.SH CENTROID OPTIONS
+
 .TP
 \fB--centroid-algo\fP \fIalgo\fP
 Runs the \fIalgo\fP centroiding algorithm. Recognized options are: dummy (random centroid algorithm), cog (center of gravity), and iwcog (iterative weighted center of gravity).  Defaults to dummy if option is not selected.
@@ -49,9 +110,7 @@ Runs the \fIalgo\fP centroiding algorithm. Recognized options are: dummy (random
 \fB--centroid-dummy-stars\fP \fInum-stars\fP
 Runs the dummy centroiding algorithm (random centroid algorithm) with \fInum-stars\fP stars centroided. Defaults to 5 if option is not selected.
 
-.TP
-\fB--centroid-mag-filter\fP \fImin-mag\fP
-Will not consider candidate as centroid if its magnitude is below \fImin-mag\fP.
+.SH STAR IDENTIFICATION OPTIONS
 
 .TP
 \fB--star-id-algo\fP \fIalgo\fP
@@ -69,10 +128,14 @@ used in some star id algorithms, to \fItolerance\fP degrees. Defaults to 0.04 de
 \fB--max-mismatch-prob\fP \fIprobability\fP
 \fIprobability\fP is the maximum allowable probability of an incorrect star identification, for star id algorithms which support it. Defaults to 0.001.
 
+.SH ATTITUDE DETERMINATION OPTIONS
+
 .TP
 \fB--attitude-algo\fP \fIalgo\fP
 Runs the \fIalgo\fP algorithm for the attitude stage of the pipeline. Current options are "dqm" (Davenport Q), "triad", and "quest". Defaults to dqm.
 
+.SH IMAGE GENERATION OPTIONS
+
 .TP
 \fB--generate\fP \fInum-images\fP
 Generates \fInum-images\fP many images. Mutually exclusive with \fB--png\fP.
@@ -139,59 +202,58 @@ The maximum (strongest) magnitude that generated false stars should have. Defaul
 
 .TP
 \fB--generate-oversampling\fP \fInum-samples\fP
-Peform \fInum-samples\fP many samples per pixel when generating images. Effectively performs antialiasing. \fInum-samples\fP must be a perfect square. Default 4.
+Perform \fInum-samples\fP many samples per pixel when generating images. Effectively performs antialiasing. \fInum-samples\fP must be a perfect square. Default 4.
 
 .TP
 \fB--generate-seed\fP \fIseed\fP
 An integer seed to pass to the random number generator used during image generation.
 
+.SH COMPARATOR OPTIONS
+
+The options that speak of an "expected" something will only work on generated images. In a generated
+image, the "ideal" output of each stage is already known because we created the image to begin with!
+For example, we know exactly where each centroid should be. So we have an "expected" output for each
+stage we can conveniently compare against!
+
 .TP
 \fB--plot-raw-input\fP [\fIpath\fP]
-Argument is optional. Plots raw BW input image to PNG. Prints to \fIpath\fP. Defaults to stdout if if \fIpath\fP is not given.
+Argument is optional. Plots raw BW input image to PNG. Prints to \fIpath\fP. Defaults to stdout.
 
 .TP
 \fB--plot-input\fP [\fIpath\fP]
-Argument is optional. Plots annotated input image to PNG. Prints to \fIpath\fP. Defaults to stdout if \fIpath\fP is not given.
+Argument is optional. Plots annotated input image to PNG. Prints to \fIpath\fP. Defaults to stdout.
 
 .TP
 \fB--plot-output\fP [\fIpath\fP]
-Argument is optional. Plot output to PNG. Prints to \fIpath\fP. Defaults to stdout if \fIpath\fP is not given.
+Argument is optional. Plot output to PNG. Prints to \fIpath\fP. Defaults to stdout.
 
 .TP
 \fB--print-centroids\fP [\fIpath\fP]
-Argument is optional. Plot output to PNG. Prints to \fIpath\fP. Defaults to stdout if \fIpath\fP is not given.
+Argument is optional. Print list of centroids to \fIpath\fP. If star identification was also performed, print which catalog star each centroid was identified as. Defaults to stdout.
 
 .TP
-\fB--compare-centroids\fP [\fIpath\fP]
-Argument is optional. Print list of centroids to \fIpath\fP. Defaults to stdout if \fIpath\fP is not given.
+\fB--print-attitude\fP [\fIpath\fP]
+Argument is optional. Print the determined right ascension, declination, and roll to \fIpath\fP. TODO: Option to print as quaternion. Defaults to stdout.
 
 .TP
-\fB--compare-stars\fP [\fIpath\fP]
-Argument is optional. Compare lists of identified stars. Prints to \fIpath\fP. Defaults to stdout if \fIpath\fP is not given.
+\fB--compare-centroids\fP [\fIpath\fP]
+Argument is option. Compare expected to actual centroids. Prints to \fIpath\fP. Defaults to stdout.
 
 .TP
-\fB--print-attitude\fP [\fIpath\fP]
-Argument is optional. Print the determined ra, de, and roll to \fIpath\fP. Defaults to stdout if \fIpath\fP is not given.
+\fB--compare-stars\fP [\fIpath\fP]
+Argument is optional. Compare expected to actual star identifiers. Prints to \fIpath\fP. Defaults to stdout.
 
 .TP
-\fB--compare-attitude\fP [\fIpath\fP]
-Argument is optional. Compare expected to actual attitude. Prints to \fIpath\fP. Defaults to stdout if \fIpath\fP is not given.
+\fB--compare-attitudes\fP [\fIpath\fP]
+Argument is optional. Compare expected to actual attitude. Prints to \fIpath\fP. Defaults to stdout.
 
 .TP
 \fB--centroid-compare-threshold\fP \fIthreshold\fP
-Sets the threshold for the centroid comparing algorithms
+Sets the threshold (in pixels) to consider two centroids equal (cf \fB--compare-centroids\fP).
 
 .TP
 \fB--attitude-compare-threshold\fP \fIthreshold\fP
-Sets the threshold for the attitude comparing algorithms
-
-.TP
-\fB--database\fP \fIfilename\fP
-Chooses \fIfilename\fP as the database to compare stars against.
-
-.TP
-\fB--help\fI
-Prints the contents of the manual entry for the command to the terminal.
+Sets the threshold (in degrees) to consider two attitudes equal (cf \fB--compare-attitudes\fP).
 
 .SH SEE ALSO
 database(3)
diff --git a/src/database-options.hpp b/src/database-options.hpp
index ace06246..7bc5536c 100644
--- a/src/database-options.hpp
+++ b/src/database-options.hpp
@@ -4,6 +4,7 @@
 
 LOST_CLI_OPTION("min-mag"              , float      , minMag                , 100   , atof(optarg)   , kNoDefaultArgument)
 LOST_CLI_OPTION("max-stars"            , int        , maxStars              , 10000 , atoi(optarg)   , kNoDefaultArgument)
+LOST_CLI_OPTION("min-separation"       , float      , minSeparation         , 0.002 , atof(optarg)   , kNoDefaultArgument)
 LOST_CLI_OPTION("kvector"              , bool       , kvector               , false , atobool(optarg), true)
 LOST_CLI_OPTION("kvector-min-distance" , float      , kvectorMinDistance    , 0.5   , atof(optarg)   , kNoDefaultArgument)
 LOST_CLI_OPTION("kvector-max-distance" , float      , kvectorMaxDistance    , 15    , atof(optarg)   , kNoDefaultArgument)
diff --git a/src/io.cpp b/src/io.cpp
index d3458b76..7178ddd7 100644
--- a/src/io.cpp
+++ b/src/io.cpp
@@ -85,7 +85,7 @@ std::vector<CatalogStar> BscParse(std::string tsvPath) {
 #endif
 
 /// Read and parse the full catalog from disk. If called multiple times, will re-use the first result.
-std::vector<CatalogStar> &CatalogRead() {
+const Catalog &CatalogRead() {
     static bool readYet = false;
     static std::vector<CatalogStar> catalog;
 
diff --git a/src/io.hpp b/src/io.hpp
index eccb3447..92ffb4c8 100644
--- a/src/io.hpp
+++ b/src/io.hpp
@@ -45,7 +45,7 @@ class UserSpecifiedOutputStream {
 };
 
 // use the environment variable LOST_BSC_PATH, or read from ./bright-star-catalog.tsv
-std::vector<CatalogStar> &CatalogRead();
+const Catalog &CatalogRead();
 // Convert a cairo surface to array of grayscale bytes
 unsigned char *SurfaceToGrayscaleImage(cairo_surface_t *cairoSurface);
 cairo_surface_t *GrayscaleImageToSurface(const unsigned char *, const int width, const int height);
@@ -245,9 +245,6 @@ void PipelineComparison(const PipelineInputList &expected,
 // DB BUILDER //
 ////////////////
 
-// TODO: rename
-Catalog PromptNarrowedCatalog(const Catalog &);
-
 /// Commannd line options when using the `database` command.
 class DatabaseOptions {
 public:
diff --git a/src/main.cpp b/src/main.cpp
index 0585b03f..401c21d5 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -25,7 +25,7 @@ namespace lost {
 
 /// Create a database and write it to a file based on the command line options in \p values
 static void DatabaseBuild(const DatabaseOptions &values) {
-    Catalog narrowedCatalog = NarrowCatalog(CatalogRead(), (int) (values.minMag * 100), values.maxStars);
+    Catalog narrowedCatalog = NarrowCatalog(CatalogRead(), (int) (values.minMag * 100), values.maxStars, DegToRad(values.minSeparation));
     std::cerr << "Narrowed catalog has " << narrowedCatalog.size() << " stars." << std::endl;
 
     MultiDatabaseBuilder builder;
diff --git a/src/star-utils.cpp b/src/star-utils.cpp
index e5a4460d..e69eedeb 100644
--- a/src/star-utils.cpp
+++ b/src/star-utils.cpp
@@ -3,6 +3,7 @@
 #include <math.h>
 #include <assert.h>
 #include <algorithm>
+#include <set>
 
 namespace lost {
 
@@ -11,20 +12,34 @@ bool CatalogStarMagnitudeCompare(const CatalogStar &a, const CatalogStar &b) {
     return a.magnitude < b.magnitude;
 }
 
-/**
- * Remove dim stars from a catalog.
- * @param catalog Original catalog. Not mutated.
- * @param maxMagnitude Stars dimmer than this (greater numerical magnitude) are removed.
- * @param maxStars If there are greater than `maxStars` many stars left after filtering by `maxMagnitude`, only the `maxStars` brightest of them are kept.
- * @return Newly constructed catalog containing only the sufficiently bright stars.
- */
-Catalog NarrowCatalog(const Catalog &catalog, int maxMagnitude, int maxStars) {
+Catalog NarrowCatalog(const Catalog &catalog, int maxMagnitude, int maxStars, float minSeparation) {
     Catalog result;
     for (int i = 0; i < (int)catalog.size(); i++) {
         if (catalog[i].magnitude <= maxMagnitude) {
             result.push_back(catalog[i]);
         }
     }
+
+    // remove stars that are too close to each other
+    std::set<int> tooCloseIndices;
+    // filter out stars that are too close together
+    // easy enough to n^2 brute force, the catalog isn't that big
+    for (int i = 0; i < (int)result.size(); i++) {
+        for (int j = i+1; j < (int)result.size(); j++) {
+            if (AngleUnit(result[i].spatial, result[j].spatial) < minSeparation) {
+                tooCloseIndices.insert(i);
+                tooCloseIndices.insert(j);
+            }
+        }
+    }
+
+    // Erase all the stars whose indices are in tooCloseIndices from the result.
+    // Loop backwards so indices don't get messed up as we iterate.
+    for (auto it = tooCloseIndices.rbegin(); it != tooCloseIndices.rend(); it++) {
+        result.erase(result.begin() + *it);
+    }
+
+    // and finally limit to n brightest stars
     if (maxStars < (int)result.size()) {
         std::sort(result.begin(), result.end(), CatalogStarMagnitudeCompare);
         result.resize(maxStars);
diff --git a/src/star-utils.hpp b/src/star-utils.hpp
index 0cc0c6da..d833412a 100644
--- a/src/star-utils.hpp
+++ b/src/star-utils.hpp
@@ -106,9 +106,23 @@ void SerializeCatalog(const Catalog &, bool inclMagnitude, bool inclName, unsign
 Catalog DeserializeCatalog(const unsigned char *buffer, bool *inclMagnitudeReturn, bool *inclNameReturn);
 Catalog::const_iterator FindNamedStar(const Catalog &catalog, int name);
 
-// TODO: make maxStars work right, need to sort by magnitude before filter! maxMagnitude is 10^-2
-// (so 523 = 5.23)
-Catalog NarrowCatalog(const Catalog &, int maxMagnitude, int maxStars);
+/**
+ * Remove unwanted stars from an unfiltered catalog.
+ *
+ * @param maxMagnitude Should be 100*(magnitude), just like CatalogStar::magnitude. The narrowed
+ * catalog will only contain stars at least as bright as that (i.e., lower magnitude). Pass
+ * something like 9999 to not filter based on magnitude.
+ *
+ * @param maxStars No more than maxStars many stars will be in the narrowed catalog (prefers
+ * brightest). Pass something like 99999 to not filter maxStars.
+ *
+ * @param minDistance Any star which is within minDistance of another star is removed from the
+ * catalog. Pass something like -1 to not filter based on minDistance. TODO: In the future, some
+ * provision may be made so that instead of being removed, these stars get a special distinguishing
+ * mark, so that star-id algorithms can reason about them instead of thinking they are false stars,
+ * but no such provision is made yet.
+ */
+Catalog NarrowCatalog(const Catalog &, int maxMagnitude, int maxStars, float minSeparation);
 
 }
 
diff --git a/test/kvector.cpp b/test/kvector.cpp
index f30d2f8d..e05b2b3d 100644
--- a/test/kvector.cpp
+++ b/test/kvector.cpp
@@ -10,7 +10,7 @@ using namespace lost; // NOLINT
 
 TEST_CASE("Kvector full database stuff", "[kvector]") {
     long length;
-    Catalog &catalog = CatalogRead();
+    const Catalog &catalog = CatalogRead();
     unsigned char *dbBytes = BuildPairDistanceKVectorDatabase(catalog, &length, DegToRad(1.0), DegToRad(2.0), 100);
     REQUIRE(length < 999999);
     PairDistanceKVectorDatabase db(dbBytes);
@@ -53,7 +53,7 @@ TEST_CASE("Kvector full database stuff", "[kvector]") {
 
 TEST_CASE("Tighter tolerance test", "[kvector]") {
     long length;
-    Catalog &catalog = CatalogRead();
+    const Catalog &catalog = CatalogRead();
     unsigned char *dbBytes = BuildPairDistanceKVectorDatabase(catalog, &length, DegToRad(0.5), DegToRad(5.0), 1000);
     REQUIRE(length < 999999);
     PairDistanceKVectorDatabase db(dbBytes);