mol2.ts 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /**
  2. * Copyright (c) 2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { Column, Table } from '../../mol-data/db';
  7. import { Model } from '../../mol-model/structure/model';
  8. import { MoleculeType } from '../../mol-model/structure/model/types';
  9. import { RuntimeContext, Task } from '../../mol-task';
  10. import { createModels } from './basic/parser';
  11. import { BasicSchema, createBasic } from './basic/schema';
  12. import { ComponentBuilder } from './common/component';
  13. import { EntityBuilder } from './common/entity';
  14. import { ModelFormat } from '../format';
  15. import { IndexPairBonds } from './property/bonds/index-pair';
  16. import { Mol2File } from '../../mol-io/reader/mol2/schema';
  17. async function getModels(mol2: Mol2File, ctx: RuntimeContext): Promise<Model[]> {
  18. const models: Model[] = [];
  19. for (let i = 0, il = mol2.structures.length; i < il; ++i) {
  20. const { atoms, bonds } = mol2.structures[i];
  21. const A = Column.ofConst('A', atoms.count, Column.Schema.str);
  22. const atom_site = Table.ofPartialColumns(BasicSchema.atom_site, {
  23. auth_asym_id: A,
  24. auth_atom_id: Column.asArrayColumn(atoms.atom_type),
  25. auth_comp_id: atoms.subst_name,
  26. auth_seq_id: atoms.subst_id,
  27. Cartn_x: Column.asArrayColumn(atoms.x, Float32Array),
  28. Cartn_y: Column.asArrayColumn(atoms.y, Float32Array),
  29. Cartn_z: Column.asArrayColumn(atoms.z, Float32Array),
  30. id: Column.asArrayColumn(atoms.atom_id),
  31. label_asym_id: A,
  32. label_atom_id: Column.asArrayColumn(atoms.atom_type),
  33. label_comp_id: atoms.subst_name,
  34. label_seq_id: atoms.subst_id,
  35. label_entity_id: Column.ofConst('1', atoms.count, Column.Schema.str),
  36. occupancy: Column.ofConst(1, atoms.count, Column.Schema.float),
  37. type_symbol: Column.asArrayColumn(atoms.atom_name),
  38. pdbx_PDB_model_num: Column.ofConst(i, atoms.count, Column.Schema.int),
  39. }, atoms.count);
  40. const entityBuilder = new EntityBuilder();
  41. entityBuilder.setNames([['MOL', 'Unknown Entity']]);
  42. entityBuilder.getEntityId('MOL', MoleculeType.Unknown, 'A');
  43. const componentBuilder = new ComponentBuilder(atoms.subst_id, atoms.atom_name);
  44. for (let i = 0, il = atoms.subst_name.rowCount; i < il; ++i) {
  45. componentBuilder.add(atoms.subst_name.value(i), i);
  46. }
  47. const basics = createBasic({
  48. entity: entityBuilder.getEntityTable(),
  49. chem_comp: componentBuilder.getChemCompTable(),
  50. atom_site
  51. });
  52. const _models = await createModels(basics, Mol2Format.create(mol2), ctx);
  53. if (_models.length > 0) {
  54. const indexA = Column.ofIntArray(Column.mapToArray(bonds.origin_atom_id, x => x - 1, Int32Array));
  55. const indexB = Column.ofIntArray(Column.mapToArray(bonds.target_atom_id, x => x - 1, Int32Array));
  56. const order = Column.ofIntArray(Column.mapToArray(bonds.bond_type, x => x === 'ar' ? 1 : parseInt(x), Int8Array));
  57. const pairBonds = IndexPairBonds.fromData({ pairs: { indexA, indexB, order }, count: bonds.count });
  58. IndexPairBonds.Provider.set(_models[0], pairBonds);
  59. models.push(_models[0]);
  60. }
  61. }
  62. return models;
  63. }
  64. //
  65. export { Mol2Format };
  66. type Mol2Format = ModelFormat<Mol2File>
  67. namespace Mol2Format {
  68. export function is(x: ModelFormat): x is Mol2Format {
  69. return x.kind === 'mol2';
  70. }
  71. export function create(mol2: Mol2File): Mol2Format {
  72. return { kind: 'mol2', name: mol2.name, data: mol2 };
  73. }
  74. }
  75. export function trajectoryFromMol2(mol2: Mol2File): Task<Model.Trajectory> {
  76. return Task.create('Parse MOL2', ctx => getModels(mol2, ctx));
  77. }