-
Notifications
You must be signed in to change notification settings - Fork 938
常见问题
清晰、准确、有效的问题既是你能力的体现,也是对所有人生命时间的尊重和珍惜。否则,则反之。
-
认真确定你的问题 是 关于
LaTeX
的一般知识性问题 还是关于 ucasthesis 编译和设计的问题! -
关于
LaTeX
的一般知识性问题,首先查阅 LaTeX 知识小站、 LaTeX Wikibook 以及 自行网络搜索 寻找解决方案,如仍需发问(再次确定问题的性质以及提问的必要性,否则就是在错误的地方问错误的/浪费时间的问题!),则前往 CTeX Forum 寻求帮助。 -
关于 ucasthesis 的问题,先仔细阅读 LaTeX 知识小站 的相关条目。若在读完所有条目后,仍找不到解答,再进行如下步骤:
-
查阅搜索 issues 的 已关闭问题
closed issues
看问题是否已被回答过。 -
若问题仍无法得到解决,按照如下步骤将问题反馈至 issues(再次确定问题的性质以及提问的必要性,否则就是在错误的地方问错误的/浪费时间的问题!):
-
将编译生成的
Thesis.log
文件拖入网页上的issue 文本框
。此文件为编译所生成的日志文件,其中给出了:-
版本信息
,如 This is XeTeX, Version 3.14159265-2.6-0.99999 (TeX Live 2018) -
宏包信息
,如 Document Class: ctexbook 2018/01/28 v2.4.12 -
编译出错及异常信息
无论论文是否机密,此文件并不会泄漏信息,若仍不愿提供,则手动从文件中找出如上信息并反馈
。否则问题无法有效回答!
-
-
将出现问题处的
截图照片
拖入网页上的issue 文本框
。 -
将出现问题附近的代码粘贴入网页上的
issue 文本框
。 -
若你的问题是在
你对模版进行修改后引发出来的问题
,那么必须提供一个MWE
(Minimal Working Example):- 其能在你的电脑上编译通过、或能给出你所描述的出错提示
- 其编译结果能
复现你的问题
,或体现你的需求
你需要将你的 'MWE' 文件和 '.log' 文件都拖入网页上的
issue 文本框
,否则问题无法得到有效解答!。
-
注:使用邮件回复 issue
时,邮件中的附件是无法被 Github
和其他收件人所接收的,文件需直接拖入网页上的 issue 文本框
。
- 在
下面添加:
\fancypagestyle{nofooterstyle}{% header and footer style for no footer
\fancyhf{}% clear fields
\fancyhead[C]{\footnotesize \ifnumodd{\value{page}}{\leftmark}{\@title}}% structure elements
%\fancyfoot[C]{\footnotesize \ifnumodd{\value{page}}{\hspace*{\fill}\thepage}{\thepage\hspace*{\fill}}}% page number
%\renewcommand{\headrulewidth}{0pt}% header rule
\renewcommand{\footrulewidth}{0pt}% footer rule
}
- 然后在
致谢
处使用:
\thispagestyle{nofooterstyle}% 如果需要移除当前页的页脚
%\pagestyle{nofooterstyle}% 如果需要移除整章的页脚
根据 tex.se 和 zhihu,LaTeX 在生成 PDF 书签时,数学命令需切换为相应的文本模式,比如 \lambda
需切换为 \textlambda
。切换工作通常在 NFSS 里完成,但 NFSS 有时定义不全。于是 hyperref 提供了 psdextra 选项。该选项会载入 psdextra.def 文件,提供更多的定义,即使用:
\usepackage[unicode,psdextra]{hyperref}
来实现额外的替换工作。尽管如此,有时仍存在定义不全或错误的问题。因此,最终推荐的解决方案是使用 \texorpdfstring{此为LaTeX编译内容}{此为书签内容}
,实例如下:
若需要
\section{测试公式编号 $\Lambda,\lambda,\theta,\bar{\Lambda},\sqrt{S_{NN}}} \label{sec:testmath}
需使用
\section{测试公式编号 \texorpdfstring{$\Lambda,\lambda,\theta,\bar{\Lambda},\sqrt{S_{NN}}$}{$\textLambda,\textlambda,\texttheta,\bar{\textLambda},\sqrt{S_{NN}}$}} \label{sec:testmath}
即可避免报错问题。
论文撰写指导中规定“中文摘要、英文摘要、目录、论文正文、参考文献、附录、致谢等均须由另页右页开始”。即论文需采用正式的双面排版,空白页的存在是为了满足“由另页右页开始”这一条件而自动生成的,这是双面排版的排版规范:每一章需开始于奇数页,若前一章结束于奇数页,则需生成一空白偶数页从而使下面新的一章可以开始于奇数页。
ucasthesis 在 Thesis.tex 中提供了三种排版方式:
\documentclass[twoside]{Style/ucasthesis}%
%- Multiple optional arguments:
%- [<oneside|twoside|print>]% oneside eprint, twoside eprint, or paper print
即:
-
\documentclass[oneside]{Style/ucasthesis}%
:单面排版,适合作为节省页面的电子版。 -
\documentclass[twoside]{Style/ucasthesis}%
:双面排版,适合作为正式电子版。 -
\documentclass[print]{Style/ucasthesis}%
:预留了装订距离的双面排版,并会将超链接设为黑色,适合作为纸质打印版。
无论选择哪种模式,论文主体内容的排版都会是完全一样的,不会受到影响。
因为包含有字体、超链接、图表等很多信息,LaTeX 生成的 PDF 文件有时尺寸较大,可以使用如下方式进行压缩以所见尺寸:
-
使用 Adobe 打开 PDF 后选择
打印成PDF
可缩减尺寸,但会导致超链接等失效。 -
如果需要保存超链接同时压缩文件尺寸,可以安装
Ghostscript (gs)
软件。此软件 Linux 默认带有,Windows 和 MacOS 可以免费安装。事实上,安装了 LaTeX 编译器如TexLive
和MikTeX
后,通常也同时安装了Ghostscript (gs)
。然后使用如下命令:
gs -sDEVICE=pdfwrite -dNOPAUSE -dBATCH -dQUIET -dPDFSETTINGS=/prepress -sOutputFile=compressed.pdf original.pdf
即可将名为 original.pdf
的文件压缩为 compressed.pdf
。
这是由于 Windows 系统的字体问题。解决方案见 字体配置。
脚注 \footnote 在不同章(chapter)里,默认总是从 1 开始编号,如果需要按全文顺序编号,只需
- 如果 LaTeX 编译器版本早于2018年,在
artracom.sty
中加入
\RequirePackage{chngcntr}
\counterwithout{footnote}{chapter}
- 如果 LaTeX 编译器版本为2018年的甚至更新,只需在
artracom.sty
中加入:
\counterwithout{footnote}{chapter}
信息来自 Continuous footnote numbering:
In a current LaTeX (not older than 2018-04-01), \counterwithout is part of the kernel, so the \usepackage{chngcntr} is not needed any more.
在 atratex.sty
中搜索 hyperref
即可找到关于超链接的各类设置,比如各类链接的样式和颜色:
\hypersetup{% set hyperlinks
colorlinks=true,% false: boxed links; true: colored links
linkcolor=black,% color of internal links
citecolor=blue,% color of links to bibliography
filecolor=blue,% color of file links
urlcolor=blue,% color of external links
}
注意:
- 打印版的论文最好是显式出现 url 而不是用超链接,因为打印的文档无法还原超链接。
- 非黑色超链接在黑白打印后可能显示为浅灰色,从而打印版论文最好设定超链接为全黑色。
这是因为下划线前面还有字头,导致文本只能在页面居中和在下划线上居中二选一。当前封面采取页面居中。如需要调整文本在下划线上的位置,可用 \hspace*{+/- n.0em}
命令来插入或删除 n
个空格,进行手动调整,比如
\advisor{\hspace*{+3.0em} xxx~研究员~xxx单位}
有时下划线看上去粗细不一致,这是显示的问题,打印正常。
图表标题的默认对齐方式为(此通常为最优排版方式):短标题居中显示,长标题左对齐并使第二行起悬挂缩进两个字符。
如果想改为长短标题皆居中,在 artratex.sty
中将:
\RequirePackage[format=plain,hangindent=2.0em,font={small,bf},skip=8pt,labelsep=space]{caption}%
改为
\RequirePackage[format=plain,hangindent=2.0em,justification=centerlast,font={small,bf},skip=8pt,labelsep=space]{caption}%
根据需要,justification=<option>
处的 <option>
可为(caption ctan):
justified Typesets the caption as a normal paragraph.
centering Each line of the caption will be centered.
centerlast The last line of each paragraph of the caption text will be centered.
centerfirst Only the first line of the caption will be centered.
raggedright Each line of the caption will be moved to the left margin.
RaggedRight Each line of the caption will be moved to the left margin, too.
raggedleft Each line of the caption will be moved to the right margin.
- 在
下面插入如下代码:
\fancypagestyle{enfrontmatterstyle}{% style for frontmatter
\fancyhf{}% clear fields
\fancyhead[C]{\footnotesize \ifnumodd{\value{page}}{\leftmark}{\ucas@value@en@title}}% structure elements
\fancyfoot[C]{\footnotesize \thepage}% page number
\renewcommand{\headrulewidth}{0.8pt}% header rule
\renewcommand{\footrulewidth}{0pt}% footer rule
}
- 在
下面插入代码:
\pagestyle{enfrontmatterstyle}%
- 在
下面插入代码:
\cleardoublepage\pagestyle{frontmatterstyle}%
这是 LaTeX 的一种排版机制,即许多排版参数会根据对当前内容的计算结果而在给定阈值附近轻微浮动以达到最优的排版效果。
国科大指导文件对目录字体的规定为:
ucasthesis 严格的执行了上述规定,即章主标题一行为四号字体,而节标题行为小四号字体。
大家在使用 ucasthesis 或 LaTeX 时,不要限制自己的想象力。 LaTeX 写作是一个用编程语言表达思想的具有创造性的过程,而非一个机械的填表行为。比如:
- 把导师的单位放在下一行:
\advisor{刘青泉~研究员\\中国科学院力学研究所}% 指导教师:姓名 专业技术职务 工作单位
- 多位导师共享单位名:
\advisor{刘青泉~研究员、刘青泉~研究员\\中国科学院力学研究所}% 指导教师:姓名 专业技术职务 工作单位
- 英文多位导师:
\ADVISOR{Supervisors: \\ Professor Liu Qingquan \\ Professor Liu Qingquan}% 指导教师
中英文及 LaTeX 命令的混排易出现文本行不等长的情形,最简单有效的解决方案为:使用空格分开中、英、LaTeX 命令
,如使用
测试。_\citet{xxx}_提出了_CNN_\citep{yyy}_理论,如表~ \ref{tab:zzz}_和方程~\eqref{eq:ns}。
而不是
测试。\citet{xxx}提出了CNN\citep{yyy}理论,如表~ \ref{tab:zzz}和方程~\eqref{eq:ns}。
其中 _
表示输入空格。这一规则对于中英
和 LaTeX 命令
之间尤为重要。
\nomenclatureitem
的开发初衷是用一个简单的命令来实现对符号列表的排版,从而避免调用对编译过程有特殊要求的 nomencl
宏包。因为简单,所以可自动处理好的情形较为有限,对于某些特殊情形需进行针对性的调整。
以如下情形为例:
\nomenclatureitem{BEDPOSTX}{Bayesian Estimation of Diffusion Parameters Obtained Using Sampling Techniques}
- 首先在
artratex.sty
中将
\providecommand{\nomenclatureitem}[3][ ]{%
\noindent\makebox[0.15\textwidth][l]{#2}{{#3}\hfill{#1}}\par
}
中的 0.15
改为 0.18
以适应字符串 BEDPOSTX
的长度。
- 然后使用如下方法对原条目进行分解即可:
\nomenclatureitem{BEDPOSTX}{Bayesian Estimation of Diffusion Parameters Obtained Using Sampling}
\nomenclatureitem{}{Techniques}
效果如下:
如需调整目录行距,在 Thesis.tex 中修改 \linespread
的值即可,如需将目录、图列表、表列表加入目录,将 intobmk
改为 intotoc
即可:
{% content list region
\linespread{1.2}% local line space
\intobmk*{\cleardoublepage}{\contentsname}% add link to bookmark
\tableofcontents% content catalog
\intobmk*{\cleardoublepage}{\listfigurename}% add link to bookmark
\listoffigures% figure catalog
\intobmk*{\cleardoublepage}{\listtablename}% add link to bookmark
\listoftables% table catalog
}
如需将摘要、 Abstract 等加入目录,只需将
\intobmk\chapter*{摘\quad 要}% 显示在书签但不显示在目录
\intobmk\chapter*{Abstract}% 显示在书签但不显示在目录
改为
\chapter{摘\quad 要}% 显示在书签和目录
\chapter{Abstract}% 显示在书签和目录
可以在 artracom.sty
中添加:
\RequirePackage[titles]{tocloft}
\newlength{\mylen}
\renewcommand{\cftfigpresnum}{\figurename\enspace}
\renewcommand{\cftfigaftersnum}{}
\settowidth{\mylen}{\cftfigpresnum\cftfigaftersnum}
\addtolength{\cftfignumwidth}{\mylen}
\renewcommand{\cfttabpresnum}{\tablename\enspace}
\renewcommand{\cfttabaftersnum}{}
\settowidth{\mylen}{\cfttabpresnum\cfttabaftersnum}
\addtolength{\cfttabnumwidth}{\mylen}
\renewcommand{\cftchapfont}{\zihao{4}\sffamily}
\renewcommand{\cftsecfont}{\zihao{-4}\sffamily}
\renewcommand{\cftsubsecfont}{\zihao{-4}\sffamily}
\renewcommand{\cftsubsubsecfont}{\zihao{-4}\sffamily}
\renewcommand{\cftfigfont}{\zihao{-4}\sffamily}
\renewcommand{\cfttabfont}{\zihao{-4}\sffamily}
\renewcommand{\cftchapleader}{\cftdotfill{\cftdotsep}}
\renewcommand{\cftdotsep}{1.5}
其可能导致目录的行距会自动变成文章的默认行距。
样例如下:
%---------------------------------------------------------------------------%
%->> Titlepage information
%---------------------------------------------------------------------------%
%-
%-> 中文封面信息
%-
\classid{\hspace*{5em}Oxxx}% 分类号
\udc{\hspace*{5em}xxx}% UDC
\confidential{}% 密级
\orderid{\hspace*{5em}1003}% 编号
\schoollogo{清华大学}% 校名
\title{xxx的高效精确计算}% 论文中文题目
\author{{\ziju{0.5}莫晃锐}}% 论文作者
\subject{xxxx工程}% 一级学科专业名称
\major{xx工程}% 二级学科专业名称
\completedate{\hspace*{4em} 20xx~年~x~月 -- 20xx~年~x~月}% 完成日期
\submitdate{\hspace*{3em} 20xx~年~x~月}% 提交日期
\studydatefrom{20xx~年~x~月~xx~日}% 研究工作起始时间
\studydateto{20xx~年~x~月~xx~日}% 研究工作期满时间
\institute{{\ziju{0.5}清华大学}(北京)}% 院系名称
\orginization{清华大学人事部(北京)}% 部门名称
\school{清华大学}% 学校名称
\date{20xx~年~x~月}% 毕业日期
%-
%-> 英文封面信息
%-
\TITLE{Efficient and Accurate Determination of xxx}% 论文英文题目
\AUTHOR{Mo Huangrui}% 论文作者
\DEGREE{Postdoctor}% 学位:Bachelor, Master, Doctor, Postdoctor。封面据英文学位名称自动切换,需确保拼写准确
\SCHOOL{Tsinghua University}% 学校名称
%---------------------------------------------------------------------------%
学位办发布的 Word 模板中的附录位置较为特殊, ucasthesis 的默认设定采用符合学术常规的排版。若坚持采用学位办的设定,可在 Thesis.tex
中采用如下文档结构命令进行相应地替换:
%-
%-> Mainmatter
%-
\mainmatter% initialize the environment
\input{Tex/Mainmatter}% main content
%-
%-> Bibliography
%-
\cleardoublepage%
\pagestyle{backmatterstyle}%
\intotoc*{\cleardoublepage}{\bibname}% add link to toc
\bibliography{Biblio/ref}% bibliography
\cleardoublepage%
\pagestyle{mainmatterstyle}%
%-
%-> Appendix
%-
\cleardoublepage%
\appendix% initialize the environment
\input{Tex/Appendix}% appendix content
%-
%-> Backmatter: bibliography, glossary, index
%-
\backmatter% initialize the environment
\input{Tex/Backmatter}% other information
根据 tex.se 源一 和 tex.se 源二 此问题的解决有如下几种方式,但无论哪种都不甚理想,目前 ucasthesis 默认采用方案1。
方案1. 修改 macro 方式
在 artracom.sty
中添加:
\newcommand{\adddotsbeforeeqnnum}{\def\maketag@@@##1{\hbox{\m@th\normalfont\dots\ ##1}}}%
然后,在每个方程内调用 \adddotsbeforeeqnnum
命令,如:
\begin{equation} \label{eq:ns}
\adddotsbeforeeqnnum%
\begin{cases}
\frac{\partial \rho}{\partial t} + \nabla\cdot(\rho\Vector{V}) = 0 \ \mathrm{times\ font\ test}\\
\frac{\partial (\rho\Vector{V})}{\partial t} + \nabla\cdot(\rho\Vector{V}\Vector{V}) = \nabla\cdot\Tensor{\sigma} \ \text{times font test}\\
\frac{\partial (\rho E)}{\partial t} + \nabla\cdot(\rho E\Vector{V}) = \nabla\cdot(k\nabla T) + \nabla\cdot(\Tensor{\sigma}\cdot\Vector{V})
\end{cases}
\end{equation}
如此,便可以正常使用 eqref
命令引用,如
比如Navier-Stokes方程(方程~\eqref{eq:ns})
方案2. 使用 mathtools 宏包
在 artracom.sty
中添加:
\RequirePackage{mathtools}%
\newtagform{dots}{\ldots\ (}{)}%
然后,在每个方程内调用 \usetagform{dots}
命令,如:
\begin{equation} \label{eq:ns}
\usetagform{dots}%
\begin{cases}
\frac{\partial \rho}{\partial t} + \nabla\cdot(\rho\Vector{V}) = 0 \ \mathrm{times\ font\ test}\\
\frac{\partial (\rho\Vector{V})}{\partial t} + \nabla\cdot(\rho\Vector{V}\Vector{V}) = \nabla\cdot\Tensor{\sigma} \ \text{times font test}\\
\frac{\partial (\rho E)}{\partial t} + \nabla\cdot(\rho E\Vector{V}) = \nabla\cdot(k\nabla T) + \nabla\cdot(\Tensor{\sigma}\cdot\Vector{V})
\end{cases}
\end{equation}
如此,便可以正常使用 eqref
命令引用,如
比如Navier-Stokes方程(方程~\eqref{eq:ns})
方案3. 上述方案共同的不理想处在于必须在每一个方程环境内额外添加一个命令。如果采用全局设定,比如在 artracom.sty
中添加的是:
\newcommand{\adddotsbeforeeqnnum}{\def\maketag@@@##1{\hbox{\m@th\normalfont\dots\ ##1}}}%
\adddotsbeforeeqnnum%
或
\RequirePackage{mathtools}%
\newtagform{dots}{\ldots\ (}{)}%
\usetagform{dots}%
则会导致 eqref
被不必要的修改,即不能正常使用 eqref
:
比如Navier-Stokes方程(方程~\eqref{eq:ns})
而只能使用 ref
:
比如Navier-Stokes方程(方程~(\ref{eq:ns}))
\nomenclatureitem
的开发初衷是用一个简单的命令来实现对符号列表的排版,从而避免调用对编译过程有特殊要求的 nomencl
宏包。因为简单,所以可自动处理好的情形较为有限,对于某些特殊情形需进行针对性的调整。
以如下情形为例:
\nomenclatureitem{BEDPOSTX}{Bayesian Estimation of Diffusion Parameters Obtained Using Sampling Techniques}
- 首先在
artratex.sty
中将
\providecommand{\nomenclatureitem}[3][ ]{%
\noindent\makebox[0.15\textwidth][l]{#2}{{#3}\hfill{#1}}\par
}
中的 0.15
改为 0.18
以适应字符串 BEDPOSTX
的长度。
- 然后使用如下方法对原条目进行分解即可:
\nomenclatureitem{BEDPOSTX}{Bayesian Estimation of Diffusion Parameters Obtained Using Sampling}
\nomenclatureitem{}{Techniques}
效果如下:
如果不愿手动调整或者需要更加复杂的功能,则需使用用 nomencl
宏包,其使用方法详见宏包文档。
问题源自 issue 146
采用如下命令即可:
\intotoc\chapter*{引言}
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intotoc\section*{研究背景与意义}%
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intotoc\section*{研究内容和目标}%
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
更多的设定方式及样式参考如下:
\intotoc*[chapter]{\cleardoublepage}{显示在一级目录和书签,但无编号 I}%
\chapter*{显示在一级目录和书签,但无编号 I}
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intotoc\section*{显示在二级目录和书签,但无编号 I}%
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intotoc*[section]{}{显示在二级目录和书签,但无编号 II}%
\section*{显示在二级目录和书签,但无编号 II}
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intotoc\chapter*{显示在一级目录和书签,但无编号、无clearpage II}
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intobmk*[0]{\cleardoublepage}{显示在一级书签,但无编号、无目录显示 I}%
\chapter*{显示在一级书签,但无编号、无目录显示 I}
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intobmk*[1]{}{显示在二级书签,但无编号、无目录显示 I}%
\section*{显示在二级书签,但无编号、无目录显示 I}
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intobmk[1]\section*{显示在二级书签,但无编号、无目录显示 II}%
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text
\intobmk\chapter*{显示在一级书签,但无编号、无目录显示、无clearpage II}
text, text, text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text,text, text