-
Notifications
You must be signed in to change notification settings - Fork 95
/
Makefile
152 lines (122 loc) · 5.43 KB
/
Makefile
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
# Makefile for Sphinx documentation
#
# You can set these variables from the command line.
SPHINXOPTS =
SPHINXBUILD = sphinx-build
PAPER =
BUILDDIR = build
NTBOOK = $(shell ls scientific_python/*.ipynb statistics/*.ipynb machine_learning/*.ipynb optimization/*.ipynb deep_learning/*.ipynb)
# Notebook to execute. Exclude DL file (requires GPU)
NTBOOK_TO_EXE = $(shell ls scientific_python/*.ipynb statistics/*.ipynb machine_learning/*.ipynb optimization/*.ipynb)
#NTBOOK = $(shell ls statistics/*.ipynb)
NTBOOK_FILES = $(NTBOOK:.ipynb=_files)
#SRC = $(shell ls python/*.py)
RST = $(NTBOOK:.ipynb=.rst) $(SRC:.py=.rst)
#$(info $(NTBOOK))
#$(info $(RST))
#$(info $(NTBOOK_FILES))
#$(info $(PYTORST))
# User-friendly check for sphinx-build
ifeq ($(shell which $(SPHINXBUILD) >/dev/null 2>&1; echo $$?), 1)
$(error The '$(SPHINXBUILD)' command was not found. Make sure you have Sphinx installed, then set the SPHINXBUILD environment variable to point to the full path of the '$(SPHINXBUILD)' executable. Alternatively you can add the directory with the executable to your PATH. If you don't have Sphinx installed, grab it from http://sphinx-doc.org/)
endif
# Internal variables.
PAPEROPT_a4 = -D latex_paper_size=a4
PAPEROPT_letter = -D latex_paper_size=letter
ALLSPHINXOPTS = -d $(BUILDDIR)/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) .
# the i18n builder cannot share the environment and doctrees with the others
I18NSPHINXOPTS = $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) .
#$(shell find notebooks -name "*.ipynb" -exec bash -c -exec sh -c 'echo "$${1%.ipynb}.rst"' _ {} \;)
.SUFFIXES: .rst .ipynb .py
.PHONY: help clean html dirhtml singlehtml htmlhelp epub latex latexpdf text changes linkcheck doctest coverage gettext exe
help:
@echo "Please use \`make <target>' where <target> is one of"
@echo " pdf to make LaTeX files and run them through pdflatex"
@echo " html to make standalone HTML files"
@echo " exe to run jupyter notebooks except those in deep_learning that requires GPU."
@echo " clean rm BUILDDIR, auto_gallery, rst files"
@echo " cleanall rm BUILDDIR, auto_gallery, rst files and clear output of notebooks"
@echo " dirhtml to make HTML files named index.html in directories"
@echo " singlehtml to make a single large HTML file"
@echo " epub to make an epub"
@echo " latex to make LaTeX files, you can set PAPER=a4 or PAPER=letter"
@echo " latexpdf to make LaTeX files and run them through pdflatex"
@echo " text to make text files"
@echo " changes to make an overview of all changed/added/deprecated items"
@echo " linkcheck to check all external links for integrity"
@echo " doctest to run all doctests embedded in the documentation (if enabled)"
@echo " coverage to run coverage check of the documentation (if enabled)"
# Rule to convert notebook to rst
#.ipynb.rst:
%.rst : %.ipynb
jupyter nbconvert --to rst $<
mv $@ [email protected]
cat [email protected]|bin/filter_fix_rst.py > $@
rm -f [email protected]
# jupyter nbconvert --to rst --stdout $< | bin/filter_fix_rst.py > $@
# jupyter nbconvert --to rst $< --output $@
debug:
@echo $(RST)
rst: $(RST)
clean:
rm -rf $(BUILDDIR)/*
rm -rf auto_gallery/
rm -f $(RST)
rm -rf $(NTBOOK_FILES)
cleanall:
rm -rf $(BUILDDIR)/*
rm -rf auto_gallery/
rm -f $(RST)
rm -rf $(NTBOOK_FILES)
for nb in $(NTBOOK) ; do jupyter nbconvert --clear-output $$nb; done
exe:
@echo "Execute notebooks"
for nb in $(NTBOOK_TO_EXE) ; do jupyter nbconvert --to notebook --execute $$nb --output $$(basename $$nb); done
# $(EXEIPYNB) $(NTBOOK)
# @echo toto nbconvert --to notebook --execute $< --output $(basename $<)
html: rst
$(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html
@echo
@echo "Build finished. The HTML pages are in $(BUILDDIR)/html."
dirhtml: rst
$(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml
@echo
@echo "Build finished. The HTML pages are in $(BUILDDIR)/dirhtml."
singlehtml: rst
$(SPHINXBUILD) -b singlehtml $(ALLSPHINXOPTS) $(BUILDDIR)/singlehtml
@echo
@echo "Build finished. The HTML page is in $(BUILDDIR)/singlehtml."
docx: rst
$(SPHINXBUILD) -b docx $(ALLSPHINXOPTS) $(BUILDDIR)/docx
@echo
@echo "Build finished. The docx page is in $(BUILDDIR)/docx."
epub: rst
$(SPHINXBUILD) -b epub $(ALLSPHINXOPTS) $(BUILDDIR)/epub
@echo
@echo "Build finished. The epub file is in $(BUILDDIR)/epub."
latex: rst
$(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex
@echo
@echo "Build finished; the LaTeX files are in $(BUILDDIR)/latex."
@echo "Run \`make' in that directory to run these through (pdf)latex" \
"(use \`make latexpdf' here to do that automatically)."
latexpdf: rst
$(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex
@echo "Running LaTeX files through pdflatex..."
$(MAKE) -C $(BUILDDIR)/latex all-pdf
@echo "pdflatex finished; the PDF files are in $(BUILDDIR)/latex."
cp build/latex/StatisticsMachineLearningPython.pdf StatisticsMachineLearningPython.pdf
pdf: latexpdf
text: rst
$(SPHINXBUILD) -b text $(ALLSPHINXOPTS) $(BUILDDIR)/text
@echo
@echo "Build finished. The text files are in $(BUILDDIR)/text."
changes: rst
$(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) $(BUILDDIR)/changes
@echo
@echo "The overview file is in $(BUILDDIR)/changes."
linkcheck: rst
$(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) $(BUILDDIR)/linkcheck
@echo
@echo "Link check complete; look for any errors in the above output " \
"or in $(BUILDDIR)/linkcheck/output.txt."