Setup On Linux

Содержание

Введение

Пошаговое руководство по установке GEANT4, которое раньше предлагалось на этом сайте в качестве основного, не содержало фактических ошибок. Пользуясь им, GEANT4 можно установить и сейчас, однако на момент, когда оно было написано, последней версией библиотеки была 4.6.0. За полтора года изменилось довольно многое, и, в частности, официально рекомендованный разработчиками способ установки GEANT4. Скрипт Configure находился в корне дерева папок geant4 и раньше, но тогда он не работал.


Source(s): GEANT4 (http://www.downloadranking.com)


Совместимость

Лучшей платформой для запуска Geant4 является Linux. Официально поддерживается еще целый список архитектур, в числе которых есть и Windows, но Linux является основной платформой разработки geant, и поэтому вероятность успешной устанвки именно в ней будет несколько выше. Нам ничего не известно о случаях запуска Geant4 в Windows, поэтому не желающих переключаться в более свободную ОС просто отсылаем к официальному руководству по установке в Windows с использованием окружения Cygwin (англ.) или к статье об установке без Cygwin, но с с экстраординарными усилиями.

Итак, установка в Линуксе. Вопреки расхожему мнению, установить GEANT4 удастся на любом более-менее современном дистрибутиве линукса. Единственным условием успешности этого процесса является наличие достаточно свежих версий gcc (http://en.wikipedia.org/wiki/GNU_Compiler_Collection). Проверить его наличие можно командой

$ gcc --version

На нашей машине данная команда выдает следующий текст:

gcc (GCC) 3.4.2 20041017 (Red Hat 3.4.2-6.fc3)
Copyright (C) 2004 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

Из чего следует, что версия GCC, установленная у нас — gcc 3.4.2. Geant4 нельзя установить на систему с версией gcc ниже, чем 3.0.6. В любом современно дистрибутиве Линукса это требование выполнено, так что волноваться по этому поводу нет причин.


Source(s): GEANT4 (http://www.downloadranking.com)


Несколько замечаний про Ubuntu

Перед установкой Geant4 в Ubuntu надо предварительно установить несколько отсутствующих изначально пакетов:

# apt-get install build-essential freeglut3-dev xorg-dev


Source(s): GEANT4 (http://www.downloadranking.com)

Подготовка

Нам понадобится несколько файлов.

Математическая библиотека CLHEP

CLHEP (A Class Library for High Energy Physics) содержит базовые операции для манипуляций с векторами, матрицами, случайными числами и т. п. Содержит описание стандартных математических объектов, часто используемых в ФВЭ:

  • 3-векторы и 4-векторы
  • действия с матрицами
  • геометрические объекты и преобразования
  • генераторы случайных чисел
  • система единиц и основные физические константы

Эту библиотеку нам придется установить из исходного кода. Соответствующий архив можно взять здесь: http://proj-clhep.web.cern.ch/proj-clhep/, по ссылке Downloading / Latest source code.

Обычно доступно сразу несколько версий CLHEP, и на ее сайте ничего не сказано о том, какую версию использовать для работы с Geant4. В действительности, последняя версия Clhep не всегда совместима с Geant4 — могут возникать различные непонятные проблемы: ошибки компиляции, утечки памяти, и т. д. Лучше всего скачивать ту версию CLHEP, с которой был протестирован Geant. Это написано на сайте загрузки Geant (http://geant4.web.cern.ch/geant4/support/download.shtml) в разделе Pre-compiled libraries. «These libraries were built using CLHEP version i.j.k.»

Собственно, Geant4

Теперь нужно загрузить исходный код Geant4. Архив скачивается по уже известному адресу: http://geant4.web.cern.ch/geant4/support/download.shtml. Для скачивания нужно нажать под заголовком Source Files на кнопку слева от надписи "GNU or Linux tar format, compressed using gzip".

Data files

Если мы собираемся использовать процессы G4LowEnergy или G4HP, нам также понадобятся пять библиотек с базами данных, доступных на той же странице под заголовком Data files. Их нужно точно так же скачать, нажав на соответствующие кнопки.

Установка

В дальнейшем полагаем, что у нас есть директория ~/geantfiles/ в которую были загружены все перечисленные выше файлы.

CLHEP

Будем устанавливать библиотеку в директорию /usr/local/CLHEP.

Переходим в ~/geantfiles/:

$ cd ~/geantfiles

и выполняем следующие команды:

$ tar xzf clhep-2.0.3.1.tgz
$ cd 2.0.3.1/CLHEP

Далее переходим в режим администратора

$ su (или sudo -s)
Password:

и продолжаем:

# ./configure --prefix=/usr/local/CLHEP --disable-shared
# make && make install

Здесь мы отключили компиляцию динамических библиотек по причинам, которые станут ясны несколько позднее.

Geant4: распаковка

Мы будем устанавливать Geant в директорию /usr/local/geant4. Сначала мы распакуем архив в эту папку, а потом запустим скрипт Configure, который сделает всё остальное.

# cd ~/geantfiles
# tar xzf geant4.8.2.p01.gtar.gz -C /usr/local
# cd /usr/local

Теперь пишем "mv ge" и нажимаем табуляцию. Строчка развернётся до

# mv geant4.8.2.p01

geant4.8.2.p01 -- так называлась папка внутри архива. Дописываем через пробел "geant4" и нажимаем Enter:

# mv geant4.8.2.p01 geant4

Тем самым мы переименовываем её в geant4, как и хотели.

Data files

Возвращаемся в папку с файлами.

# cd ~/geantfiles

Распаковываем Data files:

# mkdir /usr/local/geant4/data
# tar xzf PhotonEvaporation.2.0.tar.gz -C /usr/local/geant4/data
# tar xzf G4RadioactiveDecay.3.1.tar.gz -C /usr/local/geant4/data
# tar xzf G4EMLOW.4.2.tar.gz -C /usr/local/geant4/data
# tar xzf G4NDL.3.10.tar.gz -C /usr/local/geant4/data

Geant4: скрипт Configure

Переходим обратно:

# cd /usr/local/geant4

Теперь запускаем собственно скрипт Configure:

# ./Configure -build

Его работа состоит в том, что он задаст вам несколько вопросов и на основании ваших ответов создаст конфигурацию для установки и использований Geant4. Итак, первые несколько экранов его вывода можно безопасно пропустить, нажимая Enter в ответ на запрос

[Type carriage return to continue] 

Первым важным вопросом будет вопрос о платформе:

Definition of G4SYSTEM variable is Linux-g++.
That stands for:

1) OS		: Linux

2) Compiler	: g++

To modify default settings, select number above (e.g. 2) 
[Press [Enter] for default settings] 

Нам был предложен вариант по умолчанию (система Linux и компилятор GCC), с которым мы соглашаемся. Configure всегда предлагает достаточно разумные варианты ответов по умолчанию, которые выводятся в квадратных скобках и с которыми можно согласиться просто нажатием Enter.

Следующий вопрос касается портабельности сгенерированных Configure скриптов, которые будут в дальнейшем использоваться при компиляции программ на основе Geant.

I can set things up so that your shell scripts and binaries are more portable,
at what may be a noticable cost in performance.  In particular, if you
ask to be portable, the following happens:

    1) Shell scripts will rely on the PATH variable rather than using
       the paths derived above.
    2) ~username interpretations will be done at run time rather than
       by Configure.

Do you expect to run these scripts and binaries on multiple machines? [n] 

На этот вопрос стоит ответить y, если вы планируете использовать одну и ту же установку Geant4 по сети, или, скажем, просто захотите скопировать его с одной машины на другую. На уже откомпилированные программы ограничения ответа n не распространяются, но и ответ y вопреки утверждениям Configure не даст сколько-нибудь заметного падения скорости компиляции. Отвечаем y и нажимаем Enter

Where is Geant4 source installed? [/usr/local/geant4] 

Где находится исходный код Geant. Ответ по умолчанию подходит.

Specify the path where Geant4 libraries and source files should be
installed. [/usr/local/geant4] 

Куда будет установлен Geant4. Так как мы планируем устанавливать его в ту же самую директорию, куда и распаковали, то соглашаемся с предложенным вариантом (нажатием Enter)

Do you want to copy all Geant4 headers
in one directory? [n] 

Configure любезно предлагает скопировать все заголовочные файлы Geant4 в одну папку. В принципе это может оказаться в один момент очень удобно, так что отвечаем y.

Please, specify default directory where ALL the Geant4 data is installed:

G4LEVELGAMMADATA:              /usr/local/geant4/data/PhotonEvaporation2.0

G4RADIOACTIVEDATA:             /usr/local/geant4/data/RadioactiveDecay3.1

G4LEDATA:                      /usr/local/geant4/data/G4EMLOW4.2

NeutronHPCrossSections:        /usr/local/geant4/data/G4NDL3.10

You will be asked about customizing these next.

 
[/usr/local/geant4/data] 

Нажимаем Enter, ибо в предыдущем пункте мы распаковали файлы как раз в указываемое место.

Please, specify where CLHEP is installed:

CLHEP_BASE_DIR:

 

Пишем "/usr/local/CLHEP" и жмём Enter.

You can customize paths and library name of you CLHEP installation:

1) CLHEP_INCLUDE_DIR:           /usr/local/CLHEP/include
2) CLHEP_LIB_DIR:               /usr/local/CLHEP/lib
3) CLHEP_LIB:                   CLHEP

