 
                        
        
                        
        org.broadinstitute.hellbender.tools.copynumber.segmentation.AlleleFractionKernelSegmenter Maven / Gradle / Ivy
 The newest version!
        
        package org.broadinstitute.hellbender.tools.copynumber.segmentation;
import org.broadinstitute.hellbender.tools.copynumber.formats.collections.AllelicCountCollection;
import org.broadinstitute.hellbender.tools.copynumber.formats.collections.CopyRatioCollection;
import org.broadinstitute.hellbender.tools.copynumber.formats.collections.SimpleIntervalCollection;
import org.broadinstitute.hellbender.utils.Utils;
import java.util.Collections;
import java.util.List;
/**
 * Segments alternate-allele-fraction data using kernel segmentation.  Segments do not span chromosomes.
 *
 * Refactored to be a thin wrapper around the {@link MultisampleMultidimensionalKernelSegmenter} so that
 * preexisting test code could be reused for testing that class; do not use this class in production code.
 *
 * @author Samuel Lee <[email protected]>
 */
public final class AlleleFractionKernelSegmenter {
    private static final double DUMMY_COPY_RATIO_KERNEL_VARIANCE = 1.;
    private static final double DUMMY_KERNEL_SCALING_ALLELE_FRACTION = 1.;
    private final MultisampleMultidimensionalKernelSegmenter segmenter;
    public AlleleFractionKernelSegmenter(final AllelicCountCollection allelicCounts) {
        Utils.nonNull(allelicCounts);
        segmenter = new MultisampleMultidimensionalKernelSegmenter(
                Collections.singletonList(new CopyRatioCollection(allelicCounts.getMetadata(), Collections.emptyList())),
                Collections.singletonList(allelicCounts));
    }
    /**
     * @param kernelVariance    variance of the Gaussian kernel; if zero, a linear kernel is used instead
     */
    public SimpleIntervalCollection findSegmentation(final int maxNumSegmentsPerChromosome,
                                                     final double kernelVariance,
                                                     final int kernelApproximationDimension,
                                                     final List windowSizes,
                                                     final double numChangepointsPenaltyLinearFactor,
                                                     final double numChangepointsPenaltyLogLinearFactor) {
        return segmenter.findSegmentation(
                maxNumSegmentsPerChromosome,
                DUMMY_COPY_RATIO_KERNEL_VARIANCE,
                kernelVariance,
                DUMMY_KERNEL_SCALING_ALLELE_FRACTION,
                kernelApproximationDimension,
                windowSizes,
                numChangepointsPenaltyLinearFactor,
                numChangepointsPenaltyLogLinearFactor);
    }
}
 © 2015 - 2025 Weber Informatics LLC | Privacy Policy