Search in sources :

Example 16 with HmfGenomeRegion

use of com.hartwig.hmftools.common.region.hmfslicer.HmfGenomeRegion in project hmftools by hartwigmedical.

the class GeneCopyNumberBuilderTest method setup.

@Before
public void setup() {
    HmfGenomeRegion gene = create(1001, 10000);
    victim = new GeneCopyNumberBuilder(gene);
}
Also used : HmfGenomeRegion(com.hartwig.hmftools.common.region.hmfslicer.HmfGenomeRegion) ImmutableHmfGenomeRegion(com.hartwig.hmftools.common.region.hmfslicer.ImmutableHmfGenomeRegion) Before(org.junit.Before)

Example 17 with HmfGenomeRegion

use of com.hartwig.hmftools.common.region.hmfslicer.HmfGenomeRegion in project hmftools by hartwigmedical.

the class BachelorEligibility method processStructuralVariant.

private Collection<EligibilityReport> processStructuralVariant(final String patient, final GenomePosition position, final GenomePosition other, final StructuralVariantType svType) {
    final List<EligibilityReport> results = Lists.newArrayList();
    // TODO: can we do better than this performance wise? new map?
    for (final HmfGenomeRegion region : allGenesByChromosomeMap.get(position.chromosome())) {
        if (!region.contains(position)) {
            continue;
        }
        // skip non-inversion intronic variants
        if (region.contains(other) && svType != StructuralVariantType.INV) {
            final int intronStart = intron(region.exome(), position);
            final int intronEnd = intron(region.exome(), other);
            // the variant is intronic in a gene -- we will filter it
            if (intronStart >= 0 && intronStart == intronEnd) {
                continue;
            }
        }
        programs.stream().filter(p -> p.disruptionProcessor().test(region)).map(p -> ImmutableEligibilityReport.builder().patient(patient).source(SOMATIC_DISRUPTION).program(p.name()).id("").genes(region.gene()).chrom(region.chromosome()).pos(position.position()).ref("").alts("").effects("").build()).forEach(results::add);
    }
    return results;
}
Also used : ProgramPanel(nl.hartwigmedicalfoundation.bachelor.ProgramPanel) Genotype(htsjdk.variant.variantcontext.Genotype) CloseableIterator(htsjdk.samtools.util.CloseableIterator) SOMATIC_DELETION(com.hartwig.hmftools.bachelor.EligibilityReport.ReportType.SOMATIC_DELETION) SOMATIC_DISRUPTION(com.hartwig.hmftools.bachelor.EligibilityReport.ReportType.SOMATIC_DISRUPTION) VCFFileReader(htsjdk.variant.vcf.VCFFileReader) HmfGenomeRegion(com.hartwig.hmftools.common.region.hmfslicer.HmfGenomeRegion) Multimap(com.google.common.collect.Multimap) StructuralVariant(com.hartwig.hmftools.common.variant.structural.StructuralVariant) HmfGenePanelSupplier(com.hartwig.hmftools.genepanel.HmfGenePanelSupplier) HashMultimap(com.google.common.collect.HashMultimap) Lists(com.google.common.collect.Lists) GenomePosition(com.hartwig.hmftools.common.position.GenomePosition) VariantAnnotation(com.hartwig.hmftools.common.variant.snpeff.VariantAnnotation) Map(java.util.Map) StructuralVariantType(com.hartwig.hmftools.common.variant.structural.StructuralVariantType) GenomePositions(com.hartwig.hmftools.common.position.GenomePositions) SnpEffect(nl.hartwigmedicalfoundation.bachelor.SnpEffect) GERMLINE_DELETION(com.hartwig.hmftools.bachelor.EligibilityReport.ReportType.GERMLINE_DELETION) SortedSetMultimap(com.google.common.collect.SortedSetMultimap) OtherEffect(nl.hartwigmedicalfoundation.bachelor.OtherEffect) Predicate(java.util.function.Predicate) Collection(java.util.Collection) Program(nl.hartwigmedicalfoundation.bachelor.Program) Set(java.util.Set) WhitelistPredicate(com.hartwig.hmftools.bachelor.predicates.WhitelistPredicate) Collectors(java.util.stream.Collectors) Maps(com.google.common.collect.Maps) Sets(com.google.common.collect.Sets) GeneIdentifier(nl.hartwigmedicalfoundation.bachelor.GeneIdentifier) List(java.util.List) Stream(java.util.stream.Stream) Logger(org.apache.logging.log4j.Logger) VariantContext(htsjdk.variant.variantcontext.VariantContext) HmfExonRegion(com.hartwig.hmftools.common.region.hmfslicer.HmfExonRegion) GeneCopyNumber(com.hartwig.hmftools.common.gene.GeneCopyNumber) NotNull(org.jetbrains.annotations.NotNull) Collections(java.util.Collections) LogManager(org.apache.logging.log4j.LogManager) BlacklistPredicate(com.hartwig.hmftools.bachelor.predicates.BlacklistPredicate) HmfGenomeRegion(com.hartwig.hmftools.common.region.hmfslicer.HmfGenomeRegion)

Aggregations

HmfGenomeRegion (com.hartwig.hmftools.common.region.hmfslicer.HmfGenomeRegion)17 NotNull (org.jetbrains.annotations.NotNull)11 Lists (com.google.common.collect.Lists)5 Sets (com.google.common.collect.Sets)5 GeneCopyNumber (com.hartwig.hmftools.common.gene.GeneCopyNumber)5 Collection (java.util.Collection)5 List (java.util.List)5 Set (java.util.Set)5 Predicate (java.util.function.Predicate)5 Collectors (java.util.stream.Collectors)5 Test (org.junit.Test)5 VariantAnnotation (com.hartwig.hmftools.common.variant.snpeff.VariantAnnotation)4 LogManager (org.apache.logging.log4j.LogManager)4 Logger (org.apache.logging.log4j.Logger)4 CivicApiWrapper (com.hartwig.hmftools.apiclients.civic.api.CivicApiWrapper)3 CivicVariantWithEvidence (com.hartwig.hmftools.apiclients.civic.data.CivicVariantWithEvidence)3 DiseaseOntologyApiWrapper (com.hartwig.hmftools.apiclients.diseaseontology.api.DiseaseOntologyApiWrapper)3 GeneModel (com.hartwig.hmftools.common.gene.GeneModel)3 SomaticVariant (com.hartwig.hmftools.common.variant.SomaticVariant)3 Alteration (com.hartwig.hmftools.patientreporter.report.data.Alteration)3