diff --git a/build.gradle b/build.gradle
index 896876cf73b..aeda92ccb65 100644
--- a/build.gradle
+++ b/build.gradle
@@ -59,7 +59,7 @@ repositories {
     mavenLocal()
 }
 
-final htsjdkVersion = System.getProperty('htsjdk.version','4.2.0')
+final htsjdkVersion = System.getProperty('htsjdk.version','test_cram_wiring-SNAPSHOT')
 final picardVersion = System.getProperty('picard.version','3.4.0')
 final barclayVersion = System.getProperty('barclay.version','5.0.0')
 final sparkVersion = System.getProperty('spark.version', '3.5.0')
diff --git a/src/main/java/org/broadinstitute/hellbender/cmdline/StandardArgumentDefinitions.java b/src/main/java/org/broadinstitute/hellbender/cmdline/StandardArgumentDefinitions.java
index ad1bb00a10a..ad1cdc5a3e2 100644
--- a/src/main/java/org/broadinstitute/hellbender/cmdline/StandardArgumentDefinitions.java
+++ b/src/main/java/org/broadinstitute/hellbender/cmdline/StandardArgumentDefinitions.java
@@ -56,6 +56,10 @@ private StandardArgumentDefinitions(){}
     public static final String INTERVALS_SHORT_NAME = "L";
     public static final String COMPARISON_SHORT_NAME = "comp";
     public static final String READ_INDEX_SHORT_NAME = READ_INDEX_LONG_NAME;
+    public static final String PRIMARY_RESOURCE_LONG_NAME = "primary-resource";
+    public static final String PRIMARY_RESOURCE_SHORT_NAME = "PR";
+    public static final String SECONDARY_RESOURCE_LONG_NAME = "secondary-resource";
+    public static final String SECONDARY_RESOURCE_SHORT_NAME = "SR";
     public static final String LENIENT_SHORT_NAME = "LE";
     public static final String READ_VALIDATION_STRINGENCY_SHORT_NAME = "VS";
     public static final String SAMPLE_ALIAS_SHORT_NAME = "ALIAS";
diff --git a/src/main/java/org/broadinstitute/hellbender/engine/FeatureDataSource.java b/src/main/java/org/broadinstitute/hellbender/engine/FeatureDataSource.java
index bd6fad2f6d2..85eb4d46a92 100644
--- a/src/main/java/org/broadinstitute/hellbender/engine/FeatureDataSource.java
+++ b/src/main/java/org/broadinstitute/hellbender/engine/FeatureDataSource.java
@@ -1,5 +1,10 @@
 package org.broadinstitute.hellbender.engine;
 
+import htsjdk.beta.io.bundle.Bundle;
+import htsjdk.beta.io.bundle.BundleJSON;
+import htsjdk.beta.io.bundle.BundleResource;
+import htsjdk.beta.io.bundle.BundleResourceType;
+import htsjdk.io.IOPath;
 import htsjdk.samtools.SAMSequenceDictionary;
 import htsjdk.samtools.util.IOUtil;
 import htsjdk.samtools.util.Locatable;
