PropertiesFile.rst 27.7 KB
Newer Older
1
2
.. _Properties File:

3
Properties File
4
5
===============

6
7
The ``*.properties`` Files
--------------------------
8

9
The Mantid framework is configured using up to three simple text ``*.properties`` files that are read an interpreted every time the framework is started. These properties are not the same as the properties of algorithms. All three have the same format. The three files are read from first to last, with the values in subsequent ``*.properties`` overriding those in previous ones.
10

11
12
1. Install directory ``Mantid.properties`` defines the default configuration that the development team suggest as sensible defaults. This file should not be altered by users as it will be replaced with every new install or upgrade of Mantid.
2. ``/etc/mantid.local.properties`` is an optional, linux only file that sets shared defaults on a shared system. This is commonly used for setting the ``default.facility``, ``default.instrument``, and ``datasearch.searcharchive`` properties.
13
3. Home directory ``Mantid.user.properties`` is where users may override any property setting in Mantid. Any Property setting in this file will override anything set in the ``Mantid.properties`` file. Simply either enter the property you wish to override in this file together with it's new value. The change will take effect the next time Mantid is started. Subsequent installs or upgrades of Mantid will never alter this file.
14

15
16
17
18
19
20
The user properties file, ``Mantid.user.properties``, can be found

* windows: ``$MantidInstallDirectory\bin\Mantid.user.properties``
* linux and mac-os: ``$HOME/.mantid/Mantid.user.properties``


21
22
23
The Properties
--------------

24
25
.. note:: Use forward slash (``/``) or double up on the number of backslash (``\``) characters for all paths

26

27
28
29
.. note:: Boolean properties evaluate ``true``, ``1``, and ``on`` (case insensitive) as ``true``, all other values as ``false``.


30
31
32
General properties
******************

33
34
35
36
37
38
39
40
41
42
43
44
45
46
+----------------------------------+--------------------------------------------------+------------------------+
|Property                          |Description                                       | Example value          |
+==================================+==================================================+========================+
| ``algorithms.categories.hidden`` | A comma separated list of any categories of      | ``Muons,Testing``      |
|                                  | algorithms that should be hidden in Mantid.      |                        |
+----------------------------------+--------------------------------------------------+------------------------+
| ``curvefitting.guiExclude``      | A semicolon separated list of function names     | ``ExpDecay;Gaussian;`` |
|                                  | that should be hidden in Mantid.                 |                        |
+----------------------------------+--------------------------------------------------+------------------------+
| ``MultiThreaded.MaxCores``       | Sets the maximum number of cores available to be | ``0``                  |
|                                  | used for threads for                             |                        |
|                                  | `OpenMP <http://www.openmp.org/>`_. If zero it   |                        |
|                                  | will use one thread per logical core available.  |                        |
+----------------------------------+--------------------------------------------------+------------------------+
47
48
49
50

Facility and instrument properties
**********************************

51
52
53
54
+------------------------------+----------------------------------------------------+---------------------+
|Property                      |Description                                         |Example value        |
+==============================+====================================================+=====================+
| ``default.facility``         | The name of the default facility. The facility     | ``ISIS``            |
55
|                              | must be defined within the facilities.xml file to  |                     |
56
57
58
59
60
61
62
63
64
65
66
67
|                              | be considered valid. The file is described         |                     |
|                              | :ref:`here <Facilities file>`.                     |                     |
+------------------------------+----------------------------------------------------+---------------------+
| ``default.instrument``       | The name of the default instrument. The instrument | ``WISH``            |
|                              | must be defined within the facilities.xml file to  |                     |
|                              | be valid. The file is described                    |                     |
|                              | :ref:`here <Facilities file>`.                     |                     |
+------------------------------+----------------------------------------------------+---------------------+
| ``Q.convention``             | The convention for converting to Q. For            | ``Crystallography`` |
|                              | ``Inelastic`` the convention is ki-kf.  For        | or ``Inelastic``    |
|                              | ``Crystallography`` the convention is kf-ki.       |                     |
+------------------------------+----------------------------------------------------+---------------------+
68
69
70
71

Directory Properties
********************

