Package picard.vcf.filter

Source Code of picard.vcf.filter.TestFilterVcf

/*
* The MIT License
*
* Copyright (c) 2014 The Broad Institute
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package picard.vcf.filter;

import htsjdk.samtools.util.CollectionUtil;
import htsjdk.samtools.util.ListMap;
import htsjdk.variant.variantcontext.VariantContext;
import htsjdk.variant.vcf.VCFFileReader;
import org.testng.Assert;
import org.testng.annotations.Test;
import picard.PicardException;

import java.io.File;
import java.util.Set;
import java.util.TreeSet;

/**
* Tests for VCF filtration
*/
public class TestFilterVcf {
    private final File INPUT = new File("testdata/picard/vcf/filter/testFiltering.vcf");

    /** Tests that all records get PASS set as their filter when extreme values are used for filtering. */
    @Test public void testNoFiltering() throws Exception {
        final File out = testFiltering(INPUT, 0, 0, 0, Double.MAX_VALUE);
        final VCFFileReader in = new VCFFileReader(out, false);
        for (final VariantContext ctx : in) {
            if (!ctx.filtersWereApplied() || ctx.isFiltered()) {
                Assert.fail("Context should not have been filtered: " + ctx.toString());
            }
        }
    }

    /** Tests that sites with a het allele balance < 0.4 are marked as filtered out. */
    @Test public void testAbFiltering() throws Exception {
        final Set<String> fails = CollectionUtil.makeSet("tf2", "rs28566954", "rs28548431");
        final File out = testFiltering(INPUT, 0.4, 0, 0, Double.MAX_VALUE);
        final ListMap<String,String> filters = slurpFilters(out);
        Assert.assertEquals(filters.keySet(), fails, "Failed sites did not match expected set of failed sites.");
    }

    /** Tests that genotypes with DP < 18 are marked as failed, but not >= 18. */
    @Test public void testDpFiltering() throws Exception {
        final Set<String> fails = CollectionUtil.makeSet("rs71509448", "rs71628926", "rs13302979", "rs2710876");
        final File out = testFiltering(INPUT, 0, 18, 0, Double.MAX_VALUE);
        final ListMap<String,String> filters = slurpFilters(out);
        Assert.assertEquals(filters.keySet(), fails, "Failed sites did not match expected set of failed sites.");
    }

    /** Tests that genotypes with low GQ are filtered appropriately. */
    @Test public void testGqFiltering() throws Exception {
        final Set<String> fails = CollectionUtil.makeSet("rs71509448"); // SNP with GQ=21; lowest GQ in file

        {
            final File out = testFiltering(INPUT, 0, 0, 20, Double.MAX_VALUE);
            final ListMap<String, String> filters = slurpFilters(out);
            Assert.assertEquals(filters.size(), 0, "Should not have filtered sites: " + filters);
        }
        {
            final File out = testFiltering(INPUT, 0, 0, 21, Double.MAX_VALUE);
            final ListMap<String, String> filters = slurpFilters(out);
            Assert.assertEquals(filters.size(), 0, "Should not have filtered sites: " + filters);
        }
        {
            final File out = testFiltering(INPUT, 0, 0, 22, Double.MAX_VALUE);
            final ListMap<String, String> filters = slurpFilters(out);
            Assert.assertEquals(filters.keySet(), fails, "Failed sites did not match expected set of failed sites.");
        }
    }

    /** Tests that genotypes with DP < 18 are marked as failed, but not >= 18. */
    @Test public void testFsFiltering() throws Exception {
        final Set<String> fails = CollectionUtil.makeSet("rs13303033", "rs28548431", "rs2799066");
        final File out = testFiltering(INPUT, 0, 0, 0, 5.0d);
        final ListMap<String,String> filters = slurpFilters(out);
        Assert.assertEquals(filters.keySet(), fails, "Failed sites did not match expected set of failed sites.");
    }

    @Test public void testCombinedFiltering() throws Exception {
        final TreeSet<String> fails = new TreeSet<String>(CollectionUtil.makeSet("rs13302979", "rs13303033", "rs2710876" , "rs2799066" , "rs28548431", "rs28566954", "rs71509448", "rs71628926", "tf2"));
        final File out = testFiltering(INPUT, 0.4, 18, 22, 5.0d);
        final ListMap<String,String> filters = slurpFilters(out);
        Assert.assertEquals(new TreeSet<String>(filters.keySet()), fails, "Failed sites did not match expected set of failed sites.");
    }

    /** Utility method that takes a a VCF and a set of parameters and filters the VCF. */
    File testFiltering(final File vcf, final double minAb, final int minDp, final int minGq, final double maxFs) throws Exception {
        final File out = File.createTempFile("filterVcfTest.", ".vcf.gz");
        out.deleteOnExit();

        final FilterVcf filterer = new FilterVcf();
        filterer.CREATE_INDEX = true;
        filterer.INPUT = vcf;
        filterer.OUTPUT = out;
        filterer.MIN_AB = minAb;
        filterer.MIN_DP = minDp;
        filterer.MIN_GQ = minGq;
        filterer.MAX_FS = maxFs;

        final int retval = filterer.doWork();
        if (retval != 0) {
            throw new PicardException("Return value non-zero: " + retval);
        }

        return out;
    }

    /** Consumes a VCF and returns a ListMap where each they keys are the IDs of filtered out sites and the values are the set of filters. */
    ListMap<String,String> slurpFilters(final File vcf) {
        final ListMap<String,String> map = new ListMap<String, String>();
        final VCFFileReader in = new VCFFileReader(vcf, false);
        for (final VariantContext ctx : in) {
            if (ctx.isNotFiltered()) continue;
            for (final String filter : ctx.getFilters()) {
                map.add(ctx.getID(), filter);
            }
        }
        in.close();
        return map;
    }
}
TOP

Related Classes of picard.vcf.filter.TestFilterVcf

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.