mol.ts 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /**
  2. * Copyright (c) 2019-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author David Sehnal <david.sehnal@gmail.com>
  5. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  6. * @author Panagiotis Tourlas <panagiot_tourlov@hotmail.com>
  7. */
  8. import { Column, Table } from '../../mol-data/db';
  9. import { MolFile, formalChargeMapper } from '../../mol-io/reader/mol/parser';
  10. import { MoleculeType } from '../../mol-model/structure/model/types';
  11. import { RuntimeContext, Task } from '../../mol-task';
  12. import { createModels } from './basic/parser';
  13. import { BasicSchema, createBasic } from './basic/schema';
  14. import { ComponentBuilder } from './common/component';
  15. import { EntityBuilder } from './common/entity';
  16. import { ModelFormat } from '../format';
  17. import { IndexPairBonds } from './property/bonds/index-pair';
  18. import { Trajectory } from '../../mol-model/structure';
  19. export async function getMolModels(mol: MolFile, format: ModelFormat<any> | undefined, ctx: RuntimeContext) {
  20. const { atoms, bonds, formalCharges } = mol;
  21. const MOL = Column.ofConst('MOL', mol.atoms.count, Column.Schema.str);
  22. const A = Column.ofConst('A', mol.atoms.count, Column.Schema.str);
  23. const type_symbol = Column.asArrayColumn(atoms.type_symbol);
  24. const seq_id = Column.ofConst(1, atoms.count, Column.Schema.int);
  25. const computedFormalCharges = new Int32Array(mol.atoms.count);
  26. if (formalCharges.atomIdx.rowCount > 0) {
  27. for (let i = 0; i < formalCharges.atomIdx.rowCount; i++) {
  28. computedFormalCharges[formalCharges.atomIdx.value(i) - 1] = formalCharges.charge.value(i);
  29. }
  30. } else {
  31. for (let i = 0; i < mol.atoms.count; i++) {
  32. computedFormalCharges[i] = formalChargeMapper(atoms.formal_charge.value(i));
  33. }
  34. }
  35. const atom_site = Table.ofPartialColumns(BasicSchema.atom_site, {
  36. auth_asym_id: A,
  37. auth_atom_id: type_symbol,
  38. auth_comp_id: MOL,
  39. auth_seq_id: seq_id,
  40. Cartn_x: Column.asArrayColumn(atoms.x, Float32Array),
  41. Cartn_y: Column.asArrayColumn(atoms.y, Float32Array),
  42. Cartn_z: Column.asArrayColumn(atoms.z, Float32Array),
  43. id: Column.range(0, atoms.count - 1),
  44. label_asym_id: A,
  45. label_atom_id: type_symbol,
  46. label_comp_id: MOL,
  47. label_seq_id: seq_id,
  48. label_entity_id: Column.ofConst('1', atoms.count, Column.Schema.str),
  49. occupancy: Column.ofConst(1, atoms.count, Column.Schema.float),
  50. type_symbol,
  51. pdbx_PDB_model_num: Column.ofConst(1, atoms.count, Column.Schema.int),
  52. pdbx_formal_charge: Column.ofIntArray(computedFormalCharges)
  53. }, atoms.count);
  54. const entityBuilder = new EntityBuilder();
  55. entityBuilder.setNames([['MOL', 'Unknown Entity']]);
  56. entityBuilder.getEntityId('MOL', MoleculeType.Unknown, 'A');
  57. const componentBuilder = new ComponentBuilder(seq_id, type_symbol);
  58. componentBuilder.setNames([['MOL', 'Unknown Molecule']]);
  59. componentBuilder.add('MOL', 0);
  60. const basic = createBasic({
  61. entity: entityBuilder.getEntityTable(),
  62. chem_comp: componentBuilder.getChemCompTable(),
  63. atom_site
  64. });
  65. const models = await createModels(basic, format ?? MolFormat.create(mol), ctx);
  66. if (models.frameCount > 0) {
  67. const indexA = Column.ofIntArray(Column.mapToArray(bonds.atomIdxA, x => x - 1, Int32Array));
  68. const indexB = Column.ofIntArray(Column.mapToArray(bonds.atomIdxB, x => x - 1, Int32Array));
  69. const order = Column.asArrayColumn(bonds.order, Int32Array);
  70. const pairBonds = IndexPairBonds.fromData(
  71. { pairs: { indexA, indexB, order }, count: atoms.count },
  72. { maxDistance: Infinity }
  73. );
  74. IndexPairBonds.Provider.set(models.representative, pairBonds);
  75. }
  76. return models;
  77. }
  78. //
  79. export { MolFormat };
  80. type MolFormat = ModelFormat<MolFile>
  81. namespace MolFormat {
  82. export function is(x?: ModelFormat): x is MolFormat {
  83. return x?.kind === 'mol';
  84. }
  85. export function create(mol: MolFile): MolFormat {
  86. return { kind: 'mol', name: mol.title, data: mol };
  87. }
  88. }
  89. export function trajectoryFromMol(mol: MolFile): Task<Trajectory> {
  90. return Task.create('Parse MOL', ctx => getMolModels(mol, void 0, ctx));
  91. }