Files
rdkit/Code/JavaWrappers/gmwrapper/src-test/org/RDKit/TautomerQueryTests.java
jones-gareth 21a8a263bd Tautomer search (#3205)
* TautomerQuery class

* working test

* Comment header

* Merge with master. Greg's suggestions. More tests. Python wrapper

* Updated Pattern Fingerprints to merge with master. Reset email

* Java/C# wrappers. Java test

* Java/C# wrappers. Java test

* Java/C# wrappers. Java test

* Greg suggestions of 6_2_2020

* Explicit types in Java TautomerQueryTests class

* Update Code/GraphMol/QueryOps.h

Co-authored-by: Greg Landrum <greg.landrum@gmail.com>

* get windows dll builds working

* Removed tautomer query wrappers from RDKit namespace

* Fixes from evaluation

* Template molecule identification fix. Greg's suggestion

* Final check search functor for evaluating template matches as they are found

Co-authored-by: Gareth Jones <gjones@glysade.com>
Co-authored-by: Greg Landrum <greg.landrum@gmail.com>
2020-06-24 17:27:40 +02:00

54 lines
1.8 KiB
Java

//
// Created by Gareth Jones on 6/1/2020.
//
// Copyright 2020 Schrodinger, Inc
//
package org.RDKit;
import static org.junit.Assert.*;
import org.junit.Test;
public class TautomerQueryTests extends GraphMolTest {
@Test
public void basicOperations() {
RWMol mol = RWMol.MolFromSmiles("O=C1CCCCC1");
TautomerQuery tautomerQuery = TautomerQuery.fromMol(mol);
assertEquals(2, tautomerQuery.getTautomers().size());
Sizet_Vect modifiedAtoms = tautomerQuery.getModifiedAtoms();
assertEquals(3, modifiedAtoms.size());
RWMol target = RWMol.MolFromSmiles("OC1=CCCC(CC)C1");
boolean match = tautomerQuery.isSubstructOf(target);
assertTrue(match);
Match_Vect_Vect allMatches = tautomerQuery.substructOf(target);
assertEquals(1, allMatches.size());
Match_Vect atomMatches = allMatches.get(0);
assertEquals(7, atomMatches.size());
SubstructMatchParameters params = new SubstructMatchParameters();
ROMol_Vect matchingTautomers = new ROMol_Vect();
allMatches = tautomerQuery.substructOf(target, params, matchingTautomers);
assertEquals(1, allMatches.size());
assertEquals(1, matchingTautomers.size());
match = target.hasSubstructMatch(matchingTautomers.get(0));
assertTrue(match);
ExplicitBitVect tautomerFingerprint = tautomerQuery.patternFingerprintTemplate();
ExplicitBitVect targetFingerprint = TautomerQuery.patternFingerprintTarget(target);
boolean matchingFingerprints = RDKFuncs.AllProbeBitsMatch(tautomerFingerprint, targetFingerprint);
assertTrue(matchingFingerprints);
tautomerFingerprint.delete();
targetFingerprint.delete();
}
public static void main(String args[]) {
org.junit.runner.JUnitCore.main("org.RDKit.TautomerQueryTests");
}
}