Skip to content
Snippets Groups Projects
Select Git revision
  • 733df07e0ec381f15dc1cdb73bf8ab7db95110a7
  • master default protected
  • rednatco-v2
  • base-pairs-ladder
  • rednatco
  • test
  • ntc-tube-uniform-color
  • ntc-tube-missing-atoms
  • restore-vertex-array-per-program
  • watlas2
  • dnatco_new
  • cleanup-old-nodejs
  • webmmb
  • fix_auth_seq_id
  • update_deps
  • ext_dev
  • ntc_balls
  • nci-2
  • plugin
  • bugfix-0.4.5
  • nci
  • v0.5.0-dev.1
  • v0.4.5
  • v0.4.4
  • v0.4.3
  • v0.4.2
  • v0.4.1
  • v0.4.0
  • v0.3.12
  • v0.3.11
  • v0.3.10
  • v0.3.9
  • v0.3.8
  • v0.3.7
  • v0.3.6
  • v0.3.5
  • v0.3.4
  • v0.3.3
  • v0.3.2
  • v0.3.1
  • v0.3.0
41 results

gap-iterator.ts

Blame
  • gap-iterator.ts 2.77 KiB
    /**
     * Copyright (c) 2018 mol* contributors, licensed under MIT, See LICENSE file for more info.
     *
     * @author Alexander Rose <alexander.rose@weirdbyte.de>
     */
    
    import { Unit, StructureElement, ElementIndex, ResidueIndex } from 'mol-model/structure';
    import Iterator from 'mol-data/iterator';
    import SortedRanges from 'mol-data/int/sorted-ranges';
    import { getGapRanges } from '../polymer';
    
    /** Iterates over gaps, i.e. the stem residues/coarse elements adjacent to gaps */
    export function PolymerGapIterator(unit: Unit): Iterator<PolymerGapPair> {
        switch (unit.kind) {
            case Unit.Kind.Atomic: return new AtomicPolymerGapIterator(unit)
            case Unit.Kind.Spheres:
            case Unit.Kind.Gaussians:
                return new CoarsePolymerGapIterator(unit)
        }
    }
    
    interface PolymerGapPair {
        centerA: StructureElement
        centerB: StructureElement
    }
    
    function createPolymerGapPair (unit: Unit) {
        return {
            centerA: StructureElement.create(unit),
            centerB: StructureElement.create(unit),
        }
    }
    
    export class AtomicPolymerGapIterator implements Iterator<PolymerGapPair> {
        private traceElementIndex: ArrayLike<ElementIndex>
        private value: PolymerGapPair
        private gapIt: SortedRanges.Iterator<ElementIndex, ResidueIndex>
        hasNext: boolean = false;
    
        move() {
            const { elements, residueIndex } = this.unit
            const gapSegment = this.gapIt.move();
            this.value.centerA.element = this.traceElementIndex[residueIndex[elements[gapSegment.start]]]
            this.value.centerB.element = this.traceElementIndex[residueIndex[elements[gapSegment.end - 1]]]
            this.hasNext = this.gapIt.hasNext
            return this.value;
        }
    
        constructor(private unit: Unit.Atomic) {
            this.traceElementIndex = unit.model.atomicHierarchy.derived.residue.traceElementIndex as ArrayLike<ElementIndex> // can assume it won't be -1 for polymer residues
            this.gapIt = SortedRanges.transientSegments(getGapRanges(unit), unit.elements);
            this.value = createPolymerGapPair(unit)
            this.hasNext = this.gapIt.hasNext
        }
    }
    
    export class CoarsePolymerGapIterator implements Iterator<PolymerGapPair> {
        private value: PolymerGapPair
        private gapIt: SortedRanges.Iterator<ElementIndex, ElementIndex>
        hasNext: boolean = false;
    
        move() {
            const gapSegment = this.gapIt.move();
            this.value.centerA.element = this.unit.elements[gapSegment.start]
            this.value.centerB.element = this.unit.elements[gapSegment.end - 1]
            this.hasNext = this.gapIt.hasNext
            return this.value;
        }
    
        constructor(private unit: Unit.Spheres | Unit.Gaussians) {