mirror of
https://github.com/rdkit/rdkit.git
synced 2026-06-04 21:54:27 +08:00
* Start of GettingStartedInC++ documentation. * Changed GettingStartedInC++ from rst to markdown format. Added some more text. * Added Working with Molecules to GettingStartedInC++ * Expanded on behaviour of Kekulize wrt clearing aromatic flags on atoms and bonds. * Added section Modifying Molecules. * More plodding progress. * A load more documentation. * Undid change to global CMakeLists.txt * Minor editing of docs. * Changed examples so they use RDBASE to find test data rather than relative path. * Fixed use of -std=c++ in CMakeLists.txt. Extra waffling about memory. * Modifications to examples and documentation as requested. * Couple of minor changes. * Change to example11.cpp and associated text in docs.
38 lines
1.2 KiB
C++
38 lines
1.2 KiB
C++
//
|
|
// Generating depictions - example10.cpp
|
|
|
|
#include <iostream>
|
|
#include <Geometry/point.h>
|
|
#include <GraphMol/SmilesParse/SmilesParse.h>
|
|
#include <GraphMol/GraphMol.h>
|
|
#include <GraphMol/MolOps.h>
|
|
#include <GraphMol/Depictor/RDDepictor.h>
|
|
#include <GraphMol/Substruct/SubstructMatch.h>
|
|
|
|
int main( int argc , char **argv ) {
|
|
|
|
RDKit::RWMOL_SPTR mol( new RDKit::RWMol( *RDKit::SmilesToMol( "c1nccc2n1ccc2" ) ) );
|
|
RDDepict::compute2DCoords( *mol );
|
|
|
|
RDDepict::compute2DCoords( *mol , static_cast<RDGeom::INT_POINT2D_MAP *>( 0 ) ,
|
|
true );
|
|
|
|
RDKit::ROMOL_SPTR templ( RDKit::SmilesToMol( "c1nccc2n1ccc2" ) );
|
|
RDDepict::compute2DCoords( *templ );
|
|
RDKit::ROMOL_SPTR mol1( RDKit::SmilesToMol( "c1cccc2ncn3cccc3c21" ) );
|
|
|
|
RDKit::MatchVectType matchVect;
|
|
if( RDKit::SubstructMatch( *mol1 , *templ , matchVect ) ) {
|
|
RDKit::Conformer &conf = templ->getConformer();
|
|
RDGeom::INT_POINT2D_MAP coordMap;
|
|
for( RDKit::MatchVectType::const_iterator mv = matchVect.begin() ;
|
|
mv != matchVect.end() ; ++mv ) {
|
|
RDGeom::Point3D pt3 = conf.getAtomPos( mv->first );
|
|
RDGeom::Point2D pt2( pt3.x , pt3.y );
|
|
coordMap[mv->second] = pt2;
|
|
}
|
|
RDDepict::compute2DCoords( *mol1 , &coordMap );
|
|
}
|
|
|
|
}
|