72
73
74
+--------------------------------------+---------------------------------------------------+-------------------------------------+
|Property                              |Description                                        |Example value                        |
+======================================+===================================================+=====================================+
75
76
| ``colormaps.directory``              | The directory where colormaps are located         | ``/opt/mantid/colormaps``           |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
77
78
79
80
81
82
83
84
85
86
87
| ``datasearch.directories``           | A semi-colon(``;``) separated list of directories | ``../data;\\\\isis\\isis$\\ndxgem`` |
|                                      | to use to search for data.                        |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
| ``datasearch.searcharchive``         | ``on`` (only the default facility), ``off``       | ``on`` or ``hfir,sns``              |
|                                      | (none), ``all`` (all archives), or a list of      |                                     |
|                                      | individual facilities to search for files in the  |                                     |
|                                      | data archive                                      |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
| ``defaultsave.directory``            | A default directory to use for saving files.      | ``../data``                         |
|                                      | the data archive                                  |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
88
89
90
91
92
93
| ``framework.plugins.directory``      | The path to the directory that contains the       | ``../plugins``                      |
|                                      | Mantid plugin libraries                           |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
| ``framework.plugins.exclude``        | A list of substrings to allow libraries to be     | ``Qt4;Qt5``                         |
|                                      | skipped                                           |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
94
95
| ``instrumentDefinition.directory``   | Where to load instrument definition files from    | ``../Test/Instrument``              |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
96
97
98
| ``mantidqt.plugins.directory``       | The path to the directory containing the          | ``../plugins/qtX``                  |
|                                      | Mantid Qt-based plugin libraries                  |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
| ``parameterDefinition.directory``    | Where to load parameter definition files from     | ``../Test/Instrument``              |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
| ``pythonscripts.directories``        | Python will also search the listed directories    | ``../scripts`` or ``C:/MyScripts``  |
|                                      | when importing modules.                           |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
| ``pythonscripts.directory``          | **DEPRECATED:** Use ``pythonscripts.directories`` | N/A                                 |
|                                      | instead                                           |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
| ``requiredpythonscript.directories`` | A list of directories containing Python scripts   | N/A                                 |
|                                      | that Mantid requires to function correctly.       |                                     |
|                                      | **WARNING:** Do not alter the default value.      |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
| ``requiredpythonscript.directories`` | A list of directories containing Python scripts   | N/A                                 |
|                                      | that Mantid requires to function correctly.       |                                     |
|                                      | **WARNING:** Do not alter the default value.      |                                     |
+--------------------------------------+---------------------------------------------------+-------------------------------------+
115
116
117
118
119
120



Logging Properties
******************

121
122
123
124
125
126
127
128
129
The details of configuring the logging functionality within Mantid will not be explained here. For those who want more
details look into the `POCO logging classes <https://pocoproject.org/docs/package-Foundation.Logging.html>`_ and the
`Log4J logging module <https://logging.apache.org/log4j/>`_ that it closely emulates. There are several comments in the
properties file itself that explain the configuration we provide by default.  However there are some obvious areas that
you may want to alter and those properties are detailed below.

+-------------------------------------------------+---------------------------------------------------+-----------------------------+
|Property                                         |Description                                        |Example value                |
+=================================================+===================================================+=============================+
130
131
132
| ``logging.loggers.root.level``                  |Defines the level of messages to be output         | ``debug``, ``information``, |
|                                                 |by the system.                                     | ``notice``, ``warning``,    |
|                                                 |The default is information, but                    | ``error``, ``critical``     |
133
134
135
136
|                                                 |this can be lowered to debug for more detailed     | or ``fatal``                |
|                                                 |feedback.                                          |                             |
|                                                 |                                                   |                             |
+-------------------------------------------------+---------------------------------------------------+-----------------------------+
137

138
The logging priority levels for the file logging and console logging can also be adjusted in python using the command:
139
140
141

.. testcode:: LoggingConfigExample

142
143
144
145
  #Set the log to debug level or above (7=debug)
  ConfigService.setLogLevel(7)
  #Set the log to critical level (2=critical)
  ConfigService.setLogLevel(2)
146

147

148

149
150
Mantid Graphical User Interface Properties
******************************************
151

152
153
154
+--------------------------------------------+---------------------------------------------------+-----------------+
|Property                                    |Description                                        |Example value    |
+============================================+===================================================+=================+
155
156
157
| ``Notifications.Enabled``                  |Should Mantid use System Notifications for         | ``On``, ``Off`` |
|                                            |important messages?                                |                 |
+--------------------------------------------+---------------------------------------------------+-----------------+
158
| ``cluster.submission``                     |Enable cluster submission elements in GUIs         | ``On``, ``Off`` |
159
160
161
162
+--------------------------------------------+---------------------------------------------------+-----------------+
| ``MantidOptions.InstrumentView.UseOpenGL`` |Controls the use of OpenGL in rendering the        | ``On``, ``Off`` |
|                                            |"unwrapped" (flat) instrument views.               |                 |
+--------------------------------------------+---------------------------------------------------+-----------------+
163
| ``MantidOptions.InvisibleWorkspaces``      |Do not show 'invisible' workspaces                 | ``0``, ``1``    |
164
+--------------------------------------------+---------------------------------------------------+-----------------+
165
| ``PeakColumn.hklPrec``                     |Precision of hkl values shown in tables            | ``2``           |
166
167
+--------------------------------------------+---------------------------------------------------+-----------------+

