Molecular Query Language (MQL) - A context-free grammar for substructure matching

32Citations
Citations of this article
58Readers
Mendeley users who have this article in their library.
Get full text

Abstract

We have developed a Java library for substructure matching that features easy-to-read syntax and extensibility. This molecular query language (MQL) is grounded on a context-free grammar, which allows for straightforward modification and extension. The formal description of MQL is provided in this paper. Molecule primitives are atoms, bonds, properties, branching, and rings. User-defined features can be added via a Java interface. In MQL, molecules are represented as graphs. Substructure matching was implemented using the Ullmann algorithm because of favorable run-time performance. The Ullmann algorithm carries out a fast subgraph isomorphism search by combining backtracking with effective forward checking. MQL software design was driven by the aim to facilitate the use of various cheminformatics toolkits. Two Java interfaces provide a bridge from our MQL package to an external toolkit: the first one provides the matching rules for every feature of a particular toolkit; the second one converts the found match from the internal format of MQL to the format of the external toolkit. We already implemented these interfaces for the Chemistry Development Toolkit. © 2007 American Chemical Society.

Cite

CITATION STYLE

APA

Proschak, E., Wegner, J. K., Schüller, A., Schneider, G., & Fechner, U. (2007). Molecular Query Language (MQL) - A context-free grammar for substructure matching. Journal of Chemical Information and Modeling, 47(2), 295–301. https://doi.org/10.1021/ci600305h

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free