comparison m-toolbox/m/helper/generateModelTechNote.m @ 0:f0afece42f48

Import.
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Wed, 23 Nov 2011 19:22:13 +0100 (2011-11-23)
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:f0afece42f48
1 function generateModelTechNote(modelname)
2
3 % Header
4 txt = docHeader(modelname);
5
6 % Description and Documentation
7 txt = [txt writeIntroduction(modelname)];
8
9 % Versions
10 txt = [txt writeVersionTable(modelname)];
11
12 % Write each version section
13 txt = [txt writeVersionSections(modelname)];
14
15 % Footer
16 txt = [txt docFooter(modelname)];
17
18 % write file
19 fd = fopen([modelname '.tex'], 'w+');
20 fprintf(fd, strrep(strrep(txt, '\', '\\'), '%', '%%'));
21 fclose(fd);
22
23 % compile
24 % cmd = sprintf('/usr/texbin/pdflatex %s', modelname);
25 % [status, result] = system(cmd)
26
27 edit([modelname '.tex'])
28
29 end
30
31 % Models are documented in html so we need to swap out html tags and
32 % replace them by appropriate LaTeX tags. One replacement per line, please,
33 % and remember to include replacements for closing tags. This is assuming
34 % that all html tags have associated closing tags.
35 function map = tagmap()
36
37 map = {...
38 '<p>', '', ...
39 '</p>', '', ...
40 '<br>', '\newline', ...
41 '<tt>', '$', ...
42 '</tt>', '$', ...
43 };
44
45 end
46
47
48 function txt = docHeader(modelname)
49
50 ename = strrep(modelname, '_', '\_');
51
52
53 txt = sprintf('\\documentclass[11pt]{article}\n');
54 txt = [txt sprintf('\\usepackage{ifpdf}\n')];
55 txt = [txt sprintf('\\ifpdf\n')];
56 txt = [txt sprintf(' \\usepackage[pdftex]{graphicx} %% to include graphics\n')];
57 txt = [txt sprintf(' \\pdfcompresslevel=9 \n')];
58 txt = [txt sprintf(' \\usepackage[pdftex, %% sets up hyperref to use pdftex driver\n')];
59 txt = [txt sprintf(' plainpages=false, %% allows page i and 1 to exist in the same document\n')];
60 txt = [txt sprintf(' breaklinks=true, %% link texts can be broken at the end of line\n')];
61 txt = [txt sprintf(' colorlinks=true,\n')];
62 txt = [txt sprintf(' pdftitle=%s,\n', ename)];
63 txt = [txt sprintf(' pdfauthor=LTPDA\n')];
64 txt = [txt sprintf(' ]{hyperref} \n')];
65 txt = [txt sprintf(' \\usepackage{thumbpdf}\n')];
66 txt = [txt sprintf('\\else \n')];
67 txt = [txt sprintf(' \\usepackage{graphicx} %% to include graphics\n')];
68 txt = [txt sprintf(' \\usepackage{hyperref} %% to simplify the use of \\href\n')];
69 txt = [txt sprintf('\\fi \n')];
70
71 txt = [txt sprintf('\\title{Technical Report of LTPDA built-in model \\texttt{%s}}\n', ename)];
72 txt = [txt sprintf('\\author{LTPDA (%s)}\n', getappdata(0, 'ltpda_version'))];
73
74 txt = [txt sprintf('\\begin{document}\n')];
75 txt = [txt sprintf('\\maketitle\n')];
76
77 end
78
79
80 function txt = docFooter(modelname)
81 txt = sprintf('\\end{document} %% End of %s\n', modelname);
82 end
83
84 function txt = writeVersionSections(modelname)
85
86 versionTable = feval(modelname, 'versionTable');
87 vers = versionTable(1:2:end);
88 fcns = versionTable(2:2:end);
89 Nvers = numel(vers);
90 txt = '';
91 for kk=1:Nvers
92
93 v = vers{kk};
94 vtag = strrep(v, ' ', '');
95 fcn = fcns{kk};
96
97 txt = [txt sprintf('\\clearpage\n\n')];
98 txt = [txt sprintf('\\section{Version `%s''}\n', v)];
99 txt = [txt sprintf('\\label{ref:%s}\n', vtag)];
100
101 txt = [txt sprintf('\n\n')];
102 txt = [txt writeSectionForVersion(modelname, v, fcn)];
103
104 txt = [txt writeSubmodelSectionForVersion(modelname, v)];
105 txt = [txt sprintf('\n\n')];
106
107 end
108
109 txt = [txt sprintf('\n\n')];
110
111
112 end
113
114 function txt = writeSubmodelSectionForVersion(modelname, v)
115
116 ii = feval(modelname, 'info', v);
117
118 ciis = ii.children;
119 txt = '';
120 if numel(ciis) > 0
121
122 label = strrep(sprintf('tab:submodels_%s_%s', modelname, strrep(v, ' ', '')), '_', '');
123 txt = [txt sprintf('\\subsection{Sub-models}\n')];
124 txt = [txt sprintf('Sub-models used in this version are shown in Table \\ref{%s}.\n', label)];
125 txt = [txt sprintf('\\begin{table}[htdp]\n')];
126 txt = [txt sprintf('\\begin{center}\n')];
127 txt = [txt sprintf('\\begin{tabular}{|c|c|p{4cm}|l|} \\hline\n')];
128
129 txt = [txt sprintf('Sub-model & Description \\\\ \\hline\\hline \n')];
130 for kk=1:numel(ciis)
131 cii = ciis(kk);
132 name = strrep(cii.mname, '_', '\_');
133 txt = [txt sprintf('%s & %s \\\\ \\hline\n', name, cii.description)];
134
135 end
136
137 % table footer
138 txt = [txt sprintf('\\end{tabular}\n')];
139 txt = [txt sprintf('\\end{center}\n')];
140 txt = [txt sprintf('\\caption{Sub-models}\n')];
141 txt = [txt sprintf('\\label{%s}\n', label)];
142 txt = [txt sprintf('\\end{table}\n')];
143
144
145 end
146 end
147
148 function txt = writeSectionForVersion(modelname, v, fcn)
149
150 txt = '';
151
152 % Description
153 desc = fcn('description');
154 desc = replaceTags(desc);
155 txt = [txt sprintf('\\subsection{Description}\n')];
156 txt = [txt sprintf('%s\n', desc)];
157 txt = [txt sprintf('\n\n')];
158
159 % Plist for version
160 txt = [txt sprintf('\\subsection{Parameter List}\n')];
161 label = strrep(sprintf('tab:plist_%s_%s', modelname, strrep(v, ' ', '')), '_', '');
162 txt = [txt sprintf('Parameters used in this version are shown in Table \\ref{%s}.\n', label)];
163 pl = feval(modelname, 'plist');
164
165 txt = [txt plistTable(pl, label)];
166
167 txt = [txt sprintf('\n\n')];
168
169 end
170
171 function txt = plistTable(pl, label)
172
173 txt = '';
174 txt = [txt sprintf('\\begin{table}[htdp]\n')];
175 txt = [txt sprintf('\\begin{center}\n')];
176 txt = [txt sprintf('\\begin{tabular}{|c|p{4cm}|p{4cm}|p{4cm}|} \\hline\n')];
177
178 txt = [txt sprintf('Key & Default Value & Options & Description \\\\ \\hline\\hline \n')];
179 for kk=1:pl.nparams
180
181 txt = [txt sprintf('%s & ', pl.params(kk).key)];
182 ptxt = display(pl.params(kk));
183 txt = [txt sprintf('%s & ', strtrim(strrep(ptxt{3}, 'val:', '')))];
184 if numel(pl.params(kk).getOptions) > 1
185 opts = pl.params(kk).getOptions;
186 optlist = sprintf('\\begin{itemize} ');
187 for oo=1:numel(opts)
188 optlist = [optlist sprintf('\\item %s ', utils.helper.val2str(opts{oo}))];
189 end
190 optlist = [optlist sprintf('\\end{itemize}')];
191 txt = [txt sprintf('%s & ', optlist)];
192 else
193 txt = [txt sprintf('\\textit{none} & ')];
194 end
195 desc = char(strrep(pl.params(kk).desc, '\n', '\\newline\\newline'));
196 if isempty(desc)
197 desc = '\textit{no description}';
198 end
199 txt = [txt sprintf('%s ', desc)];
200 txt = [txt sprintf(' \\\\ \\hline \n')];
201
202
203 end
204
205 % table footer
206 txt = [txt sprintf('\\end{tabular}\n')];
207 txt = [txt sprintf('\\end{center}\n')];
208 txt = [txt sprintf('\\caption{Parameter list}\n')];
209 txt = [txt sprintf('\\label{%s}\n', label)];
210 txt = [txt sprintf('\\end{table}\n')];
211
212
213 end
214
215 function txt = writeVersionTable(modelname)
216
217 ename = strrep(modelname, '_', '\_');
218
219 % table header
220 txt = '';
221 txt = [txt sprintf('\\subsection{Versions}\n')];
222 txt = [txt sprintf('\\begin{table}[htdp]\n')];
223 txt = [txt sprintf('\\begin{center}\n')];
224 txt = [txt sprintf('\\begin{tabular}{|c|c|} \\hline\n')];
225
226 versionTable = feval(modelname, 'versionTable');
227 vers = versionTable(1:2:end);
228 fcns = versionTable(2:2:end);
229 Nvers = numel(vers);
230 txt = [txt sprintf('Version & Description \\\\ \\hline\\hline \n')];
231 for kk=1:Nvers
232
233 v = vers{kk};
234 vtag = strrep(v, ' ', '');
235 fcn = fcns{kk};
236
237 txt = [txt sprintf('\\hyperref[ref:%s]{%s} & %s \\\\ \\hline \n', vtag, v, fcn('description'))];
238
239 end
240
241 % table footer
242 txt = [txt sprintf('\\end{tabular}\n')];
243 txt = [txt sprintf('\\end{center}\n')];
244 txt = [txt sprintf('\\caption{Versions for model %s}\n', ename)];
245 txt = [txt sprintf('\\label{versions:\texttt{%s}}\n', modelname)];
246 txt = [txt sprintf('\\end{table}\n')];
247
248 end
249
250 function txt = writeIntroduction(modelname)
251
252 % section
253 txt = sprintf('\\section{Overview}\n');
254
255 % description
256 desc = feval(modelname, 'description');
257 desc = replaceTags(desc);
258 txt = [txt sprintf('\\subsection{Description}\n\n')];
259 txt = [txt sprintf('%s\n\n\n', desc)];
260
261 % Documentation
262 doc = feval(modelname, 'doc');
263 doc = replaceTags(doc);
264 txt = [txt sprintf('\\subsection{Details}\n\n')];
265 txt = [txt sprintf('%s\n\n\n', doc)];
266
267
268 end
269
270 function txt = replaceTags(txt)
271
272 tm = tagmap();
273 tags = tm(1:2:end);
274 reps = tm(2:2:end);
275
276 for kk=1:numel(tags)
277 txt = strrep(txt, tags{kk}, reps{kk});
278 end
279
280 end
281
282
283
284
285
286