Skip to content
Snippets Groups Projects
mol-script.ts 3.78 KiB
Newer Older
import { MolScriptBuilder } from 'mol-script/language/builder';
David Sehnal's avatar
David Sehnal committed
import { compile, QuerySymbolRuntime, DefaultQueryRuntimeTable } from 'mol-script/runtime/query/compiler';
import { QueryContext, Structure, StructureQuery, ModelPropertyDescriptor } from 'mol-model/structure';
import { readCifFile, getModelsAndStructure } from '../apps/structure-info/model';
David Sehnal's avatar
David Sehnal committed
import { CustomPropSymbol } from 'mol-script/language/symbol';
import Type from 'mol-script/language/type';
David Sehnal's avatar
David Sehnal committed
import { parseMolScript } from 'mol-script/language/parser';
import * as util from 'util'
import { transpileMolScript } from 'mol-script/script/mol-script/symbols';
import { formatMolScript } from 'mol-script/language/expression-formatter';
import { StructureQualityReport } from 'mol-model-props/pdbe/structure-quality-report';
Alexander Rose's avatar
Alexander Rose committed
import fetch from 'node-fetch';

// import Examples from 'mol-script/script/mol-script/examples'
// import { parseMolScript } from 'mol-script/script/mol-script/parser'
// //import { compileAST } from 'mol-script/script/mol-script/compile';

// for (const e of Examples) {
//     const expr = parseMolScript(e.value)[0];
//     console.log(e.name, util.inspect(expr, true, 10, true));
// }
// const exprs = parseMolScript(`(sel.atom.atom-groups
//     :residue-test (= atom.auth_comp_id ALA)
//     ;; ho ho ho
//     :atom-test (set.has { _C _N } atom.el)) ; comm
//     ;; this is a comment
//     ((hi) (ho))`);

Alexander Rose's avatar
Alexander Rose committed
// ;; :residue-test (= atom.label_comp_id REA)
David Sehnal's avatar
David Sehnal committed
const exprs = parseMolScript(`(sel.atom.atom-groups
    :residue-test (> pdbe.structure-quality.issue-count 0)
    :atom-test (= atom.el _C))`);

const tsp = transpileMolScript(exprs[0]);

Alexander Rose's avatar
Alexander Rose committed
// console.log(util.inspect(exprs, true, 10, true));
David Sehnal's avatar
David Sehnal committed

console.log(util.inspect(tsp, true, 10, true));

console.log(formatMolScript);
console.log(formatMolScript(tsp));
// //console.log(expr);

const expr = MolScriptBuilder.core.math.add([1, 2, 3]);
const compiled = compile<number>(expr);
const result = compiled(new QueryContext(Structure.Empty));
console.log(result);

David Sehnal's avatar
David Sehnal committed
const CustomProp = ModelPropertyDescriptor({
    name: 'test_prop',
    isStatic: true,
    cifExport: { prefix: '', categories: [ ]},
David Sehnal's avatar
David Sehnal committed
    symbols: {
        residueIndex: QuerySymbolRuntime.Dynamic(CustomPropSymbol('custom.test-prop', 'residue-index', Type.Num), ctx => {
            const e = ctx.element;
Alexander Rose's avatar
Alexander Rose committed
            // console.log(e.element, e.unit.model.atomicHierarchy.residueAtomSegments.index[e.element])
David Sehnal's avatar
David Sehnal committed
            return e.unit.model.atomicHierarchy.residueAtomSegments.index[e.element];
        })
    }
});

DefaultQueryRuntimeTable.addCustomProp(CustomProp);

DefaultQueryRuntimeTable.addCustomProp(StructureQualityReport.Descriptor);

David Sehnal's avatar
David Sehnal committed
export async function testQ() {
    const frame = await readCifFile('e:/test/quick/1cbs_updated.cif');
    const { structure } = await getModelsAndStructure(frame);

    await StructureQualityReport.attachFromCifOrApi(structure.models[0], {
        PDBe_apiSourceJson: async model => {
            const rawData = await fetch(`https://www.ebi.ac.uk/pdbe/api/validation/residuewise_outlier_summary/entry/${model.label.toLowerCase()}`, { timeout: 1500 });
            return await rawData.json();
        }
    })

    let expr = MolScriptBuilder.struct.generator.atomGroups({
        'atom-test': MolScriptBuilder.core.rel.eq([
            MolScriptBuilder.struct.atomProperty.core.elementSymbol(),
            MolScriptBuilder.es('C')
        ]),
David Sehnal's avatar
David Sehnal committed
        // 'residue-test': MolScriptBuilder.core.rel.eq([
        //     MolScriptBuilder.struct.atomProperty.macromolecular.label_comp_id(),
        //     'REA'
        // ])
        'residue-test': MolScriptBuilder.core.rel.inRange([CustomProp.symbols.residueIndex.symbol(), 1, 5])
    const compiled = compile<StructureQuery>(expr);
    const result = compiled(new QueryContext(structure));

    console.log(result);
}