You
To modify default settings, select number above (e.g. 2)

[Press [Enter] for default settings] 

Жмём Enter.

By default 'static' (.a) libraries are built.

Do you want to build 'shared' (.so) libraries? [n] 

На i386 динамические библиотеки приблизительно на 20—30% медленнее статических, поэтому принимаем предложение по умолчанию не собирать динамических библиотек.

Do you want to build 'global' compound libraries? [n] 

Здесь вам предстоит выбрать, компилировать Geant в огромное количество (~150) маленьких «гранулярных» библиотек, либо десять, но больших. Разницы в скорости работы Geant это не дает, однако, на медленных старых машинах с небольшим количеством памяти программы на Geant4 компилируются значительно быстрее при использовании гранулярных библиотек. Однако этот подход привязывает вас к собственной системе Geant4 для нахождения зависимостей и сборки, что может оказаться неудобным в каких-то случаях. На Athlon 1700+ с 512 Мб памяти использование глобальных (больших) библиотек никак не замедляет работу с Geant4. Итак, y.

Granular libraries are used by defaults, you asked to build global
compound libraries. Do you want to build 'granular' libraries too?
[n] 

Нужно ли собирать гранулярные библиотеки. Они только занимают место, так что отвечаем n.

Do you want to compile libraries in DEBUG mode (-g)? [n] 

