molecular-surface.ts 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. /**
  2. * Copyright (c) 2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { Unit } from 'mol-model/structure';
  7. import { Task, RuntimeContext } from 'mol-task';
  8. import { getUnitConformationAndRadius } from './common';
  9. import { PositionData, DensityData } from 'mol-math/geometry';
  10. import { MolecularSurfaceCalculationProps, calcMolecularSurface } from 'mol-math/geometry/molecular-surface';
  11. import { OrderedSet } from 'mol-data/int';
  12. export function computeUnitMolecularSurface(unit: Unit, props: MolecularSurfaceCalculationProps) {
  13. const { position, radius } = getUnitConformationAndRadius(unit)
  14. return Task.create('Molecular Surface', async ctx => {
  15. const { indices } = position
  16. const n = OrderedSet.size(indices)
  17. const radii = new Float32Array(n)
  18. let maxRadius = 0
  19. for (let i = 0; i < n; ++i) {
  20. const r = radius(OrderedSet.getAt(indices, i))
  21. if (maxRadius < r) maxRadius = r
  22. radii[i] = r + props.probeRadius
  23. if (i % 10000 === 0 && ctx.shouldUpdate) {
  24. await ctx.update({ message: 'calculating max radius', current: i, max: n })
  25. }
  26. }
  27. return await MolecularSurface(ctx, { ...position, radius: radii }, maxRadius, props);
  28. });
  29. }
  30. //
  31. async function MolecularSurface(ctx: RuntimeContext, position: Required<PositionData>, maxRadius: number, props: MolecularSurfaceCalculationProps): Promise<DensityData> {
  32. return calcMolecularSurface(ctx, position, maxRadius, props)
  33. }