helpers.ts 5.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /**
  2. * Copyright (c) 2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author David Sehnal <david.sehnal@gmail.com>
  5. */
  6. import { Mat4, Vec3 } from '../../mol-math/linear-algebra';
  7. import { PluginContext } from '../../mol-plugin/context';
  8. import { PluginStateObject as PSO } from '../../mol-plugin/state/objects';
  9. import { StateTransforms } from '../../mol-plugin/state/transforms';
  10. import { StructureRepresentation3DHelpers } from '../../mol-plugin/state/transforms/representation';
  11. import { MolScriptBuilder as MS } from '../../mol-script/language/builder';
  12. import { StateBuilder } from '../../mol-state';
  13. import Expression from '../../mol-script/language/expression';
  14. import { BuiltInColorThemeName } from '../../mol-theme/color';
  15. type SupportedFormats = 'cif' | 'pdb'
  16. export namespace StateHelper {
  17. export function download(b: StateBuilder.To<PSO.Root>, url: string, ref?: string) {
  18. return b.apply(StateTransforms.Data.Download, { url, isBinary: false }, { ref });
  19. }
  20. export function getModel(b: StateBuilder.To<PSO.Data.Binary | PSO.Data.String>, format: SupportedFormats, modelIndex = 0) {
  21. const parsed = format === 'cif'
  22. ? b.apply(StateTransforms.Data.ParseCif).apply(StateTransforms.Model.TrajectoryFromMmCif)
  23. : b.apply(StateTransforms.Model.TrajectoryFromPDB);
  24. return parsed.apply(StateTransforms.Model.ModelFromTrajectory, { modelIndex });
  25. }
  26. export function structure(b: StateBuilder.To<PSO.Molecule.Model>) {
  27. return b.apply(StateTransforms.Model.StructureFromModel, { tags: 'structure' })
  28. };
  29. export function selectChain(b: StateBuilder.To<PSO.Molecule.Structure>, auth_asym_id: string) {
  30. const expression = MS.struct.generator.atomGroups({
  31. 'chain-test': MS.core.rel.eq([MS.struct.atomProperty.macromolecular.auth_asym_id(), auth_asym_id])
  32. })
  33. return b.apply(StateTransforms.Model.StructureSelectionFromExpression, { expression, label: `Chain ${auth_asym_id}` });
  34. }
  35. export function select(b: StateBuilder.To<PSO.Molecule.Structure>, expression: Expression) {
  36. return b.apply(StateTransforms.Model.StructureSelectionFromExpression, { expression });
  37. }
  38. export function selectSurroundingsOfFirstResidue(b: StateBuilder.To<PSO.Molecule.Structure>, comp_id: string, radius: number) {
  39. const expression = MS.struct.modifier.includeSurroundings({
  40. 0: MS.struct.filter.first([
  41. MS.struct.generator.atomGroups({
  42. 'residue-test': MS.core.rel.eq([MS.struct.atomProperty.macromolecular.label_comp_id(), comp_id]),
  43. 'group-by': MS.struct.atomProperty.macromolecular.residueKey()
  44. })
  45. ]),
  46. radius
  47. })
  48. return b.apply(StateTransforms.Model.StructureSelectionFromExpression, { expression, label: `Surr. ${comp_id} (${radius} ang)` });
  49. }
  50. export function identityTransform(b: StateBuilder.To<PSO.Molecule.Structure>, m: Mat4) {
  51. return b.apply(StateTransforms.Model.TransformStructureConformation,
  52. { axis: Vec3.create(1, 0, 0), angle: 0, translation: Vec3.zero() },
  53. { tags: 'transform' });
  54. }
  55. export function transform(b: StateBuilder.To<PSO.Molecule.Structure>, matrix: Mat4) {
  56. return b.apply(StateTransforms.Model.TransformStructureConformationByMatrix, { matrix }, { tags: 'transform' });
  57. }
  58. export function assemble(b: StateBuilder.To<PSO.Molecule.Model>, id?: string) {
  59. return b.apply(StateTransforms.Model.StructureAssemblyFromModel, { id: id || 'deposited' }, { tags: 'asm' })
  60. }
  61. export function visual(ctx: PluginContext, visualRoot: StateBuilder.To<PSO.Molecule.Structure>) {
  62. visualRoot.apply(StateTransforms.Model.StructureComplexElement, { type: 'atomic-sequence' })
  63. .apply(StateTransforms.Representation.StructureRepresentation3D,
  64. StructureRepresentation3DHelpers.getDefaultParamsStatic(ctx, 'cartoon'), { tags: 'seq-visual' });
  65. visualRoot.apply(StateTransforms.Model.StructureComplexElement, { type: 'atomic-het' })
  66. .apply(StateTransforms.Representation.StructureRepresentation3D,
  67. StructureRepresentation3DHelpers.getDefaultParamsStatic(ctx, 'ball-and-stick'), { tags: 'het-visual' });
  68. // visualRoot.apply(StateTransforms.Model.StructureComplexElement, { type: 'water' })
  69. // .apply(StateTransforms.Representation.StructureRepresentation3D,
  70. // StructureRepresentation3DHelpers.getDefaultParamsStatic(ctx, 'ball-and-stick', { alpha: 0.51 }), { tags: 'water-visual' });
  71. return visualRoot;
  72. }
  73. export function ballsAndSticks(ctx: PluginContext, visualRoot: StateBuilder.To<PSO.Molecule.Structure>, expression: Expression, coloring?: BuiltInColorThemeName) {
  74. visualRoot
  75. .apply(StateTransforms.Model.StructureSelectionFromExpression, { expression })
  76. .apply(StateTransforms.Representation.StructureRepresentation3D,
  77. StructureRepresentation3DHelpers.getDefaultParamsStatic(ctx, 'ball-and-stick', void 0, coloring), { tags: 'het-visual' });
  78. return visualRoot;
  79. }
  80. }