168

169
170
171
Network Properties
******************

172
173
174
+-------------------------------------------+---------------------------------------------------+---------------------------------+
|Property                                   |Description                                        |Example value                    |
+===========================================+===================================================+=================================+
175
176
| ``catalog.timeout.value``                 | Network timeout for ICAT4 requests                | ``30``                          |
+-------------------------------------------+---------------------------------------------------+---------------------------------+
177
178
179
| ``CheckMantidVersion.OnStartup``          | Check if there is a newer version available and   |                                 |
|                                           | logs a message at ``information`` level           | ``1``                           |
+-------------------------------------------+---------------------------------------------------+---------------------------------+
180
181
182
| ``ISISDAE.Timeout``                       | Timeout for network requests when reading live    |  ``100``                        |
|                                           | data from ISIS (in seconds)                       |                                 |
+-------------------------------------------+---------------------------------------------------+---------------------------------+
183
184
185
186
| ``network.default.timeout``               |Defines the default timeout for all network        | ``30``                          |
|                                           |operations (in seconds).                           |                                 |
+-------------------------------------------+---------------------------------------------------+---------------------------------+
| ``network.scriptrepo.timeout``            |The timeout for network operations in the script   | ``5``                           |
187
|                                           |repository, this overrides the default timeout.    |                                 |
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
+-------------------------------------------+---------------------------------------------------+---------------------------------+
| ``proxy.host``                            | Allows the system proxy to be overridden, if not  | ``http://www.proxy.org``        |
|                                           | set mantid will use the system proxy              |                                 |
+-------------------------------------------+---------------------------------------------------+---------------------------------+
| ``proxy.port``                            | Must be set if proxy.host is set                  | ``8080``                        |
+-------------------------------------------+---------------------------------------------------+---------------------------------+
| ``proxy.httpsTargetUrl``                  | A sample url used to determine the system proxy to| ``http://www.google.com``       |
|                                           | use on windows.                                   |                                 |
+-------------------------------------------+---------------------------------------------------+---------------------------------+
| ``UpdateInstrumentDefinitions.OnStartup`` | Download new instrument definition files and      |                                 |
|                                           | ``Facilities.xml`` to ``~/.mantid/instruments``   |                                 |
|                                           | on linux or ``APPDATA`` directory on windows. If  |                                 |
|                                           | this is disabled, previously downloaded           |                                 |
|                                           | instruments are ignored and only those in the     |                                 |
|                                           | installation are used.                            | ``1``                           |
+-------------------------------------------+---------------------------------------------------+---------------------------------+
| ``usagereports.enabled``                  | Enable usage reporting                            | ``1``                           |
+-------------------------------------------+---------------------------------------------------+---------------------------------+

207

208
209
210
ScriptRepository Properties
***************************

211
212
213
214
215
+----------------------------+-----------------------------------------------+----------------------------------------------------------------------+
|Property                    |Description                                    |Example value                                                         |
+============================+===============================================+======================================================================+
| ``ScriptLocalRepository``  |Directory where ScriptRepository is Installed. | ``C:\\MantidInstall\\MyScriptRepository``                            |
+----------------------------+-----------------------------------------------+----------------------------------------------------------------------+
216
| ``ScriptRepository``       |Base URL for the remote script repository.     | ``https://download.mantidproject.org/scriptrepository/``             |
217
218
219
220
+----------------------------+-----------------------------------------------+----------------------------------------------------------------------+
| ``ScriptRepositoryIgnore`` |CSV patterns for paths that should not be      | ``*pyc;``                                                            |
|                            |listed at ScriptRepository.                    |                                                                      |
+----------------------------+-----------------------------------------------+----------------------------------------------------------------------+
221
| ``UploaderWebServer``      |URL for uploading scripts.                     | ``https://upload.mantidproject.org/scriptrepository/payload/publish``|
222
+----------------------------+-----------------------------------------------+----------------------------------------------------------------------+
223
224


225
226
227
Project Recovery
****************

Peterson, Peter's avatar
Peterson, Peter committed
228
See :ref:`project recovery <Project Recovery>` for more details.
229
230
231
232
233
234
235
236
237
238
239