@@ -148,7 +153,7 @@ public FeatureDataSource(final File featureFile) {
      * generated name, and will look ahead the default number of bases ({@link #DEFAULT_QUERY_LOOKAHEAD_BASES})
      * during queries that produce cache misses.
      *
-     * @param featurePath path or URI to source of Features
+     * @param featurePath path or URI to source of Features (may be a Bundle)
      */
     public FeatureDataSource(final String featurePath) {
         this(featurePath, null, DEFAULT_QUERY_LOOKAHEAD_BASES, null);
@@ -159,7 +164,7 @@ public FeatureDataSource(final String featurePath) {
      * name. We will look ahead the default number of bases ({@link #DEFAULT_QUERY_LOOKAHEAD_BASES}) during queries
      * that produce cache misses.
      *
-     * @param featureFile file containing Features
+     * @param featureFile file or Bundle containing Features
      * @param name        logical name for this data source (may be null)
      */
     public FeatureDataSource(final File featureFile, final String name) {
@@ -170,7 +175,7 @@ public FeatureDataSource(final File featureFile, final String name) {
      * Creates a FeatureDataSource backed by the provided File and assigns this data source the specified logical
      * name. We will look ahead the specified number of bases during queries that produce cache misses.
      *
-     * @param featureFile         file containing Features
+     * @param featureFile         file or Bundle containing Features
      * @param name                logical name for this data source (may be null)
      * @param queryLookaheadBases look ahead this many bases during queries that produce cache misses
      */
@@ -181,7 +186,7 @@ public FeatureDataSource(final File featureFile, final String name, final int qu
     /**
      * Creates a FeatureDataSource backed by the resource at the provided path.
      *
-     * @param featurePath         path to file or GenomicsDB url containing features
+     * @param featurePath         path to file or GenomicsDB url or Bundle containing features
      * @param name                logical name for this data source (may be null)
      * @param queryLookaheadBases look ahead this many bases during queries that produce cache misses
      * @param targetFeatureType   When searching for a {@link FeatureCodec} for this data source, restrict the search to codecs
@@ -195,7 +200,7 @@ public FeatureDataSource(final String featurePath, final String name, final int
      * Creates a FeatureDataSource backed by the provided FeatureInput. We will look ahead the specified number of bases
      * during queries that produce cache misses.
      *
-     * @param featureInput        a FeatureInput specifying a source of Features
+     * @param featureInput        a FeatureInput specifying a source of Features (or a Bundle)
      * @param queryLookaheadBases look ahead this many bases during queries that produce cache misses
      * @param targetFeatureType   When searching for a {@link FeatureCodec} for this data source, restrict the search to codecs
      *                            that produce this type of Feature. May be null, which results in an unrestricted search.
@@ -207,7 +212,7 @@ public FeatureDataSource(final FeatureInput featureInput, final int queryLook
     /**
      * Creates a FeatureDataSource backed by the resource at the provided path.
      *
-     * @param featurePath              path to file or GenomicsDB url containing features
+     * @param featurePath              path to file or GenomicsDB url or Bundle containing features
      * @param name                     logical name for this data source (may be null)
      * @param queryLookaheadBases      look ahead this many bases during queries that produce cache misses
      * @param targetFeatureType        When searching for a {@link FeatureCodec} for this data source, restrict the search to codecs
@@ -224,7 +229,7 @@ public FeatureDataSource(final String featurePath, final String name, final int
      * Creates a FeatureDataSource backed by the provided FeatureInput. We will look ahead the specified number of bases
      * during queries that produce cache misses.
      *
-     * @param featureInput             a FeatureInput specifying a source of Features
+     * @param featureInput             a FeatureInput specifying a source of Features (may be a Bundle)
      * @param queryLookaheadBases      look ahead this many bases during queries that produce cache misses
      * @param targetFeatureType        When searching for a {@link FeatureCodec} for this data source, restrict the search to codecs
      *                                 that produce this type of Feature. May be null, which results in an unrestricted search.
@@ -241,7 +246,7 @@ public FeatureDataSource(final FeatureInput featureInput, final int queryLook
      * Creates a FeatureDataSource backed by the provided FeatureInput. We will look ahead the specified number of bases
      * during queries that produce cache misses.
      *
-     * @param featureInput             a FeatureInput specifying a source of Features
+     * @param featureInput             a FeatureInput specifying a source of Features (may be a Bundle)
      * @param queryLookaheadBases      look ahead this many bases during queries that produce cache misses
      * @param targetFeatureType        When searching for a {@link FeatureCodec} for this data source, restrict the search to codecs
      *                                 that produce this type of Feature. May be null, which results in an unrestricted search.
@@ -259,7 +264,7 @@ public FeatureDataSource(final FeatureInput featureInput, final int queryLook
      * Creates a FeatureDataSource backed by the provided FeatureInput. We will look ahead the specified number of bases
      * during queries that produce cache misses.
      *
-     * @param featureInput             a FeatureInput specifying a source of Features
+     * @param featureInput             a FeatureInput specifying a source of Features (may be a Bundle)
      * @param queryLookaheadBases      look ahead this many bases during queries that produce cache misses
      * @param targetFeatureType        When searching for a {@link FeatureCodec} for this data source, restrict the search to codecs
      *                                 that produce this type of Feature. May be null, which results in an unrestricted search.
@@ -278,7 +283,7 @@ public FeatureDataSource(final FeatureInput featureInput, final int queryLook
      * Creates a FeatureDataSource backed by the provided FeatureInput. We will look ahead the specified number of bases
      * during queries that produce cache misses.
      *
-     * @param featureInput             a FeatureInput specifying a source of Features
+     * @param featureInput             a FeatureInput specifying a source of Features (may be a Bundle)
      * @param queryLookaheadBases      look ahead this many bases during queries that produce cache misses
      * @param targetFeatureType        When searching for a {@link FeatureCodec} for this data source, restrict the search to codecs
      *                                 that produce this type of Feature. May be null, which results in an unrestricted search.
@@ -296,7 +301,7 @@ public FeatureDataSource(final FeatureInput featureInput, final int queryLook
      * Creates a FeatureDataSource backed by the provided FeatureInput. We will look ahead the specified number of bases
      * during queries that produce cache misses.
      *
-     * @param featureInput             a FeatureInput specifying a source of Features
+     * @param featureInput             a FeatureInput specifying a source of Features (may be a Bundle)
      * @param queryLookaheadBases      look ahead this many bases during queries that produce cache misses
      * @param targetFeatureType        When searching for a {@link FeatureCodec} for this data source, restrict the search to codecs
      *                                 that produce this type of Feature. May be null, which results in an unrestricted search.
@@ -369,9 +374,26 @@ private static  FeatureReader getFeatureReader(final Featu
             } catch (final ClassCastException e) {
                 throw new UserException("GenomicsDB inputs can only be used to provide VariantContexts.", e);
             }
+        } else if (featureInput.hasExtension(BundleJSON.BUNDLE_EXTENSION)) {
+            // the feature input specifies a serialized json bundle file
+            final Bundle vcfBundle = BundleJSON.toBundle(htsjdk.beta.plugin.IOUtils.getStringFromPath(featureInput), GATKPath::new);
+            final IOPath vcfPath = vcfBundle.getOrThrow(BundleResourceType.CT_VARIANT_CONTEXTS).getIOPath().get();
+            // to get the codec we have to use the path of the underlying vcf resource, not the bundle path
+            final FeatureInput fi = new FeatureInput(vcfPath.getRawInputString(), featureInput.getName());
+            final FeatureCodec codec = getCodecForFeatureInput(fi, targetFeatureType, setNameOnCodec);
+            // propagate the bundle path, not the vcf path, to the reader, so that downstream code can retrieve
+            // the index path from the bundle
+            return getTribbleFeatureReader(featureInput, codec, cloudWrapper, cloudIndexWrapper);
+        } else if (featureInput.getParentBundle() != null) {
+            // the featureInput was created from a bundle list expansion (i.e, MultiVariantWalkers). it has the
+            // primary resource as the underlying resource path, and the containing bundle attached as the
+            // "parent bundle". Use the original FI to get the codec, but to get the feature reader, we use
+            // the FI that contains the bundle path, since the feature reader may require acccess to the index
+            final FeatureCodec codec = getCodecForFeatureInput(featureInput, targetFeatureType, setNameOnCodec);
+            return getTribbleFeatureReader(featureInput, codec, cloudWrapper, cloudIndexWrapper);
         } else {
             final FeatureCodec codec = getCodecForFeatureInput(featureInput, targetFeatureType, setNameOnCodec);
-            if ( featureInput.getFeaturePath().toLowerCase().endsWith(BCI_FILE_EXTENSION) ) {
+            if (featureInput.getFeaturePath().toLowerCase().endsWith(BCI_FILE_EXTENSION)) {
                 return new Reader(featureInput, codec);
             }
             return getTribbleFeatureReader(featureInput, codec, cloudWrapper, cloudIndexWrapper);
@@ -419,18 +441,48 @@ private static  FeatureReader getFeatureReader(final Featu
     private static  AbstractFeatureReader getTribbleFeatureReader(final FeatureInput featureInput, final FeatureCodec codec, final Function cloudWrapper, final Function cloudIndexWrapper) {
         Utils.nonNull(codec);
         try {
-            // Must get the path to the data file from the codec here:
-            final String absoluteRawPath = featureInput.getRawInputString();
-
             // Instruct the reader factory to not require an index. We will require one ourselves as soon as
             // a query by interval is attempted.
             final boolean requireIndex = false;
 
-            // Only apply the wrappers if the feature input is in a remote location which will benefit from prefetching.
-            if (BucketUtils.isEligibleForPrefetching(featureInput)) {
-                return AbstractFeatureReader.getFeatureReader(absoluteRawPath, null, codec, requireIndex, cloudWrapper, cloudIndexWrapper);
+            if (featureInput.hasExtension(BundleJSON.BUNDLE_EXTENSION)) {
+                final Bundle vcfBundle = BundleJSON.toBundle(htsjdk.beta.plugin.IOUtils.getStringFromPath(featureInput), GATKPath::new);
+                final IOPath vcfPath = vcfBundle.getOrThrow(BundleResourceType.CT_VARIANT_CONTEXTS).getIOPath().get();
+                final Optional vcfIndexPath = vcfBundle.get(BundleResourceType.CT_VARIANTS_INDEX);
+                final String rawIndexResourcePath =
+                        vcfIndexPath.isPresent() ? vcfIndexPath.get().getIOPath().get().getRawInputString() : null;
+
+                // Only apply the wrappers if the feature input is in a remote location which will benefit from prefetching.
+                if (BucketUtils.isEligibleForPrefetching(vcfPath)) {
+                    final String absoluteRawPath = vcfPath.getRawInputString();
+                    return AbstractFeatureReader.getFeatureReader(absoluteRawPath, rawIndexResourcePath, codec, requireIndex, cloudWrapper, cloudIndexWrapper);
+                } else {
+                    return AbstractFeatureReader.getFeatureReader(vcfPath.getRawInputString(), rawIndexResourcePath, codec, requireIndex, Utils.identityFunction(), Utils.identityFunction());
+                }
+            } else if (featureInput.getParentBundle() != null) {
+                final Bundle vcfBundle = featureInput.getParentBundle();
+                // code path for when a user has specified multiple bundles on the command line, so there is no single
+                // serialized bundle file to access
+                final IOPath vcfPath = vcfBundle.getOrThrow(BundleResourceType.CT_VARIANT_CONTEXTS).getIOPath().get();
+                // Only apply the wrappers if the feature input is in a remote location which will benefit from prefetching.
+                final Optional vcfIndexPath = vcfBundle.get(BundleResourceType.CT_VARIANTS_INDEX);
+                final String rawIndexResourcePath =
+                        vcfIndexPath.isPresent() ? vcfIndexPath.get().getIOPath().get().getRawInputString() : null;
+                final String absoluteRawPath = vcfPath.getRawInputString();
+                if (BucketUtils.isEligibleForPrefetching(vcfPath)) {
+                    return AbstractFeatureReader.getFeatureReader(absoluteRawPath, rawIndexResourcePath, codec, requireIndex, cloudWrapper, cloudIndexWrapper);
+                } else {
+                    return AbstractFeatureReader.getFeatureReader(absoluteRawPath, rawIndexResourcePath, codec, requireIndex, Utils.identityFunction(), Utils.identityFunction());
+                }
             } else {
-                return AbstractFeatureReader.getFeatureReader(absoluteRawPath, null, codec, requireIndex, Utils.identityFunction(), Utils.identityFunction());
+                final String absoluteRawPath = featureInput.getRawInputString();
+
+                // Only apply the wrappers if the feature input is in a remote location which will benefit from prefetching.
+                if (BucketUtils.isEligibleForPrefetching(featureInput)) {
+                    return AbstractFeatureReader.getFeatureReader(absoluteRawPath, null, codec, requireIndex, cloudWrapper, cloudIndexWrapper);
+                } else {
+                    return AbstractFeatureReader.getFeatureReader(absoluteRawPath, null, codec, requireIndex, Utils.identityFunction(), Utils.identityFunction());
+                }
             }
         } catch (final TribbleException e) {
             throw new GATKException("Error initializing feature reader for path " + featureInput.getFeaturePath(), e);
diff --git a/src/main/java/org/broadinstitute/hellbender/engine/FeatureInput.java b/src/main/java/org/broadinstitute/hellbender/engine/FeatureInput.java
index 53bcb117afc..e0a108d58ed 100644
--- a/src/main/java/org/broadinstitute/hellbender/engine/FeatureInput.java
+++ b/src/main/java/org/broadinstitute/hellbender/engine/FeatureInput.java
@@ -1,6 +1,7 @@
 package org.broadinstitute.hellbender.engine;
 
 import com.google.common.annotations.VisibleForTesting;
+import htsjdk.beta.io.bundle.Bundle;
 import htsjdk.tribble.Feature;
 import htsjdk.tribble.FeatureCodec;
 import org.apache.logging.log4j.LogManager;
@@ -52,6 +53,12 @@ public final class FeatureInput extends GATKPath implements S
      */
     private transient Class> featureCodecClass;
 
+    /**
+     * retain the parent (enclosing) bundle from which this feature input is derived, in case we need to extract
+     * other resources from it
+     */
+    private Bundle parentBundle;
+
     /**
      * Delimiter between the logical name and the file name in the --argument_name logical_name:feature_file syntax
      */
@@ -129,6 +136,34 @@ public FeatureInput(final String rawInputSpecifier, final String name, final Map
         setTagAttributes(keyValueMap);
     }
 
+    /**
+     * Construct a FeatureInput from a Bundle.
+     *
+     * @param primaryResourcePath the path for the primary feature resource for this bundle
+     * @param featureBundle an existing Bundle object; resources in this bundle MUST be IOPathBundleResources (that is,
+     *                      they must be backed by an IOPath, not an in-memory object)
+     * @param name the tag name for this feature input - may be null
+     */
+    public FeatureInput(
+            final GATKPath primaryResourcePath,
+            final Bundle featureBundle,
+            final String name) {
+        super(primaryResourcePath);
+        // retain the enclosing bundle for later, so we can interrogate it for other resources such as the index
+        this.parentBundle = featureBundle;
+        if (name != null) {
+            if (primaryResourcePath.getTag() != null) {
+                logger.warn(String.format(
+                        "FeatureInput: user-provided tag name %s will be replaced with %s",
+                        primaryResourcePath.getTag(),
+                        name));
+            }
+            setTag(name);
+        }
+
+    }
+
+
     /**
      * Remember the FeatureCodec class for this input the first time it is discovered so we can bypass dynamic codec
      * discovery when multiple FeatureDataSources are created for the same input.
@@ -144,6 +179,14 @@ public void setFeatureCodecClass(final Class> featureCodecCla
         return this.featureCodecClass;
     }
 
+    /**
+     * @return the parent bundle for this FeatureInput, if this input was derived from a Bundle.  May
+     * return {@code null}. The returned bundle can be interrogated for companion resources.
+     */
+    public Bundle getParentBundle() {
+        return parentBundle;
+    }
+
     /**
      * creates a name from the given filePath by finding the absolute path of the given input
      */
diff --git a/src/main/java/org/broadinstitute/hellbender/engine/MultiVariantWalker.java b/src/main/java/org/broadinstitute/hellbender/engine/MultiVariantWalker.java
index 7f12ff641e2..189104155cd 100644
--- a/src/main/java/org/broadinstitute/hellbender/engine/MultiVariantWalker.java
+++ b/src/main/java/org/broadinstitute/hellbender/engine/MultiVariantWalker.java
@@ -1,5 +1,10 @@
 package org.broadinstitute.hellbender.engine;
 
+import htsjdk.beta.io.bundle.Bundle;
+import htsjdk.beta.io.bundle.BundleJSON;
+import htsjdk.beta.io.bundle.BundleResource;
+import htsjdk.beta.io.bundle.BundleResourceType;
+import htsjdk.beta.plugin.IOUtils;
 import htsjdk.samtools.SAMSequenceDictionary;
 import htsjdk.variant.variantcontext.VariantContext;
 import htsjdk.variant.vcf.VCFHeader;
@@ -74,17 +79,54 @@ public boolean doDictionaryCrossValidation() {
     @Override
     protected void initializeDrivingVariants() {
         multiVariantInputArgumentCollection.getDrivingVariantPaths().stream().forEach(
-                f -> {
-                    FeatureInput featureInput = new FeatureInput<>(f);
-                    if (drivingVariantsFeatureInputs.contains(featureInput)) {
-                        throw new UserException.BadInput("Feature inputs must be unique: " + featureInput.toString());
+                gatkPath -> {
+                    if (gatkPath.hasExtension(BundleJSON.BUNDLE_EXTENSION)) {
+                        // expand any bundle(s) into one or more FeatureInputs (depending on whether it is a single
+                        // bundle or list)
+                        final List bundles = BundleJSON.toBundleList(IOUtils.getStringFromPath(gatkPath), GATKPath::new);
+                        for (final Bundle bundle : bundles) {
+                            if (bundle.getPrimaryContentType().equals(BundleResourceType.CT_VARIANT_CONTEXTS)) {
+                                // use the bundle primary resource as the FeatureInput URI, and tear off and attach
+                                // the enclosing bundle as the parent bundle for the FI so downstream code can extract
+                                // other resources from it on demand. note that if the original value from the user has
+                                // a tag, we can't propagate it unless there is only one input, since FIs have to be
+                                // unique
+                                final FeatureInput bundleFI = new FeatureInput<>(
+                                        new GATKPath(bundle.getPrimaryResource().getIOPath().get().getURIString()),
+                                        bundle,
+                                        bundles.size() > 1 ?
+                                                gatkPath.getTag() :
+                                                "drivingVariants"
+                                );
+                                if (drivingVariantsFeatureInputs.contains(bundleFI)) {
+                                    throw new UserException.BadInput("Feature inputs must be unique: " + gatkPath);
+                                }
+                                drivingVariantsFeatureInputs.add(bundleFI);
+                                // Add each driving variants FeatureInput to the feature manager so that it can be queried, using a lookahead value
+                                // of 0 to avoid caching because of windowed queries that need to "look behind" as well.
+                                features.addToFeatureSources(0, bundleFI, VariantContext.class, cloudPrefetchBuffer, cloudIndexPrefetchBuffer,
+                                        referenceArguments.getReferencePath());
+                            } else {
+                                final BundleResource br = bundle.getPrimaryResource();
+                                throw new UserException.BadInput(
+                                        String.format(
+                                                "Feature input bundles must have a primary resource of type %s. Found content type %s with path %s",
+                                                BundleResourceType.CT_VARIANT_CONTEXTS,
+                                                bundle.getPrimaryContentType(),
+                                                br.getIOPath().get()));
+                            }
+                        }
+                    } else {
+                        final FeatureInput featureInput = new FeatureInput<>(gatkPath);
+                        if (drivingVariantsFeatureInputs.contains(featureInput)) {
+                            throw new UserException.BadInput("Feature inputs must be unique: " + gatkPath);
+                        }
+                        drivingVariantsFeatureInputs.add(featureInput);
+                        // Add each driving variants FeatureInput to the feature manager so that it can be queried, using a lookahead value
+                        // of 0 to avoid caching because of windowed queries that need to "look behind" as well.
+                        features.addToFeatureSources(0, featureInput, VariantContext.class, cloudPrefetchBuffer, cloudIndexPrefetchBuffer,
+                                referenceArguments.getReferencePath());
                     }
-                    drivingVariantsFeatureInputs.add(featureInput);
-
-                    // Add each driving variants FeatureInput to the feature manager so that it can be queried, using a lookahead value
-                    // of 0 to avoid caching because of windowed queries that need to "look behind" as well.
-                    features.addToFeatureSources(0, featureInput, VariantContext.class, cloudPrefetchBuffer, cloudIndexPrefetchBuffer,
-                                                 referenceArguments.getReferencePath());
                 }
         );
 
diff --git a/src/main/java/org/broadinstitute/hellbender/tools/CreateBundle.java b/src/main/java/org/broadinstitute/hellbender/tools/CreateBundle.java
new file mode 100644
index 00000000000..8c2567c3309
--- /dev/null
+++ b/src/main/java/org/broadinstitute/hellbender/tools/CreateBundle.java
@@ -0,0 +1,404 @@
+package org.broadinstitute.hellbender.tools;
+
+import htsjdk.beta.io.bundle.*;
+import htsjdk.beta.plugin.registry.HaploidReferenceResolver;
+import htsjdk.beta.plugin.variants.VariantsBundle;
+import htsjdk.samtools.util.FileExtensions;
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.Logger;
+import org.broadinstitute.barclay.argparser.Argument;
+import org.broadinstitute.barclay.argparser.CommandLineProgramProperties;
+import org.broadinstitute.barclay.help.DocumentedFeature;
+import org.broadinstitute.hellbender.cmdline.CommandLineProgram;
+import org.broadinstitute.hellbender.cmdline.StandardArgumentDefinitions;
+import org.broadinstitute.hellbender.engine.GATKPath;
+import picard.cmdline.programgroups.OtherProgramGroup;
+
+import java.io.*;
+import java.nio.file.Files;
+import java.nio.file.StandardOpenOption;
+import java.util.*;
+
+/**
+ * 
+ * Create a single bundle (JSON) file for one or more related inputs, for use as input to a GATK tool.
+ * 
Bundle File Structure
+ * A bundle is a JSON file that contains references to one or more related resources (i.e., a VCF file
+ * and it's associated index file, or a .fasta reference file and it's associated index and dictionary files).
+ * Bundle files can be supplied as inputs for many GATK tools. The primary advantage to using a bundle input
+ * over an individual file input is that a bundle allows the individual resources to be located in different
+ * directories (ie., when providing a VCF input, the corresponding index file generally needs to be a sibling
+ * file in the same directory as the VCF, whereas using a bundle file, because each resource is specified
+ * explicitly, the index file can be located in a different directory than the VCF).
+ * 
+ * Each resource in a bundle has an associated content type, which is a string that identifies the type of data
+ * in that resource. One resource in the bundle is always designated as the "primary" resource, which determines
+ * the type of the bundle.
+ *
+ *  An example bundle JSON file is show below. The bundle has 3 resources, with content types
+ * "HAPLOID_REFERENCE", "REFERENCE_DICTIONARY", and "REFERENCE_INDEX" respectively, with the "HAPLOID_REFERENCE"
+ * resource designated as the primary resource. This bundle is a reference bundle, and can be used as an
+ * input where ever a reference argument is required.
+ * 
+ *  {
+ *    "schema": {
+ *     "schemaVersion": "0.1.0",
+ *     "schemaName": "htsbundle"
+ *    },
+ *    "HAPLOID_REFERENCE": {"path": "file:///projects/print_reads.fasta"},
+ *    "REFERENCE_DICTIONARY": {"path": "file:///projects/print_reads.dict"},
+ *    "REFERENCE_INDEX": {"path": "file:///projects/print_reads.fasta.fai"},
+ *    "primary": "HAPLOID_REFERENCE"
+ *  }
+ * 
+ * Using CreateBundle
+ * 
+ * CreateBundle requires at least one primary resource input. One or more optional secondary resource inputs
+ * may also be supplied.
+ * 
+ * The simplest way to use CreateBundle is to specify only the primary resource. In this case, with no secondary
+ * resources are explicitly provided, CreateBundle will attempt to locate and resolve "standard" secondary resources
+ * (see "Standard Secondary Resources" below) for the primary resource, as long as:
+ * 
+ *     - the content type of the primary resource can be determined from the resources's file extension+ *
- the primary resource content type is a well known type (i.e., a variants or a fasta file)+ *
- the secondary resources are siblings (in the same parent directory) as the primary resource+ *
+ * The "--suppress-resource-resolution" argument can be used to suppress secondary resource resolution behavior.
+ * If the type of the primary resource is not explicitly provided, or cannot be determined from the file extension,
+ * or if a standard secondary resource for a standard primary resource cannot be found in the same directory as
+ * the primary, an exception will be thrown.
+ *
+ * Alternatively, you can specify all of the resources and their content types explicitly. This is useful when
+ * the resources are not in the same directory, or when the content types are not standard.
+ * 
+ * For the primary resource, if the content type is not specified on the command line (content types are
+ * supplied on the command line using argument tags - see "Standard Content Types" and the examples below),
+ * CreateBundle will attempt to  determine the content type of the primary resource. Content types for explicitly
+ * supplied secondary resources are never inferred, and must always be supplied explicitly.
+ * 
+ * Bundle output file names must end with the suffix ".json".
+ * 
+ * 
Standard Content Types
+ * In general, bundle content types can be any string, but many tools expect bundles to use standard, well known
+ * content types that are pre-defined, such as content types for a VCF, a VCF index, a .fasta file, or a reference
+ * dictionary file. The common well known content type strings that can be used as command line argument tags are:
+ * Standard VCF Content Types:
+ * 
+ *  - "CT_VARIANT_CONTEXTS": a VCF file+ *
- "CT_VARIANTS_INDEX": a VCF index file+ *
+ *Standard Reference Content Types:
+ * 
+ *  - "CT_HAPLOID_REFERENCE": a fasta reference file+ *
- "CT_HAPLOID_REFERENCE_INDEX": a fasta index file+ *
- "CT_HAPLOID_REFERENCE_DICTIONARY": a fasta dictionary file+ *
+ * 
Standard Secondary Resources
+ * VCF standard secondary resources:
+ * 
+ * FASTA reference standard secondary resources:
+ * 
+ * - an index file+ *
- a dictionary file+ *
+ *Bundle Creation Examples
+ * 
+ * VCF Bundle Examples
+ * 
+ * 1) Create a resource bundle for a VCF from just the VCF, letting the tool resolve the secondary (index) resource by
+ * automatically finding the sibling index file, and letting the tool determine the content types. If the sibling index
+ * file cannot be found, an exception will be thrown. The resulting bundle contains the VCF and associated index.
+ * 
+ *    CreateBundle \
+ *      --primary path/to/my.vcf \
+ *      --output mybundle.json
+ * 
+ * The exact same bundle could be created manually by specifying both the resources and the content types explicitly:
+ * 
+ *     CreateBundle \
+ *      --primary:CT_VARIANT_CONTEXTS path/to/my.vcf \
+ *      --secondary:CT_VARIANTS_INDEX path/to/my.vcf.idx \
+ *      --output mybundle.json
+ * 
+ * 
+ * 2) Create a resource bundle for a VCF from just the VCF, but suppress automatic resolution of the secondary
+ * resources. Let the tool determine the content type. The resulting bundle will contain only the VCF resource:
+ * 
+ *    CreateBundle \
+ *      --primary path/to/my.vcf \
+ *      --suppress-resource-resolution \
+ *      --output mybundle.json
+ * 
+ *  3) Create a resource bundle for a VCF, but specify the VCF AND the secondary index resource explicitly (which
+ *  suppresses automatic secondary resolution). This is useful when the VCF and index are not in the same directory.
+ *  Let the tool determine the primary content type. The resulting bundle will contain the VCF and index resources:
+ * 
+ *     CreateBundle \
+ *      --primary path/to/my.vcf \
+ *      --secondary:CT_VARIANTS_INDEX some/other/path/to/vcd.idx \
+ *      --output mybundle.json
+ * 
+ *  4) Create a resource bundle for a VCF, but specify the VCF AND the secondary index resource explicitly (this
+ *  is useful when the VCF and index are not in the same directory), and specify the content types explicitly via
+ *  command line argument tags. The resulting bundle will contain the VCF and index resources.
+ * 
+ *     CreateBundle \
+ *      --primary:CT_VARIANT_CONTEXTS path/to/my.vcf \
+ *      --secondary:CT_VARIANTS_INDEX some/other/path/to/vcd.idx \
+ *      --output mybundle.json
+ * 
+ *
Reference Bundle Examples
+ *
+ * 1) Create a resource bundle for a reference from just the .fasta, letting the tool resolve the secondary
+ * (index and dictionary) resource by automatically finding the sibling files, and determining the content types.
+ * If the sibling index file cannot be found, an exception will be thrown. The resulting bundle will contain the
+ * reference, index, and dictionary.
+ * 
+ *    CreateBundle \
+ *      --primary path/to/my.fasta \
+ *      --output mybundle.json
+ * 
+ * 2) Create a resource bundle for a reference from just the .fasta, but suppress resolution of the secondary index and
+ * dictionary resources. Let the tool determine the content type. The resulting bundle will contain only the .fasta
+ * resource:
+ * 
+ *    CreateBundle \
+ *      --primary path/to/my.fasta \
+ *      --suppress-resource-resolution \
+ *      --output mybundle.json
+ * 
+ *  3) Create a resource bundle for a fasta, but specify the fasta AND the secondary index and dictionary resources
+ *  explicitly (which suppresses automatic secondary resolution). Let the tool determine the content types. The
+ *  resulting bundle will contain the fasta, index  and dictionary resources:
+ * 
+ *     CreateBundle \
+ *      --primary path/to/my.fasta \
+ *      --secondary:CT_HAPLOID_REFERENCE_INDEX some/other/path/to/my.fai \
+ *      --secondary:CT_HAPLOID_REFERENCE_DICTIONARY some/other/path/to/my.dict \
+ *      --output mybundle.json
+ * 
+ *  4) Create a resource bundle for a fasta, but specify the fasta, index and dictionary resources and the content
+ *  types explicitly. The resulting bundle will contain the fasta, index  and dictionary resources:
+ * 
+ *     CreateBundle \
+ *      --primary:CT_HAPLOID_REFERENCE path/to/my.fasta \
+ *      --secondary:CT_HAPLOID_REFERENCE_INDEX some/other/path/to/my.fai \
+ *      --secondary:CT_HAPLOID_REFERENCE_DICTIONARY some/other/path/to/my.dict \
+ *      --output mybundle.json
+ * 
+ */
+@DocumentedFeature
+@CommandLineProgramProperties(
+        summary = "Create a bundle (JSON) file for use with a GATK tool",
+        oneLineSummary = "Create a bundle (JSON) file for use with a GATK tool",
+        programGroup = OtherProgramGroup.class
+)
+public class CreateBundle extends CommandLineProgram {
+    protected static final Logger logger = LogManager.getLogger(CreateBundle.class);
+
+    @Argument(fullName = StandardArgumentDefinitions.PRIMARY_RESOURCE_LONG_NAME,
+            shortName = StandardArgumentDefinitions.PRIMARY_RESOURCE_SHORT_NAME,
+            doc="Path to the primary resource (content type will be inferred if no content type tag is specified)")
+    GATKPath primaryResource;
+
+    @Argument(fullName = StandardArgumentDefinitions.SECONDARY_RESOURCE_LONG_NAME,
+            shortName = StandardArgumentDefinitions.SECONDARY_RESOURCE_SHORT_NAME,
+            doc = "Path to a secondary resource for" + StandardArgumentDefinitions.PRIMARY_RESOURCE_LONG_NAME +
+                    " (usually an index). If no secondary resource is specified, standard secondary resources" +
+                    " for the primary bundle resource will be automatically resolved unless " +
+                    SUPPRESS_SECONDARY_RESOURCE_RESOLUTION_FULL_NAME +
+                    " is specified.",
+            optional = true)
+    GATKPath secondaryResource;
+
+    public static final String OTHER_RESOURCE_FULL_NAME = "other-resource";
+    @Argument(fullName = OTHER_RESOURCE_FULL_NAME,
+            shortName = OTHER_RESOURCE_FULL_NAME,
+            doc = "Path to other bundle resources for " + StandardArgumentDefinitions.PRIMARY_RESOURCE_LONG_NAME
+                    + ". The content is not inferred for \"other\" (non-primary and non-secondary) resources, so a" +
+                    " content type tag MUST be provided for each \"other\" resource.",
+            optional = true)
+    List otherResources;
+
+    public static final String SUPPRESS_SECONDARY_RESOURCE_RESOLUTION_FULL_NAME = "suppress-resource-resolution";
+    @Argument(fullName = SUPPRESS_SECONDARY_RESOURCE_RESOLUTION_FULL_NAME,
+            doc ="Don't attempt to resolve the primary resource's secondary resources if no secondary resource is explicitly" +
+                    " provided (defaults to false) ",
+            optional = true)
+    boolean suppressResourceResolution = false;
+
+    @Argument(fullName = StandardArgumentDefinitions.OUTPUT_LONG_NAME,
+            shortName = StandardArgumentDefinitions.OUTPUT_SHORT_NAME,
+            doc = "Path the output bundle file (must end with the suffix " + BundleJSON.BUNDLE_EXTENSION + ")")
+    GATKPath outputBundlePath;
+
+    private enum BundleType {
+        VCF,
+        REFERENCE,
+        CUSTOM
+    }
+    private BundleType outputBundleType;
+
+    @Override
+    protected String[] customCommandLineValidation() {
+        if (!outputBundlePath.toString().endsWith(BundleJSON.BUNDLE_EXTENSION)){
+            return new String[]{ String.format("Output bundle path must end with the suffix %s", BundleJSON.BUNDLE_EXTENSION) };
+        }
+        outputBundleType = determinePrimaryContentType();
+        return super.customCommandLineValidation();
+    }
+
+    @Override
+    protected Object doWork() {
+        try (final BufferedWriter writer = Files.newBufferedWriter(outputBundlePath.toPath(), StandardOpenOption.CREATE)) {
+            final Bundle bundle = switch (outputBundleType) {
+                case VCF -> createVCFBundle();
+                case REFERENCE -> createHaploidReferenceBundle();
+                case CUSTOM -> createOtherBundle();
+            };
+            writer.write(BundleJSON.toJSON(bundle));
+        } catch (final IOException e) {
+            throw new RuntimeException(String.format("Failed writing bundle to output %s", outputBundlePath), e);
+        }
+        return null;
+    }
+
+    private BundleType determinePrimaryContentType() {
+        BundleType bundleType;
+
+        // determine the type of bundle to create; consult the tag attributes if any, otherwise try to infer from the
+        // primary resource's file extension
+        final String primaryContentTag = primaryResource.getTag();
+        if (primaryContentTag != null) {
+            if (primaryContentTag.equals(BundleResourceType.CT_VARIANT_CONTEXTS)) {
+                bundleType = BundleType.VCF;
+            } else if (primaryContentTag.equals(BundleResourceType.CT_HAPLOID_REFERENCE)) {
+                bundleType = BundleType.REFERENCE;
+            } else {
+                logger.info(String.format("Primary input content type %s for %s not recognized. A bundle will be created using content types from the provided argument tags.",
+                        primaryContentTag,
+                        primaryResource));
+                bundleType = BundleType.CUSTOM;
+            }
+        } else {
+            logger.info(String.format("A content type for the primary input was not provided. Attempting to infer the primary content type from the %s extension.", primaryResource));
+            bundleType = inferPrimaryContentType(primaryResource);
+        }
+        return bundleType;
+    }
+
+    private BundleType inferPrimaryContentType(final GATKPath primaryResource) {
+        logger.info("Attempting to infer bundle content type from file extension.");
+        if (FileExtensions.VCF_LIST.stream().anyMatch(ext -> primaryResource.hasExtension(ext))) {
+            return BundleType.VCF;
+        } else if (FileExtensions.FASTA.stream().anyMatch(ext -> primaryResource.hasExtension(ext))) {
+            return BundleType.REFERENCE;
+        } else {
+            throw new IllegalArgumentException(String.format("Unable to infer bundle content type from file extension %s. A content type must be provided as part of the argument.", primaryResource));
+        }
+    }
+
+    private Bundle createVCFBundle() {
+        final Collection bundleResources = new ArrayList<>();
+
+        bundleResources.add(new IOPathResource(primaryResource, BundleResourceType.CT_VARIANT_CONTEXTS));
+        if (secondaryResource != null) {
+            final String secondaryContentType = secondaryResource.getTag();
+            if (secondaryContentType == null) {
+                throw new IllegalArgumentException(String.format("A content type for the secondary input %s must be provided.",
+                        secondaryResource.getRawInputString()));
+            } else {
+                bundleResources.add(new IOPathResource(secondaryResource, secondaryContentType));
+            }
+        } else if (!suppressResourceResolution) {
+            // secondary resources is null, and resource resolution suppression is off
+            final Optional indexPath = VariantsBundle.resolveIndex(primaryResource, GATKPath::new);
+            if (indexPath.isEmpty()) {
+                throw new IllegalArgumentException(
+                        String.format(
+                                "Could not resolve an index for %s, you must either specify the index path as a secondary input on the command line or specify the %s argument.",
+                                primaryResource.getRawInputString(),
+                                SUPPRESS_SECONDARY_RESOURCE_RESOLUTION_FULL_NAME));
+            }
+            bundleResources.add(new IOPathResource(indexPath.get(), BundleResourceType.CT_VARIANTS_INDEX));
+        }
+        if (otherResources != null && !otherResources.isEmpty()) {
+            for (final GATKPath otherInput : otherResources) {
+                final String otherContentType = otherInput.getTag();
+                if (otherContentType == null) {
+                    throw new IllegalArgumentException(
+                            String.format(
+                                    "A content must be provided for \"other\" input %s.",
+                                    otherInput.getRawInputString()));
+                } else {
+                    bundleResources.add(new IOPathResource(otherInput, otherContentType));
+                }
+            }
+        }
+        return new VariantsBundle(bundleResources);
+    }
+
+    private Bundle createHaploidReferenceBundle() {
+        final Collection bundleResources = new ArrayList<>();
+        if (secondaryResource == null && (otherResources == null || otherResources.isEmpty())) {
+            // resolve dictionary and index
+            return HaploidReferenceResolver.referenceBundleFromFastaPath(primaryResource, GATKPath::new);
+        }
+
+        bundleResources.add(new IOPathResource(primaryResource, primaryResource.getTag()));
+        if (secondaryResource != null) {
+            final String secondaryContentType = secondaryResource.getTag();
+            if (secondaryContentType == null) {
+                throw new IllegalArgumentException(String.format("A content type for the secondary input %s must be provided.",
+                        secondaryResource.getRawInputString()));
+            } else {
+                bundleResources.add(new IOPathResource(secondaryResource, secondaryContentType));
+            }
+        }
+        if (otherResources != null && !otherResources.isEmpty()) {
+            for (final GATKPath otherInput : otherResources) {
+                final String otherContentType = otherInput.getTag();
+                if (otherContentType == null) {
+                    throw new IllegalArgumentException(
+                            String.format(
+                                    "A content type must be provided for \"other\" input %s.",
+                                    otherInput.getRawInputString()));
+                } else {
+                    bundleResources.add(new IOPathResource(otherInput, otherContentType));
+                }
+            }
+        }
+        return new Bundle(primaryResource.getTag(), bundleResources);
+    }
+
+    private Bundle createOtherBundle() {
+        final Collection bundleResources = new ArrayList<>();
+        bundleResources.add(new IOPathResource(primaryResource, primaryResource.getTag()));
+        if (secondaryResource != null) {
+            final String secondaryContentType = secondaryResource.getTag();
+            if (secondaryContentType == null) {
+                throw new IllegalArgumentException(String.format("A content type for the secondary input %s must be provided.",
+                        secondaryResource.getRawInputString()));
+            } else {
+                bundleResources.add(new IOPathResource(secondaryResource, secondaryContentType));
+            }
+        }
+        if (otherResources != null && !otherResources.isEmpty()) {
+            for (final GATKPath otherInput : otherResources) {
+                final String otherContentType = otherInput.getTag();
+                if (otherContentType == null) {
+                    throw new IllegalArgumentException(
+                            String.format(
+                                    "A content type must be provided for \"other\" input %s.",
+                                    otherInput.getRawInputString()));
+                } else {
+                    bundleResources.add(new IOPathResource(otherInput, otherContentType));
+                }
+            }
+        }
+        return new Bundle(primaryResource.getTag(), bundleResources);
+    }
+}
diff --git a/src/main/java/org/broadinstitute/hellbender/utils/fasta/CachingIndexedFastaSequenceFile.java b/src/main/java/org/broadinstitute/hellbender/utils/fasta/CachingIndexedFastaSequenceFile.java
index 6cd2d678347..88b07140257 100644
--- a/src/main/java/org/broadinstitute/hellbender/utils/fasta/CachingIndexedFastaSequenceFile.java
+++ b/src/main/java/org/broadinstitute/hellbender/utils/fasta/CachingIndexedFastaSequenceFile.java
@@ -1,5 +1,9 @@
 package org.broadinstitute.hellbender.utils.fasta;
 
+import htsjdk.beta.io.bundle.Bundle;
+import htsjdk.beta.io.bundle.BundleJSON;
+import htsjdk.beta.plugin.IOUtils;
+import htsjdk.io.IOPath;
 import htsjdk.samtools.SAMException;
 import htsjdk.samtools.SAMSequenceDictionary;
 import htsjdk.samtools.SAMSequenceRecord;
@@ -143,14 +147,24 @@ public CachingIndexedFastaSequenceFile(final Path fasta, boolean preserveAmbigui
      * @param preserveIUPAC If true, we will keep the IUPAC bases in the FASTA, otherwise they are converted to Ns
      */
      public CachingIndexedFastaSequenceFile(final Path fasta, final long cacheSize, final boolean preserveCase, final boolean  preserveIUPAC) {
-        // Check the FASTA path:
-        checkFastaPath(fasta);
         Utils.validate(cacheSize > 0, () -> "Cache size must be > 0 but was " + cacheSize);
 
         // Read reference data by creating an IndexedFastaSequenceFile.
         try {
-            final ReferenceSequenceFile referenceSequenceFile = ReferenceSequenceFileFactory.getReferenceSequenceFile(fasta, true, true);
-            sequenceFile = requireIndex(fasta, referenceSequenceFile);
+            final IOPath fastaPath = new GATKPath(fasta.toUri().toString());
+            if (fastaPath.hasExtension(BundleJSON.BUNDLE_EXTENSION)) {
+                final Bundle referenceBundle = BundleJSON.toBundle(IOUtils.getStringFromPath(fastaPath), GATKPath::new);
+                final ReferenceSequenceFile referenceSequenceFile = ReferenceSequenceFileFactory.getReferenceSequenceFileFromBundle(
+                        referenceBundle,
+                        true,
+                        true);
+                sequenceFile = requireIndex(fasta, referenceSequenceFile);
+            } else {
+                // Check the FASTA path:
+                checkFastaPath(fasta);
+                final ReferenceSequenceFile referenceSequenceFile = ReferenceSequenceFileFactory.getReferenceSequenceFile(fasta, GATKPath::new, true, true);
+                sequenceFile = requireIndex(fasta, referenceSequenceFile);
+            }
             this.cacheSize = cacheSize;
             this.cacheMissBackup = Math.max(cacheSize / 1000, 1);
             this.preserveCase = preserveCase;
@@ -159,9 +173,6 @@ public CachingIndexedFastaSequenceFile(final Path fasta, final long cacheSize, f
         catch (final IllegalArgumentException e) {
             throw new UserException.CouldNotReadInputFile(fasta, "Could not read reference sequence.  The FASTA must have either a .fasta or .fa extension", e);
         }
-        catch (final Exception e) {
-            throw new UserException.CouldNotReadInputFile(fasta, e);
-        }
     }
 
     /**
diff --git a/src/main/java/org/broadinstitute/hellbender/utils/gcs/BucketUtils.java b/src/main/java/org/broadinstitute/hellbender/utils/gcs/BucketUtils.java
index c23026640a1..998978de97b 100644
--- a/src/main/java/org/broadinstitute/hellbender/utils/gcs/BucketUtils.java
+++ b/src/main/java/org/broadinstitute/hellbender/utils/gcs/BucketUtils.java
@@ -11,6 +11,7 @@
 import com.google.cloud.storage.contrib.nio.SeekableByteChannelPrefetcher;
 import com.google.common.base.Strings;
 import com.google.common.io.ByteStreams;
+import htsjdk.io.IOPath;
 import htsjdk.samtools.util.FileExtensions;
 import htsjdk.samtools.util.IOUtil;
 import htsjdk.samtools.util.RuntimeIOException;
@@ -18,7 +19,6 @@
 import org.apache.hadoop.fs.FileStatus;
 import org.apache.hadoop.fs.FileSystem;
 import org.apache.hadoop.fs.Path;
-import org.broadinstitute.hellbender.engine.GATKPath;
 import org.broadinstitute.hellbender.exceptions.GATKException;
 import org.broadinstitute.hellbender.exceptions.UserException;
 import org.broadinstitute.hellbender.utils.Utils;
@@ -67,20 +67,20 @@ public static boolean isGcsUrl(final String path) {
     }
 
     /**
-     * Return true if this {@code GATKPath} represents a gcs URI.
+     * Return true if this {@code IOPath} represents a gcs URI.
      * @param pathSpec specifier to inspect
-     * @return true if this {@code GATKPath} represents a gcs URI.
+     * @return true if this {@code IOPath} represents a gcs URI.
      */
-    public static boolean isGcsUrl(final GATKPath pathSpec) {
+    public static boolean isGcsUrl(final IOPath pathSpec) {
         Utils.nonNull(pathSpec);
         return pathSpec.getScheme().equals(CloudStorageFileSystem.URI_SCHEME);
     }
 
     /**
      * @param pathSpec specifier to inspect
-     * @return true if this {@code GATKPath} represents a remote storage system which may benefit from prefetching (gcs or http(s))
+     * @return true if this {@code IOPath} represents a remote storage system which may benefit from prefetching (gcs or http(s))
      */
-    public static boolean isEligibleForPrefetching(final GATKPath pathSpec) {
+    public static boolean isEligibleForPrefetching(final IOPath pathSpec) {
         Utils.nonNull(pathSpec);
         return isEligibleForPrefetching(pathSpec.getScheme());
      }
@@ -319,10 +319,10 @@ public static long fileSize(String path) throws IOException {
      * Note that sub-directories are ignored - they are not recursed into.
      * Only supports HDFS and local paths.
      *
-     * @param pathSpecifier The URL to the file or directory whose size to return
+     * @param pathSpecifier The IOPath to the file or directory whose size to return
      * @return the total size of all files in bytes
      */
-    public static long dirSize(final GATKPath pathSpecifier) {
+    public static long dirSize(final IOPath pathSpecifier) {
         try {
             // GCS case (would work with local too)
             if (isGcsUrl(pathSpecifier)) {
diff --git a/src/test/java/org/broadinstitute/hellbender/engine/BundleSupportIntegrationTest.java b/src/test/java/org/broadinstitute/hellbender/engine/BundleSupportIntegrationTest.java
new file mode 100644
index 00000000000..04566869e0d
--- /dev/null
+++ b/src/test/java/org/broadinstitute/hellbender/engine/BundleSupportIntegrationTest.java
@@ -0,0 +1,34 @@
+package org.broadinstitute.hellbender.engine;
+
+import htsjdk.beta.io.IOPathUtils;
+import htsjdk.beta.io.bundle.Bundle;
+import htsjdk.beta.io.bundle.BundleJSON;
+import htsjdk.io.IOPath;
+import org.broadinstitute.hellbender.GATKBaseTest;
+import org.testng.Assert;
+import org.testng.annotations.Test;
+
+import java.io.IOException;
+
+public class BundleSupportIntegrationTest extends GATKBaseTest {
+
+    // this test uses a serialized bundle file to ensure that we don't unintentionally pick up any
+    // code (like, from htsjdk) that introduces backward compatibility issues
+    @Test
+    public void testReadWriteSerializedReferenceBundle() throws IOException {
+        // This test file contains absolute paths to files on a local dev machine, so it shouldn't really be used
+        // for anything other than this test, since the absolute paths are unlikely to work on any other machine.
+        // But here we just want to make sure we can consume and roundtrip it without error
+        final IOPath testBundleFilePath = new GATKPath("src/test/resources/org/broadinstitute/hellbender/engine/print_reads_bundle_do_not_use.json");
+
+        // get our test bundle from the file (ensure we canparse it), then write it out to a temp file, read it back
+        // in, and compare
+        final Bundle testBundle = BundleJSON.toBundle(IOPathUtils.getStringFromPath(testBundleFilePath));
+        final IOPath roundTrippedBundleFilePath = new GATKPath(
+                createTempPath("testReadWriteSerializedReferenceBundle", ".json").toString());
+        IOPathUtils.writeStringToPath(roundTrippedBundleFilePath, BundleJSON.toJSON(testBundle));
+        final Bundle roundTrippedBundle = BundleJSON.toBundle(IOPathUtils.getStringFromPath(testBundleFilePath));
+        Assert.assertTrue(Bundle.equalsIgnoreOrder(roundTrippedBundle, testBundle));
+    }
+
+}
diff --git a/src/test/java/org/broadinstitute/hellbender/engine/FeatureDataSourceUnitTest.java b/src/test/java/org/broadinstitute/hellbender/engine/FeatureDataSourceUnitTest.java
index c8b0b42b9bf..634121291e4 100644
--- a/src/test/java/org/broadinstitute/hellbender/engine/FeatureDataSourceUnitTest.java
+++ b/src/test/java/org/broadinstitute/hellbender/engine/FeatureDataSourceUnitTest.java
@@ -1,5 +1,8 @@
 package org.broadinstitute.hellbender.engine;
 
+import htsjdk.beta.io.IOPathUtils;
+import htsjdk.beta.io.bundle.BundleJSON;
+import htsjdk.beta.plugin.variants.VariantsBundle;
 import htsjdk.samtools.SAMSequenceDictionary;
 import htsjdk.tribble.Feature;
 import htsjdk.variant.variantcontext.VariantContext;
@@ -9,7 +12,6 @@
 import org.broadinstitute.hellbender.exceptions.UserException;
 import org.broadinstitute.hellbender.utils.SimpleInterval;
 import org.broadinstitute.hellbender.GATKBaseTest;
-import org.broadinstitute.hellbender.utils.io.IOUtils;
 import org.testng.Assert;
 import org.testng.annotations.DataProvider;
 import org.testng.annotations.Test;
@@ -413,6 +415,20 @@ public void testQueryGVCF( final SimpleInterval queryInterval, final List expectedVariantIDs ) {
+        final GATKPath vcfPath = new GATKPath(QUERY_TEST_GVCF.getAbsolutePath());
+        final GATKPath indexPath = VariantsBundle.resolveIndex(vcfPath, GATKPath::new).get();
+        final VariantsBundle vcfBundle = new VariantsBundle(vcfPath, indexPath);
+        final GATKPath bundleFile = new GATKPath(createTempFile("testQueryGVCFThroughBundle", ".json").toString());
+        IOPathUtils.writeStringToPath(bundleFile, BundleJSON.toJSON(vcfBundle));
+
+        try ( FeatureDataSource featureSource = new FeatureDataSource<>(bundleFile.toString()) ) {
+            final List queryResults = featureSource.queryAndPrefetch(queryInterval);
+            checkVariantQueryResults(queryResults, expectedVariantIDs, queryInterval);
+        }
+    }
+
     /**************************************************
      * Direct testing on the FeatureCache inner class
      **************************************************/
diff --git a/src/test/java/org/broadinstitute/hellbender/engine/FeatureInputUnitTest.java b/src/test/java/org/broadinstitute/hellbender/engine/FeatureInputUnitTest.java
index 9c09edb1a28..87257d61f6f 100644
--- a/src/test/java/org/broadinstitute/hellbender/engine/FeatureInputUnitTest.java
+++ b/src/test/java/org/broadinstitute/hellbender/engine/FeatureInputUnitTest.java
@@ -1,5 +1,9 @@
 package org.broadinstitute.hellbender.engine;
 
+import htsjdk.beta.io.IOPathUtils;
+import htsjdk.beta.io.bundle.Bundle;
+import htsjdk.beta.io.bundle.BundleJSON;
+import htsjdk.beta.plugin.variants.VariantsBundle;
 import htsjdk.tribble.Feature;
 import htsjdk.tribble.FeatureCodec;
 import htsjdk.variant.variantcontext.VariantContext;
@@ -7,7 +11,6 @@
 import org.broadinstitute.barclay.argparser.Argument;
 import org.broadinstitute.barclay.argparser.CommandLineArgumentParser;
 import org.broadinstitute.barclay.argparser.CommandLineException;
-import org.broadinstitute.barclay.argparser.CommandLineParser;
 import org.broadinstitute.hellbender.GATKBaseTest;
 import org.broadinstitute.hellbender.testutils.SparkTestUtils;
 import org.testng.Assert;
@@ -150,6 +153,25 @@ public void testHdfsPathAndName( final String argWithTags, final String inputVal
         Assert.assertEquals(hdfsInput.getName(), expectedLogicalName, "wrong logical name");
     }
 
+    @Test(dataProvider = "GcsPathAndNameData", groups={"bucket"})
+    public void testGcsBundlePathAndName( final String argWithTags, final String inputValue, final String unusedFeaturePath, final String expectedLogicalName ) {
+        // reuse the GcsPathAndNameData data provider, but with the input written to a bundle file
+        final Bundle bundleOfGcsPaths = new VariantsBundle(new GATKPath(inputValue));
+        final GATKPath bundleFile = new GATKPath(createTempFile("testGcsBundlePathAndName", ".json").toString());
+        IOPathUtils.writeStringToPath(new GATKPath(bundleFile.toString()), BundleJSON.toJSON(bundleOfGcsPaths));
+
+        final FeatureInput gcsInput = runCommandLineWithTaggedFeatureInput(argWithTags, bundleFile.toString());
+
+        Assert.assertEquals(gcsInput.getFeaturePath(), bundleFile.toString(), "wrong featurePath");
+        if (argWithTags.contains(":")) {
+            Assert.assertEquals(gcsInput.getName(), expectedLogicalName, "wrong logical name");
+        } else {
+            // if the input arg has no tags, then the expected logical name is the same as the input value, but
+            // in this test, the input value is actually the bundle json file name, not the original input value
+            Assert.assertEquals(gcsInput.getName(), bundleFile.toString(), "wrong logical name");
+        }
+    }
+
     @Test
     public void testFeatureNameSpecified() {
         final FeatureInput featureInput = runCommandLineWithTaggedFeatureInput("argName:myName", "myFile");
diff --git a/src/test/java/org/broadinstitute/hellbender/engine/MultiVariantWalkerIntegrationTest.java b/src/test/java/org/broadinstitute/hellbender/engine/MultiVariantWalkerIntegrationTest.java
index dca3fc7ee59..99f135f273a 100644
--- a/src/test/java/org/broadinstitute/hellbender/engine/MultiVariantWalkerIntegrationTest.java
+++ b/src/test/java/org/broadinstitute/hellbender/engine/MultiVariantWalkerIntegrationTest.java
@@ -1,5 +1,8 @@
 package org.broadinstitute.hellbender.engine;
 
+import htsjdk.beta.io.IOPathUtils;
+import htsjdk.beta.io.bundle.*;
+import htsjdk.io.IOPath;
 import htsjdk.variant.variantcontext.VariantContext;
 import htsjdk.variant.vcf.VCFHeader;
 import org.broadinstitute.barclay.argparser.CommandLineProgramProperties;
@@ -8,11 +11,16 @@
 import org.broadinstitute.hellbender.exceptions.UserException;
 import org.broadinstitute.hellbender.utils.IntervalUtils;
 import org.broadinstitute.hellbender.utils.SimpleInterval;
+import org.broadinstitute.hellbender.utils.gcs.BucketUtils;
+import org.broadinstitute.hellbender.utils.io.IOUtils;
 import org.testng.Assert;
 import org.testng.annotations.DataProvider;
 import org.testng.annotations.Test;
 
 import java.io.File;
+import java.io.IOException;
+import java.nio.file.Files;
+import java.nio.file.Path;
 import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.List;
@@ -77,25 +85,25 @@ public void testDuplicateSources() throws Exception {
     @DataProvider(name="variantFiles")
     public Object[][] getVariantFiles() {
         return new Object[][]
-            {
-                { Arrays.asList(new File(getTestDataDir(), "baseVariants.vcf")), null, 26 },
-                { Arrays.asList(new File(getTestDataDir(), "interleavedVariants_1.vcf")), null, 13 },
-                { Arrays.asList(
-                        new File(getTestDataDir(), "interleavedVariants_1.vcf"),
-                        new File(getTestDataDir(), "interleavedVariants_2.vcf")), null, 26 },
-                { Arrays.asList(
-                        new File(getTestDataDir(), "splitVariants_1.vcf"),
-                        new File(getTestDataDir(), "splitVariants_2.vcf")), null, 26 },
-
-                // with intervals
-                { Arrays.asList(new File(getTestDataDir(), "baseVariants.vcf")), "1", 14 },
-                { Arrays.asList(new File(getTestDataDir(), "interleavedVariants_1.vcf")), "1", 7 },
-                { Arrays.asList(
-                        new File(getTestDataDir(), "interleavedVariants_1.vcf"),
-                        new File(getTestDataDir(), "interleavedVariants_2.vcf")), "1", 14 },
-                { Arrays.asList(
-                        new File(getTestDataDir(), "interleavedVariants_1.vcf"),
-                        new File(getTestDataDir(), "interleavedVariants_2.vcf")), "2:200-600", 3 },
+                {
+                        {Arrays.asList(new File(getTestDataDir(), "baseVariants.vcf")), null, 26},
+                        {Arrays.asList(new File(getTestDataDir(), "interleavedVariants_1.vcf")), null, 13},
+                        {Arrays.asList(
+                                new File(getTestDataDir(), "interleavedVariants_1.vcf"),
+                                new File(getTestDataDir(), "interleavedVariants_2.vcf")), null, 26},
+                        {Arrays.asList(
+                                new File(getTestDataDir(), "splitVariants_1.vcf"),
+                                new File(getTestDataDir(), "splitVariants_2.vcf")), null, 26},
+
+                        // with intervals
+                        {Arrays.asList(new File(getTestDataDir(), "baseVariants.vcf")), "1", 14},
+                        {Arrays.asList(new File(getTestDataDir(), "interleavedVariants_1.vcf")), "1", 7},
+                        {Arrays.asList(
+                                new File(getTestDataDir(), "interleavedVariants_1.vcf"),
+                                new File(getTestDataDir(), "interleavedVariants_2.vcf")), "1", 14},
+                        {Arrays.asList(
+                                new File(getTestDataDir(), "interleavedVariants_1.vcf"),
+                                new File(getTestDataDir(), "interleavedVariants_2.vcf")), "2:200-600", 3},
             };
     }
 
@@ -115,10 +123,86 @@ public void testVariantOrder(final List inputFiles, final String interval,
         Assert.assertEquals(tool.count, expectedCount);
     }
 
+    // tests using bundles
+    @DataProvider(name="variantBundles")
+    public Object[][] getVariantBundles() throws IOException {
+        return new Object[][]
+                {
+                        {createRemoteBundleForFile(
+                                new File(getTestDataDir(), "interleavedVariants_1.vcf"),
+                                new File(getTestDataDir(), "interleavedVariants_1.vcf.idx"),
+                                new File(getTestDataDir(), "interleavedVariants_2.vcf"),
+                                new File(getTestDataDir(), "interleavedVariants_2.vcf.idx")
+                            ), "1", 14},
+                        {createRemoteBundleForFile(
+                                new File(getTestDataDir(), "interleavedVariants_1.vcf"),
+                                new File(getTestDataDir(), "interleavedVariants_1.vcf.idx"),
+                                new File(getTestDataDir(), "interleavedVariants_2.vcf"),
+                                new File(getTestDataDir(), "interleavedVariants_2.vcf.idx")
+                        ), "2:200-600", 3},
+                };
+    };
+
+    @Test(dataProvider = "variantBundles")
+    public void testVariantsFromBundleOrder(final IOPath inputBundleFile, final String interval, final int expectedCount) {
+        final TestMultiVariantWalker tool = new TestMultiVariantWalker();
+
+        final List args = new ArrayList<>();
+        args.add("--variant");
+        args.add(inputBundleFile.getRawInputString());
+        if (interval != null) {
+            args.add("-L");
+            args.add(interval);
+        }
+
+        tool.instanceMain(args.toArray(new String[args.size()]));
+        Assert.assertEquals(tool.count, expectedCount);
+    }
+
+    // copy  two .vcfs to a temporary remote location; create a bundle list with two bundles, each containing
+    // a reference to the remote vcf and it's local companion index file, and then write the whole bundle out to
+    // a temporary remote bundle file
+    private static IOPath createRemoteBundleForFile(
+            final File vcf1,
+            final File index1,
+            final File vcf2,
+            final File index2) throws IOException {
+        final String remotePath = BucketUtils.randomRemotePath(getGCPTestStaging() + "remoteBundles", "remote_bundle_test", "dir");
+        final Path remoteDirPath = IOUtils.getPath(remotePath + "/");
+
+        Files.createDirectory(remoteDirPath);
+        Assert.assertTrue(Files.exists(remoteDirPath));
+        Assert.assertTrue(Files.isDirectory(remoteDirPath));
+        final Path remoteVCF1 = IOUtils.getPath(remotePath + "/" + vcf1.getName());
+        final Path remoteVCF2 = IOUtils.getPath(remotePath + "/" + vcf2.getName());
+        final Path c_remoteVCF1 = Files.copy(vcf1.toPath(), remoteVCF1);
+        if (!c_remoteVCF1.equals(remoteVCF1)) {
+            throw new IOException("Not equal " + vcf1 + " to " + remoteVCF1);
+        }
+        final Path c_remoteVCF2 = Files.copy(vcf2.toPath(), remoteVCF2);
+        if (!c_remoteVCF2.equals(remoteVCF2)) {
+            throw new IOException("Not equal " + vcf2 + " to " + remoteVCF2);
+        }
+
+        final Bundle variantsBundle1 = new BundleBuilder()
+                .addPrimary(new IOPathResource(new GATKPath(remoteVCF1.toUri().toString()), BundleResourceType.CT_VARIANT_CONTEXTS))
+                .addSecondary(new IOPathResource(new GATKPath(index1.toURI().toString()), BundleResourceType.CT_VARIANTS_INDEX))
+                .build();
+        final Bundle variantsBundle2 = new BundleBuilder()
+                .addPrimary(new IOPathResource(new GATKPath(remoteVCF2.toUri().toString()), BundleResourceType.CT_VARIANT_CONTEXTS))
+                .addSecondary(new IOPathResource(new GATKPath(index2.toURI().toString()), BundleResourceType.CT_VARIANTS_INDEX))
+                .build();
+
+        final List bundles = Arrays.asList(variantsBundle1, variantsBundle2);
+        final GATKPath remoteBundlePath = new GATKPath(remoteDirPath.resolve("remote_bundle.json").toUri().toString());
+        IOPathUtils.writeStringToPath(remoteBundlePath, BundleJSON.toJSON(bundles));
+        return remoteBundlePath;
+    }
+
     @CommandLineProgramProperties(
-            summary = "TestGATKToolWithFeatures",
-            oneLineSummary = "TestGATKToolWithFeatures",
-            programGroup = TestProgramGroup.class
+        summary = "TestGATKToolWithFeatures",
+        oneLineSummary = "TestGATKToolWithFeatures",
+        programGroup = TestProgramGroup.class
     )
     private static final class TestMultiVariantWalkerIterator extends MultiVariantWalker {
         String expectedIDOrder[];
diff --git a/src/test/java/org/broadinstitute/hellbender/tools/AbstractPrintReadsIntegrationTest.java b/src/test/java/org/broadinstitute/hellbender/tools/AbstractPrintReadsIntegrationTest.java
index 160d2e43380..fb65a0ececf 100644
--- a/src/test/java/org/broadinstitute/hellbender/tools/AbstractPrintReadsIntegrationTest.java
+++ b/src/test/java/org/broadinstitute/hellbender/tools/AbstractPrintReadsIntegrationTest.java
@@ -1,5 +1,9 @@
 package org.broadinstitute.hellbender.tools;
 
+import htsjdk.beta.io.IOPathUtils;
+import htsjdk.beta.io.bundle.Bundle;
+import htsjdk.beta.io.bundle.BundleJSON;
+import htsjdk.beta.plugin.registry.HaploidReferenceResolver;
 import htsjdk.samtools.SAMFileHeader;
 import htsjdk.samtools.SAMRecord;
 import htsjdk.samtools.SamReader;
@@ -9,6 +13,7 @@
 import org.broadinstitute.hellbender.GATKBaseTest;
 import org.broadinstitute.hellbender.cmdline.ReadFilterArgumentDefinitions;
 import org.broadinstitute.hellbender.cmdline.StandardArgumentDefinitions;
+import org.broadinstitute.hellbender.engine.GATKPath;
 import org.broadinstitute.hellbender.engine.ReadsDataSource;
 import org.broadinstitute.hellbender.engine.ReadsPathDataSource;
 import org.broadinstitute.hellbender.engine.filters.ReadLengthReadFilter;
@@ -17,10 +22,13 @@
 import org.broadinstitute.hellbender.testutils.ArgumentsBuilder;
 import org.broadinstitute.hellbender.testutils.IntegrationTestSpec;
 import org.broadinstitute.hellbender.testutils.SamAssertionUtils;
+import org.broadinstitute.hellbender.tools.spark.pipelines.PrintReadsSparkIntegrationTest;
 import org.broadinstitute.hellbender.utils.Utils;
 import org.broadinstitute.hellbender.utils.gcs.BucketUtils;
+import org.broadinstitute.hellbender.utils.io.IOUtils;
 import org.broadinstitute.hellbender.utils.read.GATKRead;
 import org.testng.Assert;
+import org.testng.SkipException;
 import org.testng.annotations.DataProvider;
 import org.testng.annotations.Test;
 
@@ -37,14 +45,20 @@ public void doFileToFile(String fileIn, String extOut, String reference, boolean
         String samFile = fileIn;
         final File outFile = GATKBaseTest.createTempFile(samFile + ".", extOut);
         final File ORIG_BAM = new File(TEST_DATA_DIR, samFile);
-        final File refFile;
+        final GATKPath refFile;
 
         final ArrayList args = new ArrayList<>();
         args.add("--input"); args.add(ORIG_BAM.getAbsolutePath());
         args.add("--output"); args.add(outFile.getAbsolutePath());
         if (reference != null) {
-            refFile = new File(TEST_DATA_DIR, reference);
-            args.add("-R"); args.add(refFile.getAbsolutePath());
+            if (reference.endsWith(BundleJSON.BUNDLE_EXTENSION)) {
+                // the test json files are temporary files, not files in TEST_DATA_DIR
+                refFile = new GATKPath(reference);
+                args.add("-R"); args.add(reference);
+            } else {
+                refFile = new GATKPath(new File(TEST_DATA_DIR, reference).getAbsolutePath());
+                args.add("-R"); args.add(refFile.toString());
+            }
         }
         else {
             refFile = null;
@@ -55,13 +69,39 @@ public void doFileToFile(String fileIn, String extOut, String reference, boolean
         }
         runCommandLine(args);
 
-        SamAssertionUtils.assertSamsEqual(outFile, ORIG_BAM, refFile);
+        SamAssertionUtils.assertSamsEqual(outFile, ORIG_BAM, refFile == null ? null : refFile.toPath().toFile());
 
         if (testMD5) {
             checkMD5asExpected(outFile);
         }
     }
 
+    public void doFileToFileUsingReferenceBundle(final String fileIn, final String extOut, final String reference, final boolean testMD5) throws Exception {
+        // this is ugly, but we need to skip this test in Spark tools because they don't support bundles, and
+        // if I put an override of this method in PrintReadsSparkIntegrationTest, it results in dependency injection
+        // errors when the tests are run
+        if (this.getClass().equals(PrintReadsSparkIntegrationTest.class)) {
+            throw new SkipException("Bundles are not supported in Spark tools");
+        }
+        final String referenceToUse;
+        if (reference != null) {
+            // create the bundle, using inference to find the sibling files, then write the bundle out to a temp file
+            final Bundle referenceBundle = HaploidReferenceResolver.referenceBundleFromFastaPath(
+                    new GATKPath(new File(TEST_DATA_DIR, reference).toPath().toString()),
+                    GATKPath::new);
+            final GATKPath tempBundlePath = new GATKPath(
+                    IOUtils.createTempFile("printReadsRefBundle", ".json").getAbsolutePath()
+            );
+            IOPathUtils.writeStringToPath(tempBundlePath, BundleJSON.toJSON(referenceBundle));
+            referenceToUse = tempBundlePath.toString();
+        } else {
+            referenceToUse = reference;
+        }
+
+        // no run the regular test, but using the reference bundle
+        doFileToFile(fileIn, extOut, referenceToUse, testMD5);
+    }
+
     private void checkMD5asExpected(final File outFile) throws IOException {
         final File md5File = new File(outFile.getAbsolutePath() + ".md5");
         if (md5File.exists()) {
@@ -73,11 +113,6 @@ private void checkMD5asExpected(final File outFile) throws IOException {
         Assert.assertEquals(actualMD5, expectedMD5);
     }
 
-    @Test(dataProvider="testingData")
-    public void testFileToFile(String fileIn, String extOut, String reference) throws Exception {
-        doFileToFile(fileIn, extOut, reference, false);
-    }
-
     @DataProvider(name="testingData")
     public Object[][] testingData() {
         return new String[][]{
@@ -120,6 +155,18 @@ public Object[][] testingData() {
         };
     }
 
+    @Test(dataProvider="testingData")
+    public void testFileToFileUsingReferenceBundle(final String fileIn, final String extOut, final String reference) throws Exception {
+        if (reference != null) {
+            doFileToFileUsingReferenceBundle(fileIn, extOut, reference, false);
+        }
+    }
+
+    @Test(dataProvider="testingData")
+    public void testFileToFile(String fileIn, String extOut, String reference) throws Exception {
+        doFileToFile(fileIn, extOut, reference, false);
+    }
+
     @Test
     public void testReadThatConsumesNoReferenceBases() throws IOException {
         final File zeroRefBasesReadBam = new File(TEST_DATA_DIR, "read_consumes_zero_ref_bases.bam");
diff --git a/src/test/java/org/broadinstitute/hellbender/tools/CreateBundleIntegrationTest.java b/src/test/java/org/broadinstitute/hellbender/tools/CreateBundleIntegrationTest.java
new file mode 100644
index 00000000000..73e6a5de5d3
--- /dev/null
+++ b/src/test/java/org/broadinstitute/hellbender/tools/CreateBundleIntegrationTest.java
@@ -0,0 +1,225 @@
+package org.broadinstitute.hellbender.tools;
+
+import htsjdk.beta.io.bundle.*;
+import htsjdk.beta.plugin.IOUtils;
+import htsjdk.beta.plugin.variants.VariantsBundle;
+import org.broadinstitute.barclay.argparser.CommandLineException;
+import org.broadinstitute.hellbender.CommandLineProgramTest;
+import org.broadinstitute.hellbender.cmdline.StandardArgumentDefinitions;
+import org.broadinstitute.hellbender.engine.GATKPath;
+import org.testng.Assert;
+import org.testng.annotations.DataProvider;
+import org.testng.annotations.Test;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+
+public class CreateBundleIntegrationTest extends CommandLineProgramTest {
+
+    // force our local paths to use absolute path names to make BundleResource and IOPath equality checks easier,
+    // since once a bundle is round-tripped/serialized to JSON, the resources will always contain absolute path names
+    // for local files
+
+    //NOTE: These variables are Strings, but they are initialized to values obtained by first creating a GATKPath,
+    // and then calling getURIString on the resulting object. This is just a shortcut to normalize the paths so they
+    // match the strings that will be embedded in the bundles created by the CreateBundle tool (i.e., to have
+    // full/absolute paths and protocol schemes).
+    private final static String LOCAL_VCF = new GATKPath(getTestDataDir() + "/count_variants_withSequenceDict.vcf").getURIString();
+    private final static String LOCAL_VCF_IDX = new GATKPath(getTestDataDir() + "/count_variants_withSequenceDict.vcf.idx").getURIString();
+    private final static String LOCAL_VCF_GZIP = new GATKPath("src/test/resources/large/NA24385.vcf.gz").getURIString();
+    private final static String LOCAL_VCF_TBI = new GATKPath("src/test/resources/large/NA24385.vcf.gz.tbi").getURIString();
+    private final static String LOCAL_VCF_WITH_NO_INDEX = new GATKPath("src/test/resources/org/broadinstitute/hellbender/tools/count_variants_withSequenceDict_noIndex.vcf").getURIString();
+    private final static String CLOUD_VCF = GCS_GATK_TEST_RESOURCES + "large/1000G.phase3.broad.withGenotypes.chr20.10100000.vcf";
+    private final static String CLOUD_VCF_IDX = GCS_GATK_TEST_RESOURCES + "large/1000G.phase3.broad.withGenotypes.chr20.10100000.vcf.idx";
+
+    private final static String LOCAL_FASTA = new GATKPath("src/test/resources/large/Homo_sapiens_assembly38.20.21.fasta").getURIString();
+    private final static String LOCAL_FASTA_INDEX = new GATKPath("src/test/resources/large/Homo_sapiens_assembly38.20.21.fasta.fai").getURIString();
+    private final static String LOCAL_FASTA_DICT = new GATKPath("src/test/resources/large/Homo_sapiens_assembly38.20.21.dict").getURIString();
+
+    private final static String CUSTOM_PRIMARY_CT = "primary_ct";
+    private final static String CUSTOM_SECONDARY_CT = "secondary_ct";
+    private final static String CUSTOM_OTHER_CT = "other_ct";
+
+    @DataProvider(name = "bundleCases")
+    public Object[][] bundleCases() {
+        return new Object[][] {
+                // primary, primary tag, secondary, secondary tag, other(s), other tag(s), suppressResourceResolution, expectedBundle
+
+                // VCF bundle cases, with AUTOMATIC secondary resolution, and INFERRED primary content types
+                {LOCAL_VCF, null, null, null, null, null, false, new VariantsBundle(new GATKPath(LOCAL_VCF), new GATKPath(LOCAL_VCF_IDX))},
+                {LOCAL_VCF, null, LOCAL_VCF_IDX, BundleResourceType.CT_VARIANTS_INDEX, null, null, false, new VariantsBundle(new GATKPath(LOCAL_VCF), new GATKPath(LOCAL_VCF_IDX))},
+                {LOCAL_VCF_GZIP, null, null, null, null, null, false, new VariantsBundle(new GATKPath(LOCAL_VCF_GZIP), new GATKPath(LOCAL_VCF_TBI))},
+                {LOCAL_VCF_GZIP, null, LOCAL_VCF_TBI, BundleResourceType.CT_VARIANTS_INDEX, null, null, true, new VariantsBundle(new GATKPath(LOCAL_VCF_GZIP), new GATKPath(LOCAL_VCF_TBI))},
+                {CLOUD_VCF, null, null, null, null, null, false, new VariantsBundle(new GATKPath(CLOUD_VCF), new GATKPath(CLOUD_VCF_IDX))},
+                {CLOUD_VCF, null, CLOUD_VCF_IDX, BundleResourceType.CT_VARIANTS_INDEX, null, null, false, new VariantsBundle(new GATKPath(CLOUD_VCF), new GATKPath(CLOUD_VCF_IDX))},
+
+                // VCF bundle cases, with SUPPRESSED secondary resolution, and INFERRED primary content types
+                {LOCAL_VCF, null, null, null, null, null, true, new VariantsBundle(new GATKPath(LOCAL_VCF))},
+                // local vcf that has no index, but since suppressSecondaryResourceResolution is true, we don't throw since we don't try to infer the index
+                {LOCAL_VCF_WITH_NO_INDEX, null, null, null, null, null, true, new VariantsBundle(new GATKPath(LOCAL_VCF_WITH_NO_INDEX))},
+                {CLOUD_VCF, null, null, null, null, null, true, new VariantsBundle(new GATKPath(CLOUD_VCF))},
+
+                // VCF bundle cases, with AUTOMATIC secondary resolution, and EXPLICIT primary content types
+                {LOCAL_VCF, BundleResourceType.CT_VARIANT_CONTEXTS, null, null, null, null, false, new VariantsBundle(new GATKPath(LOCAL_VCF), new GATKPath(LOCAL_VCF_IDX))},
+                {LOCAL_VCF, BundleResourceType.CT_VARIANT_CONTEXTS, LOCAL_VCF_IDX, BundleResourceType.CT_VARIANTS_INDEX, null, null, false, new VariantsBundle(new GATKPath(LOCAL_VCF), new GATKPath(LOCAL_VCF_IDX))},
+
+                // VCF bundle cases, with SUPPRESSED secondary resolution, and EXPLICIT content types
+                {LOCAL_VCF, BundleResourceType.CT_VARIANT_CONTEXTS, null, null, null, null, true, new VariantsBundle(new GATKPath(LOCAL_VCF))},
+                {LOCAL_VCF, BundleResourceType.CT_VARIANT_CONTEXTS, LOCAL_VCF_IDX, BundleResourceType.CT_VARIANTS_INDEX, null, null, true, new VariantsBundle(new GATKPath(LOCAL_VCF), new GATKPath(LOCAL_VCF_IDX))},
+
+                // vcf bundle with a vcf, an index, and some other custom resource with an explicit content type
+                {LOCAL_VCF, BundleResourceType.CT_VARIANT_CONTEXTS, LOCAL_VCF_IDX, BundleResourceType.CT_VARIANTS_INDEX, Arrays.asList("someVariantsCompanion.txt"), Arrays.asList("someVariantsCT"), false,
+                    new BundleBuilder()
+                        .addPrimary(new IOPathResource(new GATKPath(LOCAL_VCF), BundleResourceType.CT_VARIANT_CONTEXTS))
+                        .addSecondary(new IOPathResource(new GATKPath(LOCAL_VCF_IDX), BundleResourceType.CT_VARIANTS_INDEX))
+                        .addSecondary(new IOPathResource(new GATKPath(new GATKPath("someVariantsCompanion.txt").getURIString()), "someVariantsCT"))
+                        .build()
+                },
+
+                // reference bundles
+                { LOCAL_FASTA, null, null, null, null, null, false,
+                        new BundleBuilder()
+                                .addPrimary(new IOPathResource(new GATKPath(LOCAL_FASTA), BundleResourceType.CT_HAPLOID_REFERENCE))
+                                .addSecondary(new IOPathResource(new GATKPath(LOCAL_FASTA_INDEX), BundleResourceType.CT_REFERENCE_INDEX))
+                                .addSecondary(new IOPathResource(new GATKPath(LOCAL_FASTA_DICT), BundleResourceType.CT_REFERENCE_DICTIONARY))
+                                .build()
+                },
+                { LOCAL_FASTA, BundleResourceType.CT_HAPLOID_REFERENCE, LOCAL_FASTA_INDEX, BundleResourceType.CT_REFERENCE_INDEX, Arrays.asList(LOCAL_FASTA_DICT), Arrays.asList(BundleResourceType.CT_REFERENCE_DICTIONARY), false,
+                        new BundleBuilder()
+                                .addPrimary(new IOPathResource(new GATKPath(LOCAL_FASTA), BundleResourceType.CT_HAPLOID_REFERENCE))
+                                .addSecondary(new IOPathResource(new GATKPath(LOCAL_FASTA_INDEX), BundleResourceType.CT_REFERENCE_INDEX))
+                                .addSecondary(new IOPathResource(new GATKPath(LOCAL_FASTA_DICT), BundleResourceType.CT_REFERENCE_DICTIONARY))
+                                .build()
+                },
+
+                // "custom" bundles
+                {
+                        LOCAL_VCF, CUSTOM_PRIMARY_CT, null, null, null, null, true,
+                        new BundleBuilder()
+                                .addPrimary(new IOPathResource(new GATKPath(LOCAL_VCF), CUSTOM_PRIMARY_CT))
+                                .build()
+                },
+                {
+                        LOCAL_VCF, CUSTOM_PRIMARY_CT, LOCAL_VCF_IDX, CUSTOM_SECONDARY_CT, null, null, true,
+                        new BundleBuilder()
+                                .addPrimary(new IOPathResource(new GATKPath(LOCAL_VCF), CUSTOM_PRIMARY_CT))
+                                .addSecondary(new IOPathResource(new GATKPath(LOCAL_VCF_IDX), CUSTOM_SECONDARY_CT))
+                                .build()
+                },
+                {
+                        // frankenbundle with multiple resources
+                        LOCAL_VCF, CUSTOM_PRIMARY_CT, LOCAL_VCF_IDX, CUSTOM_SECONDARY_CT, Arrays.asList(LOCAL_VCF_TBI), Arrays.asList(CUSTOM_OTHER_CT), true,
+                        new BundleBuilder()
+                                .addPrimary(new IOPathResource(new GATKPath(LOCAL_VCF), CUSTOM_PRIMARY_CT))
+                                .addSecondary(new IOPathResource(new GATKPath(LOCAL_VCF_IDX), CUSTOM_SECONDARY_CT))
+                                .addSecondary(new IOPathResource(new GATKPath(LOCAL_VCF_TBI), CUSTOM_OTHER_CT))
+                                .build()
+                },
+        };
+    }
+
+    @DataProvider(name = "negativeBundleCases")
+    public Object[][] negativeBundleCases() {
+        return new Object[][] {
+                // primary, primary tag, secondary, secondary tag, other(s), other tag(s), suppressIndexResolution, expectedBundle
+
+                // no vcf index file can be inferred
+                {LOCAL_VCF_WITH_NO_INDEX, null, null, null, null, null, false, new VariantsBundle(new GATKPath(LOCAL_VCF_WITH_NO_INDEX))},
+                // vcf bundle with secondary/other content type not explicitly provided
+                {LOCAL_VCF, BundleResourceType.CT_VARIANT_CONTEXTS, null, null, Arrays.asList("other.txt"), null, false, null},
+                {LOCAL_VCF, null, LOCAL_VCF_IDX, null, null, null, false, new VariantsBundle(new GATKPath(LOCAL_VCF), new GATKPath(LOCAL_VCF_IDX))},
+                {LOCAL_VCF, null, LOCAL_VCF_IDX, null, null, null, true, new VariantsBundle(new GATKPath(LOCAL_VCF), new GATKPath(LOCAL_VCF_IDX))},
+                {LOCAL_VCF_GZIP, null, LOCAL_VCF_TBI, null, null, null, true, new VariantsBundle(new GATKPath(LOCAL_VCF_GZIP), new GATKPath(LOCAL_VCF_TBI))},
+                {CLOUD_VCF, null, CLOUD_VCF_IDX, null, null, null, false, new VariantsBundle(new GATKPath(CLOUD_VCF), new GATKPath(CLOUD_VCF_IDX))},
+                {CLOUD_VCF, null, CLOUD_VCF_IDX, null, null, null, true, new VariantsBundle(new GATKPath(CLOUD_VCF), new GATKPath(CLOUD_VCF_IDX))},
+                // primary content type not provided, and cannot be inferred from the extension
+                {"primaryFile.ext", null, null, null, null, null, false, null},
+                // secondary content type not provided
+                {"primaryFile.ext", CUSTOM_PRIMARY_CT, "secondaryFile.ext", null, null, null, false, null},
+
+                // reference input with unknown content type specified
+                { LOCAL_FASTA, null, LOCAL_FASTA_INDEX, "unknown", null, null, false, null},
+
+                // other bundle with other content type not provided
+                {"primaryFile.ext", CUSTOM_PRIMARY_CT, "secondaryFile.ext", CUSTOM_SECONDARY_CT, Arrays.asList("other.txt"), null, false, null},
+
+        };
+    }
+
+    @Test(dataProvider = "bundleCases")
+    public void testBundleCases(
+            final String primaryInput,
+            final String primaryInputTag,
+            final String secondaryInput,
+            final String secondaryInputTag,
+            final List otherInputs,
+            final List otherInputTags,
+            final boolean suppressResourceResolution,
+            final Bundle expectedBundle) {
+        doCreateBundleTest (primaryInput, primaryInputTag, secondaryInput, secondaryInputTag, otherInputs, otherInputTags, suppressResourceResolution, expectedBundle);
+    }
+
+    @Test(dataProvider = "negativeBundleCases", expectedExceptions = IllegalArgumentException.class)
+    public void testNegativeBundleCases(
+            final String primaryInput,
+            final String primaryInputTag,
+            final String secondaryInput,
+            final String secondaryInputTag,
+            final List otherInputs,
+            final List otherInputTags,
+            final boolean suppressResourceResolution,
+            final Bundle expectedBundle) {
+        doCreateBundleTest (primaryInput, primaryInputTag, secondaryInput, secondaryInputTag, otherInputs, otherInputTags, suppressResourceResolution, expectedBundle);
+    }
+
+    @Test(expectedExceptions={CommandLineException.class})
+    public void testRequireBundleExtension() {
+        final GATKPath outputPath = new GATKPath(createTempFile("test", ".bundle.BOGUS").getAbsolutePath().toString());
+        final List args = new ArrayList<>();
+        args.add("--" + StandardArgumentDefinitions.PRIMARY_RESOURCE_LONG_NAME);
+        args.add(LOCAL_FASTA);
+        args.add("--" + StandardArgumentDefinitions.OUTPUT_LONG_NAME);
+        args.add(outputPath.toString());
+        runCommandLine(args);
+    }
+
+    private void doCreateBundleTest(
+            final String primaryInput,
+            final String primaryInputTag,
+            final String secondaryInput,
+            final String secondaryInputTag,
+            final List otherInputs,
+            final List otherInputTags,
+            final boolean suppressResourceResolution,
+            final Bundle expectedBundle) {
+        final GATKPath outputPath = new GATKPath(createTempFile("test", ".bundle.json").getAbsolutePath().toString());
+
+        final List args = new ArrayList<>();
+
+        args.add("--" + StandardArgumentDefinitions.PRIMARY_RESOURCE_LONG_NAME + (primaryInputTag != null ? ":" + primaryInputTag : ""));
+        args.add(primaryInput);
+        if (secondaryInput != null) {
+            args.add("--" + StandardArgumentDefinitions.SECONDARY_RESOURCE_LONG_NAME + (secondaryInputTag != null ? ":" + secondaryInputTag : ""));
+            args.add(secondaryInput);
+        }
+        if (otherInputs != null) {
+            for (int i = 0; i < otherInputs.size(); i++) {
+                args.add("--" + CreateBundle.OTHER_RESOURCE_FULL_NAME + ((otherInputTags != null && otherInputTags.get(i) != null) ? ":" + otherInputTags.get(i) : ""));
+                args.add(otherInputs.get(i) != null ? otherInputs.get(i) : "");
+            }
+        }
+        if (suppressResourceResolution == true) {
+            args.add("--" + CreateBundle.SUPPRESS_SECONDARY_RESOURCE_RESOLUTION_FULL_NAME);
+        }
+        args.add("--" + StandardArgumentDefinitions.OUTPUT_LONG_NAME);
+        args.add(outputPath.toString());
+
+        runCommandLine(args);
+
+        final Bundle actualBundle = BundleJSON.toBundle(IOUtils.getStringFromPath(outputPath), GATKPath::new);
+
+        // bundle resource order is not preserved when round-tripping through JSON, so compare ignoring order
+        Assert.assertTrue(Bundle.equalsIgnoreOrder(actualBundle, expectedBundle));
+    }
+}
diff --git a/src/test/java/org/broadinstitute/hellbender/tools/PrintReadsIntegrationTest.java b/src/test/java/org/broadinstitute/hellbender/tools/PrintReadsIntegrationTest.java
index bb45b7b15b7..baf1aaf4b27 100644
--- a/src/test/java/org/broadinstitute/hellbender/tools/PrintReadsIntegrationTest.java
+++ b/src/test/java/org/broadinstitute/hellbender/tools/PrintReadsIntegrationTest.java
@@ -1,9 +1,13 @@
 package org.broadinstitute.hellbender.tools;
 
-import htsjdk.samtools.SamReaderFactory;
-import htsjdk.samtools.ValidationStringency;
+import htsjdk.beta.io.IOPathUtils;
+import htsjdk.beta.io.bundle.*;
+import htsjdk.io.IOPath;
+import htsjdk.samtools.*;
+import htsjdk.samtools.cram.ref.ReferenceSource;
 import org.broadinstitute.hellbender.GATKBaseTest;
 import org.broadinstitute.hellbender.cmdline.StandardArgumentDefinitions;
+import org.broadinstitute.hellbender.engine.GATKPath;
 import org.broadinstitute.hellbender.engine.ReadsDataSource;
 import org.broadinstitute.hellbender.engine.ReadsPathDataSource;
 import org.broadinstitute.hellbender.testutils.ArgumentsBuilder;
@@ -11,12 +15,15 @@
 import org.broadinstitute.hellbender.utils.SimpleInterval;
 import org.broadinstitute.hellbender.utils.Utils;
 import org.broadinstitute.hellbender.utils.gcs.BucketUtils;
+import org.broadinstitute.hellbender.utils.io.IOUtils;
 import org.testng.Assert;
 import org.testng.annotations.DataProvider;
 import org.testng.annotations.Test;
 
 import java.io.File;
 import java.io.IOException;
+import java.nio.file.Files;
+import java.nio.file.Path;
 import java.util.Arrays;
 import java.util.List;
 
@@ -104,4 +111,57 @@ public void testHttpPaths(String reads, String index, String nonHttpReads, Strin
         SamAssertionUtils.assertEqualBamFiles(out, out2, false, ValidationStringency.DEFAULT_STRINGENCY);
     }
 
+    @Test(groups = {"cloud"})
+    public void testPrintReadsWithReferenceBundle() throws IOException {
+        // test that both reading and writing a cram work when the reference is specified via a bundle where the
+        // reference, reference index, and reference dictionary are all in different buckets
+        final IOPath testFastaFile = new GATKPath(getTestDataDir() + "/print_reads.fasta");
+        final IOPath testIndexFile = new GATKPath(getTestDataDir() + "/print_reads.fasta.fai");
+        final IOPath testDictFile = new GATKPath(getTestDataDir() + "/print_reads.dict");
+
+        final String targetBucketName = BucketUtils.randomRemotePath(getGCPTestStaging(), "testPrintReadsWithReferenceBundle", "") + "/";
+        final IOPath targetBucket = new GATKPath(targetBucketName);
+        IOUtils.deleteOnExit(targetBucket.toPath());
+
+        final Path remoteFasta = Files.copy(testFastaFile.toPath(), new GATKPath(targetBucketName + "print_reads.fasta").toPath());
+        final IOPath targetIndex = new GATKPath(targetBucketName + "refindex/print_reads.fasta.fai");
+        final Path remoteFastaIndex = Files.copy(testIndexFile.toPath(), targetIndex.toPath());
+        final IOPath targetDict = new GATKPath(targetBucketName + "refdict/print_reads.dict");
+        final Path remoteFastaDict = Files.copy(testDictFile.toPath(), targetDict.toPath());
+
+        // create a bundle with the remote reference, index, and dict files
+        final Bundle refBundle = new BundleBuilder()
+                .addPrimary(new IOPathResource(new GATKPath(remoteFasta.toUri().toString()), BundleResourceType.CT_HAPLOID_REFERENCE))
+                .addSecondary(new IOPathResource(new GATKPath(remoteFastaIndex.toUri().toString()), BundleResourceType.CT_REFERENCE_INDEX))
+                .addSecondary(new IOPathResource(new GATKPath(remoteFastaDict.toUri().toString()), BundleResourceType.CT_REFERENCE_DICTIONARY))
+                .build();
+        final IOPath bundleFilePath = new GATKPath(targetBucketName + "refBundle.json");
+        IOPathUtils.writeStringToPath(bundleFilePath, BundleJSON.toJSON(refBundle));
+
+        final IOPath targetOutCRAM = new GATKPath(IOUtils.createTempFile("testReferenceSequenceForNioBundle", ".cram").getAbsolutePath());
+        final ArgumentsBuilder args = new ArgumentsBuilder()
+                .addInput(getTestDataDir() + "/print_reads.cram")
+                .addReference(bundleFilePath.toString())
+                .addOutput(targetOutCRAM.toString());
+                runCommandLine(args);
+
+        int count = 0;
+        try (final SamReader in = SamReaderFactory.makeDefault()
+                .validationStringency(ValidationStringency.SILENT)
+                .referenceSource(new ReferenceSource(bundleFilePath.toPath()))
+                .open(targetOutCRAM.toPath())) {
+            for (@SuppressWarnings("unused") final SAMRecord rec : in) {
+                count++;
+            }
+        }
+        Assert.assertEquals(count, 8);
+    }
+
+    // only do reference bundle tests for non-spark tools, since for now the spark tools don't support reference bundles
+    // (since they use 2-bit and hadoop references)
+    @Test(dataProvider="testingData")
+    public void testFileToFileWithReferenceBundle(final String fileIn, final String extOut, final String reference) throws Exception {
+        doFileToFileUsingReferenceBundle(fileIn, extOut, reference, false);
+    }
+
 }
\ No newline at end of file
diff --git a/src/test/java/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariantsIntegrationTest.java b/src/test/java/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariantsIntegrationTest.java
index cfe959e15e2..4532c301a0d 100644
--- a/src/test/java/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariantsIntegrationTest.java
+++ b/src/test/java/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariantsIntegrationTest.java
@@ -1,9 +1,15 @@
 package org.broadinstitute.hellbender.tools.walkers.variantutils;
 
+import java.nio.file.Files;
+import java.nio.file.StandardCopyOption;
 import java.util.Arrays;
 import java.util.Comparator;
 import java.util.List;
 
+import htsjdk.beta.io.IOPathUtils;
+import htsjdk.beta.io.bundle.BundleJSON;
+import htsjdk.beta.plugin.variants.VariantsBundle;
+import htsjdk.io.IOPath;
 import htsjdk.variant.variantcontext.VariantContext;
 import htsjdk.variant.vcf.VCFHeader;
 import org.apache.commons.lang3.tuple.Pair;
@@ -1252,6 +1258,81 @@ public void testSampleSelectionOnNio() throws IOException {
         IntegrationTestSpec.assertEqualTextFiles(IOUtils.getPath(out), IOUtils.getPath(expectedFile), null);
     }
 
+    @DataProvider(name="cloudBucketBundles")
+    public Object[][] cloudBucketBundles() {
+        return new Object[][]{
+                {
+                    // cloud vcf with a .idx
+                        new GATKPath("gs://hellbender/test/resources/large/dbsnp_138.b37.1.1-65M.vcf"),
+                        new GATKPath("gs://hellbender/test/resources/large/dbsnp_138.b37.1.1-65M.vcf.idx"),
+                        "1:20547",
+                        "expected/testSelectVariants_BundleWith_idx.vcf"
+                },
+                {
+                    // cloud vcf with a .tbi
+                        new GATKPath("gs://hellbender/test/resources/large/dbsnp_138.b37.20.21.vcf.blockgz.gz"),
+                        new GATKPath("gs://hellbender/test/resources/large/dbsnp_138.b37.20.21.vcf.blockgz.gz.tbi"),
+                        "21:10000128",
+                        "expected/testSelectVariants_BundleWith_tbi.vcf"
+                }
+        };
+    }
+
+    @Test(dataProvider="cloudBucketBundles", groups = "bucket")
+    public void testBundleRemoteQueryWithVCFAndIndexInSeparateBuckets(
+            final IOPath vcfPath,
+            final IOPath indexPath,
+            final String queryInterval,
+            final String expectedOutputFile
+    ) throws IOException {
+        // test that a query using a bundle containing remote nio paths to a vcf works when the index is
+        // in a different bucket than the vcf
+        final String targetBucketName = BucketUtils.randomRemotePath(getGCPTestStaging(), "testSelectVariantsBundleOnNio", "") + "/";
+        IOUtils.deleteOnExit(IOUtils.getPath(targetBucketName));
+        final GATKPath targetVCFPath = new GATKPath(targetBucketName + vcfPath.toPath().getFileName());
+
+        // copy our test vcf (which is already in a bucket with it's accompanying index) to a different bucket where the
+        // index does not reside, and then create a bundle referencing the copy of the vcf and the original index, so
+        // the vcf and the index are in separate buckets
+        Files.copy(vcfPath.toPath(), targetVCFPath.toPath(), StandardCopyOption.REPLACE_EXISTING);
+
+        // create a bundle with the copied vcf and the original index
+        final VariantsBundle vcfBundle = new VariantsBundle(new GATKPath(targetVCFPath), indexPath);
+        final GATKPath bundleFilePath = new GATKPath(createTempFile("testSelectVariantsBundleOnNio", ".json").toString());
+        IOPathUtils.writeStringToPath(bundleFilePath, BundleJSON.toJSON(vcfBundle));
+
+        final IntegrationTestSpec spec = new IntegrationTestSpec(
+                " --variant " + bundleFilePath
+                        + " -L " + queryInterval
+                        + " --suppress-reference-path " // suppress reference file path in output for test differencing
+                        + " -O %s "
+                        + " --" + StandardArgumentDefinitions.ADD_OUTPUT_VCF_COMMANDLINE +" false",
+                Collections.singletonList(getToolTestDataDir() + expectedOutputFile)
+        );
+
+        spec.executeTest("testBundle", this);
+    }
+
+    @Test(groups = "bucket")
+    public void testBundleRemoteWithQueryParams() throws IOException {
+        final VariantsBundle vcfBundle = new VariantsBundle(
+                new GATKPath(BucketUtils.createSignedUrlToGcsObject("gs://hellbender/test/resources/large/1000G.phase3.broad.withGenotypes.chr20.10100000.vcf", 1)),
+                new GATKPath(BucketUtils.createSignedUrlToGcsObject("gs://hellbender/test/resources/large/1000G.phase3.broad.withGenotypes.chr20.10100000.vcf.idx", 1)));
+        final IOPath bundleFile = new GATKPath(createTempFile("testSelectVariantsThroughBundle", ".json").toString());
+        IOPathUtils.writeStringToPath(bundleFile, BundleJSON.toJSON(vcfBundle));
+
+        final IntegrationTestSpec spec = new IntegrationTestSpec(
+                " --variant " + bundleFile.toString()
+                        + " -L 20:10001365 "
+                        + " --suppress-reference-path " // suppress reference file path in output for test differencing
+                        + " -O %s "
+                        + " --" + StandardArgumentDefinitions.ADD_OUTPUT_VCF_COMMANDLINE +" false",
+                Collections.singletonList(getToolTestDataDir() + "expected/" + "testSelectVariants_Bundle.vcf")
+        );
+
+        spec.executeTest("testBundle", this);
+    }
+
     // the input test file is a somatic VCF with several many-allelic sites and no PLs.  This tests that the tool does not attempt
     // to create a PL-to-alleles cache, which would cause the tool to freeze.  See https://github.com/broadinstitute/gatk/issues/6291
     @Test
diff --git a/src/test/resources/org/broadinstitute/hellbender/engine/print_reads_bundle_do_not_use.json b/src/test/resources/org/broadinstitute/hellbender/engine/print_reads_bundle_do_not_use.json
new file mode 100644
index 00000000000..66fe7bf0ecb
--- /dev/null
+++ b/src/test/resources/org/broadinstitute/hellbender/engine/print_reads_bundle_do_not_use.json
@@ -0,0 +1,10 @@
+{
+ "schema": {
+  "schemaVersion": "0.1.0",
+  "schemaName": "htsbundle"
+ },
+ "HAPLOID_REFERENCE": {"path": "file:///Users/cnorman/projects/gatk/src/test/resources/org/broadinstitute/hellbender/tools/print_reads.fasta"},
+ "REFERENCE_DICTIONARY": {"path": "file:///Users/cnorman/projects/gatk/src/test/resources/org/broadinstitute/hellbender/tools/print_reads.dict"},
+ "REFERENCE_INDEX": {"path": "file:///Users/cnorman/projects/gatk/src/test/resources/org/broadinstitute/hellbender/tools/print_reads.fasta.fai"},
+ "primary": "HAPLOID_REFERENCE"
+}
diff --git a/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_Bundle.vcf b/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_Bundle.vcf
new file mode 100644
index 00000000000..667b6c0b656
--- /dev/null
+++ b/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_Bundle.vcf
@@ -0,0 +1,45 @@
+##fileformat=VCFv4.2
+##FILTER=
+##FILTER=
+##FILTER=
+##FILTER=
+##FILTER=
+##FILTER=
+##FILTER=
+##FILTER=
+##FILTER=
+##FORMAT=
+##FORMAT=
+##FORMAT=
+##FORMAT=
+##FORMAT=
+##GATKCommandLine=
+##GATKVersion=2.5-191-g02f8427
+##HaplotypeCaller="analysis_type=HaplotypeCaller input_file=[/humgen/1kg/processing/production_wgs_final/chr20/ALL.chr20.bam.list] read_buffer_size=null phone_home=AWS gatk_key=null tag=NA read_filter=[] intervals=[/humgen/1kg/processing/production_wgs_final/chr20/.queue/scatterGather/call.for.1000G-1-sg/temp_0001_of_1000/scatter.intervals] excludeIntervals=null interval_set_rule=UNION interval_merging=ALL interval_padding=0 reference_sequence=/humgen/1kg/reference/human_g1k_v37_decoy.fasta nonDeterministicRandomSeed=false disableDithering=false maxRuntime=-1 maxRuntimeUnits=MINUTES downsampling_type=BY_SAMPLE downsample_to_fraction=null downsample_to_coverage=200 baq=OFF baqGapOpenPenalty=40.0 fix_misencoded_quality_scores=false allow_potentially_misencoded_quality_scores=false performanceLog=null useOriginalQualities=false BQSR=null quantize_quals=0 disable_indel_quals=false emit_original_quals=false preserve_qscores_less_than=6 globalQScorePrior=-1.0 allow_bqsr_on_reduced_bams_despite_repeated_warnings=false defaultBaseQualities=-1 validation_strictness=SILENT remove_program_records=false keep_program_records=false unsafe=null disable_auto_index_creation_and_locking_when_reading_rods=false num_threads=1 num_cpu_threads_per_data_thread=1 num_io_threads=0 monitorThreadEfficiency=false num_bam_file_handles=null read_group_black_list=null pedigree=[] pedigreeString=[] pedigreeValidationType=STRICT allow_intervals_with_unindexed_bam=false generateShadowBCF=false logging_level=INFO log_to_file=null help=false version=false out=org.broadinstitute.sting.gatk.io.stubs.VariantContextWriterStub no_cmdline_in_header=org.broadinstitute.sting.gatk.io.stubs.VariantContextWriterStub sites_only=org.broadinstitute.sting.gatk.io.stubs.VariantContextWriterStub bcf=org.broadinstitute.sting.gatk.io.stubs.VariantContextWriterStub graphOutput=null bamOutput=null bam_compression=null disable_bam_indexing=null generate_md5=null simplifyBAM=null bamWriterType=CALLED_HAPLOTYPES dbsnp=(RodBinding name= source=UNBOUND) comp=[] annotation=[ClippingRankSumTest, DepthPerSampleHC] excludeAnnotation=[SpanningDeletions, TandemRepeatAnnotator] heterozygosity=0.001 indel_heterozygosity=1.25E-4 genotyping_mode=DISCOVERY output_mode=EMIT_VARIANTS_ONLY standard_min_confidence_threshold_for_calling=10.0 standard_min_confidence_threshold_for_emitting=10.0 alleles=(RodBinding name= source=UNBOUND) max_alternate_alleles=6 input_prior=[] contamination_fraction_to_filter=0.05 contamination_fraction_per_sample_file=null p_nonref_model=EXACT_INDEPENDENT exactcallslog=null useDebruijnAssembler=false minKmerForDebruijnAssembler=11 onlyUseKmerSizeForDebruijnAssembler=-1 kmerSize=[10, 25] dontIncreaseKmerSizesForCycles=false numPruningSamples=3 maxPathsPerSample=8 dontRecoverDanglingTails=false minPruning=2 gcpHMM=10 includeUmappedReads=false useAllelesTrigger=false useFilteredReadsForAnnotations=false phredScaledGlobalReadMismappingRate=45 maxNumHaplotypesInPopulation=25 mergeVariantsViaLD=false pair_hmm_implementation=LOGLESS_CACHING keepRG=null justDetermineActiveRegions=false dontGenotype=false errorCorrectKmers=false debug=false debugGraphTransformations=false useLowQualityBasesForAssembly=false dontTrimActiveRegions=false dontUseSoftClippedBases=false captureAssemblyFailureBAM=false allowCyclesInKmerGraphToGeneratePaths=false errorCorrectReads=false kmerLengthForReadErrorCorrection=25 minObservationsForKmerToBeSolid=20 activityProfileOut=null activeRegionOut=null activeRegionIn=null activeRegionExtension=null forceActive=false activeRegionMaxSize=null bandPassSigma=null min_mapping_quality_score=20 filter_reads_with_N_cigar=false filter_mismatching_base_and_quals=false filter_bases_not_stored=false"
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##contig=
+##contig=
+##source=SelectVariants
+#CHROM	POS	ID	REF	ALT	QUAL	FILTER	INFO	FORMAT	HG00096	HG00097	HG00099	HG00100	HG00101	HG00102	HG00103	HG00105	HG00106	HG00107	HG00108	HG00109	HG00110	HG00111	HG00112	HG00113	HG00114	HG00115	HG00116	HG00117	HG00118	HG00119	HG00120	HG00121	HG00122	HG00123	HG00124	HG00125	HG00126	HG00127	HG00128	HG00129	HG00130	HG00131	HG00132	HG00133	HG00136	HG00137	HG00138	HG00139	HG00140	HG00141	HG00142	HG00143	HG00145	HG00146	HG00148	HG00149	HG00150	HG00151	HG00154	HG00155	HG00157	HG00158	HG00159	HG00160	HG00171	HG00173	HG00174	HG00176	HG00177	HG00178	HG00179	HG00180	HG00181	HG00182	HG00183	HG00185	HG00186	HG00187	HG00188	HG00189	HG00190	HG00231	HG00232	HG00233	HG00234	HG00235	HG00236	HG00237	HG00238	HG00239	HG00240	HG00242	HG00243	HG00244	HG00245	HG00246	HG00250	HG00251	HG00252	HG00253	HG00254	HG00255	HG00256	HG00257	HG00258	HG00259	HG00260	HG00261	HG00262	HG00263	HG00264	HG00265	HG00266	HG00267	HG00268	HG00269	HG00271	HG00272	HG00273	HG00274	HG00275	HG00276	HG00277	HG00278	HG00280	HG00281	HG00282	HG00284	HG00285	HG00288	HG00290	HG00304	HG00306	HG00308	HG00309	HG00310	HG00311	HG00313	HG00315	HG00318	HG00319	HG00320	HG00321	HG00323	HG00324	HG00325	HG00326	HG00327	HG00328	HG00329	HG00330	HG00331	HG00332	HG00334	HG00335	HG00336	HG00337	HG00338	HG00339	HG00341	HG00342	HG00343	HG00344	HG00345	HG00346	HG00349	HG00350	HG00351	HG00353	HG00355	HG00356	HG00357	HG00358	HG00360	HG00361	HG00362	HG00364	HG00365	HG00366	HG00367	HG00368	HG00369	HG00371	HG00372	HG00373	HG00375	HG00376	HG00378	HG00379	HG00380	HG00381	HG00382	HG00383	HG00384	HG00403	HG00404	HG00406	HG00407	HG00409	HG00410	HG00419	HG00421	HG00422	HG00428	HG00436	HG00437	HG00442	HG00443	HG00445	HG00446	HG00448	HG00449	HG00451	HG00452	HG00457	HG00458	HG00463	HG00464	HG00472	HG00473	HG00475	HG00476	HG00478	HG00479	HG00500	HG00501	HG00513	HG00524	HG00525	HG00530	HG00531	HG00533	HG00534	HG00536	HG00537	HG00542	HG00543	HG00551	HG00553	HG00554	HG00556	HG00557	HG00559	HG00560	HG00565	HG00566	HG00580	HG00581	HG00583	HG00584	HG00589	HG00590	HG00592	HG00593	HG00595	HG00596	HG00598	HG00599	HG00607	HG00608	HG00610	HG00611	HG00613	HG00614	HG00619	HG00620	HG00622	HG00623	HG00625	HG00626	HG00628	HG00629	HG00631	HG00632	HG00634	HG00635	HG00637	HG00638	HG00640	HG00641	HG00650	HG00651	HG00653	HG00654	HG00656	HG00657	HG00662	HG00663	HG00671	HG00672	HG00674	HG00675	HG00683	HG00684	HG00689	HG00690	HG00692	HG00693	HG00698	HG00699	HG00701	HG00702	HG00704	HG00705	HG00707	HG00708	HG00717	HG00728	HG00729	HG00731	HG00732	HG00733	HG00734	HG00736	HG00737	HG00739	HG00740	HG00742	HG00743	HG00759	HG00766	HG00844	HG00851	HG00864	HG00867	HG00879	HG00881	HG00956	HG00978	HG00982	HG01028	HG01029	HG01031	HG01046	HG01047	HG01048	HG01049	HG01051	HG01052	HG01054	HG01055	HG01058	HG01060	HG01061	HG01063	HG01064	HG01066	HG01067	HG01069	HG01070	HG01072	HG01073	HG01075	HG01077	HG01079	HG01080	HG01082	HG01083	HG01085	HG01086	HG01088	HG01089	HG01092	HG01094	HG01095	HG01097	HG01098	HG01101	HG01102	HG01104	HG01105	HG01107	HG01108	HG01110	HG01111	HG01112	HG01113	HG01119	HG01121	HG01122	HG01124	HG01125	HG01130	HG01131	HG01133	HG01134	HG01136	HG01137	HG01139	HG01140	HG01142	HG01148	HG01149	HG01161	HG01162	HG01164	HG01167	HG01168	HG01170	HG01171	HG01173	HG01174	HG01176	HG01177	HG01182	HG01183	HG01187	HG01188	HG01190	HG01191	HG01197	HG01198	HG01200	HG01204	HG01205	HG01241	HG01242	HG01247	HG01248	HG01250	HG01251	HG01253	HG01254	HG01256	HG01257	HG01259	HG01260	HG01269	HG01271	HG01272	HG01275	HG01277	HG01280	HG01281	HG01284	HG01286	HG01302	HG01303	HG01305	HG01308	HG01311	HG01312	HG01323	HG01325	HG01326	HG01334	HG01341	HG01342	HG01344	HG01345	HG01348	HG01350	HG01351	HG01353	HG01354	HG01356	HG01357	HG01359	HG01360	HG01362	HG01363	HG01365	HG01366	HG01369	HG01372	HG01374	HG01375	HG01377	HG01378	HG01383	HG01384	HG01389	HG01390	HG01392	HG01393	HG01395	HG01396	HG01398	HG01402	HG01403	HG01405	HG01412	HG01413	HG01414	HG01431	HG01432	HG01435	HG01437	HG01438	HG01440	HG01441	HG01443	HG01444	HG01447	HG01455	HG01456	HG01459	HG01461	HG01462	HG01464	HG01465	HG01468	HG01474	HG01479	HG01485	HG01486	HG01488	HG01489	HG01491	HG01492	HG01494	HG01495	HG01497	HG01498	HG01500	HG01501	HG01503	HG01504	HG01506	HG01507	HG01509	HG01510	HG01512	HG01513	HG01515	HG01516	HG01518	HG01519	HG01521	HG01522	HG01524	HG01525	HG01527	HG01528	HG01530	HG01531	HG01536	HG01537	HG01550	HG01551	HG01556	HG01565	HG01566	HG01571	HG01572	HG01577	HG01578	HG01583	HG01586	HG01589	HG01593	HG01595	HG01596	HG01597	HG01598	HG01599	HG01600	HG01602	HG01603	HG01605	HG01606	HG01607	HG01608	HG01610	HG01612	HG01613	HG01615	HG01617	HG01618	HG01619	HG01620	HG01623	HG01624	HG01625	HG01626	HG01628	HG01630	HG01631	HG01632	HG01668	HG01669	HG01670	HG01672	HG01673	HG01675	HG01676	HG01678	HG01679	HG01680	HG01682	HG01684	HG01685	HG01686	HG01694	HG01695	HG01697	HG01699	HG01700	HG01702	HG01704	HG01705	HG01707	HG01708	HG01709	HG01710	HG01746	HG01747	HG01756	HG01757	HG01761	HG01762	HG01765	HG01766	HG01767	HG01768	HG01770	HG01771	HG01773	HG01775	HG01776	HG01777	HG01779	HG01781	HG01783	HG01784	HG01785	HG01786	HG01789	HG01790	HG01791	HG01794	HG01795	HG01796	HG01797	HG01798	HG01799	HG01800	HG01801	HG01802	HG01804	HG01805	HG01806	HG01807	HG01808	HG01809	HG01810	HG01811	HG01812	HG01813	HG01815	HG01816	HG01817	HG01840	HG01841	HG01842	HG01843	HG01844	HG01845	HG01846	HG01847	HG01848	HG01849	HG01850	HG01851	HG01852	HG01853	HG01855	HG01857	HG01858	HG01859	HG01860	HG01861	HG01862	HG01863	HG01864	HG01865	HG01866	HG01867	HG01868	HG01869	HG01870	HG01871	HG01872	HG01873	HG01874	HG01878	HG01879	HG01880	HG01882	HG01883	HG01885	HG01886	HG01889	HG01890	HG01892	HG01893	HG01894	HG01896	HG01912	HG01914	HG01915	HG01917	HG01918	HG01920	HG01921	HG01923	HG01924	HG01926	HG01927	HG01932	HG01933	HG01935	HG01936	HG01938	HG01939	HG01941	HG01942	HG01944	HG01945	HG01947	HG01948	HG01950	HG01951	HG01953	HG01954	HG01956	HG01958	HG01961	HG01965	HG01967	HG01968	HG01970	HG01971	HG01973	HG01974	HG01976	HG01977	HG01979	HG01980	HG01982	HG01983	HG01985	HG01986	HG01988	HG01989	HG01990	HG01991	HG01992	HG01997	HG02002	HG02003	HG02006	HG02008	HG02009	HG02010	HG02012	HG02013	HG02014	HG02016	HG02017	HG02019	HG02020	HG02023	HG02024	HG02025	HG02026	HG02028	HG02029	HG02031	HG02032	HG02035	HG02040	HG02046	HG02047	HG02048	HG02049	HG02050	HG02051	HG02052	HG02053	HG02054	HG02057	HG02058	HG02060	HG02061	HG02064	HG02067	HG02069	HG02070	HG02072	HG02073	HG02075	HG02076	HG02078	HG02079	HG02081	HG02082	HG02084	HG02085	HG02086	HG02087	HG02088	HG02089	HG02090	HG02095	HG02102	HG02104	HG02105	HG02107	HG02108	HG02111	HG02113	HG02116	HG02121	HG02122	HG02127	HG02128	HG02130	HG02131	HG02133	HG02134	HG02136	HG02137	HG02138	HG02139	HG02140	HG02141	HG02142	HG02143	HG02144	HG02146	HG02147	HG02150	HG02151	HG02152	HG02153	HG02154	HG02155	HG02156	HG02164	HG02165	HG02166	HG02178	HG02179	HG02180	HG02181	HG02182	HG02184	HG02185	HG02186	HG02187	HG02188	HG02190	HG02215	HG02219	HG02220	HG02221	HG02223	HG02224	HG02230	HG02231	HG02232	HG02233	HG02235	HG02236	HG02238	HG02239	HG02250	HG02252	HG02253	HG02255	HG02256	HG02259	HG02260	HG02262	HG02265	HG02266	HG02271	HG02272	HG02274	HG02275	HG02277	HG02278	HG02281	HG02282	HG02283	HG02284	HG02285	HG02286	HG02291	HG02292	HG02298	HG02299	HG02301	HG02304	HG02307	HG02308	HG02309	HG02312	HG02314	HG02315	HG02317	HG02318	HG02322	HG02323	HG02325	HG02330	HG02332	HG02334	HG02337	HG02339	HG02343	HG02345	HG02348	HG02351	HG02353	HG02355	HG02356	HG02360	HG02363	HG02364	HG02367	HG02371	HG02372	HG02373	HG02374	HG02375	HG02377	HG02379	HG02380	HG02381	HG02382	HG02383	HG02384	HG02385	HG02386	HG02387	HG02388	HG02389	HG02390	HG02391	HG02392	HG02394	HG02395	HG02396	HG02397	HG02398	HG02399	HG02401	HG02402	HG02406	HG02407	HG02408	HG02409	HG02410	HG02419	HG02420	HG02425	HG02427	HG02429	HG02433	HG02439	HG02442	HG02445	HG02449	HG02450	HG02455	HG02461	HG02462	HG02464	HG02465	HG02470	HG02471	HG02476	HG02477	HG02479	HG02481	HG02484	HG02485	HG02489	HG02490	HG02491	HG02493	HG02494	HG02496	HG02497	HG02501	HG02502	HG02505	HG02508	HG02511	HG02512	HG02513	HG02521	HG02522	HG02536	HG02537	HG02541	HG02545	HG02546	HG02549	HG02554	HG02555	HG02557	HG02558	HG02561	HG02562	HG02568	HG02570	HG02571	HG02573	HG02574	HG02577	HG02580	HG02582	HG02583	HG02585	HG02586	HG02588	HG02589	HG02594	HG02595	HG02597	HG02600	HG02601	HG02603	HG02604	HG02610	HG02611	HG02613	HG02614	HG02620	HG02621	HG02623	HG02624	HG02628	HG02629	HG02634	HG02635	HG02642	HG02643	HG02645	HG02646	HG02648	HG02649	HG02651	HG02652	HG02654	HG02655	HG02657	HG02658	HG02660	HG02661	HG02666	HG02667	HG02675	HG02676	HG02678	HG02679	HG02681	HG02682	HG02684	HG02685	HG02687	HG02688	HG02690	HG02691	HG02694	HG02696	HG02697	HG02699	HG02700	HG02702	HG02703	HG02715	HG02716	HG02721	HG02722	HG02724	HG02725	HG02727	HG02728	HG02731	HG02733	HG02734	HG02736	HG02737	HG02756	HG02757	HG02759	HG02760	HG02763	HG02768	HG02769	HG02771	HG02772	HG02774	HG02775	HG02778	HG02780	HG02783	HG02784	HG02786	HG02787	HG02789	HG02790	HG02792	HG02793	HG02798	HG02799	HG02804	HG02805	HG02807	HG02808	HG02810	HG02811	HG02813	HG02814	HG02816	HG02817	HG02819	HG02820	HG02836	HG02837	HG02839	HG02840	HG02851	HG02852	HG02854	HG02855	HG02860	HG02861	HG02870	HG02878	HG02879	HG02881	HG02882	HG02884	HG02885	HG02887	HG02888	HG02890	HG02891	HG02895	HG02896	HG02922	HG02923	HG02938	HG02941	HG02943	HG02944	HG02946	HG02947	HG02952	HG02953	HG02968	HG02970	HG02971	HG02973	HG02974	HG02976	HG02977	HG02979	HG02981	HG02982	HG02983	HG03006	HG03007	HG03009	HG03012	HG03015	HG03016	HG03018	HG03019	HG03021	HG03022	HG03024	HG03025	HG03027	HG03028	HG03039	HG03040	HG03045	HG03046	HG03048	HG03049	HG03052	HG03054	HG03055	HG03057	HG03058	HG03060	HG03061	HG03063	HG03064	HG03066	HG03069	HG03072	HG03073	HG03074	HG03077	HG03078	HG03079	HG03081	HG03082	HG03084	HG03085	HG03086	HG03088	HG03091	HG03095	HG03096	HG03097	HG03099	HG03100	HG03103	HG03105	HG03108	HG03109	HG03111	HG03112	HG03114	HG03115	HG03117	HG03118	HG03120	HG03121	HG03123	HG03124	HG03126	HG03127	HG03129	HG03130	HG03132	HG03133	HG03135	HG03136	HG03139	HG03157	HG03159	HG03160	HG03162	HG03163	HG03166	HG03168	HG03169	HG03172	HG03175	HG03189	HG03190	HG03193	HG03195	HG03196	HG03198	HG03199	HG03202	HG03209	HG03212	HG03224	HG03225	HG03228	HG03229	HG03234	HG03235	HG03237	HG03238	HG03240	HG03241	HG03246	HG03247	HG03258	HG03259	HG03265	HG03267	HG03268	HG03270	HG03271	HG03279	HG03280	HG03291	HG03294	HG03295	HG03297	HG03298	HG03300	HG03301	HG03303	HG03304	HG03311	HG03313	HG03342	HG03343	HG03351	HG03352	HG03354	HG03363	HG03366	HG03367	HG03369	HG03370	HG03372	HG03376	HG03378	HG03380	HG03382	HG03385	HG03388	HG03391	HG03394	HG03397	HG03401	HG03410	HG03419	HG03428	HG03432	HG03433	HG03436	HG03437	HG03439	HG03442	HG03445	HG03446	HG03449	HG03451	HG03452	HG03455	HG03457	HG03458	HG03460	HG03461	HG03464	HG03469	HG03470	HG03472	HG03473	HG03476	HG03478	HG03479	HG03484	HG03485	HG03488	HG03490	HG03491	HG03499	HG03511	HG03514	HG03515	HG03517	HG03518	HG03520	HG03521	HG03538	HG03539	HG03547	HG03548	HG03556	HG03557	HG03558	HG03559	HG03563	HG03565	HG03567	HG03571	HG03572	HG03575	HG03577	HG03578	HG03583	HG03585	HG03589	HG03593	HG03594	HG03595	HG03598	HG03600	HG03603	HG03604	HG03607	HG03611	HG03615	HG03616	HG03619	HG03624	HG03625	HG03629	HG03631	HG03634	HG03636	HG03640	HG03642	HG03643	HG03644	HG03645	HG03646	HG03649	HG03652	HG03653	HG03660	HG03663	HG03667	HG03668	HG03672	HG03673	HG03679	HG03680	HG03681	HG03684	HG03685	HG03686	HG03687	HG03689	HG03690	HG03691	HG03692	HG03693	HG03694	HG03695	HG03696	HG03697	HG03698	HG03702	HG03703	HG03705	HG03706	HG03708	HG03709	HG03711	HG03713	HG03714	HG03715	HG03716	HG03717	HG03718	HG03720	HG03722	HG03727	HG03729	HG03730	HG03731	HG03733	HG03736	HG03738	HG03740	HG03741	HG03742	HG03743	HG03744	HG03745	HG03746	HG03750	HG03752	HG03753	HG03754	HG03755	HG03756	HG03757	HG03760	HG03762	HG03765	HG03767	HG03770	HG03771	HG03772	HG03773	HG03774	HG03775	HG03777	HG03778	HG03779	HG03780	HG03781	HG03782	HG03784	HG03785	HG03786	HG03787	HG03788	HG03789	HG03790	HG03792	HG03793	HG03796	HG03800	HG03802	HG03803	HG03805	HG03808	HG03809	HG03812	HG03814	HG03815	HG03817	HG03821	HG03823	HG03824	HG03826	HG03829	HG03830	HG03832	HG03833	HG03836	HG03837	HG03838	HG03844	HG03846	HG03848	HG03849	HG03850	HG03851	HG03854	HG03856	HG03857	HG03858	HG03861	HG03862	HG03863	HG03864	HG03866	HG03867	HG03868	HG03869	HG03870	HG03871	HG03872	HG03873	HG03874	HG03875	HG03882	HG03884	HG03885	HG03886	HG03887	HG03888	HG03890	HG03894	HG03895	HG03896	HG03897	HG03898	HG03899	HG03900	HG03902	HG03905	HG03907	HG03908	HG03910	HG03911	HG03913	HG03914	HG03916	HG03917	HG03919	HG03920	HG03922	HG03925	HG03926	HG03928	HG03931	HG03934	HG03937	HG03940	HG03941	HG03943	HG03944	HG03945	HG03947	HG03948	HG03949	HG03950	HG03951	HG03953	HG03955	HG03960	HG03963	HG03965	HG03967	HG03968	HG03969	HG03971	HG03973	HG03974	HG03976	HG03977	HG03978	HG03985	HG03986	HG03989	HG03990	HG03991	HG03995	HG03998	HG03999	HG04001	HG04002	HG04003	HG04006	HG04014	HG04015	HG04017	HG04018	HG04019	HG04020	HG04022	HG04023	HG04025	HG04026	HG04029	HG04033	HG04035	HG04038	HG04039	HG04042	HG04047	HG04054	HG04056	HG04059	HG04060	HG04061	HG04062	HG04063	HG04070	HG04075	HG04076	HG04080	HG04090	HG04093	HG04094	HG04096	HG04098	HG04099	HG04100	HG04106	HG04107	HG04118	HG04131	HG04134	HG04140	HG04141	HG04144	HG04146	HG04152	HG04153	HG04155	HG04156	HG04158	HG04159	HG04161	HG04162	HG04164	HG04171	HG04173	HG04176	HG04177	HG04180	HG04182	HG04183	HG04185	HG04186	HG04188	HG04189	HG04194	HG04195	HG04198	HG04200	HG04202	HG04206	HG04209	HG04210	HG04211	HG04212	HG04214	HG04216	HG04219	HG04222	HG04225	HG04227	HG04229	HG04235	HG04238	HG04239	NA06984	NA06985	NA06986	NA06989	NA06994	NA07000	NA07037	NA07048	NA07051	NA07056	NA07347	NA07357	NA10847	NA10851	NA11829	NA11830	NA11831	NA11832	NA11840	NA11843	NA11881	NA11892	NA11893	NA11894	NA11918	NA11919	NA11920	NA11930	NA11931	NA11932	NA11933	NA11992	NA11994	NA11995	NA12003	NA12004	NA12005	NA12006	NA12043	NA12044	NA12045	NA12046	NA12058	NA12144	NA12154	NA12155	NA12156	NA12234	NA12249	NA12272	NA12273	NA12275	NA12282	NA12283	NA12286	NA12287	NA12340	NA12341	NA12342	NA12347	NA12348	NA12383	NA12399	NA12400	NA12413	NA12414	NA12489	NA12546	NA12716	NA12717	NA12718	NA12748	NA12749	NA12750	NA12751	NA12760	NA12761	NA12762	NA12763	NA12775	NA12776	NA12777	NA12778	NA12812	NA12813	NA12814	NA12815	NA12827	NA12828	NA12829	NA12830	NA12842	NA12843	NA12872	NA12873	NA12874	NA12878	NA12889	NA12890	NA18486	NA18488	NA18489	NA18498	NA18499	NA18501	NA18502	NA18504	NA18505	NA18507	NA18508	NA18510	NA18511	NA18516	NA18517	NA18519	NA18520	NA18522	NA18523	NA18525	NA18526	NA18528	NA18530	NA18531	NA18532	NA18533	NA18534	NA18535	NA18536	NA18537	NA18538	NA18539	NA18541	NA18542	NA18543	NA18544	NA18545	NA18546	NA18547	NA18548	NA18549	NA18550	NA18552	NA18553	NA18555	NA18557	NA18558	NA18559	NA18560	NA18561	NA18562	NA18563	NA18564	NA18565	NA18566	NA18567	NA18570	NA18571	NA18572	NA18573	NA18574	NA18577	NA18579	NA18582	NA18591	NA18592	NA18593	NA18595	NA18596	NA18597	NA18599	NA18602	NA18603	NA18605	NA18606	NA18608	NA18609	NA18610	NA18611	NA18612	NA18613	NA18614	NA18615	NA18616	NA18617	NA18618	NA18619	NA18620	NA18621	NA18622	NA18623	NA18624	NA18625	NA18626	NA18627	NA18628	NA18629	NA18630	NA18631	NA18632	NA18633	NA18634	NA18635	NA18636	NA18637	NA18638	NA18639	NA18640	NA18641	NA18642	NA18643	NA18644	NA18645	NA18646	NA18647	NA18648	NA18740	NA18745	NA18747	NA18748	NA18749	NA18757	NA18853	NA18856	NA18858	NA18861	NA18864	NA18865	NA18867	NA18868	NA18870	NA18871	NA18873	NA18874	NA18876	NA18877	NA18878	NA18879	NA18881	NA18907	NA18908	NA18909	NA18910	NA18912	NA18915	NA18916	NA18917	NA18923	NA18924	NA18933	NA18934	NA18939	NA18940	NA18941	NA18942	NA18943	NA18944	NA18945	NA18946	NA18947	NA18948	NA18949	NA18950	NA18951	NA18952	NA18953	NA18954	NA18956	NA18957	NA18959	NA18960	NA18961	NA18962	NA18963	NA18964	NA18965	NA18966	NA18967	NA18968	NA18969	NA18970	NA18971	NA18972	NA18973	NA18974	NA18975	NA18976	NA18977	NA18978	NA18979	NA18980	NA18981	NA18982	NA18983	NA18984	NA18985	NA18986	NA18987	NA18988	NA18989	NA18990	NA18991	NA18992	NA18993	NA18994	NA18995	NA18997	NA18998	NA18999	NA19000	NA19001	NA19002	NA19003	NA19004	NA19005	NA19006	NA19007	NA19009	NA19010	NA19011	NA19012	NA19017	NA19019	NA19020	NA19023	NA19024	NA19025	NA19026	NA19027	NA19028	NA19030	NA19031	NA19035	NA19036	NA19037	NA19038	NA19041	NA19042	NA19043	NA19054	NA19055	NA19056	NA19057	NA19058	NA19059	NA19060	NA19062	NA19063	NA19064	NA19065	NA19066	NA19067	NA19068	NA19070	NA19072	NA19074	NA19075	NA19076	NA19077	NA19078	NA19079	NA19080	NA19081	NA19082	NA19083	NA19084	NA19085	NA19086	NA19087	NA19088	NA19089	NA19090	NA19091	NA19092	NA19093	NA19095	NA19096	NA19098	NA19099	NA19102	NA19107	NA19108	NA19113	NA19114	NA19116	NA19117	NA19118	NA19119	NA19121	NA19129	NA19130	NA19131	NA19137	NA19138	NA19141	NA19143	NA19144	NA19146	NA19147	NA19149	NA19152	NA19153	NA19159	NA19160	NA19171	NA19172	NA19175	NA19184	NA19185	NA19189	NA19190	NA19197	NA19198	NA19200	NA19201	NA19204	NA19206	NA19207	NA19209	NA19210	NA19213	NA19214	NA19222	NA19223	NA19225	NA19235	NA19236	NA19238	NA19239	NA19240	NA19247	NA19248	NA19256	NA19257	NA19307	NA19308	NA19309	NA19310	NA19311	NA19312	NA19313	NA19314	NA19315	NA19316	NA19317	NA19318	NA19319	NA19320	NA19321	NA19323	NA19324	NA19327	NA19328	NA19331	NA19332	NA19334	NA19338	NA19346	NA19347	NA19350	NA19351	NA19355	NA19360	NA19372	NA19374	NA19375	NA19376	NA19377	NA19378	NA19379	NA19380	NA19383	NA19384	NA19385	NA19390	NA19391	NA19393	NA19394	NA19395	NA19397	NA19399	NA19401	NA19403	NA19404	NA19428	NA19429	NA19430	NA19431	NA19434	NA19435	NA19436	NA19437	NA19438	NA19439	NA19440	NA19443	NA19445	NA19446	NA19448	NA19449	NA19451	NA19452	NA19454	NA19455	NA19456	NA19457	NA19461	NA19462	NA19463	NA19466	NA19467	NA19468	NA19471	NA19472	NA19473	NA19474	NA19475	NA19625	NA19648	NA19649	NA19651	NA19652	NA19654	NA19655	NA19657	NA19658	NA19660	NA19661	NA19663	NA19664	NA19669	NA19670	NA19675	NA19676	NA19678	NA19679	NA19681	NA19682	NA19684	NA19685	NA19700	NA19701	NA19703	NA19704	NA19707	NA19711	NA19712	NA19713	NA19716	NA19717	NA19719	NA19720	NA19722	NA19723	NA19725	NA19726	NA19728	NA19729	NA19731	NA19732	NA19734	NA19735	NA19740	NA19741	NA19746	NA19747	NA19749	NA19750	NA19752	NA19755	NA19756	NA19758	NA19759	NA19761	NA19762	NA19764	NA19770	NA19771	NA19773	NA19774	NA19776	NA19777	NA19779	NA19780	NA19782	NA19783	NA19785	NA19786	NA19788	NA19789	NA19792	NA19794	NA19795	NA19818	NA19819	NA19834	NA19835	NA19900	NA19901	NA19904	NA19908	NA19909	NA19913	NA19914	NA19916	NA19917	NA19920	NA19921	NA19922	NA19923	NA19982	NA19984	NA19985	NA20126	NA20127	NA20274	NA20276	NA20278	NA20281	NA20282	NA20287	NA20289	NA20291	NA20294	NA20296	NA20298	NA20299	NA20314	NA20317	NA20318	NA20320	NA20321	NA20322	NA20332	NA20334	NA20336	NA20339	NA20340	NA20341	NA20342	NA20344	NA20346	NA20348	NA20351	NA20355	NA20356	NA20357	NA20359	NA20362	NA20412	NA20502	NA20503	NA20504	NA20505	NA20506	NA20507	NA20508	NA20509	NA20510	NA20511	NA20512	NA20513	NA20514	NA20515	NA20516	NA20517	NA20518	NA20519	NA20520	NA20521	NA20522	NA20524	NA20525	NA20526	NA20527	NA20528	NA20529	NA20530	NA20531	NA20532	NA20533	NA20534	NA20535	NA20536	NA20538	NA20539	NA20540	NA20541	NA20542	NA20543	NA20544	NA20581	NA20582	NA20585	NA20586	NA20587	NA20588	NA20589	NA20752	NA20753	NA20754	NA20755	NA20756	NA20757	NA20758	NA20759	NA20760	NA20761	NA20762	NA20763	NA20764	NA20765	NA20766	NA20767	NA20768	NA20769	NA20770	NA20771	NA20772	NA20773	NA20774	NA20775	NA20778	NA20783	NA20785	NA20786	NA20787	NA20790	NA20792	NA20795	NA20796	NA20797	NA20798	NA20799	NA20800	NA20801	NA20802	NA20803	NA20804	NA20805	NA20806	NA20807	NA20808	NA20809	NA20810	NA20811	NA20812	NA20813	NA20814	NA20815	NA20818	NA20819	NA20821	NA20822	NA20826	NA20827	NA20828	NA20832	NA20845	NA20846	NA20847	NA20849	NA20850	NA20851	NA20852	NA20853	NA20854	NA20856	NA20858	NA20859	NA20861	NA20862	NA20863	NA20864	NA20866	NA20867	NA20868	NA20869	NA20870	NA20871	NA20872	NA20874	NA20875	NA20876	NA20877	NA20878	NA20881	NA20882	NA20884	NA20885	NA20886	NA20887	NA20888	NA20889	NA20890	NA20891	NA20892	NA20893	NA20894	NA20895	NA20896	NA20897	NA20898	NA20899	NA20900	NA20901	NA20902	NA20903	NA20904	NA20905	NA20906	NA20908	NA20910	NA20911	NA21086	NA21087	NA21088	NA21089	NA21090	NA21091	NA21092	NA21093	NA21094	NA21095	NA21097	NA21098	NA21099	NA21100	NA21101	NA21102	NA21103	NA21104	NA21105	NA21106	NA21107	NA21108	NA21109	NA21110	NA21111	NA21112	NA21113	NA21114	NA21115	NA21116	NA21117	NA21118	NA21119	NA21120	NA21122	NA21123	NA21124	NA21125	NA21126	NA21127	NA21128	NA21129	NA21130	NA21133	NA21135	NA21137	NA21141	NA21142	NA21143	NA21144
+20	10001365	.	C	T	306.66	PASS	AC=6;AF=1.197e-03;AN=5012;BaseQRankSum=0.412;ClippingRankSum=-1.561;DP=16300;FS=10.694;InbreedingCoeff=-0.0180;MLEAC=3;MLEAF=5.986e-04;MQ=51.55;MQ0=0;MQRankSum=3.769;POSITIVE_TRAIN_SITE;QD=6.97;ReadPosRankSum=-1.487;VQSLOD=1.39;culprit=MQ	GT:AD:DP:GQ:PL	0/0:4,0:4:12:0,12,132	0/0:15,0:15:45:0,45,480	0/0:10,0:10:30:0,30,333	0/0:8,0:8:24:0,24,250	0/0:5,0:5:15:0,15,134	0/0:4,0:4:12:0,12,116	0/0:8,0:8:24:0,24,291	0/0:14,0:14:41:0,41,455	0/0:10,0:10:30:0,30,325	0/0:6,0:6:16:0,16,128	0/0:3,0:3:9:0,9,107	0/0:7,0:7:21:0,21,235	0/0:10,0:10:30:0,30,345	0/0:6,0:6:18:0,18,206	0/0:3,0:3:9:0,9,102	0/0:11,0:11:33:0,33,386	0/0:5,0:5:15:0,15,154	0/0:9,0:9:27:0,27,322	0/0:4,0:4:12:0,12,109	0/0:2,0:2:6:0,6,71	0/0:12,0:12:36:0,36,382	0/0:4,0:4:12:0,12,112	0/0:8,0:8:24:0,24,217	0/0:2,0:2:6:0,6,77	0/0:8,0:8:23:0,23,251	0/0:9,0:9:27:0,27,254	0/0:14,0:14:42:0,42,429	0/0:7,0:7:21:0,21,221	0/0:7,0:7:21:0,21,231	0/0:1,0:1:3:0,3,30	0/0:7,0:7:21:0,21,189	0/0:8,0:8:24:0,24,290	0/0:3,0:3:9:0,9,95	0/0:4,0:4:12:0,12,122	0/0:8,0:8:23:0,23,242	0/0:6,0:6:18:0,18,172	0/0:3,0:3:9:0,9,83	0/0:6,0:6:18:0,18,204	0/0:1,0:1:3:0,3,32	0/0:9,0:9:27:0,27,293	0/0:14,0:14:42:0,42,427	0/0:18,0:18:54:0,54,613	0/0:1,0:1:3:0,3,30	0/0:5,0:5:15:0,15,173	0/0:8,0:8:24:0,24,273	0/0:6,0:6:18:0,18,188	0/0:7,0:7:21:0,21,255	0/0:7,0:7:21:0,21,220	0/0:4,0:4:12:0,12,128	0/0:4,0:4:12:0,12,137	0/0:4,0:4:12:0,12,115	0/0:3,0:3:9:0,9,97	0/0:8,0:8:24:0,24,234	0/0:1,0:1:3:0,3,35	0/0:5,0:5:15:0,15,152	0/0:4,0:4:12:0,12,121	0/0:1,0:1:3:0,3,29	0/0:4,0:4:12:0,12,157	0/0:2,0:2:6:0,6,60	0/0:7,0:7:21:0,21,249	0/0:6,0:6:18:0,18,179	0/0:5,0:5:15:0,15,163	0/0:7,0:7:21:0,21,241	0/0:4,0:4:11:0,11,93	0/0:6,0:6:18:0,18,196	./.	0/0:2,0:2:6:0,6,57	0/0:10,0:10:30:0,30,339	0/0:2,0:2:6:0,6,66	0/0:1,0:1:3:0,3,35	0/0:6,0:6:18:0,18,177	./.	0/0:5,0:5:15:0,15,159	0/0:10,0:10:30:0,30,321	0/0:4,0:4:12:0,12,116	0/0:3,0:3:9:0,9,69	0/0:6,0:6:18:0,18,183	0/0:6,0:6:18:0,18,180	0/0:13,0:13:39:0,39,413	0/0:7,0:7:21:0,21,232	0/0:4,0:4:12:0,12,109	0/0:7,0:7:21:0,21,244	0/0:7,0:7:21:0,21,180	0/0:1,0:1:3:0,3,37	0/0:10,0:10:30:0,30,335	0/0:7,0:7:21:0,21,213	0/0:3,0:3:9:0,9,85	0/0:5,0:5:15:0,15,158	0/0:11,0:11:33:0,33,327	0/0:14,0:14:42:0,42,460	0/0:16,0:16:48:0,48,520	0/0:10,0:10:30:0,30,312	0/0:9,0:9:27:0,27,311	0/0:8,0:8:23:0,23,225	0/0:12,0:12:36:0,36,374	0/0:2,0:2:6:0,6,53	0/0:6,0:6:18:0,18,159	0/0:6,0:6:18:0,18,193	0/0:11,0:11:33:0,33,348	0/0:3,0:3:8:0,8,74	0/0:4,0:4:12:0,12,131	0/0:2,0:2:6:0,6,58	0/0:4,0:4:11:0,11,98	0/0:4,0:4:12:0,12,129	0/0:5,0:5:15:0,15,159	0/0:4,0:4:12:0,12,138	0/0:5,0:5:15:0,15,154	0/0:1,0:1:3:0,3,32	0/0:8,0:8:24:0,24,265	0/0:1,0:1:3:0,3,38	0/0:13,0:13:39:0,39,418	0/0:1,0:1:3:0,3,26	0/0:4,0:4:12:0,12,130	0/0:3,0:3:9:0,9,108	0/0:7,0:7:21:0,21,256	0/0:2,0:2:6:0,6,72	0/0:4,0:4:11:0,11,95	0/0:3,0:3:9:0,9,106	0/0:5,0:5:14:0,14,107	0/0:6,0:6:18:0,18,202	0/0:5,0:5:15:0,15,145	0/0:9,0:9:27:0,27,277	0/0:7,0:7:21:0,21,229	0/0:2,0:2:6:0,6,49	0/0:3,0:3:9:0,9,83	0/0:5,0:5:15:0,15,172	0/0:12,0:12:34:0,34,348	0/0:2,0:2:6:0,6,56	./.	./.	0/0:4,0:4:12:0,12,136	0/0:3,0:3:9:0,9,95	0/0:2,0:2:6:0,6,62	0/0:6,0:6:18:0,18,216	0/0:4,0:4:11:0,11,106	./.	0/0:3,0:3:9:0,9,111	0/0:5,0:5:15:0,15,150	0/0:3,0:3:9:0,9,98	0/0:5,0:5:15:0,15,145	0/0:3,0:3:9:0,9,91	0/0:2,0:2:6:0,6,80	0/0:3,0:3:9:0,9,90	0/0:4,0:4:12:0,12,138	0/0:6,0:6:18:0,18,184	0/0:4,0:4:12:0,12,135	0/0:9,0:9:27:0,27,297	0/0:4,0:4:12:0,12,133	0/0:9,0:9:26:0,26,238	0/0:3,0:3:9:0,9,73	0/0:6,0:6:18:0,18,215	0/0:6,0:6:17:0,17,189	0/0:4,0:4:12:0,12,129	0/0:4,0:4:12:0,12,155	0/0:1,0:1:3:0,3,28	0/0:11,0:11:32:0,32,321	0/0:10,0:10:30:0,30,330	0/0:8,0:8:24:0,24,269	0/0:4,0:4:12:0,12,136	./.	0/0:7,0:7:20:0,20,198	0/0:1,0:1:3:0,3,36	0/0:3,0:3:9:0,9,101	0/0:5,0:5:15:0,15,154	0/0:7,0:7:21:0,21,215	0/0:10,0:10:30:0,30,283	0/0:4,0:4:12:0,12,130	0/0:5,0:5:15:0,15,160	0/0:5,0:5:15:0,15,183	0/0:5,0:5:15:0,15,163	0/0:3,0:3:8:0,8,69	0/0:4,0:4:12:0,12,117	0/0:2,0:2:6:0,6,67	0/0:2,0:2:6:0,6,65	0/0:8,0:8:24:0,24,274	0/0:3,0:3:9:0,9,107	0/0:4,0:4:12:0,12,123	0/0:4,0:4:12:0,12,125	0/0:3,0:3:9:0,9,101	0/0:7,0:7:20:0,20,187	0/0:8,0:8:24:0,24,251	0/0:3,0:3:9:0,9,102	0/0:8,0:8:24:0,24,275	0/0:9,0:9:26:0,26,273	0/0:2,0:2:6:0,6,68	0/0:7,0:7:21:0,21,240	0/0:4,0:4:10:0,10,74	0/0:3,0:3:9:0,9,97	0/0:5,0:5:15:0,15,175	0/0:9,0:9:25:0,25,232	0/0:9,0:9:26:0,26,245	0/0:13,0:13:39:0,39,374	0/0:6,0:6:17:0,17,147	0/0:12,0:12:34:0,34,357	0/0:5,0:5:15:0,15,149	0/0:14,0:14:42:0,42,408	0/0:3,0:3:9:0,9,84	0/0:14,0:14:41:0,41,443	0/0:12,0:12:36:0,36,371	0/0:12,0:12:36:0,36,404	0/0:6,0:6:18:0,18,167	0/0:10,0:10:29:0,29,313	0/0:5,0:5:15:0,15,134	0/0:2,0:2:6:0,6,65	0/0:6,0:6:18:0,18,163	0/0:6,0:6:18:0,18,199	0/0:3,0:3:9:0,9,63	0/0:6,0:6:18:0,18,203	0/0:6,0:6:18:0,18,196	0/0:5,0:5:15:0,15,170	0/0:10,0:10:30:0,30,328	0/0:10,0:10:30:0,30,309	0/0:6,0:6:18:0,18,172	0/0:14,0:14:42:0,42,455	0/0:11,0:11:31:0,31,282	0/0:4,0:4:12:0,12,126	0/0:6,0:6:17:0,17,150	0/0:5,0:5:15:0,15,163	0/0:8,0:8:24:0,24,233	0/0:4,0:4:12:0,12,136	0/0:7,0:7:20:0,20,212	0/0:5,0:5:15:0,15,160	0/0:3,0:3:9:0,9,87	0/0:5,0:5:15:0,15,158	0/0:6,0:6:18:0,18,208	0/0:4,0:4:12:0,12,132	0/0:5,0:5:15:0,15,157	0/0:2,0:2:6:0,6,60	0/0:6,0:6:18:0,18,203	0/0:6,0:6:18:0,18,210	./.	0/0:3,0:3:9:0,9,112	0/0:7,0:7:21:0,21,222	0/0:7,0:7:20:0,20,162	0/0:2,0:2:6:0,6,73	./.	0/0:2,0:2:6:0,6,63	0/0:1,0:1:3:0,3,38	0/0:4,0:4:12:0,12,145	0/0:1,0:1:3:0,3,32	0/0:4,0:4:12:0,12,121	0/0:5,0:5:15:0,15,178	0/0:3,0:3:9:0,9,106	0/0:4,0:4:12:0,12,143	0/0:2,0:2:6:0,6,77	0/0:7,0:7:21:0,21,242	0/0:2,0:2:6:0,6,66	0/0:2,0:2:6:0,6,58	0/0:6,0:6:18:0,18,196	0/0:14,0:14:42:0,42,438	0/0:2,0:2:6:0,6,68	0/0:3,0:3:9:0,9,101	0/0:6,0:6:18:0,18,207	0/0:1,0:1:3:0,3,32	0/0:8,0:8:24:0,24,278	0/0:2,0:2:6:0,6,69	0/0:3,0:3:9:0,9,99	0/0:2,0:2:6:0,6,58	0/0:8,0:8:24:0,24,247	0/0:9,0:9:27:0,27,280	0/0:3,0:3:9:0,9,89	0/0:4,0:4:12:0,12,119	0/0:4,0:4:12:0,12,113	0/0:2,0:2:6:0,6,72	0/0:5,0:5:15:0,15,166	0/0:8,0:8:24:0,24,267	0/1:2,2:4:54:61,0,54	0/0:3,0:3:9:0,9,99	0/0:2,0:2:6:0,6,60	0/0:1,0:1:3:0,3,29	0/0:10,0:10:29:0,29,292	0/0:6,0:6:18:0,18,210	0/0:5,0:5:15:0,15,190	0/0:1,0:1:3:0,3,40	0/0:6,0:6:18:0,18,200	0/0:2,0:2:6:0,6,76	0/0:6,0:6:18:0,18,193	0/0:5,0:5:15:0,15,172	0/0:2,0:2:6:0,6,62	0/0:4,0:4:12:0,12,143	0/0:5,0:5:15:0,15,163	0/0:3,0:3:9:0,9,98	0/0:2,0:2:6:0,6,62	0/0:13,0:13:39:0,39,442	0/0:4,0:4:12:0,12,119	0/0:4,0:4:12:0,12,133	0/0:7,0:7:21:0,21,243	0/0:3,0:3:9:0,9,82	0/0:4,0:4:12:0,12,135	0/0:2,0:2:6:0,6,67	0/0:3,0:3:9:0,9,116	0/0:3,0:3:9:0,9,115	0/0:6,0:6:18:0,18,194	0/0:4,0:4:12:0,12,139	0/0:7,0:7:21:0,21,248	0/0:6,0:6:18:0,18,216	0/0:5,0:5:15:0,15,150	0/0:5,0:5:15:0,15,159	0/0:4,0:4:12:0,12,116	0/0:9,0:9:27:0,27,251	0/0:13,0:13:39:0,39,401	0/0:22,0:22:65:0,65,670	0/0:25,0:25:73:0,73,711	0/0:24,0:24:69:0,69,660	0/0:8,0:8:24:0,24,273	0/0:3,0:3:9:0,9,101	0/0:8,0:8:24:0,24,247	0/0:13,0:13:39:0,39,407	0/0:1,0:1:3:0,3,35	0/0:6,0:6:18:0,18,190	0/0:5,0:5:14:0,14,120	0/0:7,0:7:20:0,20,214	0/0:2,0:2:6:0,6,65	0/0:6,0:6:18:0,18,204	0/0:16,0:16:48:0,48,514	0/0:4,0:4:12:0,12,133	0/0:7,0:7:21:0,21,217	0/0:3,0:3:9:0,9,95	0/0:8,0:8:24:0,24,290	0/0:12,0:12:36:0,36,398	0/0:5,0:5:14:0,14,133	0/0:5,0:5:15:0,15,152	0/0:4,0:4:12:0,12,145	0/0:6,0:6:18:0,18,187	0/0:3,0:3:9:0,9,87	0/0:6,0:6:17:0,17,194	0/0:3,0:3:9:0,9,106	0/0:6,0:6:18:0,18,177	0/0:9,0:9:25:0,25,244	0/0:5,0:5:15:0,15,241	0/0:6,0:6:18:0,18,216	0/0:1,0:1:3:0,3,26	0/0:6,0:6:18:0,18,196	0/0:2,0:2:6:0,6,54	0/0:4,0:4:12:0,12,130	0/0:6,0:6:17:0,17,191	0/0:12,0:12:36:0,36,328	./.	0/0:6,0:6:18:0,18,201	0/0:3,0:3:9:0,9,87	0/0:9,0:9:27:0,27,311	0/0:10,0:10:29:0,29,312	0/0:6,0:6:18:0,18,198	0/0:7,0:7:21:0,21,252	0/0:13,0:13:39:0,39,400	0/0:3,0:3:9:0,9,75	0/0:8,0:8:24:0,24,261	0/0:2,0:2:6:0,6,55	0/0:4,0:4:12:0,12,155	0/0:2,0:2:6:0,6,63	0/0:5,0:5:15:0,15,159	0/0:3,0:3:9:0,9,94	0/0:5,0:5:15:0,15,178	0/1:8,1:9:5:5,0,222	0/0:12,0:12:36:0,36,391	0/0:8,0:8:24:0,24,270	0/0:10,0:10:30:0,30,279	0/0:7,0:7:21:0,21,231	0/0:8,0:8:24:0,24,260	0/0:15,0:15:45:0,45,445	0/0:3,0:3:9:0,9,87	0/0:3,0:3:9:0,9,112	0/0:4,0:4:12:0,12,117	0/0:10,0:10:30:0,30,330	0/0:7,0:7:21:0,21,232	0/0:10,0:10:30:0,30,332	0/0:9,0:9:27:0,27,316	0/0:6,0:6:18:0,18,159	0/0:4,0:4:12:0,12,130	0/0:6,0:6:18:0,18,193	0/0:4,0:4:12:0,12,136	0/0:9,0:9:27:0,27,320	0/0:9,0:9:27:0,27,317	0/0:7,0:7:20:0,20,196	0/0:7,0:7:21:0,21,224	0/0:12,0:12:36:0,36,358	0/0:17,0:17:51:0,51,599	0/0:1,0:1:3:0,3,27	0/0:16,0:16:47:0,47,522	0/0:6,0:6:18:0,18,215	0/0:5,0:5:15:0,15,169	0/0:12,0:12:36:0,36,391	0/0:7,0:7:21:0,21,208	0/0:3,0:3:9:0,9,105	0/0:6,0:6:18:0,18,222	0/0:6,0:6:18:0,18,176	0/0:4,0:4:12:0,12,110	0/0:3,0:3:9:0,9,88	0/0:19,0:19:57:0,57,598	0/0:2,0:2:6:0,6,65	0/0:4,0:4:12:0,12,121	0/0:4,0:4:12:0,12,139	0/0:5,0:5:15:0,15,167	0/0:2,0:2:6:0,6,67	0/0:17,0:17:50:0,50,446	0/0:8,0:8:24:0,24,260	0/0:5,0:5:15:0,15,151	0/0:8,0:8:24:0,24,222	0/0:5,0:5:15:0,15,147	0/0:7,0:7:21:0,21,198	0/0:11,0:11:33:0,33,313	0/0:5,0:5:15:0,15,145	0/0:2,0:2:6:0,6,62	0/0:4,0:4:12:0,12,115	0/0:3,0:3:9:0,9,80	0/0:7,0:7:20:0,20,197	0/0:14,0:14:39:0,39,369	0/0:13,0:13:39:0,39,407	0/0:6,0:6:18:0,18,163	0/0:8,0:8:24:0,24,248	0/0:1,0:1:3:0,3,29	0/0:4,0:4:12:0,12,126	0/0:2,0:2:6:0,6,69	0/0:3,0:3:9:0,9,96	0/0:1,0:1:3:0,3,32	0/0:3,0:3:9:0,9,89	0/0:5,0:5:15:0,15,143	0/0:6,0:6:18:0,18,195	0/0:7,0:7:19:0,19,172	0/0:5,0:5:15:0,15,174	0/0:4,0:4:12:0,12,123	0/0:4,0:4:12:0,12,117	0/0:5,0:5:15:0,15,158	0/0:1,0:1:3:0,3,29	0/0:4,0:4:12:0,12,114	0/0:4,0:4:12:0,12,142	0/0:14,0:14:42:0,42,435	0/0:4,0:4:12:0,12,136	0/0:3,0:3:9:0,9,103	0/0:5,0:5:15:0,15,183	0/0:2,0:2:6:0,6,52	0/0:4,0:4:12:0,12,133	0/0:5,0:5:15:0,15,151	0/0:7,0:7:21:0,21,254	0/0:6,0:6:18:0,18,225	0/0:10,0:10:30:0,30,350	0/0:5,0:5:15:0,15,150	0/0:4,0:4:12:0,12,129	0/0:4,0:4:12:0,12,129	0/0:5,0:5:15:0,15,161	0/0:8,0:8:23:0,23,224	0/0:2,0:2:5:0,5,32	0/0:10,0:10:30:0,30,293	0/0:7,0:7:21:0,21,239	0/0:4,0:4:12:0,12,149	0/0:2,0:2:6:0,6,77	0/0:3,0:3:9:0,9,101	0/0:5,0:5:15:0,15,213	0/0:1,0:1:3:0,3,50	0/0:7,0:7:21:0,21,200	0/0:4,0:4:12:0,12,129	0/0:10,0:10:30:0,30,337	0/0:5,0:5:15:0,15,155	0/0:5,0:5:15:0,15,177	0/0:5,0:5:15:0,15,177	0/0:9,0:9:27:0,27,284	0/0:5,0:5:15:0,15,169	0/0:2,0:2:6:0,6,70	0/0:5,0:5:15:0,15,161	0/0:4,0:4:12:0,12,161	0/0:3,0:3:9:0,9,111	0/0:3,0:3:9:0,9,124	0/0:2,0:2:6:0,6,87	0/0:9,0:9:27:0,27,292	0/0:3,0:3:9:0,9,109	0/0:5,0:5:15:0,15,182	0/0:8,0:8:23:0,23,228	0/0:6,0:6:18:0,18,200	0/0:11,0:11:33:0,33,378	0/0:4,0:4:12:0,12,122	0/0:9,0:9:27:0,27,285	0/0:7,0:7:21:0,21,243	0/0:4,0:4:12:0,12,125	0/0:8,0:8:24:0,24,260	0/0:9,0:9:25:0,25,246	0/0:5,0:5:15:0,15,149	0/0:10,0:10:29:0,29,281	0/0:6,0:6:18:0,18,204	0/0:8,0:8:23:0,23,235	0/0:2,0:2:5:0,5,22	0/0:3,0:3:9:0,9,95	0/0:1,0:1:3:0,3,38	0/0:4,0:4:12:0,12,113	0/0:5,0:5:15:0,15,161	0/0:4,0:4:12:0,12,99	0/0:7,0:7:20:0,20,190	0/0:6,0:6:17:0,17,141	0/0:9,0:9:27:0,27,308	0/0:5,0:5:15:0,15,136	0/0:4,0:4:12:0,12,118	0/0:6,0:6:18:0,18,199	0/0:13,0:13:38:0,38,386	0/0:7,0:7:21:0,21,197	0/0:4,0:4:12:0,12,112	0/0:1,0:1:3:0,3,37	0/0:2,0:2:6:0,6,58	0/0:6,0:6:17:0,17,165	0/0:10,0:10:30:0,30,314	0/0:6,0:6:18:0,18,175	0/0:6,0:6:18:0,18,166	0/0:1,0:1:3:0,3,26	0/0:7,0:7:21:0,21,212	0/0:1,0:1:3:0,3,36	0/0:10,0:10:30:0,30,319	0/0:2,0:2:6:0,6,55	0/0:1,0:1:3:0,3,29	0/0:4,0:4:11:0,11,105	0/0:3,0:3:9:0,9,88	0/0:3,0:3:9:0,9,110	0/0:4,0:4:12:0,12,123	0/0:3,0:3:9:0,9,109	0/0:4,0:4:12:0,12,151	0/0:8,0:8:24:0,24,222	0/0:3,0:3:9:0,9,93	0/0:4,0:4:12:0,12,128	0/0:4,0:4:12:0,12,132	0/0:3,0:3:9:0,9,96	0/0:5,0:5:15:0,15,145	0/0:4,0:4:12:0,12,118	0/0:5,0:5:15:0,15,156	0/0:7,0:7:21:0,21,208	0/0:10,0:10:30:0,30,309	0/0:5,0:5:15:0,15,173	0/0:10,0:10:29:0,29,291	0/0:7,0:7:21:0,21,219	0/0:7,0:7:21:0,21,229	0/0:4,0:4:12:0,12,124	0/0:5,0:5:15:0,15,136	0/0:7,0:7:21:0,21,237	0/0:8,0:8:24:0,24,257	0/0:3,0:3:9:0,9,90	0/0:6,0:6:18:0,18,201	0/0:6,0:6:18:0,18,197	0/0:3,0:3:9:0,9,101	0/0:3,0:3:9:0,9,77	./.	0/0:5,0:5:15:0,15,184	0/0:4,0:4:11:0,11,113	0/0:5,0:5:15:0,15,169	./.	0/0:6,0:6:18:0,18,170	0/0:5,0:5:15:0,15,149	0/0:8,0:8:24:0,24,228	0/0:3,0:3:9:0,9,100	0/0:5,0:5:15:0,15,149	0/0:9,0:9:27:0,27,315	0/0:7,0:7:21:0,21,235	0/0:1,0:1:3:0,3,25	0/0:7,0:7:21:0,21,246	0/0:7,0:7:21:0,21,332	0/0:4,0:4:12:0,12,147	0/0:4,0:4:12:0,12,183	0/0:4,0:4:12:0,12,145	0/0:4,0:4:12:0,12,169	0/0:4,0:4:12:0,12,171	0/0:3,0:3:9:0,9,110	0/0:3,0:3:9:0,9,133	0/0:5,0:5:15:0,15,219	0/0:6,0:6:18:0,18,256	0/0:6,0:6:18:0,18,177	0/0:5,0:5:15:0,15,178	0/0:4,0:4:12:0,12,138	0/0:3,0:3:9:0,9,107	0/0:6,0:6:18:0,18,198	0/0:10,0:10:30:0,30,313	0/0:3,0:3:9:0,9,94	0/0:5,0:5:15:0,15,183	0/0:3,0:3:9:0,9,88	0/0:8,0:8:24:0,24,268	0/0:6,0:6:18:0,18,193	0/0:6,0:6:18:0,18,193	0/0:3,0:3:9:0,9,104	0/0:3,0:3:9:0,9,103	0/0:4,0:4:12:0,12,134	0/0:4,1:5:9:0,9,138	0/0:3,0:3:9:0,9,104	0/0:6,0:6:18:0,18,200	0/0:9,0:9:27:0,27,294	0/0:5,0:5:15:0,15,172	0/0:2,0:2:6:0,6,61	0/0:9,0:9:27:0,27,331	0/0:5,0:5:15:0,15,153	0/0:7,0:7:20:0,20,196	0/0:8,0:8:22:0,22,201	0/0:3,0:3:9:0,9,111	0/0:6,0:6:18:0,18,191	0/0:5,0:5:14:0,14,132	0/0:6,0:6:18:0,18,228	0/0:10,0:10:30:0,30,319	0/0:4,0:4:12:0,12,138	0/0:4,0:4:12:0,12,124	0/0:5,0:5:15:0,15,160	0/0:5,0:5:15:0,15,161	0/0:7,0:7:21:0,21,229	0/0:7,0:7:20:0,20,210	0/0:9,0:9:27:0,27,289	0/0:7,0:7:21:0,21,228	0/0:7,0:7:21:0,21,202	0/0:3,0:3:9:0,9,102	0/0:17,0:17:51:0,51,526	0/0:12,0:12:36:0,36,365	0/0:17,0:17:50:0,50,470	0/0:9,0:9:26:0,26,274	0/0:5,0:5:15:0,15,180	0/0:4,0:4:12:0,12,136	0/0:6,0:6:17:0,17,165	0/0:4,0:4:12:0,12,139	0/0:13,0:13:39:0,39,500	0/0:16,0:16:48:0,48,631	0/0:6,0:6:18:0,18,238	0/0:4,0:4:12:0,12,151	0/0:2,0:2:6:0,6,87	0/0:9,0:9:27:0,27,313	0/0:4,0:4:12:0,12,123	0/0:4,0:4:12:0,12,152	0/0:9,0:9:27:0,27,299	0/0:15,0:15:44:0,44,481	0/0:6,0:6:18:0,18,171	0/0:7,0:7:21:0,21,221	0/0:3,0:3:9:0,9,87	./.	0/0:5,0:5:15:0,15,172	./.	0/0:8,0:8:24:0,24,242	0/0:5,0:5:15:0,15,138	0/0:10,0:10:30:0,30,334	0/0:2,0:2:6:0,6,58	0/0:5,0:5:15:0,15,158	0/0:8,0:8:24:0,24,251	0/0:2,0:2:6:0,6,60	0/0:10,0:10:29:0,29,316	0/0:7,0:7:21:0,21,201	0/0:7,0:7:21:0,21,225	0/0:4,0:4:12:0,12,147	0/0:2,0:2:6:0,6,70	0/0:5,0:5:15:0,15,165	0/0:3,0:3:9:0,9,106	0/0:5,0:5:15:0,15,168	0/0:10,0:10:30:0,30,293	0/0:8,0:8:24:0,24,268	0/0:4,0:4:12:0,12,120	0/0:2,0:2:6:0,6,68	0/0:6,0:6:18:0,18,203	0/0:7,0:7:21:0,21,191	0/0:5,0:5:15:0,15,146	0/0:9,0:9:27:0,27,301	0/0:4,0:4:11:0,11,80	0/0:4,0:4:12:0,12,134	0/0:4,0:4:11:0,11,107	0/0:8,0:8:24:0,24,264	0/0:6,0:6:18:0,18,210	0/0:5,0:5:15:0,15,156	0/0:5,0:5:15:0,15,178	0/0:3,0:3:9:0,9,97	0/0:5,0:5:15:0,15,175	0/0:3,0:3:9:0,9,103	0/0:5,0:5:15:0,15,140	0/0:8,0:8:24:0,24,270	0/0:4,0:4:12:0,12,131	0/0:9,0:9:27:0,27,286	0/0:4,0:4:12:0,12,135	0/0:7,0:7:20:0,20,208	0/0:9,0:9:27:0,27,292	0/0:5,0:5:15:0,15,153	0/0:6,0:6:18:0,18,201	0/0:1,0:1:3:0,3,36	0/0:13,0:13:39:0,39,392	0/0:10,0:10:29:0,29,259	0/0:1,0:1:3:0,3,28	0/0:7,0:7:21:0,21,253	0/0:5,0:5:15:0,15,159	0/0:8,0:8:24:0,24,288	0/0:16,0:16:48:0,48,470	0/0:22,0:22:65:0,65,687	0/0:16,0:16:48:0,48,495	0/0:26,0:26:78:0,78,809	0/0:16,0:16:48:0,48,548	0/0:19,0:19:57:0,57,550	0/0:4,0:4:12:0,12,136	0/0:6,0:6:18:0,18,208	0/0:8,0:8:24:0,24,258	0/0:9,0:9:27:0,27,302	0/0:3,0:3:9:0,9,99	0/0:22,0:22:66:0,66,629	0/0:16,0:16:48:0,48,640	0/0:9,0:9:27:0,27,320	0/0:2,0:2:6:0,6,66	0/0:5,0:5:15:0,15,159	0/0:2,0:2:6:0,6,67	0/0:2,0:2:6:0,6,57	0/0:4,0:4:12:0,12,134	0/0:4,0:4:12:0,12,124	0/0:4,0:4:12:0,12,231	0/0:7,0:7:21:0,21,229	0/0:7,0:7:21:0,21,230	0/0:6,0:6:18:0,18,210	0/0:8,0:8:24:0,24,259	0/0:1,0:1:3:0,3,33	0/0:7,0:7:21:0,21,234	0/0:8,0:8:23:0,23,218	0/0:4,0:4:12:0,12,118	0/0:9,0:9:27:0,27,306	0/0:6,0:6:17:0,17,136	0/0:9,0:9:27:0,27,252	0/0:1,0:1:3:0,3,36	0/0:5,0:5:15:0,15,156	0/0:12,0:12:36:0,36,367	0/0:5,0:5:15:0,15,142	0/0:9,0:9:27:0,27,292	0/0:8,0:8:24:0,24,242	0/0:3,0:3:8:0,8,74	0/0:3,0:3:9:0,9,111	0/0:4,0:4:11:0,11,113	0/0:11,0:11:33:0,33,324	0/0:8,0:8:24:0,24,247	0/0:12,0:12:36:0,36,361	0/0:15,0:15:44:0,44,439	0/0:2,0:2:6:0,6,52	0/0:6,0:6:18:0,18,186	0/0:6,0:6:18:0,18,194	0/0:2,0:2:6:0,6,52	0/0:8,0:8:24:0,24,216	0/0:13,0:13:39:0,39,400	0/0:8,0:8:23:0,23,199	0/0:20,0:20:60:0,60,643	0/0:21,0:21:62:0,62,574	0/0:16,0:16:47:0,47,453	0/0:13,0:13:39:0,39,414	0/0:19,0:19:57:0,57,572	0/0:8,0:8:24:0,24,300	0/0:10,0:10:30:0,30,372	0/0:5,0:5:14:0,14,153	0/0:4,0:4:12:0,12,141	0/0:7,0:7:21:0,21,233	0/0:6,0:6:18:0,18,202	0/0:4,0:4:12:0,12,145	0/0:3,0:3:9:0,9,109	0/0:8,0:8:24:0,24,274	0/0:12,0:12:36:0,36,449	0/0:19,0:19:56:0,56,683	0/0:6,0:6:18:0,18,198	0/0:1,0:1:3:0,3,32	0/0:7,0:7:21:0,21,227	0/0:3,0:3:8:0,8,76	0/0:5,0:5:14:0,14,131	0/0:17,0:17:50:0,50,629	0/0:12,0:12:35:0,35,398	0/0:5,0:5:15:0,15,176	0/0:2,0:2:6:0,6,58	0/0:7,0:7:21:0,21,212	0/0:1,0:1:3:0,3,17	0/0:3,0:3:9:0,9,102	0/0:2,0:2:6:0,6,65	0/0:6,0:6:18:0,18,191	./.	0/0:7,0:7:20:0,20,167	0/0:9,0:9:24:0,24,202	0/0:10,1:11:27:0,27,292	0/0:1,0:1:3:0,3,23	0/0:3,0:3:9:0,9,103	0/0:5,0:5:15:0,15,160	0/0:6,0:6:17:0,17,167	0/0:7,0:7:21:0,21,238	0/0:7,0:7:21:0,21,227	0/0:5,0:5:15:0,15,147	0/0:4,0:4:12:0,12,135	0/0:13,0:13:39:0,39,355	0/0:8,0:8:24:0,24,229	0/0:14,0:14:42:0,42,483	0/0:8,0:8:24:0,24,267	0/0:6,0:6:18:0,18,167	0/0:3,0:3:9:0,9,103	./.	0/0:21,0:21:62:0,62,610	0/0:6,0:6:18:0,18,196	0/0:3,0:3:9:0,9,105	0/0:7,0:7:21:0,21,204	0/0:5,0:5:15:0,15,147	0/0:7,0:7:21:0,21,236	0/0:15,0:15:44:0,44,378	0/0:15,0:15:45:0,45,430	0/0:12,0:12:36:0,36,344	0/0:14,0:14:39:0,39,323	0/0:14,0:14:42:0,42,549	0/0:17,0:17:51:0,51,635	0/0:17,0:17:51:0,51,647	0/0:17,0:17:50:0,50,592	0/0:3,0:3:9:0,9,99	0/0:10,0:10:30:0,30,352	0/0:8,0:8:24:0,24,249	0/0:6,0:6:18:0,18,184	0/0:4,0:4:12:0,12,130	0/0:1,0:1:2:0,2,5	0/0:1,0:1:3:0,3,30	0/0:5,0:5:15:0,15,161	0/0:4,0:4:12:0,12,139	0/0:9,0:9:27:0,27,274	0/0:4,0:4:12:0,12,127	0/0:11,0:11:33:0,33,336	0/0:1,0:1:3:0,3,29	0/0:45,0:45:99:0,133,1305	0/0:8,0:8:24:0,24,238	0/0:3,0:3:9:0,9,81	0/0:9,0:9:27:0,27,294	0/0:5,0:5:13:0,13,107	0/0:8,0:8:23:0,23,261	0/0:8,0:8:24:0,24,255	0/0:4,0:4:12:0,12,148	0/0:5,0:5:14:0,14,147	0/0:8,0:8:23:0,23,224	0/0:5,0:5:15:0,15,156	0/0:5,0:5:15:0,15,171	0/0:3,0:3:9:0,9,103	0/0:6,0:6:18:0,18,192	0/0:7,0:7:21:0,21,265	0/0:6,0:6:18:0,18,212	0/0:3,0:3:9:0,9,104	0/0:2,0:2:6:0,6,58	0/0:6,0:6:18:0,18,186	0/0:2,0:2:6:0,6,68	0/0:6,0:6:18:0,18,197	0/0:8,0:8:24:0,24,236	0/0:5,0:5:15:0,15,159	0/0:8,0:8:24:0,24,274	0/0:8,0:8:24:0,24,274	0/0:7,0:7:21:0,21,247	0/0:3,0:3:9:0,9,93	0/0:4,0:4:12:0,12,130	0/0:9,0:9:27:0,27,306	0/0:7,0:7:21:0,21,247	0/0:5,0:5:15:0,15,174	0/0:2,0:2:6:0,6,68	0/0:3,0:3:9:0,9,101	0/0:1,0:1:3:0,3,38	0/0:4,0:4:12:0,12,152	0/0:5,0:5:15:0,15,154	0/0:5,0:5:15:0,15,168	0/0:2,0:2:6:0,6,71	0/0:4,0:4:12:0,12,116	0/0:4,0:4:12:0,12,151	0/0:6,0:6:18:0,18,198	0/0:7,0:7:21:0,21,234	0/0:5,0:5:15:0,15,172	0/0:5,0:5:15:0,15,158	0/0:2,0:2:6:0,6,75	0/0:11,0:11:33:0,33,363	0/0:5,0:5:15:0,15,137	0/0:6,0:6:17:0,17,202	0/0:5,0:5:15:0,15,170	0/0:1,0:1:3:0,3,32	./.	0/0:2,0:2:6:0,6,65	0/0:3,0:3:9:0,9,113	0/0:6,0:6:18:0,18,201	0/0:10,0:10:30:0,30,342	0/0:8,0:8:24:0,24,311	0/0:8,0:8:24:0,24,309	0/0:4,0:4:12:0,12,132	0/0:9,0:9:26:0,26,256	0/0:5,0:5:15:0,15,175	0/0:8,0:8:24:0,24,283	0/0:4,0:4:12:0,12,132	0/0:5,0:5:15:0,15,208	0/0:6,0:6:18:0,18,211	0/0:12,0:12:36:0,36,370	0/0:7,0:7:20:0,20,219	0/0:6,0:6:18:0,18,213	0/0:2,0:2:6:0,6,58	0/0:4,0:4:12:0,12,125	0/0:10,0:10:30:0,30,324	0/0:14,0:14:41:0,41,413	0/0:9,0:9:27:0,27,294	0/0:5,0:5:15:0,15,164	0/0:9,0:9:27:0,27,312	0/0:6,0:6:18:0,18,191	0/0:12,0:12:36:0,36,390	0/0:12,0:12:36:0,36,433	0/0:12,0:12:36:0,36,404	0/0:9,0:9:26:0,26,238	0/0:3,0:3:9:0,9,92	0/0:5,0:5:15:0,15,177	0/0:3,0:3:9:0,9,99	0/0:2,0:2:6:0,6,73	0/0:3,0:3:9:0,9,111	0/0:5,0:5:15:0,15,154	0/0:12,0:12:36:0,36,366	0/0:9,0:9:27:0,27,308	0/0:11,0:11:33:0,33,332	0/0:5,0:5:15:0,15,163	0/0:8,0:8:24:0,24,253	0/0:5,0:5:15:0,15,149	0/0:6,0:6:18:0,18,196	0/0:6,0:6:18:0,18,171	0/0:9,0:9:27:0,27,259	0/0:1,0:1:3:0,3,32	0/0:5,0:5:15:0,15,163	0/0:4,0:4:12:0,12,116	0/0:7,0:7:21:0,21,279	0/0:7,0:7:21:0,21,226	0/0:13,0:13:39:0,39,398	0/0:6,0:6:18:0,18,173	0/0:8,0:8:24:0,24,227	0/0:2,0:2:6:0,6,69	0/0:10,0:10:30:0,30,351	0/0:4,0:4:12:0,12,119	0/0:6,0:6:18:0,18,191	0/0:6,0:6:18:0,18,193	./.	0/0:4,0:4:12:0,12,137	0/0:7,0:7:21:0,21,225	0/0:7,0:7:21:0,21,240	0/0:11,0:11:33:0,33,341	0/0:3,0:3:9:0,9,100	0/0:6,0:6:17:0,17,170	0/0:4,0:4:12:0,12,140	0/0:3,0:3:9:0,9,110	0/0:7,0:7:21:0,21,222	0/0:7,0:7:21:0,21,216	0/0:3,0:3:9:0,9,111	0/0:3,0:3:9:0,9,98	0/0:7,0:7:21:0,21,214	0/0:2,0:2:6:0,6,73	0/0:9,0:9:27:0,27,320	0/0:4,0:4:12:0,12,112	0/0:8,0:8:24:0,24,297	0/0:7,0:7:21:0,21,254	0/0:2,0:2:6:0,6,56	0/0:4,0:4:12:0,12,132	0/0:1,0:1:3:0,3,27	0/0:5,0:5:15:0,15,131	0/0:6,0:6:18:0,18,199	0/0:3,0:3:9:0,9,91	0/0:6,0:6:18:0,18,194	0/0:5,0:5:15:0,15,169	0/0:5,0:5:15:0,15,185	0/0:6,0:6:18:0,18,193	0/0:4,0:4:12:0,12,149	0/0:3,0:3:9:0,9,86	0/0:9,0:9:27:0,27,310	0/0:3,0:3:9:0,9,91	0/0:3,0:3:9:0,9,88	0/0:3,0:3:9:0,9,94	0/0:7,0:7:21:0,21,248	0/0:7,0:7:21:0,21,227	0/0:7,0:7:21:0,21,234	0/0:4,0:4:12:0,12,127	0/0:12,0:12:36:0,36,413	0/0:9,0:9:27:0,27,284	0/0:8,0:8:24:0,24,300	0/0:7,0:7:21:0,21,231	0/0:10,0:10:30:0,30,316	0/0:8,0:8:23:0,23,205	0/0:5,0:5:15:0,15,171	0/0:10,0:10:30:0,30,307	0/0:2,0:2:6:0,6,66	0/0:3,0:3:9:0,9,96	0/0:4,0:4:12:0,12,127	0/0:9,0:9:27:0,27,282	0/0:14,0:14:42:0,42,450	0/0:11,0:11:32:0,32,335	0/0:9,0:9:27:0,27,285	0/0:6,0:6:18:0,18,169	0/0:8,0:8:23:0,23,213	0/0:2,0:2:6:0,6,67	0/0:9,0:9:27:0,27,297	0/0:7,0:7:21:0,21,249	0/0:5,0:5:15:0,15,170	0/0:2,0:2:6:0,6,59	0/0:7,0:7:21:0,21,205	0/0:8,0:8:23:0,23,228	0/0:14,0:14:42:0,42,450	0/0:5,0:5:15:0,15,169	0/0:7,0:7:21:0,21,212	0/0:8,0:8:24:0,24,205	0/0:4,0:4:12:0,12,114	0/0:5,0:5:15:0,15,141	0/0:5,0:5:14:0,14,120	0/0:4,0:4:11:0,11,82	0/0:4,0:4:12:0,12,133	0/0:2,0:2:6:0,6,64	0/0:6,0:6:18:0,18,210	0/0:14,0:14:40:0,40,419	0/0:2,0:2:6:0,6,58	0/0:8,0:8:24:0,24,258	0/0:17,0:17:51:0,51,554	0/0:6,0:6:18:0,18,183	0/0:10,0:10:30:0,30,308	0/0:5,0:5:15:0,15,142	0/0:11,0:11:33:0,33,355	0/0:5,0:5:15:0,15,150	0/0:10,0:10:30:0,30,352	0/0:4,0:4:12:0,12,133	0/0:7,0:7:21:0,21,225	0/0:11,0:11:33:0,33,370	0/0:6,0:6:17:0,17,147	0/0:1,0:1:3:0,3,30	0/0:11,0:11:33:0,33,378	0/0:7,0:7:19:0,19,158	0/0:19,0:19:55:0,55,525	0/0:8,0:8:24:0,24,254	0/0:12,0:12:32:0,32,274	0/0:13,0:13:39:0,39,432	0/0:3,0:3:9:0,9,90	0/0:5,0:5:15:0,15,163	0/0:5,0:5:14:0,14,140	0/0:5,0:5:15:0,15,175	0/0:7,0:7:20:0,20,219	0/0:5,0:5:15:0,15,135	0/0:11,0:11:33:0,33,363	0/0:4,0:4:12:0,12,124	0/0:7,0:7:21:0,21,248	0/0:8,0:8:24:0,24,231	0/0:13,0:13:38:0,38,368	0/0:5,0:5:15:0,15,142	0/0:5,0:5:15:0,15,154	0/0:8,0:8:23:0,23,212	0/0:8,0:8:24:0,24,243	0/0:12,0:12:36:0,36,321	0/0:7,0:7:21:0,21,217	0/0:8,0:8:23:0,23,217	0/0:12,0:12:35:0,35,542	0/0:8,0:8:23:0,23,218	0/0:4,0:4:12:0,12,103	0/0:9,0:9:26:0,26,244	0/0:3,0:3:9:0,9,94	0/0:15,0:15:45:0,45,750	0/0:10,0:10:30:0,30,275	0/0:9,0:9:27:0,27,279	0/0:11,0:11:32:0,32,299	0/0:10,0:10:29:0,29,286	0/0:12,0:12:36:0,36,387	0/0:5,0:5:14:0,14,124	0/0:10,0:10:28:0,28,249	0/0:8,0:8:24:0,24,232	0/0:10,0:10:30:0,30,296	0/0:7,0:7:21:0,21,228	0/0:9,0:9:27:0,27,293	0/0:8,0:8:24:0,24,233	0/0:6,0:6:18:0,18,180	0/0:12,0:12:35:0,35,311	0/0:15,0:15:45:0,45,442	0/0:6,0:6:18:0,18,164	0/0:4,0:4:11:0,11,85	0/0:7,0:7:21:0,21,211	0/0:7,0:7:21:0,21,211	0/0:8,0:8:24:0,24,207	0/0:9,0:9:27:0,27,281	0/0:6,0:6:18:0,18,165	0/0:3,0:3:9:0,9,78	0/0:7,0:7:21:0,21,199	0/0:6,0:6:18:0,18,179	0/0:4,0:4:12:0,12,137	0/0:6,0:6:18:0,18,195	0/0:7,0:7:21:0,21,204	0/0:12,0:12:35:0,35,344	0/0:8,0:8:23:0,23,220	0/0:4,0:4:12:0,12,127	0/0:8,0:8:22:0,22,216	0/0:6,0:6:18:0,18,192	0/0:4,0:4:11:0,11,103	0/0:11,0:11:33:0,33,308	0/0:6,0:6:18:0,18,184	0/0:7,0:7:20:0,20,193	0/0:4,0:4:12:0,12,113	0/0:10,0:10:30:0,30,300	0/0:6,0:6:18:0,18,310	0/0:11,0:11:31:0,31,289	0/0:12,0:12:35:0,35,332	0/0:11,0:11:33:0,33,314	0/0:10,0:10:30:0,30,348	0/0:5,0:5:14:0,14,121	0/0:2,0:2:6:0,6,71	0/0:9,0:9:25:0,25,245	0/0:8,0:8:24:0,24,188	0/0:4,0:4:12:0,12,92	0/0:12,0:12:36:0,36,376	0/0:5,0:5:15:0,15,130	0/0:9,0:9:27:0,27,255	0/0:5,0:5:15:0,15,161	0/0:8,0:8:23:0,23,226	0/0:9,0:9:27:0,27,281	0/0:4,0:4:12:0,12,136	0/0:11,0:11:33:0,33,336	0/0:1,0:1:3:0,3,37	0/0:9,0:9:26:0,26,253	0/0:9,0:9:27:0,27,278	0/0:12,0:12:35:0,35,314	0/0:11,0:11:33:0,33,321	0/0:8,0:8:24:0,24,254	0/0:4,0:4:12:0,12,113	0/0:3,0:3:9:0,9,101	0/0:8,0:8:23:0,23,208	0/0:7,0:7:21:0,21,202	0/0:7,0:7:21:0,21,221	0/0:8,0:8:23:0,23,239	0/0:9,0:9:27:0,27,325	0/0:9,0:9:27:0,27,263	0/0:7,0:7:21:0,21,235	0/0:4,0:4:12:0,12,119	0/0:7,0:7:21:0,21,223	0/0:11,0:11:33:0,33,317	0/0:11,0:11:33:0,33,338	0/0:14,0:14:42:0,42,481	0/0:8,0:8:24:0,24,424	0/0:7,0:7:21:0,21,207	0/0:5,0:5:14:0,14,123	0/0:17,0:17:51:0,51,490	0/0:15,0:15:43:0,43,407	0/0:3,0:3:9:0,9,107	0/0:6,0:6:18:0,18,202	0/0:9,0:9:27:0,27,282	0/0:5,0:5:15:0,15,139	0/0:9,0:9:27:0,27,303	0/0:10,0:10:30:0,30,342	0/0:7,0:7:21:0,21,225	0/0:8,0:8:23:0,23,230	0/0:8,0:8:24:0,24,249	0/0:8,0:8:24:0,24,281	0/0:4,0:4:12:0,12,143	0/0:6,0:6:18:0,18,177	0/0:3,0:3:9:0,9,99	0/0:11,0:11:33:0,33,376	0/0:4,0:4:12:0,12,123	0/0:4,0:4:12:0,12,135	0/0:6,0:6:17:0,17,157	0/0:4,0:4:12:0,12,130	0/0:8,0:8:24:0,24,257	0/0:7,0:7:21:0,21,225	0/0:7,0:7:21:0,21,219	0/0:6,0:6:18:0,18,209	0/0:7,0:7:21:0,21,230	0/0:3,0:3:9:0,9,87	0/0:5,0:5:15:0,15,156	0/0:8,0:8:24:0,24,259	0/0:8,0:8:24:0,24,266	0/0:4,0:4:12:0,12,124	0/0:1,0:1:3:0,3,36	0/0:10,0:10:30:0,30,323	0/0:10,0:10:30:0,30,272	0/0:3,0:3:9:0,9,84	0/0:4,0:4:12:0,12,135	0/0:5,0:5:15:0,15,144	0/0:9,0:9:26:0,26,252	0/0:15,0:15:45:0,45,814	0/0:8,0:8:24:0,24,264	0/0:6,0:6:17:0,17,155	0/0:6,0:6:18:0,18,201	0/0:4,0:4:11:0,11,96	0/0:10,0:10:30:0,30,328	0/0:3,0:3:9:0,9,104	0/0:11,0:11:32:0,32,309	0/0:8,0:8:24:0,24,252	0/0:5,0:5:15:0,15,169	0/0:8,0:8:24:0,24,264	0/0:5,0:5:15:0,15,165	0/0:4,0:4:12:0,12,134	0/0:8,0:8:23:0,23,231	0/0:4,0:4:11:0,11,119	0/0:9,0:9:27:0,27,248	0/0:17,0:17:50:0,50,465	0/0:1,0:1:3:0,3,30	0/0:7,0:7:21:0,21,221	0/0:1,0:1:3:0,3,39	0/0:11,0:11:33:0,33,367	0/0:2,0:2:6:0,6,58	0/0:6,0:6:18:0,18,211	0/0:1,0:1:3:0,3,26	0/0:2,0:2:6:0,6,52	0/0:8,0:8:24:0,24,252	0/0:4,0:4:11:0,11,93	0/0:10,0:10:29:0,29,256	0/0:14,0:14:41:0,41,418	0/0:7,0:7:20:0,20,170	0/0:11,0:11:33:0,33,342	0/0:8,0:8:23:0,23,208	0/0:10,0:10:28:0,28,261	0/0:6,0:6:18:0,18,189	0/0:5,0:5:15:0,15,149	0/0:10,0:10:29:0,29,270	0/0:11,0:11:32:0,32,295	0/0:11,0:11:33:0,33,380	0/0:18,0:18:54:0,54,496	0/0:5,0:5:15:0,15,139	0/0:8,0:8:24:0,24,261	0/0:4,0:4:12:0,12,134	0/0:8,0:8:24:0,24,249	0/0:6,0:6:17:0,17,177	0/0:6,0:6:18:0,18,208	0/0:12,0:12:36:0,36,404	0/0:10,0:10:30:0,30,285	0/0:11,0:11:33:0,33,333	0/0:3,0:3:8:0,8,77	0/0:5,0:5:15:0,15,178	0/0:15,0:15:45:0,45,397	0/0:6,0:6:18:0,18,187	0/0:11,0:11:33:0,33,366	0/0:5,0:5:15:0,15,144	0/0:14,0:14:42:0,42,430	0/0:9,0:9:26:0,26,228	0/0:7,0:7:21:0,21,207	0/0:1,0:1:3:0,3,29	0/0:4,0:4:12:0,12,136	0/0:7,0:7:21:0,21,384	0/0:8,0:8:24:0,24,232	0/0:15,0:15:44:0,44,415	0/0:14,0:14:41:0,41,366	0/0:5,0:5:14:0,14,135	0/0:4,0:4:12:0,12,135	0/0:3,0:3:9:0,9,95	0/0:10,0:10:29:0,29,268	0/0:9,0:9:27:0,27,264	0/0:7,0:7:21:0,21,218	0/0:6,0:6:18:0,18,174	0/0:6,0:6:18:0,18,182	0/0:7,0:7:21:0,21,202	0/0:5,0:5:15:0,15,165	0/0:1,0:1:3:0,3,38	0/0:16,0:16:47:0,47,465	0/0:11,0:11:32:0,32,310	0/0:8,0:8:24:0,24,301	0/0:10,0:10:29:0,29,282	0/0:7,0:7:21:0,21,225	0/0:6,0:6:18:0,18,188	0/0:5,0:5:15:0,15,311	0/0:6,0:6:18:0,18,176	0/0:4,0:4:12:0,12,107	0/0:7,0:7:20:0,20,195	0/0:10,0:10:30:0,30,297	0/0:8,0:8:24:0,24,210	0/0:5,0:5:15:0,15,158	0/0:2,0:2:6:0,6,70	0/0:6,0:6:18:0,18,186	0/0:5,0:5:15:0,15,152	0/0:8,0:8:24:0,24,253	0/0:9,0:9:26:0,26,292	0/0:12,0:12:36:0,36,354	0/0:15,0:15:45:0,45,506	0/0:5,0:5:15:0,15,162	0/0:6,0:6:17:0,17,174	0/0:7,0:7:21:0,21,218	0/0:5,0:5:15:0,15,141	0/0:3,0:3:9:0,9,106	0/0:12,0:12:36:0,36,410	0/0:4,0:4:12:0,12,118	0/0:9,0:9:27:0,27,291	0/0:6,0:6:18:0,18,221	0/0:5,0:5:15:0,15,181	0/0:4,0:4:11:0,11,98	0/0:2,0:2:6:0,6,60	0/0:14,1:15:38:0,38,420	0/0:11,0:11:33:0,33,371	0/0:6,0:6:18:0,18,192	0/0:5,0:5:15:0,15,148	0/0:6,0:6:18:0,18,199	0/0:8,0:8:24:0,24,252	0/0:5,0:5:15:0,15,162	0/0:9,0:9:27:0,27,303	0/0:4,0:4:11:0,11,101	0/0:6,0:6:18:0,18,220	0/0:9,0:9:27:0,27,276	0/0:5,0:5:15:0,15,162	0/0:1,0:1:3:0,3,38	0/0:8,0:8:23:0,23,218	0/0:9,0:9:26:0,26,252	0/0:6,0:6:18:0,18,189	0/0:5,0:5:15:0,15,163	0/0:8,0:8:24:0,24,261	0/0:6,0:6:18:0,18,222	0/0:4,0:4:12:0,12,142	0/0:15,0:15:45:0,45,478	0/0:4,0:4:12:0,12,132	0/0:10,0:10:30:0,30,325	0/0:4,0:4:12:0,12,124	0/0:11,0:11:33:0,33,353	0/0:7,0:7:21:0,21,218	0/0:4,0:4:12:0,12,119	0/0:5,0:5:15:0,15,169	0/0:9,0:9:27:0,27,266	0/0:9,0:9:27:0,27,285	0/0:4,0:4:12:0,12,136	0/0:4,0:4:12:0,12,109	0/0:10,0:10:30:0,30,571	0/0:5,0:5:14:0,14,122	0/0:6,0:6:18:0,18,186	0/0:3,0:3:9:0,9,80	0/0:5,0:5:14:0,14,122	0/0:1,0:1:3:0,3,38	0/0:3,0:3:9:0,9,95	0/0:3,0:3:9:0,9,97	0/0:7,0:7:21:0,21,213	0/0:7,0:7:21:0,21,234	0/0:9,0:9:26:0,26,269	0/0:5,0:5:15:0,15,148	0/0:3,0:3:8:0,8,71	0/0:10,0:10:30:0,30,320	0/0:6,0:6:17:0,17,154	0/0:5,0:5:15:0,15,131	0/0:9,0:9:27:0,27,280	0/0:5,0:5:14:0,14,104	0/0:8,0:8:24:0,24,260	0/0:5,0:5:15:0,15,132	0/0:4,0:4:12:0,12,116	0/0:7,0:7:21:0,21,225	0/0:12,0:12:35:0,35,362	0/0:3,0:3:9:0,9,90	0/0:5,0:5:15:0,15,159	0/0:8,0:8:24:0,24,235	0/0:9,0:9:27:0,27,267	0/0:8,0:8:24:0,24,497	0/0:10,0:10:29:0,29,305	0/0:4,0:4:12:0,12,139	0/0:4,0:4:11:0,11,98	0/0:10,0:10:30:0,30,316	0/0:8,0:8:24:0,24,269	0/0:5,0:5:15:0,15,181	0/0:9,0:9:27:0,27,279	0/0:7,0:7:21:0,21,186	0/0:9,0:9:27:0,27,424	0/0:3,0:3:9:0,9,89	0/0:7,0:7:21:0,21,439	0/0:7,0:7:21:0,21,234	0/0:13,0:13:39:0,39,408	0/0:16,0:16:48:0,48,759	0/0:9,0:9:27:0,27,275	0/0:14,0:14:41:0,41,431	0/0:8,0:8:24:0,24,243	0/0:9,0:9:27:0,27,307	0/0:13,0:13:39:0,39,415	0/0:11,0:11:33:0,33,334	0/0:12,0:12:36:0,36,398	0/0:8,0:8:24:0,24,238	0/0:15,0:15:45:0,45,481	0/0:7,0:7:21:0,21,255	0/0:8,0:8:24:0,24,282	0/0:6,0:6:18:0,18,217	0/0:6,0:6:18:0,18,172	0/0:4,0:4:12:0,12,121	0/0:10,0:10:30:0,30,634	0/0:12,0:12:35:0,35,361	0/0:13,0:13:39:0,39,386	0/0:7,0:7:21:0,21,216	0/0:10,0:10:30:0,30,324	0/0:8,0:8:24:0,24,271	0/0:7,0:7:21:0,21,227	0/0:7,0:7:21:0,21,237	0/0:7,0:7:21:0,21,239	0/0:9,0:9:27:0,27,304	0/0:7,0:7:21:0,21,223	0/0:9,0:9:26:0,26,257	0/0:11,0:11:33:0,33,326	0/0:5,0:5:15:0,15,163	0/0:8,0:8:24:0,24,274	0/0:8,0:8:24:0,24,358	0/0:11,0:11:33:0,33,344	0/0:6,0:6:18:0,18,211	0/0:5,0:5:14:0,14,126	0/0:4,0:4:12:0,12,136	0/0:10,0:10:30:0,30,318	0/0:3,0:3:9:0,9,107	0/0:5,0:5:15:0,15,161	0/0:4,0:4:12:0,12,147	0/0:5,0:5:15:0,15,177	0/0:4,0:4:12:0,12,138	0/0:2,0:2:6:0,6,51	0/0:5,0:5:15:0,15,158	0/0:2,0:2:6:0,6,66	0/0:7,0:7:21:0,21,215	0/0:7,0:7:21:0,21,239	0/0:5,0:5:14:0,14,129	0/0:12,0:12:35:0,35,333	0/0:6,0:6:18:0,18,182	0/0:10,0:10:29:0,29,269	0/0:14,0:14:41:0,41,390	0/0:4,0:4:12:0,12,124	0/0:5,0:5:14:0,14,128	0/0:5,0:5:14:0,14,122	0/0:8,0:8:24:0,24,255	0/0:5,0:5:14:0,14,151	0/0:7,0:7:21:0,21,237	0/0:2,0:2:6:0,6,57	0/0:8,0:8:23:0,23,213	0/0:12,0:12:36:0,36,374	0/0:9,0:9:26:0,26,241	0/0:13,0:13:38:0,38,328	0/0:5,0:5:15:0,15,159	0/0:6,0:6:18:0,18,203	0/0:6,0:6:18:0,18,177	0/0:5,0:5:15:0,15,156	0/0:8,0:8:24:0,24,261	0/0:4,0:4:12:0,12,144	0/0:5,0:5:15:0,15,162	0/0:3,0:3:9:0,9,90	0/0:6,0:6:18:0,18,193	0/0:5,0:5:15:0,15,171	0/0:12,0:12:35:0,35,335	0/0:13,0:13:39:0,39,407	0/0:9,0:9:27:0,27,285	0/0:8,0:8:24:0,24,231	0/0:18,0:18:53:0,53,457	0/0:3,0:3:9:0,9,80	0/0:6,0:6:17:0,17,179	0/0:6,0:6:18:0,18,184	0/0:10,0:10:30:0,30,379	0/0:6,0:6:18:0,18,198	0/0:5,0:5:15:0,15,159	0/0:9,0:9:26:0,26,268	0/0:5,0:5:15:0,15,132	0/0:7,0:7:21:0,21,233	0/0:5,0:5:15:0,15,169	0/0:7,0:7:21:0,21,234	0/0:7,0:7:21:0,21,249	0/0:8,0:8:24:0,24,281	0/0:9,0:9:27:0,27,294	0/0:4,0:4:11:0,11,110	0/0:4,0:4:12:0,12,122	0/0:5,0:5:15:0,15,159	0/0:7,0:7:21:0,21,213	0/0:5,0:5:14:0,14,128	0/0:6,0:6:18:0,18,210	0/0:11,0:11:32:0,32,312	0/0:8,0:8:24:0,24,241	0/0:7,0:7:21:0,21,193	0/0:11,0:11:33:0,33,325	0/0:11,0:11:33:0,33,307	0/0:7,0:7:20:0,20,202	0/0:5,0:5:15:0,15,170	0/0:20,0:20:60:0,60,587	0/0:12,0:12:36:0,36,334	0/0:9,0:9:27:0,27,315	0/0:13,0:13:39:0,39,397	0/0:8,0:8:24:0,24,270	0/0:3,0:3:9:0,9,100	0/0:9,0:9:26:0,26,260	0/0:4,0:4:12:0,12,138	0/0:10,0:10:29:0,29,260	0/0:8,0:8:24:0,24,239	0/0:6,0:6:18:0,18,174	0/0:20,0:20:59:0,59,565	0/0:7,0:7:21:0,21,252	0/0:11,0:11:33:0,33,344	0/0:16,0:16:48:0,48,496	0/0:9,0:9:27:0,27,301	0/0:9,0:9:26:0,26,270	0/0:6,0:6:18:0,18,218	0/0:9,0:9:26:0,26,260	0/0:5,0:5:15:0,15,161	0/0:12,0:12:36:0,36,370	0/0:9,0:9:26:0,26,223	0/0:11,0:11:33:0,33,354	0/0:6,0:6:18:0,18,173	0/0:2,0:2:6:0,6,59	0/0:6,0:6:18:0,18,155	0/0:12,0:12:35:0,35,334	0/0:10,0:10:30:0,30,327	0/0:7,0:7:20:0,20,175	0/0:9,0:9:27:0,27,254	0/0:7,0:7:21:0,21,189	0/0:10,0:10:30:0,30,304	0/0:11,0:11:33:0,33,380	0/0:7,0:7:19:0,19,179	0/0:3,0:3:9:0,9,101	0/0:5,0:5:15:0,15,163	0/0:9,0:9:27:0,27,273	0/0:9,1:10:23:0,23,255	0/0:11,0:11:33:0,33,358	0/0:5,0:5:15:0,15,166	0/0:9,0:9:27:0,27,267	0/0:7,0:7:21:0,21,217	0/0:9,0:9:27:0,27,291	0/0:3,0:3:9:0,9,102	0/0:5,0:5:15:0,15,154	0/0:8,0:8:24:0,24,280	0/0:4,0:4:8:0,8,37	0/0:13,0:13:39:0,39,373	0/0:16,0:16:44:0,44,406	0/0:6,0:6:18:0,18,187	0/0:11,0:11:32:0,32,292	0/0:2,0:2:6:0,6,49	0/0:8,0:8:24:0,24,270	0/0:6,0:6:18:0,18,213	0/0:8,0:8:24:0,24,281	0/0:10,0:10:30:0,30,323	0/0:4,0:4:11:0,11,87	0/0:2,0:2:6:0,6,76	0/0:6,0:6:18:0,18,178	0/0:8,0:8:24:0,24,272	0/0:11,0:11:33:0,33,335	0/0:7,0:7:21:0,21,228	0/0:9,0:9:27:0,27,306	0/0:6,0:6:18:0,18,211	0/0:9,0:9:27:0,27,285	0/0:5,0:5:15:0,15,160	0/0:11,0:11:33:0,33,361	0/0:13,0:13:37:0,37,388	0/0:10,0:10:28:0,28,259	0/0:11,0:11:30:0,30,302	0/0:6,0:6:18:0,18,203	0/0:5,0:5:15:0,15,184	0/0:12,0:12:35:0,35,329	0/0:1,0:1:3:0,3,29	0/0:5,0:5:15:0,15,165	0/0:8,0:8:24:0,24,221	0/0:8,0:8:24:0,24,269	0/0:10,0:10:29:0,29,263	0/0:5,0:5:15:0,15,153	0/0:14,0:14:41:0,41,460	0/0:8,0:8:23:0,23,211	0/0:9,0:9:27:0,27,306	0/0:14,0:14:42:0,42,424	0/0:4,0:4:12:0,12,120	0/0:7,0:7:21:0,21,231	0/0:2,0:2:6:0,6,70	0/0:6,0:6:17:0,17,167	0/0:6,0:6:18:0,18,206	0/0:4,0:4:12:0,12,146	0/0:7,0:7:21:0,21,243	0/0:7,0:7:21:0,21,242	0/0:9,0:9:27:0,27,274	0/0:5,0:5:15:0,15,154	0/0:5,0:5:15:0,15,143	0/0:12,0:12:35:0,35,307	0/0:12,0:12:36:0,36,330	0/0:6,0:6:18:0,18,202	0/0:4,0:4:12:0,12,110	0/0:8,0:8:23:0,23,236	0/0:7,0:7:21:0,21,242	0/0:6,0:6:18:0,18,200	0/0:10,0:10:29:0,29,286	0/0:13,0:13:39:0,39,404	0/0:8,0:8:24:0,24,266	0/0:10,0:10:30:0,30,348	0/0:11,0:11:33:0,33,341	0/0:10,0:10:30:0,30,317	0/0:8,0:8:23:0,23,239	0/0:6,0:6:18:0,18,199	0/0:7,0:7:21:0,21,243	0/0:7,0:7:21:0,21,195	0/0:6,0:6:18:0,18,219	0/0:4,0:4:12:0,12,141	0/0:4,0:4:12:0,12,124	0/0:3,0:3:9:0,9,92	0/0:3,0:3:8:0,8,67	0/0:6,0:6:18:0,18,186	0/0:4,0:4:12:0,12,110	0/0:7,0:7:21:0,21,238	0/0:4,0:4:11:0,11,100	0/0:10,0:10:29:0,29,313	0/0:6,0:6:17:0,17,169	0/0:4,0:4:12:0,12,132	0/0:9,0:9:27:0,27,306	0/0:6,0:6:17:0,17,166	0/0:3,0:3:9:0,9,114	0/0:6,0:6:17:0,17,176	0/0:7,0:7:21:0,21,248	0/0:9,0:9:27:0,27,279	0/0:7,0:7:21:0,21,211	0/0:10,0:10:30:0,30,334	0/0:4,0:4:12:0,12,141	0/0:10,0:10:30:0,30,294	0/0:9,0:9:27:0,27,296	0/0:3,0:3:9:0,9,101	0/0:8,0:8:24:0,24,246	0/0:4,0:4:12:0,12,131	0/0:9,0:9:27:0,27,314	0/0:7,0:7:21:0,21,229	0/0:8,0:8:24:0,24,235	0/0:6,0:6:18:0,18,197	0/0:9,0:9:27:0,27,285	0/0:6,0:6:18:0,18,203	0/0:4,0:4:12:0,12,126	0/0:5,0:5:15:0,15,161	0/0:2,0:2:6:0,6,65	0/0:7,0:7:21:0,21,212	0/0:9,0:9:27:0,27,274	0/0:2,0:2:6:0,6,64	0/0:15,0:15:45:0,45,502	0/0:6,0:6:17:0,17,149	0/0:8,0:8:22:0,22,173	0/0:7,0:7:21:0,21,204	0/0:4,0:4:12:0,12,135	0/0:3,0:3:9:0,9,87	0/0:7,0:7:20:0,20,180	0/0:5,0:5:15:0,15,160	0/0:6,0:6:18:0,18,204	0/0:7,0:7:21:0,21,213	0/0:3,0:3:9:0,9,93	0/0:7,0:7:20:0,20,179	0/0:16,0:16:48:0,48,451	0/0:2,0:2:6:0,6,77	./.	0/0:8,0:8:24:0,24,257	0/0:5,0:5:15:0,15,173	0/0:14,0:14:41:0,41,452	0/0:4,0:4:12:0,12,148	0/0:5,0:5:15:0,15,173	0/0:6,0:6:18:0,18,186	./.	0/0:9,0:9:27:0,27,284	0/0:4,0:4:12:0,12,123	0/0:2,0:2:6:0,6,75	0/0:6,0:6:18:0,18,198	0/0:5,0:5:15:0,15,130	0/0:5,0:5:15:0,15,153	0/0:5,0:5:15:0,15,162	0/0:10,0:10:30:0,30,307	0/0:5,0:5:15:0,15,152	0/0:6,0:6:18:0,18,178	0/0:2,0:2:6:0,6,53	0/0:5,0:5:15:0,15,166	0/0:4,0:4:12:0,12,104	./.	0/0:5,0:5:15:0,15,167	0/0:11,0:11:33:0,33,368	0/0:5,0:5:15:0,15,149	0/0:3,0:3:9:0,9,94	0/0:9,0:9:26:0,26,250	0/0:7,0:7:21:0,21,224	0/0:5,0:5:15:0,15,174	0/0:6,0:6:18:0,18,162	0/0:12,0:12:36:0,36,347	0/0:6,0:6:18:0,18,185	0/0:5,0:5:15:0,15,150	0/0:11,0:11:33:0,33,312	0/0:4,0:4:12:0,12,143	0/0:7,0:7:21:0,21,199	0/0:7,0:7:21:0,21,238	0/0:7,0:7:21:0,21,232	0/0:4,0:4:12:0,12,126	0/0:2,0:2:6:0,6,55	0/0:4,0:4:12:0,12,116	0/0:7,0:7:21:0,21,239	0/0:4,0:4:12:0,12,120	0/0:11,0:11:33:0,33,377	0/0:5,0:5:15:0,15,166	0/0:7,0:7:21:0,21,209	0/0:8,0:8:24:0,24,251	./.	0/0:7,0:7:21:0,21,230	0/0:9,0:9:27:0,27,312	0/0:13,0:13:38:0,38,389	0/0:8,0:8:23:0,23,225	0/0:13,0:13:39:0,39,364	0/0:3,0:3:9:0,9,83	0/0:10,0:10:30:0,30,315	0/0:7,0:7:19:0,19,184	0/0:11,0:11:33:0,33,354	0/0:8,0:8:24:0,24,229	0/0:3,0:3:9:0,9,87	0/0:2,0:2:6:0,6,69	0/0:9,0:9:27:0,27,283	0/0:6,0:6:18:0,18,180	0/0:6,0:6:17:0,17,181	0/0:5,0:5:14:0,14,136	0/0:8,0:8:24:0,24,281	0/0:10,0:10:30:0,30,354	0/0:4,0:4:12:0,12,142	0/0:4,0:4:12:0,12,152	0/0:4,0:4:12:0,12,107	0/0:8,0:8:24:0,24,244	0/0:6,0:6:18:0,18,205	0/0:4,0:4:12:0,12,127	0/0:6,0:6:18:0,18,210	0/0:12,0:12:36:0,36,423	0/0:5,0:5:15:0,15,183	0/0:8,0:8:24:0,24,249	0/0:8,0:8:24:0,24,259	0/0:3,0:3:9:0,9,103	0/0:6,0:6:18:0,18,194	0/0:11,0:11:32:0,32,344	0/0:3,0:3:9:0,9,65	0/0:5,0:5:15:0,15,163	0/0:4,0:4:12:0,12,122	0/0:5,0:5:15:0,15,153	0/0:18,0:18:53:0,53,507	0/0:13,0:13:39:0,39,360	0/0:10,0:10:30:0,30,331	0/0:8,0:8:23:0,23,203	0/0:8,0:8:24:0,24,268	0/0:9,0:9:27:0,27,299	0/0:5,0:5:15:0,15,164	0/0:3,0:3:9:0,9,81	0/0:4,0:4:11:0,11,101	0/0:12,0:12:36:0,36,348	0/0:5,0:5:15:0,15,157	0/0:12,0:12:36:0,36,399	0/0:4,0:4:12:0,12,142	0/0:8,0:8:24:0,24,201	0/0:3,0:3:9:0,9,72	0/0:7,0:7:20:0,20,160	0/0:11,0:11:33:0,33,344	0/0:8,0:8:23:0,23,210	0/0:4,0:4:12:0,12,140	0/0:8,0:8:24:0,24,262	0/0:8,0:8:24:0,24,276	0/0:11,0:11:33:0,33,351	0/0:4,0:4:12:0,12,122	0/0:4,0:4:12:0,12,112	0/0:16,0:16:48:0,48,457	0/0:8,0:8:24:0,24,225	0/0:7,0:7:21:0,21,201	0/0:1,0:1:3:0,3,32	0/0:2,0:2:6:0,6,66	0/0:9,0:9:27:0,27,284	0/0:6,0:6:18:0,18,143	0/0:15,0:15:45:0,45,430	0/0:5,0:5:15:0,15,139	0/0:4,0:4:11:0,11,78	0/0:8,0:8:23:0,23,201	0/0:15,0:15:44:0,44,444	0/0:7,0:7:21:0,21,218	0/0:8,0:8:23:0,23,239	0/0:12,0:12:35:0,35,335	0/0:12,0:12:36:0,36,394	0/0:9,0:9:27:0,27,283	0/0:6,0:6:18:0,18,228	0/0:9,0:9:27:0,27,317	0/0:9,0:9:27:0,27,230	0/0:14,0:14:42:0,42,371	0/0:10,0:10:30:0,30,292	0/0:7,0:7:21:0,21,219	0/0:1,0:1:3:0,3,28	0/0:6,0:6:18:0,18,189	0/0:11,0:11:31:0,31,312	0/0:4,0:4:10:0,10,66	0/0:4,0:4:11:0,11,98	0/0:7,0:7:20:0,20,192	0/0:5,0:5:15:0,15,174	0/0:8,0:8:24:0,24,266	0/0:5,0:5:15:0,15,168	0/0:8,0:8:24:0,24,222	0/0:17,0:17:51:0,51,520	0/0:4,1:5:9:0,9,105	0/0:9,0:9:27:0,27,339	0/0:7,0:7:21:0,21,226	0/0:2,0:2:6:0,6,63	0/0:4,0:4:12:0,12,111	0/0:11,0:11:33:0,33,373	0/0:9,0:9:27:0,27,263	0/0:16,0:16:48:0,48,415	0/0:6,0:6:18:0,18,186	0/0:4,0:4:12:0,12,134	0/0:5,0:5:15:0,15,165	0/0:3,0:3:9:0,9,87	0/0:6,0:6:18:0,18,165	0/0:2,0:2:6:0,6,66	0/0:6,0:6:18:0,18,212	0/0:7,0:7:21:0,21,218	0/0:7,0:7:21:0,21,213	0/0:6,0:6:18:0,18,181	0/0:9,0:9:27:0,27,261	0/0:7,0:7:21:0,21,224	0/0:10,0:10:30:0,30,353	0/0:4,0:4:12:0,12,142	0/0:6,0:6:18:0,18,212	0/0:6,0:6:18:0,18,192	0/0:10,0:10:29:0,29,320	0/0:6,0:6:18:0,18,148	0/0:5,0:5:15:0,15,166	0/0:4,0:4:12:0,12,123	0/0:10,0:10:29:0,29,306	0/0:2,0:2:6:0,6,71	0/0:8,0:8:23:0,23,245	0/0:5,0:5:15:0,15,155	0/0:5,0:5:14:0,14,135	0/0:7,0:7:20:0,20,199	0/0:10,0:10:30:0,30,349	0/0:3,0:3:9:0,9,99	0/0:11,0:11:33:0,33,372	0/0:5,0:5:15:0,15,186	0/0:7,0:7:21:0,21,223	0/0:7,0:7:20:0,20,196	0/0:2,0:2:6:0,6,47	0/0:5,0:5:15:0,15,174	0/0:22,0:22:61:0,61,536	0/0:1,0:1:2:0,2,5	0/0:13,0:13:34:0,34,281	0/0:7,0:7:21:0,21,214	0/0:4,0:4:12:0,12,140	0/0:15,0:15:45:0,45,396	0/0:11,0:11:33:0,33,373	0/0:1,0:1:3:0,3,19	0/0:6,0:6:18:0,18,210	0/0:8,0:8:24:0,24,218	0/0:3,0:3:9:0,9,96	0/0:7,0:7:20:0,20,175	0/0:3,0:3:9:0,9,102	0/0:7,0:7:20:0,20,167	0/0:9,0:9:27:0,27,250	0/0:4,0:4:12:0,12,98	0/0:4,0:4:12:0,12,139	0/0:15,0:15:45:0,45,475	0/0:9,0:9:27:0,27,305	0/0:3,0:3:9:0,9,86	./.	0/0:4,0:4:12:0,12,120	0/0:4,0:4:11:0,11,98	0/0:6,0:6:18:0,18,171	0/0:2,0:2:5:0,5,44	0/0:8,0:8:24:0,24,256	0/0:7,0:7:21:0,21,206	0/0:4,0:4:12:0,12,121	0/0:4,0:4:12:0,12,140	0/0:6,0:6:17:0,17,151	0/0:9,0:9:27:0,27,280	0/0:8,0:8:23:0,23,247	0/0:5,0:5:15:0,15,174	0/0:7,0:7:21:0,21,193	0/0:2,0:2:6:0,6,56	0/0:4,0:4:12:0,12,111	0/0:8,0:8:24:0,24,279	0/0:3,0:3:7:0,7,46	0/0:7,0:7:21:0,21,216	0/0:7,0:7:20:0,20,180	0/0:4,0:4:11:0,11,109	0/0:9,0:9:26:0,26,230	0/0:3,0:3:9:0,9,100	0/0:12,0:12:36:0,36,388	0/0:6,0:6:18:0,18,151	0/0:4,0:4:12:0,12,140	0/0:7,0:7:21:0,21,219	0/0:9,0:9:27:0,27,288	0/0:8,0:8:24:0,24,246	0/0:5,0:5:15:0,15,170	0/0:8,0:8:24:0,24,209	0/0:6,0:6:18:0,18,201	0/0:5,0:5:15:0,15,167	0/0:4,0:4:12:0,12,134	0/0:9,0:9:27:0,27,289	0/0:10,0:10:28:0,28,253	0/0:3,0:3:9:0,9,112	0/0:7,0:7:21:0,21,235	0/0:3,0:3:9:0,9,98	0/0:11,0:11:33:0,33,330	0/0:13,0:13:39:0,39,435	0/0:7,0:7:18:0,18,132	0/0:9,0:9:27:0,27,277	0/0:10,0:10:30:0,30,305	0/0:4,0:4:12:0,12,134	0/0:4,0:4:12:0,12,121	0/0:4,0:4:12:0,12,125	0/0:4,0:4:12:0,12,137	0/0:4,0:4:12:0,12,122	0/0:2,0:2:6:0,6,67	0/0:10,0:10:30:0,30,275	0/0:4,0:4:12:0,12,130	0/0:5,0:5:15:0,15,137	0/0:11,0:11:33:0,33,299	0/0:3,0:3:9:0,9,82	0/0:4,0:4:12:0,12,105	0/0:9,0:9:27:0,27,261	0/0:8,0:8:24:0,24,231	0/0:1,0:1:3:0,3,38	0/0:6,0:6:18:0,18,189	0/0:10,0:10:30:0,30,276	0/0:8,0:8:23:0,23,204	0/0:9,0:9:26:0,26,235	0/0:2,0:2:6:0,6,62	0/0:2,0:2:6:0,6,70	0/0:5,0:5:15:0,15,132	0/0:6,0:6:18:0,18,180	0/1:7,7:14:99:185,0,187	0/0:13,0:13:39:0,39,385	0/0:9,0:9:27:0,27,273	0/0:4,0:4:12:0,12,126	0/0:8,0:8:24:0,24,269	0/0:4,0:4:12:0,12,128	0/0:4,0:4:11:0,11,107	0/0:3,0:3:9:0,9,85	0/0:4,0:4:12:0,12,103	0/1:1,1:2:18:21,0,18	0/0:9,0:9:27:0,27,299	0/0:8,0:8:24:0,24,231	0/0:5,0:5:15:0,15,155	0/0:8,0:8:24:0,24,219	0/0:12,0:12:36:0,36,344	0/0:5,0:5:15:0,15,169	0/0:12,0:12:35:0,35,372	0/0:7,0:7:21:0,21,214	0/0:11,0:11:33:0,33,340	0/0:8,0:8:24:0,24,261	0/0:3,0:3:9:0,9,85	0/0:4,0:4:12:0,12,145	0/0:3,0:3:9:0,9,91	0/0:3,0:3:9:0,9,88	0/0:3,0:3:8:0,8,58	0/0:8,0:8:24:0,24,280	0/0:7,0:7:20:0,20,183	0/0:6,0:6:18:0,18,213	0/0:5,0:5:15:0,15,151	0/0:9,0:9:27:0,27,296	0/0:4,0:4:12:0,12,139	0/0:10,0:10:30:0,30,301	0/0:6,0:6:18:0,18,190	0/0:2,0:2:6:0,6,46	0/0:10,0:10:30:0,30,352	0/0:3,0:3:9:0,9,94	0/0:10,0:10:30:0,30,322	0/0:3,0:3:9:0,9,82	0/0:4,0:4:12:0,12,117	0/0:9,0:9:27:0,27,250	0/0:10,0:10:29:0,29,254	0/0:9,0:9:25:0,25,237	0/0:5,0:5:15:0,15,122	0/0:4,0:4:12:0,12,111	0/0:3,0:3:9:0,9,83	0/0:8,0:8:24:0,24,240	0/0:4,0:4:11:0,11,109	0/0:11,0:11:33:0,33,382	0/0:2,0:2:6:0,6,65	0/0:2,0:2:6:0,6,66	0/0:6,0:6:18:0,18,211	0/0:3,0:3:8:0,8,54	0/0:6,0:6:18:0,18,213	0/0:5,0:5:15:0,15,133	0/0:12,0:12:34:0,34,297	0/0:3,0:3:9:0,9,91	0/0:4,0:4:12:0,12,145	0/0:5,0:5:15:0,15,148	0/0:6,0:6:18:0,18,193	0/0:4,0:4:12:0,12,125	0/0:9,0:9:27:0,27,271	0/0:5,0:5:15:0,15,167	0/0:13,0:13:39:0,39,415	0/0:12,0:12:36:0,36,420	0/0:8,0:8:24:0,24,276	0/0:9,0:9:26:0,26,253	0/0:6,0:6:18:0,18,188	0/0:4,0:4:12:0,12,136	0/0:4,0:4:12:0,12,140	0/0:8,0:8:24:0,24,281	0/0:5,0:5:15:0,15,174	0/0:5,0:5:15:0,15,169	0/0:4,0:4:12:0,12,124	0/0:3,0:3:8:0,8,56	0/0:1,0:1:3:0,3,38	0/0:6,0:6:18:0,18,184	0/0:4,0:4:12:0,12,106	0/0:2,0:2:6:0,6,69	0/0:4,0:4:12:0,12,133	0/0:7,0:7:21:0,21,219	0/0:9,0:9:27:0,27,261	0/0:11,0:11:33:0,33,374	0/0:7,0:7:21:0,21,167	0/0:4,0:4:12:0,12,126	0/0:2,0:2:6:0,6,58	0/0:2,0:2:6:0,6,48	0/0:9,0:9:26:0,26,241	0/0:6,0:6:18:0,18,184	0/0:3,0:3:9:0,9,95	0/0:9,0:9:27:0,27,280	0/0:5,0:5:15:0,15,178	0/0:3,0:3:9:0,9,118	0/0:8,0:8:24:0,24,251	0/0:3,0:3:9:0,9,99	0/0:5,0:5:15:0,15,155	0/0:8,0:8:24:0,24,245	0/0:8,0:8:24:0,24,251	0/0:18,0:18:54:0,54,531	0/0:3,0:3:9:0,9,98	0/0:8,0:8:24:0,24,249	0/0:13,0:13:39:0,39,451	0/0:12,0:12:36:0,36,421	0/0:8,0:8:24:0,24,256	0/0:7,0:7:18:0,18,123	0/0:8,0:8:21:0,21,146	0/0:6,0:6:18:0,18,167	0/0:3,0:3:9:0,9,72	0/0:16,0:16:48:0,48,437	0/0:7,0:7:21:0,21,226	0/0:10,0:10:30:0,30,282	0/0:6,0:6:18:0,18,190	0/0:11,0:11:33:0,33,340	0/0:6,0:6:18:0,18,188	0/0:2,0:2:6:0,6,66	0/0:4,0:4:12:0,12,142	0/0:4,0:4:12:0,12,124	0/0:4,0:4:12:0,12,141	0/0:3,0:3:9:0,9,100	0/0:8,0:8:23:0,23,242	./.	0/0:9,0:9:26:0,26,173	0/0:11,0:11:32:0,32,305	0/0:5,0:5:15:0,15,144	0/0:1,0:1:3:0,3,22	0/0:5,0:5:14:0,14,120	0/0:9,0:9:27:0,27,230	0/0:4,0:4:12:0,12,122	0/0:3,0:3:9:0,9,81	0/0:5,0:5:15:0,15,152	0/0:6,0:6:18:0,18,177	0/0:6,0:6:18:0,18,208	0/0:3,0:3:8:0,8,45	0/0:8,0:8:24:0,24,254	0/0:14,0:14:42:0,42,417	0/0:5,0:5:15:0,15,141	0/0:8,0:8:24:0,24,235	0/0:8,0:8:24:0,24,209	0/0:4,0:4:12:0,12,122	0/0:9,0:9:27:0,27,253	0/0:6,0:6:17:0,17,192	0/0:9,0:9:27:0,27,308	0/0:4,0:4:12:0,12,119	0/0:6,0:6:18:0,18,189	0/0:5,0:5:13:0,13,129	0/0:1,0:1:3:0,3,27	0/0:5,0:5:15:0,15,133	0/0:10,0:10:30:0,30,326	0/0:10,0:10:30:0,30,305	0/0:4,0:4:11:0,11,101	0/0:9,0:9:27:0,27,276	0/0:6,0:6:14:0,14,90	0/0:5,0:5:15:0,15,124	0/0:3,0:3:9:0,9,79	0/0:2,0:2:6:0,6,60	0/0:1,0:1:3:0,3,21	0/0:4,0:4:12:0,12,113	0/0:5,0:5:15:0,15,138	0/0:2,0:2:6:0,6,59	0/0:5,0:5:15:0,15,150	0/0:7,0:7:21:0,21,176	0/0:5,0:5:14:0,14,89	0/0:12,0:12:32:0,32,229	0/0:3,0:3:9:0,9,70	0/0:16,0:16:46:0,46,352	0/0:8,0:8:24:0,24,212	0/0:13,0:13:38:0,38,398	0/0:5,0:5:15:0,15,165	0/0:4,0:4:12:0,12,135	0/0:2,0:2:6:0,6,66	0/0:9,0:9:27:0,27,271	0/0:7,0:7:21:0,21,214	0/0:9,0:9:26:0,26,225	0/0:3,0:3:8:0,8,68	0/0:3,0:3:9:0,9,86	0/0:3,0:3:9:0,9,81	0/0:6,0:6:17:0,17,164	0/0:4,0:4:12:0,12,109	0/0:7,0:7:20:0,20,190	0/0:7,0:7:21:0,21,208	0/0:5,0:5:15:0,15,134	./.	0/0:1,0:1:3:0,3,37	0/0:8,0:8:23:0,23,224	0/0:5,0:5:15:0,15,162	0/0:7,0:7:21:0,21,238	0/0:6,0:6:18:0,18,211	0/0:6,0:6:18:0,18,169	0/0:5,0:5:15:0,15,175	0/0:4,0:4:12:0,12,114	0/0:10,0:10:30:0,30,328	0/0:13,0:13:38:0,38,340	0/0:4,0:4:12:0,12,138	0/0:6,0:6:18:0,18,192	0/0:8,0:8:23:0,23,220	0/0:6,0:6:18:0,18,211	0/0:1,0:1:2:0,2,5	0/0:5,0:5:15:0,15,154	0/0:4,0:4:12:0,12,124	0/0:8,0:8:24:0,24,278	0/0:10,0:10:29:0,29,299	0/0:8,0:8:24:0,24,275	0/0:4,0:4:12:0,12,111	0/0:5,0:5:14:0,14,118	0/0:8,0:8:24:0,24,247	0/0:6,0:6:18:0,18,206	./.	0/0:5,0:5:15:0,15,184	0/0:7,0:7:21:0,21,227	0/0:8,0:8:24:0,24,234	0/0:1,0:1:3:0,3,32	0/0:5,0:5:15:0,15,141	0/0:11,0:11:33:0,33,318	0/0:5,0:5:15:0,15,142	0/0:9,0:9:26:0,26,263	0/0:2,0:2:6:0,6,63	0/0:16,0:16:48:0,48,494	0/0:4,0:4:12:0,12,105	0/0:12,0:12:35:0,35,368	0/0:10,0:10:30:0,30,332	0/0:2,0:2:6:0,6,69	0/0:1,0:1:3:0,3,30	0/0:5,0:5:15:0,15,166	0/0:1,0:1:3:0,3,30	0/0:6,0:6:18:0,18,185	0/0:6,0:6:18:0,18,170	0/0:6,0:6:18:0,18,182	0/0:7,0:7:21:0,21,240	0/0:7,0:7:21:0,21,212	0/0:2,0:2:6:0,6,68	0/0:8,0:8:22:0,22,193	0/0:8,0:8:24:0,24,226	0/0:7,0:7:21:0,21,162	0/0:2,0:2:6:0,6,58	0/0:8,0:8:23:0,23,202	0/0:5,0:5:15:0,15,179	0/0:4,0:4:12:0,12,121	0/0:4,0:4:12:0,12,108	0/0:4,0:4:12:0,12,129	0/0:3,0:3:9:0,9,83	0/0:2,0:2:6:0,6,63	0/0:1,0:1:3:0,3,24	0/0:3,0:3:9:0,9,83	0/0:1,0:1:3:0,3,31	0/0:3,0:3:9:0,9,101	0/0:10,0:10:30:0,30,349	0/0:10,0:10:30:0,30,334	0/0:10,0:10:30:0,30,324	0/0:5,0:5:15:0,15,185	0/0:9,0:9:27:0,27,283	0/0:4,0:4:11:0,11,85	0/0:8,0:8:24:0,24,237	0/0:2,0:2:6:0,6,56	0/0:7,0:7:21:0,21,210	0/0:9,0:9:27:0,27,248	0/0:3,0:3:9:0,9,91	0/0:6,0:6:18:0,18,185	0/0:6,0:6:18:0,18,185	0/0:8,0:8:24:0,24,266	0/0:5,0:5:15:0,15,155	0/0:5,0:5:15:0,15,156	0/0:5,0:5:14:0,14,110	0/0:4,0:4:12:0,12,153	0/0:8,0:8:24:0,24,229	0/0:5,0:5:15:0,15,150	0/1:6,1:7:15:15,0,137	0/0:4,0:4:12:0,12,105	0/0:7,0:7:21:0,21,183	0/0:5,0:5:15:0,15,159	0/0:7,0:7:21:0,21,169	0/0:6,0:6:18:0,18,173	0/0:3,0:3:9:0,9,87	0/0:9,0:9:27:0,27,249	0/0:5,0:5:15:0,15,170	0/0:6,0:6:18:0,18,236	0/0:6,0:6:18:0,18,205	0/0:8,0:8:24:0,24,305	0/0:3,0:3:9:0,9,107	0/0:3,0:3:9:0,9,103	0/0:6,0:6:18:0,18,215	0/0:6,0:6:15:0,15,106	0/0:6,0:6:18:0,18,208	0/0:2,0:2:6:0,6,98	0/0:5,0:5:15:0,15,169	0/0:4,0:4:12:0,12,149	0/0:7,0:7:21:0,21,251	0/0:7,0:7:21:0,21,244	0/0:4,0:4:12:0,12,148	0/0:3,0:3:9:0,9,109	0/0:2,0:2:6:0,6,69	0/0:8,0:8:24:0,24,266	0/0:6,0:6:18:0,18,204	0/0:11,0:11:33:0,33,399	0/0:5,0:5:15:0,15,170	0/0:5,0:5:15:0,15,229	0/0:9,0:9:27:0,27,297	0/0:6,0:6:18:0,18,185	0/0:5,0:5:14:0,14,130	0/0:4,0:4:12:0,12,114	0/0:1,0:1:3:0,3,29	0/0:7,0:7:20:0,20,201	0/0:5,0:5:15:0,15,137	0/0:5,0:5:14:0,14,139	0/0:6,0:6:17:0,17,180	0/0:3,0:3:8:0,8,48	0/0:7,0:7:21:0,21,236	0/0:13,0:13:38:0,38,343	0/0:5,0:5:15:0,15,127	0/0:7,0:7:21:0,21,208	0/0:6,0:6:17:0,17,189	0/0:2,0:2:6:0,6,50	0/0:5,0:5:15:0,15,132	0/0:5,0:5:15:0,15,144	0/0:9,0:9:27:0,27,269	0/0:8,0:8:22:0,22,196	0/0:3,0:3:8:0,8,70	0/0:2,0:2:6:0,6,63	0/0:2,0:2:6:0,6,63	0/0:2,0:2:6:0,6,61	0/0:10,0:10:30:0,30,307	0/0:7,0:7:21:0,21,208	0/0:2,0:2:6:0,6,61	0/0:1,0:1:3:0,3,35	0/0:3,0:3:9:0,9,96	0/0:5,0:5:15:0,15,140	0/0:7,0:7:21:0,21,198	0/0:2,0:2:6:0,6,43	0/0:4,0:4:12:0,12,115	0/0:11,0:11:33:0,33,345	0/0:2,0:2:6:0,6,69	0/0:3,0:3:9:0,9,105	0/0:5,0:5:15:0,15,176	./.	0/0:5,0:5:15:0,15,152	0/0:4,0:4:12:0,12,112	0/0:7,0:7:21:0,21,221	0/0:6,0:6:18:0,18,194	0/0:8,0:8:24:0,24,262	0/0:10,0:10:29:0,29,241	0/0:6,0:6:18:0,18,172	0/0:5,0:5:15:0,15,144	0/0:2,0:2:6:0,6,61	0/0:5,0:5:15:0,15,164	0/0:2,0:2:5:0,5,42	0/0:10,0:10:30:0,30,265	0/0:10,0:10:30:0,30,520	0/0:11,0:11:32:0,32,322	0/0:3,0:3:8:0,8,71	0/0:2,0:2:6:0,6,54	0/0:6,0:6:18:0,18,184	0/0:3,0:3:9:0,9,76	0/0:1,0:1:3:0,3,25	0/0:4,0:4:12:0,12,127	0/0:7,0:7:21:0,21,233	0/0:8,0:8:24:0,24,244	0/0:5,0:5:15:0,15,149	0/0:13,0:13:39:0,39,400	0/0:5,0:5:14:0,14,133	0/0:4,0:4:12:0,12,127	0/0:9,0:9:27:0,27,254	0/0:7,0:7:21:0,21,192	0/0:5,0:5:15:0,15,143	0/0:8,0:8:23:0,23,216	0/0:7,0:7:21:0,21,203	0/0:7,0:7:21:0,21,213	0/0:4,0:4:12:0,12,118	0/0:11,0:11:33:0,33,304	0/0:4,0:4:11:0,11,98	0/0:3,0:3:9:0,9,97	0/0:2,0:2:6:0,6,76	0/0:5,0:5:15:0,15,144	0/0:1,0:1:3:0,3,31	0/0:4,0:4:11:0,11,88	0/0:3,0:3:9:0,9,103	0/0:11,0:11:33:0,33,378	0/0:5,0:5:15:0,15,145	0/0:4,0:4:12:0,12,140	0/0:5,0:5:15:0,15,149	0/0:6,0:6:18:0,18,180	0/0:4,0:4:11:0,11,94	0/0:6,0:6:18:0,18,181	0/0:7,0:7:21:0,21,214	0/0:4,0:4:12:0,12,114	0/0:7,0:7:21:0,21,214	0/0:3,0:3:9:0,9,110	0/0:4,0:4:12:0,12,123	0/0:6,0:6:18:0,18,190	0/0:10,0:10:29:0,29,294	0/0:8,0:8:24:0,24,232	0/0:6,0:6:18:0,18,185	0/0:2,0:2:6:0,6,68	0/0:5,0:5:15:0,15,152	0/0:9,0:9:27:0,27,309	0/0:17,0:17:51:0,51,535	0/0:9,0:9:27:0,27,289	0/0:12,0:12:36:0,36,372	0/0:12,0:12:36:0,36,382	0/0:15,0:15:44:0,44,412	0/0:2,0:2:6:0,6,60	0/0:1,0:1:3:0,3,31	0/0:11,0:11:33:0,33,358	0/0:9,0:9:27:0,27,286	0/0:6,0:6:17:0,17,156	0/0:11,0:11:33:0,33,328	0/0:5,0:5:15:0,15,167	0/0:6,0:6:18:0,18,216	0/0:2,0:2:6:0,6,63	0/0:8,0:8:24:0,24,271	0/0:8,0:8:24:0,24,236	0/0:9,0:9:27:0,27,277	0/0:13,0:13:39:0,39,400	0/0:7,0:7:21:0,21,191	0/0:5,0:5:15:0,15,154	0/0:4,0:4:12:0,12,120	0/0:5,0:5:15:0,15,170	0/0:15,0:15:45:0,45,490	0/0:7,0:7:20:0,20,193	0/0:4,0:4:12:0,12,113	0/0:11,0:11:33:0,33,328	0/0:12,0:12:36:0,36,317	0/0:5,0:5:15:0,15,166	0/0:4,0:4:12:0,12,113	0/0:12,0:12:36:0,36,369	0/0:11,0:11:33:0,33,341	0/0:4,0:4:11:0,11,92	0/0:2,0:2:6:0,6,67	0/0:5,0:5:15:0,15,158	0/0:4,0:4:12:0,12,123	0/0:3,0:3:9:0,9,93	0/0:4,0:4:12:0,12,110	0/0:8,0:8:24:0,24,245	0/0:6,0:6:18:0,18,179	0/0:4,0:4:12:0,12,122	0/0:9,0:9:27:0,27,270	0/0:3,0:3:9:0,9,90	0/0:1,0:1:3:0,3,30	0/0:3,0:3:9:0,9,81	0/0:5,0:5:15:0,15,148	0/0:3,0:3:9:0,9,91	0/0:4,0:4:12:0,12,118	0/0:4,0:4:12:0,12,123	0/0:6,0:6:18:0,18,162	0/0:7,0:7:21:0,21,244	0/0:6,0:6:18:0,18,191	0/0:6,0:6:17:0,17,147	0/0:8,0:8:24:0,24,243	0/0:4,0:4:12:0,12,116	0/0:6,0:6:18:0,18,180	0/0:5,0:5:14:0,14,125	0/0:6,0:6:17:0,17,152	0/0:3,0:3:9:0,9,95	0/0:7,0:7:21:0,21,222	0/0:2,0:2:6:0,6,69	0/0:6,0:6:18:0,18,200	0/0:9,0:9:27:0,27,269	0/0:4,0:4:12:0,12,130	0/0:6,0:6:17:0,17,168	0/0:7,0:7:21:0,21,216	0/0:4,0:4:12:0,12,102	0/0:6,0:6:18:0,18,162	0/0:7,0:7:20:0,20,205	0/0:2,0:2:5:0,5,39	0/0:5,0:5:15:0,15,166	0/0:2,0:2:5:0,5,30	0/0:3,0:3:9:0,9,101	0/0:2,0:2:6:0,6,57	0/0:4,0:4:12:0,12,128	0/0:7,0:7:21:0,21,220	0/0:7,0:7:21:0,21,245	0/0:3,0:3:9:0,9,92	0/0:4,0:4:12:0,12,155	0/0:4,0:4:12:0,12,122	0/0:5,0:5:15:0,15,176	0/0:8,0:8:24:0,24,236	0/0:5,0:5:15:0,15,132	0/0:6,0:6:18:0,18,204	0/0:4,0:4:12:0,12,123	0/0:7,0:7:20:0,20,208	0/0:9,0:9:27:0,27,287	0/0:4,0:4:12:0,12,142	0/0:4,0:4:12:0,12,129	0/0:1,0:1:3:0,3,17	0/0:3,0:3:9:0,9,98	0/0:10,0:10:30:0,30,307	0/0:10,0:10:30:0,30,310	0/0:5,0:5:15:0,15,161	0/0:8,0:8:24:0,24,261	0/0:3,0:3:9:0,9,93	0/0:5,0:5:15:0,15,157	0/0:7,0:7:21:0,21,221	0/0:10,0:10:30:0,30,343	0/0:3,0:3:9:0,9,104	0/0:8,0:8:24:0,24,270	0/0:3,0:3:9:0,9,99	0/0:9,0:9:27:0,27,302	0/0:6,0:6:18:0,18,203	0/0:1,0:1:3:0,3,31	0/0:3,0:3:9:0,9,82	0/0:2,0:2:6:0,6,50	0/0:9,0:9:27:0,27,272	0/0:7,0:7:21:0,21,230	0/0:7,0:7:21:0,21,244	0/0:5,0:5:15:0,15,176	0/0:7,0:7:21:0,21,189	0/0:7,0:7:20:0,20,155	0/0:4,0:4:12:0,12,136	0/0:3,0:3:9:0,9,101	0/0:6,0:6:18:0,18,190	0/0:8,0:8:23:0,23,247	0/0:5,0:5:15:0,15,164	0/0:9,0:9:27:0,27,306	0/0:8,0:8:24:0,24,263	0/0:10,0:10:30:0,30,337	0/0:8,0:8:24:0,24,254	0/0:6,0:6:18:0,18,225	0/0:4,0:4:12:0,12,126	0/0:6,0:6:17:0,17,179	0/0:5,0:5:15:0,15,171	./.	0/0:9,0:9:27:0,27,262	0/0:6,0:6:18:0,18,179	0/0:9,0:9:27:0,27,283	0/0:7,0:7:21:0,21,231	0/0:4,0:4:12:0,12,155	0/0:6,0:6:18:0,18,211	0/0:6,0:6:18:0,18,189	0/0:11,0:11:32:0,32,333	0/0:2,0:2:6:0,6,63	0/0:8,0:8:24:0,24,282	0/0:2,0:2:6:0,6,75	0/0:2,0:2:6:0,6,67	0/0:3,0:3:9:0,9,114	0/0:11,0:11:33:0,33,375	0/0:10,0:10:30:0,30,358	0/0:8,0:8:24:0,24,283	0/0:6,0:6:17:0,17,184	0/0:3,0:3:9:0,9,101	0/0:12,0:12:35:0,35,358	0/0:4,0:4:12:0,12,141	0/0:2,0:2:6:0,6,65	0/0:4,0:4:12:0,12,115	0/0:7,0:7:21:0,21,221	0/0:2,0:2:6:0,6,53	0/0:1,0:1:3:0,3,33	0/0:1,0:1:3:0,3,36	0/0:4,0:4:12:0,12,137	0/0:1,0:1:3:0,3,29	0/0:10,0:10:30:0,30,326	0/0:3,0:3:9:0,9,91	0/0:4,0:4:12:0,12,149	0/0:7,0:7:21:0,21,236	0/0:7,0:7:21:0,21,224	0/0:9,0:9:27:0,27,277	0/0:5,0:5:15:0,15,180	0/0:3,0:3:9:0,9,97	0/0:5,0:5:15:0,15,143	0/0:5,0:5:15:0,15,152	0/0:5,0:5:15:0,15,175	0/0:12,0:12:36:0,36,378	0/0:6,0:6:18:0,18,193	0/0:5,0:5:14:0,14,142	0/0:4,0:4:12:0,12,127	0/0:6,0:6:18:0,18,187	0/0:7,0:7:21:0,21,253	0/0:2,0:2:6:0,6,62	0/0:5,0:5:15:0,15,161	0/0:6,0:6:18:0,18,211	0/0:5,0:5:15:0,15,144	0/0:4,0:4:12:0,12,147	0/0:2,0:2:6:0,6,54	0/0:7,0:7:21:0,21,236	0/0:3,0:3:8:0,8,62	0/0:2,0:2:5:0,5,45	0/0:8,0:8:24:0,24,254	0/0:3,0:3:9:0,9,107	0/0:7,0:7:21:0,21,235	0/0:2,0:2:6:0,6,60	0/0:7,0:7:21:0,21,251	0/0:5,0:5:14:0,14,132	0/0:4,0:4:12:0,12,128	0/0:2,0:2:6:0,6,45	0/0:5,0:5:14:0,14,150	0/0:4,0:4:12:0,12,125	0/0:4,0:4:12:0,12,114	0/0:8,0:8:23:0,23,224	0/0:11,0:11:33:0,33,381	0/0:4,0:4:12:0,12,135	0/0:9,0:9:27:0,27,301	0/0:3,0:3:9:0,9,91	0/0:2,0:2:6:0,6,67	0/0:6,0:6:18:0,18,198	0/0:7,0:7:21:0,21,226	0/0:7,0:7:21:0,21,247	0/0:3,0:3:9:0,9,85	./.	0/0:4,0:4:12:0,12,142	0/0:1,0:1:3:0,3,38	0/0:3,0:3:9:0,9,113	0/0:5,0:5:15:0,15,182	0/0:3,0:3:9:0,9,84	0/0:1,0:1:3:0,3,33	0/0:4,0:4:12:0,12,132	0/0:9,0:9:27:0,27,276	0/0:7,0:7:21:0,21,238	0/0:3,0:3:9:0,9,103	0/0:3,0:3:9:0,9,87	0/0:5,0:5:14:0,14,133	0/0:6,0:6:18:0,18,174	0/0:3,0:3:9:0,9,75	0/0:2,0:2:6:0,6,64	0/0:6,0:6:17:0,17,167	0/0:5,0:5:15:0,15,147	0/0:5,0:5:15:0,15,156	0/0:4,0:4:12:0,12,144	0/0:6,0:6:18:0,18,176	0/0:8,0:8:24:0,24,256	0/0:2,0:2:6:0,6,53	0/0:7,0:7:21:0,21,202	0/0:8,0:8:22:0,22,184	0/0:5,0:5:15:0,15,163	0/0:3,0:3:9:0,9,101	0/0:7,0:7:21:0,21,228	0/0:4,0:4:12:0,12,112	0/0:10,0:10:30:0,30,313	0/0:7,0:7:21:0,21,187	0/0:9,0:9:27:0,27,261	0/0:4,0:4:12:0,12,112	0/0:4,0:4:12:0,12,120	0/0:6,0:6:18:0,18,189	0/0:5,0:5:14:0,14,144	0/0:5,0:5:15:0,15,166	0/0:1,0:1:3:0,3,40	0/0:4,0:4:12:0,12,118	0/0:6,0:6:18:0,18,174	0/0:3,0:3:9:0,9,92	0/0:7,0:7:20:0,20,166	0/0:5,0:5:15:0,15,168	0/0:3,0:3:9:0,9,91	0/0:2,0:2:6:0,6,66	0/0:6,0:6:18:0,18,168	0/0:5,0:5:15:0,15,162	0/0:4,0:4:12:0,12,118	0/0:9,0:9:27:0,27,277	0/0:5,0:5:15:0,15,154	0/0:4,0:4:12:0,12,135	0/0:3,0:3:9:0,9,108	0/0:10,0:10:30:0,30,336	0/0:6,0:6:18:0,18,196	0/0:8,0:8:24:0,24,245	0/0:5,0:5:15:0,15,148	0/1:3,5:8:66:173,0,66	0/0:6,0:6:18:0,18,186	0/0:8,0:8:24:0,24,252	0/0:3,0:3:9:0,9,100	./.	0/0:7,0:7:21:0,21,237	0/0:3,0:3:9:0,9,85	0/0:8,0:8:23:0,23,261	0/0:4,0:4:12:0,12,142	0/0:3,0:3:9:0,9,102	0/0:3,0:3:9:0,9,113	0/0:4,0:4:12:0,12,157	0/0:10,0:10:30:0,30,340	0/0:12,0:12:36:0,36,412	0/0:9,0:9:27:0,27,258	0/0:5,0:5:15:0,15,132	0/0:2,0:2:6:0,6,67	0/0:4,0:4:11:0,11,106	0/0:11,0:11:32:0,32,344	0/0:4,0:4:12:0,12,129	0/0:6,0:6:18:0,18,193	0/0:10,0:10:30:0,30,383	0/0:6,0:6:18:0,18,171	0/0:4,0:4:12:0,12,122	0/0:10,0:10:30:0,30,298	0/0:1,0:1:3:0,3,38
diff --git a/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_BundleWith_idx.vcf b/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_BundleWith_idx.vcf
new file mode 100644
index 00000000000..12d3cc32292
--- /dev/null
+++ b/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_BundleWith_idx.vcf
@@ -0,0 +1,160 @@
+##fileformat=VCFv4.2
+##FILTER=
+##GATKCommandLine.SelectVariants=
+##GATKCommandLine=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO== 1% and for which 2 or more founders contribute to that minor allele frequency.">
+##INFO=
+##INFO=
+##INFO=5% minor allele frequency in 1+ populations">
+##INFO=5% minor allele frequency in each and all populations">
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=SubSNP->Batch.link_out">
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##contig=
+##dbSNP_BUILD_ID=138
+##fileDate=20130806
+##phasing=partial
+##source=SelectVariants
+##variationPropertyDocumentationUrl=ftp://ftp.ncbi.nlm.nih.gov/snp/specs/dbSNP_BitField_latest.pdf	
+#CHROM	POS	ID	REF	ALT	QUAL	FILTER	INFO
+1	20547	rs202246159	A	G	.	.	INT;OTHERKG;RS=202246159;RSPOS=20547;SAO=0;SSR=0;VC=SNV;VP=0x050000080001000002000100;WGT=1;dbSNPBuildID=137
diff --git a/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_BundleWith_tbi.vcf b/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_BundleWith_tbi.vcf
new file mode 100644
index 00000000000..4e814e12379
--- /dev/null
+++ b/src/test/resources/org/broadinstitute/hellbender/tools/walkers/variantutils/SelectVariants/expected/testSelectVariants_BundleWith_tbi.vcf
@@ -0,0 +1,160 @@
+##fileformat=VCFv4.2
+##FILTER=
+##GATKCommandLine.SelectVariants=
+##GATKCommandLine=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO== 1% and for which 2 or more founders contribute to that minor allele frequency.">
+##INFO=
+##INFO=
+##INFO=5% minor allele frequency in 1+ populations">
+##INFO=5% minor allele frequency in each and all populations">
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=
+##INFO=