Ни в коем случае не отвечаем положительно на этот вопрос! Если вы соберете Geant4 в отладочном режиме, то ваши бинарники будут занимать по 300 Мб, а при их компоновке (то есть, каждый раз, когда вы будете модифицировать свою программу для симуляции) система будет на полчаса уходить в своп.

  G4UI_NONE

If this variable is set, no UI sessions nor any UI libraries are built. 
This can be useful when running a pure batch job or in a user framework 
having its own UI system.
Do you want to set this variable ?
[n] 

  G4UI_BUILD_XAW_SESSION
  G4UI_USE_XAW

  Specifies to include and use the XAW interfaces in the
  application to be built.
  The XAW (X11 Athena Widget set) extensions are required to activate 
  and build this driver.
[n] 

  G4UI_BUILD_XM_SESSION
  G4UI_USE_XM

  Specifies to include and use the XM Motif based user interfaces.
  The XM Motif extensions are required to activate and build this
  driver.
[n] 
 


  G4VIS_NONE

If this variable is set, no visualization drivers will be built or used.
Do you want to set this variable ?
[n] 

Далее четыре вопроса, на которые отвечаем принимая предложение по умолчанию. Первый спрашивает, отключить ли все встроенные средства взаимодействия с программой во время выполнения, в том числе и командный интерпретатор. Второй и третий относятся к графическим интерфейсам на основе Xaw и Motif — если они вам нужны, то вы вряд ли сейчас выполняете по шагам действия, следуя данному руководству. Последний предлагает полностью отключить визуализацию. Кому-то может и понадобиться, но не нам. Мы — большинство.

  G4VIS_BUILD_OPENGLX_DRIVER
  G4VIS_USE_OPENGLX

It is an interface to the de facto standard 3D graphics library,
OpenGL. It is well suited for real-time fast visualization
and prototyping. The X11 version of the OpenGL libraries is
required.
[n] y

Визуализация геометрии и траекторий посредством OpenGL. По всей видимости оно вам понадобится, поскольку это основной, самый удобный и самый быстрый драйвер визуализации. Отвечаем y.


  G4VIS_BUILD_OPENGLXM_DRIVER
  G4VIS_USE_OPENGLXM

It is an interface to the de facto standard 3D graphics library,
OpenGL. It is well suited for real-time fast visualization
and prototyping. The X11 version of the OpenGL libraries and 
the Motif Xm extension is required.
[n] 

То же самое, но с использованием Motif. Cкрытые преимущества данного драйвера мне опять-таки неизвестны.

  G4VIS_BUILD_DAWN_DRIVER
  G4VIS_USE_DAWN

DAWN drivers are interfaces to the Fukui Renderer DAWN. DAWN is
a vectorized 3D PostScript processor suited to prepare technical
high quality outputs for presentation and/or documentation.
[n] y

DAWN это достаточно удобная система, которая позволяет генерировать картинки визуализации в формате .ps и .eps. Работает она в отличие от OpenGL, режиме офф-лайн, то есть, вы сначала запускаете свою программу, которая после завершения симуляций, генерирует файл в формате DAWN, который затем обрабатывается другой специальной программой Fukui Renderer, и только потом у вас на руках остается векторная иллюстрация. Но тем не менее, повторюсь, достаточно удобно и красиво.

  G4VIS_BUILD_OIX_DRIVER
  G4VIS_USE_OIX

