-
Notifications
You must be signed in to change notification settings - Fork 2
/
chemobabel.dtx
1307 lines (1191 loc) · 51.4 KB
/
chemobabel.dtx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
%#!make chemobabel.pdf
%%
%% This document describes the usage of `chemobabel.sty',
%% a LaTeX package for generating chemical structural formulas
%% using Open Babel and Inkscape.
%%
%% Copyright 2014-2022 Acetaminophen (Hironobu YAMASHITA)
%% Email : h.y.acetaminophen[a t]gmail.com
%% GitHub : https://github.com/aminophen
%% Blog : http://acetaminophen.hatenablog.com/
%% Twitter : @aminophen
%%
%
\documentclass[12pt]{ltjsarticle}
\usepackage[margin=20mm]{geometry}
\usepackage[english]{babel}
\usepackage[nofontspec,defaultsups]{newpxtext}
\usepackage[zerostyle=c,straightquotes]{newtxtt}
\usepackage{newpxmath}
\usepackage{ascmac}
\usepackage[librsvg]{chemobabel}
\usepackage[bookmarksnumbered=true,hidelinks,%
pdftitle={User Manual for chemobabel.sty},%
pdfauthor={Hironobu Yamashita (Acetaminophen)},%
pdfsubject={TeX \& LaTeX Advent Calendar 2014},%
pdfkeywords={chemistry,open babel,chemdraw,smiles}]{hyperref}
\usepackage{footnotebackref}
% --- Change the style of captions
% --- (Japanese jsarticle style => English style)
\makeatletter
\long\def\@makecaption#1#2{%
\vskip\abovecaptionskip
\sbox\@tempboxa{#1: #2}%
\global\@minipagefalse
\hbox to\hsize{\hfil\box\@tempboxa\hfil}%
\vskip\belowcaptionskip}
\makeatother
% --- XyMTeX logo definition
\newcount\TestCount
\def\XyM{\ifnum\fam=-1\relax\fam=0\relax\fi\TestCount=\fam
X\kern-.30em\smash{\raise.50ex\hbox{$\fam\TestCount\Upsilon$}}%
\kern-.30em{M}}
\def\XyMTeX{\XyM\kern-.1em\TeX}
% --- misc
\def\Lpack#1{\textsf{#1}}
\def\Lcode#1{\texttt{#1}}
\def\Lmeta#1{\textit{#1}}
\def\Lver#1{\Lpack{chemobabel} #1}
\def\TikZ{Ti\textit{k}Z}
% ------
\title{\Lpack{chemobabel} \\[1ex]
\normalsize --- Chemical Structures from MDL Molfiles,
ChemDraw Files or SMILES Notations --- \\
%<ja> 化学構造式をMOLファイルやChemDrawファイル,SMILES表記法から自動生成
}
\author{Hironobu Yamashita (@aminophen)}
\begin{document}
\renewcommand{\figurename}{Fig.\,}
\pagenumbering{roman}
\maketitle
%<*en>
This document (\jobname.pdf) describes the usage of \Lpack{chemobabel.sty},
a \LaTeX\ package for \textbf{generating chemical structural formulas}
to be inserted in your documents.
The formulas can be generated \textbf{from many kinds of chemical data
formats}, including MDL Molfiles, ChemDraw files and even from
SMILES notations, with the help of Open Babel.
The formulas below are generated using this method.\footnote{Unless
otherwise noted, this documentation used \Lcode{\input{obversion.txt}}}
日本語版ドキュメントはchemobabel-ja.pdfを参照してください。
%</en>
%<*ja>
この文書では,\textbf{化学構造式を生成}して\LaTeX の文書中に挿入するための
パッケージである\Lpack{chemobabel.sty}の使い方を説明します。
構造式はOpen Babelの機能を利用することにより,MDL Molfile, ChemDrawファイル,
さらにはSMILES表記法を含む\textbf{さまざまな化学データ形式から生成}できます。
以下の構造式はこの方法によって出力されたものです\footnote{特に断りがない
限り,この文書で使用した版は\Lcode{\input{obversion.txt}}です。}。
For English documentation, please refer to chemobabel-en.pdf.
%</ja>
\begin{figure}[ht]
\centering
\chemobabel[width=65mm]{draw/Firefly luciferin.mol}{} \quad
\chemobabel*[width=90mm]{draw/Brevetoxin A.mol}
\caption{Firefly luciferin \& Brevetoxin A (from MDL Molfiles)}
\end{figure}
\begin{figure}[ht]
\centering
\chemobabel[width=80mm]{draw/ATP.cdx}{} \hspace{1cm}
\chemobabel*[width=30mm]{draw/Glucose.cdx}
\caption{ATP (Adenosine triphosphate) \& Glucose (from ChemDraw files)}
\end{figure}
\begin{center}\small
Note: with Open Babel 3.1.1 the chemical structure of ATP from the .cdx file
becomes wrong.\\ See \url{https://github.com/openbabel/openbabel/issues/338}
\end{center}
\begin{figure}[ht]
\centering
\smilesobabel[width=36mm]{CCO}{} \hspace{1cm}
\smilesobabel*[width=40mm]{CC(C(=O)O)N} \hspace{1cm}
\smilesobabel*[width=30mm]{C1[C@H](C)C[C@@H](O)C1}
\caption{Ethanol, Alanine \& (1\textit{S},3\textit{S})-3-Methylcyclopentanol (from SMILES notations)}
\end{figure}
\begin{figure}[ht]
\centering
\smilesobabel*[width=30mm]{CC(=O)Nc1ccc(cc1)O} \hspace{1cm}
\smilesobabel*[width=40mm]{C([C@@H]1[C@H]([C@@H]([C@H]([C@H](O1)O)O)O)O)O}
\caption{Acetaminophen (Paracetamol) \& $\alpha$-\textsc{d}-Glucose (from SMILES notations)}
\end{figure}
\begin{figure}[ht]
\centering
%<en>This package is maintained on GitHub:\par
%<ja>このパッケージはGitHubで管理しています。\par
\url{https://github.com/aminophen/chemobabel}\par
%<en>If you have questions, please let me know.
%<ja>問い合わせや改善案などはGitHubのIssuesへお願いします。
\end{figure}
\begin{figure}[ht]
\centering
%<en>Also available on CTAN:
%<ja>CTANからも入手可能です →
\url{https://www.ctan.org/pkg/chemobabel}\par
%<en>Distributed with \TeX\ Live and MiK\TeX.
%<en>Below is a short description for CTAN:\par
%<ja>\TeX\ LiveやMiK\TeX でも配布されています。
%<ja>以下はCTANの短い紹介文です。\par
\begin{screen}
This package provides a way to convert and include
chemical structure graphics from various chemical formats,
such as ChemDraw files, MDL molfile or SMILES notations
using Open Babel.
To use this \LaTeX\ package, it is necessary to enable execution
of the following external commands via \Lcode{latex -shell-escape}.
\begin{itemize}
\item \Lcode{obabel} (Open Babel)
\item \Lcode{inkscape} or \Lcode{rsvg-convert}
(for SVG -> PDF/EPS conversion)
\item \Lcode{pdfcrop} or \Lcode{ps2eps}
(optional; for cropping large margins of PDF/EPS)
\end{itemize}
\end{screen}
\end{figure}
\clearpage
\setcounter{tocdepth}{3}
\tableofcontents
\clearpage
\pagenumbering{arabic}
%<*en>
\section{Introduction}
%</en>
%<*ja>
\section{はじめに}
%</ja>
%<*en>
\subsection{Motivation for Development}
%</en>
%<*ja>
\subsection{開発の動機}
%</ja>
%<*en>
As you already know, \LaTeX\ is being used all over the world.
However, when it comes to drawing chemical strucutral formulas,
ways of inserting formulas into \LaTeX\ documents are very limited.
I think it is mainly due to lack of both reliable and simple methods
of doing this that many of the researchers in chemistry are reluctant
to use \LaTeX\ system.
%</en>
%<*ja>
ご存じのとおり,\LaTeX は世界中で使われています。
しかし,化学構造式を描くという点で考えると,
\LaTeX 文書中に構造式を挿入する手段は非常に限られています。
この目的を達成する確実かつ容易な方法が存在しないことは,化学分野における
多くの研究者が\LaTeX システムを使わない要因になっていると考えられます。
%</ja>
%<*en>
Some \TeX/\LaTeX\ macros and packages are already available from
\href{http://www.ctan.org/}{CTAN}:
\begin{itemize}
\item \href{http://www.ctan.org/pkg/xymtex}{\XyMTeX}:
a set of packages for drawing chemical structural formulas
\item \href{http://www.ctan.org/pkg/chemfig}{\Lpack{chemfig}}:
a package which draws molecules using \TikZ
\end{itemize}
These packages are reliable and almost all kinds of structural formulas
can be drawn in a consistent way. However, a lot of practice will be
required before one can come to make full use of them.
%</en>
%<*ja>
すでに\href{http://www.ctan.org/}{CTAN}からいくつかのパッケージが利用可能です:
\begin{itemize}
\item \href{http://www.ctan.org/pkg/xymtex}{\XyMTeX}:
化学構造式を描くためのパッケージ集
\item \href{http://www.ctan.org/pkg/chemfig}{\Lpack{chemfig}}:
\TikZ を利用して構造式を描画するパッケージ
\end{itemize}
これらのパッケージは確実で,あらゆる構造式を一貫性をもって描画することができます。
しかし,十分にその機能を活用できるようになるには相当の熟練を要します。
%</ja>
%<*en>
You can also insert structural formulas with \verb|\includegraphics| of
PDF or EPS files exported from special softwares for chemists, such as
\href{http://www.cambridgesoft.com/Ensemble_for_Chemistry/ChemDraw/}{ChemDraw}
and other similar programs.
In this case, you have to save files in both chemical formats
(such as \verb|.cdx| or \verb|.mol|) and graphical formats
(\verb|.pdf| or \verb|.eps|) manually.
%</en>
%<*ja>
化学者向けの専用ツール
(\href{http://www.cambridgesoft.com/Ensemble_for_Chemistry/ChemDraw/}{ChemDraw}など)
でPDFやEPS形式で出力し,\verb|\includegraphics|によって
構造式を取り込むという手段もあります。
この場合,化学用のフォーマット(\verb|.cdx| や \verb|.mol| など)と
画像フォーマット(\verb|.pdf| や \verb|.eps| など)の両方で保存する必要があります。
%</ja>
%<*en>
This new package, \Lpack{chemobabel.sty}, will offer a new choice for
chemists who need chemical structures inserted in their \LaTeX\ documents.
In this method, we use \href{http://openbabel.org/}{Open Babel} for
generating chemical structural formulas in SVG format,
and \href{https://inkscape.org/en/}{Inkscape} for converting SVG to PDF/EPS.
Both programs are open source and cross-platform, and being actively maintained.
%</en>
%<*ja>
新しいパッケージ \Lpack{chemobabel.sty} は,\LaTeX 文書中に化学構造式を
挿入する必要がある化学者に新たな選択肢を提供することでしょう。
この方法では,\href{http://openbabel.org/}{Open Babel}によって
SVG形式の構造式画像を生成し,
さらに\href{https://inkscape.org/ja/}{Inkscape}によってSVGから
PDFまたはEPS形式の画像に変換します。
どちらのプログラムもオープンソースかつクロスプラットフォームであり,
盛んに開発が行われています。
%</ja>
%<*en>
\paragraph{About Open Babel}
Open Babel is a toolbox specially designed to handle many kinds of
chemical data. It is an open, collaborative project allowing anyone to search,
convert, analyze, or store data from molecular modeling, chemistry,
solid-state materials, biochemistry, or related areas.
See \href{http://openbabel.org/}{Official Website} for detail.
%</en>
%<*ja>
\paragraph{Open Babelについて}
Open Babelはさまざまな化学データを扱うために特別に設計されたツールです。
オープンな共同プロジェクトで,分子モデリング・化学・固体物性・生化学や
関連分野のデータを誰もが検索・変換・分析・保存できることを目指しています。
詳細は\href{http://openbabel.org/}{公式サイト}を参照してください。
%</ja>
\clearpage
%<*en>
\subsection{Idea and Approach}
%</en>
%<*ja>
\subsection{着想とアプローチ}
%</ja>
%<*en>
First I found a post on Noel O'Blog \cite{NOB1}, \cite{NOB2} and
the comment \cite{JLA} about generating chemical structural formulas
from SMILES notations using Open Babel.
I thought the method described in these posts were very interesting,
but I didn't like all the programs could be executed by
\verb|-shell-escape| option.
At the same time, I encountered a macro for copying all
\verb|\includegraphics| from one source file to another \cite{OKU},
which made me conceive of an idea of extracting minimal source code
which needs \verb|-shell-escape| option.
I thought this method would be applicable to converting ChemDraw files into
graphics, but I could not find any project attempting to realize this idea.
I found a project named
\href{http://chemdrawinlatex.sourceforge.net/}{Chemdraw in \LaTeX}
on Sourceforge, but now it was closed.
This drove me to develop a new package to simplify the process for
inserting chemical structural formulas into \LaTeX\ documents.
%</en>
%<*ja>
最初にOpen Babelを用いてSMILES表記から化学構造式を生成するという
Noel O'Blog の記事\cite{NOB1}, \cite{NOB2}とコメント\cite{JLA}を見つけました。
これらの投稿に示された手法は非常におもしろいと思いましたが,
すべてのプログラムが \verb|-shell-escape| オプションによって実行されて
しまうことがあまり好きではありませんでした。
それと同じころ,あるソース中の \verb|\includegraphics| を
別のソースに書き出すというマクロ\cite{OKU}を偶然みつけ,
このとき私は \verb|-shell-escape| が必要な最小のコードだけを抽出する
という着想を得ました。
この方法はChemDrawファイルを画像に変換する目的にも応用できると考えたのですが,
この発想を実現したプロジェクトが見当たらず,ただ一つ見つけたSourceforgeの
\href{http://chemdrawinlatex.sourceforge.net/}{Chemdraw in \LaTeX}は
すでに終了していました。そこで,化学構造式を\LaTeX 文書中に挿入する手順を
簡略化するパッケージを開発しようと考えました。
%</ja>
\clearpage
%<*en>
\section{Before you begin}
%</en>
%<*ja>
\section{パッケージを使う前に}
%</ja>
%<*en>
\subsection{Installing dependent softwares}
%</en>
%<*ja>
\subsection{依存ソフトウェアのインストール}
%</ja>
%<*en>
First, you have to install \href{http://openbabel.org/}{Open Babel} and
\href{https://inkscape.org/en/}{Inkscape}
(or \href{http://librsvg.sourceforge.net/download/}{librsvg}) on your
computer, and export PATH to the required command-line programs,
\Lcode{obabel} and \Lcode{inkscape} (or \Lcode{rsvg-convert}).
The package also uses \Lcode{pdfcrop} (or \Lcode{ps2eps}) to
crop large margins, but it is included in \TeX\ Live.
You can confirm by executing following commands:
%</en>
%<*ja>
初めにコンピュータに\href{http://openbabel.org/}{Open Babel}と
\href{https://inkscape.org/ja/}{Inkscape}(または
\href{http://librsvg.sourceforge.net/download/}{librsvg})をインストールし,
必要なコマンドラインプログラムである
\Lcode{obabel}と\Lcode{inkscape}(または\Lcode{rsvg-convert})に
PATHを通します。
なお,生成画像の大きな余白を切り取るために\Lcode{pdfcrop}(または
\Lcode{ps2eps})も利用しますが,これは\TeX\ Liveに収録されています。
正しくPATHが通っているかどうかは以下のコマンドによって確認できます:
%</ja>
%<en>In UNIX operating system:
%<ja>UNIX系の場合:
\begin{verbatim}
$ which obabel
$ which inkscape (if you choose inkscape)
$ which rsvg-convert (if you choose librsvg)
\end{verbatim}
%<en>In Windows operating system:
%<ja>Windowsの場合:
\begin{verbatim}
> where obabel
> where inkscape (if you choose inkscape)
> where rsvg-convert (if you choose librsvg)
\end{verbatim}
%<*en>
And when you get some command echo, installation should be successful.
%</en>
%<*ja>
何らかのディレクトリ名が返ってきた場合は,正しくインストールできているはずです。
%</ja>
%<*en>
\subsection{Loading the package}
%</en>
%<*ja>
\subsection{パッケージの読み込み}
%</ja>
%<*en>
In the preamble of your document, declare
\begin{verbatim}
\usepackage{chemobabel}
\end{verbatim}
to load \Lpack{chemobabel} package.
The package depends on \Lpack{graphicx}.
%</en>
%<*ja>
プリアンブルに
\begin{verbatim}
\usepackage{chemobabel}
\end{verbatim}
と宣言して\Lpack{chemobabel}パッケージを読み込みます。
これは\Lpack{graphicx}パッケージに依存しますので,
もし(u)p\LaTeX を使っていてDVIドライバに\Lcode{dvipdfmx}を使用する場合は
ドライバオプション \verb+[dvipdfmx]+ をクラスオプション(グローバル)に
付けるのを忘れないようにしてください。
%</ja>
\clearpage
%<*en>
\section{Basic Usage}
%</en>
%<*ja>
\section{基本的な使い方}
%</ja>
\label{basic}
%<*en>
\subsection{Conversion from Chemical Structure Data Files}
%</en>
%<*ja>
\subsection{化学構造式ファイルからの変換}
%</ja>
%<*en>
Suppose you have \verb|ATP.cdx|, a file with chemical structural formula
of ATP (Adenosine triphosphate) drawn in ChemDraw, and
\verb|Brevetoxin A.mol|, a MDL Molfile which can be obtained from
\href{http://www.chemspider.com/}{ChemSpider} (originally \verb|9041092.mol|).
Use \verb|\chemobabel| command as follows. I put original files in a
subdirectory \Lcode{draw}, so added \Lcode{draw/} before the actual filename.
Of course you can put in the same directory with your \LaTeX\ file.
%</en>
%<*ja>
\verb|ATP.cdx| はATP(アデノシン三リン酸)の構造式を
ChemDrawで描画したファイル,\verb|Brevetoxin A.mol| は
\href{http://www.chemspider.com/}{ChemSpider}から入手できるファイルです
(もとのファイル名は \verb|9041092.mol| となっています)。
\verb|\chemobabel| コマンドは本文中で以下のようにして使います。
ここでは元のファイルを\Lcode{draw}というサブディレクトリに置いたので,
ファイル名の前に \Lcode{draw/} を付けました。
もちろん \LaTeX ソースと同一ディレクトリに置くこともできます。
%</ja>
\begin{verbatim}
\chemobabel[width=90mm]{draw/ATP.cdx}{}
\chemobabel*[width=120mm]{draw/Brevetoxin A.mol}
\end{verbatim}
%<*en>
Then, typeset with \verb|-shell-escape| option.
Remember to use this option, otherwise it won't allow \LaTeX\ to
call any external command-line programs, such as obabel and inkscape!
\begin{verbatim}
$ pdflatex -shell-escape test.tex
\end{verbatim}
You will see in \verb|chemobabelimgdir| subdirectory ``chemobabelimg[NUM].pdf'',
and output file test.pdf will be Figure~\ref{fig:chem1}:
%</en>
%<*ja>
\LaTeX ファイル名がtest.texだとすると,以下のように
\verb|-shell-escape| オプションを与えてタイプセットします。
このオプションを与えることで,\LaTeX が外部プログラムである
obabelやinkscapeを呼んで実行できるようになります。
\begin{verbatim}
$ platex -shell-escape test.tex
\end{verbatim}
するとサブディレクトリ \verb|chemobabelimgdir| 以下に
「chemobabelimg[NUM].pdf」というファイルが生成します。
得られたtest.dviに対して
\begin{verbatim}
$ dvipdfmx test.dvi
\end{verbatim}
と実行すると,出力される「test.pdf」は図\ref{fig:chem1}のようになります。
%</ja>
\begin{figure}[h]
\centering
\chemobabel[width=90mm]{draw/ATP.cdx}{} \\ \vspace{1cm}
\chemobabel*[width=120mm]{draw/Brevetoxin A.mol}
\caption{Conversion from ATP.cdx and Brevetoxin A.mol}\label{fig:chem1}
\end{figure}
%<en>The syntax is:
%<ja>構文は以下のとおりです。
\begin{center}
\verb|\chemobabel[|\Lmeta{options}\verb|]{|\Lmeta{filename}\verb|}{|\Lmeta{obabel options}\verb|}| \\
\verb|\chemobabel*[|\Lmeta{options}\verb|]{|\Lmeta{filename}\verb|}|
\end{center}
%<*en>
\verb|\chemobabel| takes one optional parameter and two mandatory parameters.
\begin{itemize}
\item The optional parameter \Lmeta{options} in the box brackets
is passed to \verb|\includegraphics|.
If omitted, the default ``clip,scale=1' is assumed.
\item The first mandatory parameter \Lmeta{filename} is the file name
which contains chemical structural formula.
\item The second mandatory parameter \Lmeta{obabel options}
is passed to \verb|obabel| command
(see Section \ref{depict} for some examples).
\end{itemize}
If you want to leave the second parameter empty,
a shorthand form \verb|\chemobabel*| is also available
(since \Lver{v0.9k [2022/10/09]}).
%</en>
%<*ja>
\verb|\chemobabel| は1つのオプション引数と2つの必須引数をとります。
\begin{itemize}
\item 角括弧内のオプション引数は \verb|\includegraphics| に渡されます。
省略された場合は \verb|clip,scale=1| とみなされます。
\item 必須引数の1つめには化学構造式が描かれたファイル名を与えます。
\item 必須引数の2つめには \verb|obabel| に送るオプション
(例は第\ref{depict}節を参照)を指定します。
\end{itemize}
必須引数の2つめを空にしたい場合は,
短縮形として \verb|\chemobabel*| を使用することもできます
(\Lver{v0.9k [2022/10/09]}以降)。
%</ja>
%<*en>
\subsection{Conversion from SMILES Notations}
%</en>
%<*ja>
\subsection{SMILES表記法からの変換}
%</ja>
%<*en>
You can also write SMILES notations directly in your \LaTeX\ file to be
converted into structural formulas.
For example, \verb|CCO| is the SMILES notation of ethanol, and
\verb|CC(=O)Nc1ccc(cc1)O| is that of acetaminophen (paracetamol).
Use \verb|\smilesobabel| command as follows:
%</en>
%<*ja>
\LaTeX ソースファイル中に直接SMILES表記を書き込んで,
構造式に変換することもできます。
例えば,\verb|CCO| はエタノールのSMILES表記,
\verb|CC(=O)Nc1ccc(cc1)O| はアセトアミノフェンのSMILES表記です。
\verb|\smilesobabel| コマンドを以下のようにして使います:
%</ja>
\begin{verbatim}
\smilesobabel{CCO}{}
\smilesobabel*[width=25mm]{CC(=O)Nc1ccc(cc1)O}
\end{verbatim}
%<*en>
Again typeset with \verb|-shell-escape| option:
\begin{verbatim}
$ pdflatex -shell-escape test.tex
\end{verbatim}
This time you will get ``smilesobabelimg[NUM].pdf'' and ``test.pdf''
as Figure~\ref{fig:smi1}.
%</en>
%<*ja>
やはり \verb|-shell-escape| オプションを付けてタイプセットします。
\begin{verbatim}
$ platex -shell-escape test.tex
$ dvipdfmx test.dvi
\end{verbatim}
すると今度は「smilesobabelimg[NUM].pdf」のようなファイルが生成し,
出力される「test.pdf」は図\ref{fig:smi1}のようになります。
%</ja>
\begin{figure}[h]
\centering
\smilesobabel{CCO}{} \quad
\smilesobabel*[width=25mm]{CC(=O)Nc1ccc(cc1)O}
\caption{Conversion from SMILES notation}\label{fig:smi1}
\end{figure}
%<en>The syntax is:
%<ja>構文は以下のとおりです。
\begin{center}
\verb|\smilesobabel[|\Lmeta{options}\verb|]{|\Lmeta{SMILES notation}\verb|}{|\Lmeta{obabel options}\verb|}| \\
\verb|\smilesobabel*[|\Lmeta{options}\verb|]{|\Lmeta{SMILES notation}\verb|}|
\end{center}
%<*en>
The only difference from \verb|\chemobabel| is that
\Lmeta{SMILES notation} should be placed in the first braces.
You can put any kinds of SMILES notations in parameters of
\verb|\smilesobabel|, even when they contain some special characters
such as a backslash (\verb|\|) and a percent symbol (\verb|%|).
Similarly, parameters of \verb|\chemobabel| can also contain
these special characters.
%</en>
%<*ja>
\verb|\chemobabel| との唯一の違いは,中括弧の1つめにSMILES表記法の
テキストを与えることだけです。
\verb|\smilesobabel| の引数としては,任意のSMILES表記を用いることができます
(バックスラッシュ (\verb|\|) やパーセント記号 (\verb|%|) のような
特別な文字が入っていてもかまいません)。
なお,\verb|\chemobabel| の引数についても同様に,
特別な文字を含むことができる設計になっています。
%</ja>
\begin{verbatim}
\smilesobabel*[width=28mm]{Cl/C=C/Br}
\smilesobabel*[width=28mm]{Cl/C=C\Br}
\end{verbatim}
\begin{figure}[h]
\centering
\smilesobabel*[width=28mm]{Cl/C=C/Br} \quad
\smilesobabel*[width=28mm]{Cl/C=C\Br}
\end{figure}
%<*en>
\noindent \textbf{Notes for users of earlier versions \Lver{v0.6 [2015/06/29]} or older}
In earlier versions of \Lpack{chemobabel}, it was necessary for users
to pay another attention when using these \LaTeX\ special characters.
However, the workaround I had suggested before was far from desirable
because ``casual \LaTeX\ users'' were forced to change category codes
of these characters manually.
To solve this problem, I improved the internal macros since \Lver{v0.7 [2015/08/26]}.
Now you can put any kinds of SMILES notations directly without worrying
about special characters (\verb|\|, \verb|%|, etc).
Note that the undesirable workaround (like changing \verb|\catcode| inside
\verb|\begingroup| ... \verb|\endgroup|) has now become rather harmful.
%</en>
%<*ja>
\noindent \textbf{\Lver{v0.6 [2015/06/29]}以前の旧バージョンのユーザに対する注意}
古いバージョンの\Lpack{chemobabel}では,
これらの\LaTeX で特別な意味を持つ文字に注意を払う必要がありました。
従来私が紹介してきた回避策は“カジュアルな \LaTeX ユーザ”に
カテゴリーコードを手動で変更させていたため,好ましいものではありませんでした。
この問題を解決するため,\Lver{v0.7 [2015/08/26]}以降では
パッケージ本体の側でこれらの文字をサポートするように改良を施しました。
これにより,\verb|\| や \verb|%| といった特別な文字を心配することなく,
任意のSMILES表記を直接引数に渡すことができるようになっています。
従来の回避策(\verb|\begingroup| ... \verb|\endgroup| 内で \verb|\catcode| を
変更する方法)は今ではむしろ有害になっていますので,注意してください。
%</ja>
\clearpage
%<*en>
\subsection{Package options}
%</en>
%<*ja>
\subsection{パッケージオプション}
%</ja>
%<*en>
By default, \Lpack{chemobabel} converts chemical structures into
PDF images using Inkscape. However, you can switch the image format
and the conversion program if you like.
When you are using drivers which do not support PDF figures (such as dvips),
it will be helpful if \Lpack{chemobabel} converts them into EPS images.
For this purpose, you can use:
%</en>
%<*ja>
\Lpack{chemobabel} パッケージは,デフォルトでは化学構造式をInkscapeによって
PDF形式の画像ファイルに変換して文書中に取り込みます。
しかし,オプションで画像形式と変換プログラムを変更することができます。
dvipsなどのPDF非対応のドライバを使用する場合は,EPS形式の画像ファイルに
変換したほうが便利でしょう。この場合
%</ja>
\begin{verbatim}
\usepackage[eps]{chemobabel}
\end{verbatim}
%<*en>
The option \verb|eps| switches the image format
(that is, output format from Inkscape) into EPS (since
\Lver{v0.9d [2016/02/28]}).\footnote{Moreover, since
\Lver{v0.9l [2022/10/22]}, the package automatically switches to
EPS mode when using dvips.}
You can also change the image conversion program from ``Inkscape'' to
``rsvg-convert'' (since \Lver{v0.9e [2016/03/07]}).
The program rsvg-convert is faster than inkscape, so it will be useful.
For this purpose, use \verb|librsvg| option:
%</en>
%<*ja>
というように \verb|eps| オプションを指定すれば,内部でInkscapeから出力される
画像形式をPDFではなくEPSに変更します(\Lver{v0.9d [2016/02/28]}以降)
\footnote{\Lver{v0.9l [2022/10/22]}以降ではさらに,dvipsの場合に
自動的にEPSに切り替えるようにしました。}。
また,画像変換プログラムを Inkscape から rsvg-convert に変更することもできます
(\Lver{v0.9e [2016/03/07]}以降)。
rsvg-convertはInkscapeより高速ですから,便利かもしれません。
この場合は,以下のように \verb|librsvg| オプションを指定します。
%</ja>
\begin{verbatim}
\usepackage[librsvg]{chemobabel}
\end{verbatim}
%<*en>
The default behavior is equivalent to the \verb|pdf| and \verb|inkscape| options:
%</en>
%<*ja>
デフォルトは \verb|pdf| オプションと \verb|inkscape| オプションを
指定した場合と等価です。
%</ja>
\begin{verbatim}
\usepackage[pdf,inkscape]{chemobabel}
\end{verbatim}
%<*en>
Moreover, Open Babel v2.4.0 or later versions generate images with
a rather large margin. To avoid this, the images are cropped
using \verb|pdfcrop| for PDF or \verb|ps2eps| for EPS
(since \Lver{v0.9i [2022/09/12]}).
If you want to disable this cropping, please add \verb|nocrop| option:
%</en>
%<*ja>
さらに,Open Babel v2.4.0以降で生成される画像はデフォルトで余白が大きいため,
\verb|pdfcrop|(PDFの場合)あるいは\verb|ps2eps|(EPSの場合)で
クロップしています(\Lver{v0.9i [2022/09/12]}以降)。
これをやめたい場合は \verb|nocrop| オプションを指定してください。
%</ja>
\begin{verbatim}
\usepackage[nocrop]{chemobabel}
\end{verbatim}
\clearpage
%<*en>
\subsection{For Safer Typesetting...}
%</en>
%<*ja>
\subsection{安全なタイプセットのために}
%</ja>
\label{extract}
%<*en>
With the basic method described in Section \ref{basic},
you will get desired output in almost any situation.
However, it is sometimes NOT desirable to use \verb|-shell-escape| option,
because with that option \LaTeX\ can call \emph{any} external command-line
programs whether you like it or not.
This means that there is a chance for unknown programs to be executed,
and this can be dangerous especially in case that you don't write your
own \LaTeX\ code. To avoid this problem, I provide a workaround for
extracting all \verb|\chemobabel| and \verb|\smilesobabel| commands
to another \LaTeX\ file (Reference: \TeX\ Forum \cite{OKU}).
All you have to do is to add \verb|extract| option when loading the package:
%</en>
%<*ja>
第\ref{basic}節で述べた基本的な使い方で,ほとんどの場合問題ないでしょう。
しかし,\verb|-shell-escape| オプションを付けてタイプセットするため,
好むと好まざるとにかかわらず\LaTeX が\emph{どんな外部コマンドでも}実行
できてしまいます。つまり,知らないうちにプログラムが実行されてしまう可能性を示唆
しており,これはとりわけ自分で書いた\LaTeX ソースでない場合には危険を伴います。
この問題を回避するために,\verb|\chemobabel| と \verb|\smilesobabel| コマンド
だけを別の \LaTeX ファイルに抽出するマクロを用意しています
(参考:\TeX\ Forum \cite{OKU})。
この場合は,パッケージを読み込む際に \verb|extract| オプションを付与してください。
%</ja>
\begin{verbatim}
\usepackage[extract]{chemobabel}
\end{verbatim}
%<*en>
When typesetting, usual command
\begin{verbatim}
$ pdflatex test.tex
\end{verbatim}
can be used.
With \verb|extract| option, all \Lpack{chemobabel} does is extracting
all \verb|\chemobabel| and \verb|\smilesobabel| commands from the
original \LaTeX\ file.
You will get ``ChemFigFile.tex'' in the current directory, a minimal
\LaTeX\ source file which includes all \verb|\chemobabel| and
\verb|\smilesobabel| commands.
You can simply typeset it by
%</en>
%<*ja>
タイプセットの際には通常の
\begin{verbatim}
$ platex test.tex
\end{verbatim}
というコマンドを使います。
\verb|extract| オプションを付けると,\Lpack{chemobabel}パッケージは
単に元の\LaTeX ソースから \verb|\chemobabel| と \verb|\smilesobabel| コマンド
だけを抽出するはたらきをします。
その結果,作業ディレクトリに「ChemFigFile.tex」というファイルが生成します。
これは元のソースに書かれていた \verb|\chemobabel| と \verb|\smilesobabel| コマンド
をすべて含む最小の \LaTeX ソースで,これは直接pdflatexでタイプセットできます。
%</ja>
\begin{verbatim}
$ pdflatex -shell-escape ChemFigFile.tex
\end{verbatim}
%<*ja>
欧文と同じ仕様に統一したため,抽出される「ChemFigFile.tex」では
\Lpack{graphicx}パッケージに \verb+[dvipdfmx]+ オプション
を与えずに読み込んでいます。したがって,
このタイプセットだけは\Lcode{pdflatex}を用いてください。
%</ja>
%<*en>
and you will get PDF figures in the same way
as described in Section \ref{basic}.
After this, typeset your own document again
(this time you should remove \verb|extract| option):
\begin{verbatim}
$ pdflatex test.tex
\end{verbatim}
This time you will get desired output ``test.pdf''
which includes figures properly.
This method will also save you a lot of time for typesetting.
%</en>
%<*ja>
すると,第\ref{basic}節と同様にPDF形式の図のファイルが生成しますので,
あとは \verb|extract| オプションを除去して再度
\begin{verbatim}
$ platex test.tex
$ dvipdfmx test.dvi
\end{verbatim}
と実行すれば,適切に図を取り込んだ望みどおりの「test.pdf」が得られます。
この方法を用いれば,タイプセットに要する時間を大幅に短縮することも期待できます。
%</ja>
%<*en>
\paragraph{Note on the option \Lcode{-output-directory}}
When using the option \Lcode{-output-directory} of \TeX,
the extracted code ``ChemFigFile.tex'' goes there
but the subdirectory \verb|chemobabelimgdir| and
generated images stay in the current working directory.
To process the resulting files correctly, it would be
necessary to move files properly.
%</en>
%<*ja>
\paragraph{注意:\Lcode{-output-directory}オプション}
\TeX の\Lcode{-output-directory}オプションを使用すると,
抽出ファイル「ChemFigFile.tex」はその指定先に書き出されますが,
サブディレクトリ \verb|chemobabelimgdir| と生成画像は
現在のディレクトリとなります。
従って,抽出ファイルと元のファイルを正しく処理するためには
ファイルを適切に配置する必要があります。
%</ja>
\clearpage
%<*en>
\section{Advanced Usage}
%</en>
%<*ja>
\section{高度な使い方}
%</ja>
%<*en>
\subsection{Options for Depiction}
%</en>
%<*ja>
\subsection{描画オプション}
%</ja>
\label{depict}
%<*en>
As I have already mentioned, in both \verb|\chemobabel| and \verb|\smilesobabel|,
you can give some \Lmeta{obabel options} in the second braces.
Here I will introduce some examples.
%</en>
%<*ja>
既に述べたとおり,\verb|\chemobabel| と \verb|\smilesobabel| の両方について,
2つめの中括弧に \Lmeta{obabel options} を与えることができます。
ここで,いくつかの有用な例を挙げておきます。
%</ja>
\begin{itemize}
\item
\begin{verbatim}
\smilesobabel{CC(=O)Nc1ccc(cc1)O}{-xa}
\end{verbatim}
%<en>executes a command which gives a formula with all carbon atoms shown:
%<ja>構造式中の全ての炭素原子を省略せずに描画するコマンドを実行します:
\begin{verbatim}
$ obabel -:"CC(=O)Nc1ccc(cc1)O" -O smilesobabelimg[NUM].svg -xa
\end{verbatim}
\item
\begin{verbatim}
\smilesobabel{CC(=O)Nc1ccc(cc1)O}{-xu -xC}
\end{verbatim}
%<en>gives one without element-specific atom coloring or terminal carbon atoms:
%<ja>元素の着色を行わず,末端の炭素原子を明示しない構造式を出力します:
\begin{verbatim}
$ obabel -:"CC(=O)Nc1ccc(cc1)O" -O smilesobabelimg[NUM].svg -xu -xC
\end{verbatim}
\item
\begin{verbatim}
\chemobabel{ATP.cdx}{-xd}
\end{verbatim}
%<en>You can add \Lcode{-xd} option to remove filenames from ChemDraw figures with Open Babel 2.x.
%<ja>Open Babel 2.x系列でChemDrawの図からファイル名を取り除くには,\Lcode{-xd} オプションを付けます:
\begin{verbatim}
$ obabel -:"ATP.cdx" -O chemobabelimg[NUM].svg -xd
\end{verbatim}
\end{itemize}
\begin{figure}[ht]
\centering
\smilesobabel[width=21mm]{CC(=O)Nc1ccc(cc1)O}{} \hspace{1cm}
\smilesobabel[width=25mm]{CC(=O)Nc1ccc(cc1)O}{-xa} \hspace{1cm}
\smilesobabel[width=21mm]{CC(=O)Nc1ccc(cc1)O}{-xu}
\caption{Acetaminophen (Paracetamol): Nothing, \Lcode{-xa}, \Lcode{-xu}}
SMILES: \verb|CC(=O)Nc1ccc(cc1)O|
\end{figure}
\begin{figure}[ht]
\centering
\smilesobabel[width=25mm]{C1[C@H](C)C[C@@H](O)C1}{} \hspace{1cm}
\smilesobabel[width=25mm]{C1[C@H](C)C[C@@H](O)C1}{-xC} \hspace{1cm}
\smilesobabel[width=25mm]{C1[C@H](C)C[C@@H](O)C1}{-xt}
\caption{(1\textit{S},3\textit{S})-3-Methylcyclopentanol: Nothing, \Lcode{-xC}, \Lcode{-xt}}
SMILES: \verb|C1[C@H](C)C[C@@H](O)C1|
\end{figure}
\begin{figure}[ht]
\centering
\smilesobabel[width=42mm]{CCc1cccc(c1)C(=O)Cl}{} \hspace{1cm}
\smilesobabel[width=42mm]{CCc1cccc(c1)C(=O)Cl}{-xa -xu} \hspace{1cm}
\smilesobabel[width=42mm]{CCc1cccc(c1)C(=O)Cl}{-xu -xC}
\caption{3-Ethylbenzoyl chloride: Nothing, \Lcode{-xa -xu}, \Lcode{-xu -xC}}
SMILES: \verb|CCc1cccc(c1)C(=O)Cl|
\end{figure}
\begin{figure}[ht]
\centering
\smilesobabel[width=42mm]{CCc1cccc(c1)C(=O)Cl}{--highlight "cC=O blue"} \hspace{1cm}
\smilesobabel[width=42mm]{CCc1cccc(c1)C(=O)Cl}{-xA --genalias}
\caption{3-Ethylbenzoyl chloride: \Lcode{--highlight "cC=O blue"}, \Lcode{-xA --genalias}}
SMILES: \verb|CCc1cccc(c1)C(=O)Cl|
\end{figure}
\begin{figure}[ht]
\centering
\chemobabel[width=65mm]{draw/Firefly luciferin.mol}{} \hspace{1cm}
\chemobabel[width=65mm]{draw/Firefly luciferin.mol}{-xa}
\caption{Firefly luciferin (from MDL Molfiles): Nothing, \Lcode{-xa}}
\end{figure}
\begin{figure}[ht]
\centering
\chemobabel[width=70mm]{draw/ATP.cdx}{} \hspace{1cm}
\chemobabel[width=70mm]{draw/ATP.cdx}{-xd}
\caption{ATP (from ChemDraw files): Nothing, \Lcode{-xd}}
\end{figure}
\begin{figure}[ht]
%<*en>
For more details, see
\href{http://openbabel.org/docs/dev/Command-line_tools/babel.html}{obabel and babel}
and
\href{http://openbabel.org/docs/dev/FileFormats/SVG_2D_depiction.html}{SVG depiction (svg)}
in Open Babel documentation.
%</en>
%<*ja>
より詳細にはOpen Babel documentationの
\href{http://openbabel.org/docs/dev/Command-line_tools/babel.html}{obabel and babel}または
\href{http://openbabel.org/docs/dev/FileFormats/SVG_2D_depiction.html}{SVG depiction (svg)}を
参照してください。
%</ja>
\end{figure}
\clearpage
%<*en>
\subsection{More complex structural formulas}
%</en>
%<*ja>
\subsection{より複雑な構造式}
%</ja>
%<*en>
Open Babel can generate more complex structural formulas from SMILES notations.
%</en>
%<*ja>
Open BabelはSMILES表記から複雑な構造式を生成することができます。
%</ja>
\begin{figure}[ht]
\centering
\smilesobabel*[width=55mm]{CN1CC[C@]23c4c5ccc(c4O[C@H]2[C@H](C=C[C@H]3[C@H]1C5)O)O}
\caption{($-$)-Morphine}
SMILES: \verb|CN1CC[C@]23c4c5ccc(c4O[C@H]2[C@H](C=C[C@H]3[C@H]1C5)O)O|
\end{figure}
\begin{figure}[ht]
\centering
\smilesobabel*[width=150mm]{C[C@@H]1C[C@H]2[C@@H](CC(=O)O2)O[C@H]3C[C@@H]4[C@H](C[C@@H]([C@@H]5[C@@H](O4)C/C=C\C[C@@H]6[C@@H](O5)C/C=C\[C@@H]7[C@@H](O6)CCC[C@@H]8[C@@](O7)(C[C@@H]9[C@@H](O8)C[C@@H]2[C@@H](O9)[C@H](C[C@H](O2)CC(=C)C=O)O)C)C)O[C@@]3(C1)C}
\caption{Brevetoxin A}
SMILES (Sorry but too long): \verb|C[C@@H]1C[C@H]2[C@@H](CC(=O)O2)O[C@H]3C[C@@H]4[C@H](C[C@@H]([C@@H]5[C@@H](O4)C/C=C\C[C@@H]6[C@@H](O5)C/C=C\[C@@H]7[C@@H](O6)CCC[C@@H]8[C@@](O7)(C[C@@H]9[C@@H](O8)C[C@@H]2[C@@H](O9)[C@H](C[C@H](O2)CC(=C)C=O)O)C)C)O[C@@]3(C1)C|
\end{figure}
%<*en>
However, the results are sometimes undesirable and may also be
different depending on version numbers.
Here are some examples:
%</en>
%<*ja>
しかし,時には結果が望ましくないことがあり,
また使用するバージョン番号によって出力が異なることがあります。
いくつかの例を示します:
%</ja>