+-----------------------------------------+-----------------------------------------------+------------------+
|Property                                 |Description                                    |Example value     |
+=========================================+===============================================+==================+
| ``projectRecovery.enabled``             |Whether project recovery is enabled            |  ``On``, ``Off`` |
+-----------------------------------------+-----------------------------------------------+------------------+
| ``projectRecovery.numberOfCheckpoints`` |How many checkpoints/backups to keep           | ``5``            |
+-----------------------------------------+-----------------------------------------------+------------------+
| ``projectRecovery.secondsBetween``      |How often to save checkpoints in seconds       | ``60``           |
+-----------------------------------------+-----------------------------------------------+------------------+

240
241
242
243
244
245
246
247
248
Project Saving
**************

+---------------------------------+------------------------------------------------------------------+------------------+
|Property                         |Description                                                       |Example value     |
+=================================+==================================================================+==================+
| ``projectSaving.warningSize``   |Size in bytes of a project before the user is warned when saving  |  ``10737418240`` |
+---------------------------------+------------------------------------------------------------------+------------------+

249
250
251
252
253
254
255
256
Plotting Settings
*****************

+---------------------------------+------------------------------------------------------------------+---------------------+
|Property                         |Description                                                       |Example value        |
+=================================+==================================================================+=====================+
|``plots.ShowTitle``              |Whether to show titles on plots                                   | ``On``, ``Off``     |
+---------------------------------+------------------------------------------------------------------+---------------------+
257
258
259
260
|``plots.ShowMinorTicks``         |Whether to show minor ticks on plots                              | ``On``, ``Off``     |
+---------------------------------+------------------------------------------------------------------+---------------------+
|``plots.ShowMinorGridlines``     |Whether to show minor gridlines on plots                          | ``On``, ``Off``     |
+---------------------------------+------------------------------------------------------------------+---------------------+
261
262
263
264
265
266
|``plots.xAxesScale``             |The default x scale on 1d plots                                   |``Linear``, ``Log``  |
+---------------------------------+------------------------------------------------------------------+---------------------+
|``plots.yAxesScale``             |The default y scale on 1d plots                                   |``Linear``, ``Log``  |
+---------------------------------+------------------------------------------------------------------+---------------------+
|``plots.line.Style``             |Default Line style on 1d plots                                    |``solid``, ``dashed``|
+---------------------------------+------------------------------------------------------------------+---------------------+
Stephen's avatar
Stephen committed
267
268
|``plots.line.DrawStyle``         |Default Draw style on 1d plots                                    |``default``,``steps``|
+---------------------------------+------------------------------------------------------------------+---------------------+
269
270
271
272
273
274
|``plots.line.Width``             |Default Line width on 1d plots                                    |``1.5``              |
+---------------------------------+------------------------------------------------------------------+---------------------+
|``plots.marker.Style``           |Default marker style on 1d plots                                  |``point``            |
+---------------------------------+------------------------------------------------------------------+---------------------+
|``plots.marker.Size``            |Default maker size on 1d plots                                    |``6``                |
+---------------------------------+------------------------------------------------------------------+---------------------+
275
|``plots.errorbar.Capsize``       |Default cap size on error bars in 1d plots                        |``1.0``              |
276
277
278
279
280
281
+---------------------------------+------------------------------------------------------------------+---------------------+
|``plots.errorbar.CapThickness``  |Default cap thickness on error bars in 1d plots                   |``1.0``              |
+---------------------------------+------------------------------------------------------------------+---------------------+
|``plots.errorbar.errorEvery``    |Default number of error bars for every data point                 |``1``                |
|                                 |in 1d plots. Must be an integer                                   |                     |
+---------------------------------+------------------------------------------------------------------+---------------------+
282
|``plots.errorbar.Width``         |Default width of error bars in 1d plots                           |``1.0``              |
283
+---------------------------------+------------------------------------------------------------------+---------------------+
284
285
286
287
|``plots.legend.FontSize``        |Default legend font size                                          |``8.0``              |
+---------------------------------+------------------------------------------------------------------+---------------------+
|``plots.legend.Location``        |Default legend location                                           |``best``             |
+---------------------------------+------------------------------------------------------------------+---------------------+
288
289
|``plots.images.Colormap``        |Default colormap for image plots                                  |``cool``             |
+---------------------------------+------------------------------------------------------------------+---------------------+
290

291
292
293
294
295
296
297
298
299
Getting access to Mantid properties
***********************************

To get access to, e.g. data saving path property from a C++ program one has to issue the following command:


.. testcode:: properties

  path = ConfigService.getString("defaultsave.directory")
300

301
.. categories:: Concepts