The OpenInventor driver is based on OpenInventor technology 
for scientific visualization.
The X11 version of OpenInventor is required.
[n] 

OpenInventor — это библиотеки и софт для трехмерного моделирования от фирмы SGI. Он позволяет всячески вертеть и обозревать вашу модель прямо во время выполнения программы, все это с аппаратным ускорением. Но без шансов, что он у вас установлен, поэтому отвечаем отрицательно, по умолчанию.


  G4VIS_BUILD_RAYTRACERXX_DRIVER
  G4VIS_USE_RAYTRACERX

Allows for interactive ray-tracing graphics through X11.
The X11 package is required.
[n] 

  G4VIS_BUILD_VRML_DRIVER
  G4VIS_USE_VRML

These driver generate VRML files, which describe 3D scenes to be 
visualized with a proper VRML viewer.
[n] 

Что такое RayTracerX, я еще не знаю, эта фишка появилась в g4 только начиная с восьмой версии, а вот VRML вам очень может понадобиться. Хотя бы для того, чтобы импортировать модели Geant в 3D Max, или для отлаживания геометрии.

  OGLHOME/include
  OGLHOME/lib

You have selected to use OpenGL driver.
Specify the correct path (OGLHOME) where OpenGL is installed in your system.
It was found in: 
[/usr] 

Здесь нужно указать, где именно у вас установленны библиотеки OpenGL. На большинстве систем они именно там, куда указывает путь, предложенный Configure, в папке /usr, так что, принимаем этот вариант.

  G4LIB_BUILD_G3TOG4  

The utility module 'g3tog4' will be built by setting this
variable. NOTE: it requires a valid FORTRAN compiler to be
installed on your system and the 'cernlib' command in the
path, in order to build the ancillary tools!
Do you want to build 'g3tog4' ?
 
[n] 
 


  G4LIB_BUILD_ZLIB  

Do you wish to activate compression for output files generated
through the HepRep visualization driver ?
[n] 
 


  G4ANALYSIS_USE

Activates the configuration setup for allowing plugins to
analysis tools based on AIDA (Astract Interfaces for Data
Analysis). In order to use AIDA features and compliant analysis
tools, the proper environment for these tools will have to be
set (see documentation for the specific analysis tools).
[n] 

На эти, последние, три вопроса следует отвечать нажатием Enter. Первый из них выясняет, желаете ли вы использовать модуль G3toG4, который позволяет использовать существующий фортрановский код для GEANT3 в ваших программах на Geant4. И снова, те кому это может быть интересно, вряд ли читают этот текст.

End of configuration phase.
 
 
Stripping down executable paths...
 
Creating configuration setup file... 

WARNING: the generated configuration file
can be edited if necessary!
You can introduce any change to the configuration file
/usr/local/geant4/.config/bin/Linux-g++/config.sh before the final installation. 
To do so, use a shell escape now (e.g. !vi /usr/local/geant4/.config/bin/Linux-g++/config.sh).  

Press [Enter] to start installation or use a shell escape to edit config.sh: 

О да. Готово. Нажимаем Enter и ждем несколько часов.

После чая

Если компиляция завершится успешно, то последним шагом в установке GEANT4 с вашей стороны будет команда

# ./Configure -install

Наконец, добавляем в файлик ~/.bash_profile ссылочку на сгенерированный Configure скрипт env.sh:

# exit
$ echo . /usr/local/geant4/.config/bin/Linux-g++/env.sh >> ~/.bash_profile

Если не заработает с .bash_profile (шансы 50/50), то вызов env.sh нужно поместить в файл ~/.bashrc.

Прогоняем его, дабы всё заработало уже сейчас:

$ . ~/.bash_profile

Если вы все-таки указали ему, что хотели бы использовать GEANT в виде динамических библиотек, то, возможно, вам понадобится указать их месторасположение динамическому линкеру. Для этого можно сделать, например, так:

$ sudo -s
Password:
# echo $G4INSTALL/lib/Linux-g++ > /etc/ld.so.conf.d/GEANT.conf
# /sbin/ldconfig

Проверка

Перейдём в папку с примером:

$ cd /usr/local/geant4/examples/novice/N03

Скомпилируем и запустим пример.

$ make && exampleN03

Вводим:

$ Idle> /run/beamOn

На другом окне должна появиться кривая зелёная линия. Если она появилась, то всё прошло успешно. От души поздравляю!

Edit page