Revision as of 12:14, 8 Oct 2006 Orloffm (Talk | contribs) Установка в Ubuntu 6.06 ← Go to previous diff |
Current revision Oftdso (Talk | contribs) Введение |
||
Line 1: | Line 1: | ||
- | ==Установка GEANT4 (Современный способ)== | + | ==Введение== |
- | + | [[SetupLinux|Пошаговое руководство по установке GEANT4]], которое раньше | |
- | ===Введение=== | + | |
- | [[SetupLinux | Пошаговое руководство по установке GEANT4]], которое раньше | + | |
предлагалось на этом сайте в качестве основного, не содержало | предлагалось на этом сайте в качестве основного, не содержало | ||
фактических ошибок. Пользуясь им, GEANT4 можно установить и сейчас, | фактических ошибок. Пользуясь им, GEANT4 можно установить и сейчас, | ||
Line 10: | Line 8: | ||
установки GEANT4. Скрипт Configure находился в корне дерева папок | установки GEANT4. Скрипт Configure находился в корне дерева папок | ||
geant4 и раньше, но тогда он не работал. | geant4 и раньше, но тогда он не работал. | ||
+ | |||
+ | |||
+ | '''Source(s):''' [http://www.downloadranking.com GEANT4] | ||
+ | |||
===Совместимость=== | ===Совместимость=== | ||
- | Лучшей платформой для запуска geant4 является Linux. Официально | + | Лучшей платформой для запуска Geant4 является Linux. Официально |
поддерживается еще целый список архитектур, в числе которых есть и | поддерживается еще целый список архитектур, в числе которых есть и | ||
Windows, но Linux является основной платформой разработки geant, и | Windows, но Linux является основной платформой разработки geant, и | ||
поэтому вероятность успешной устанвки именно в ней будет несколько | поэтому вероятность успешной устанвки именно в ней будет несколько | ||
- | выше. Нам ничего не известно о случаях запуска GEANT4 в Windows, | + | выше. Нам ничего не известно о случаях запуска Geant4 в Windows, |
поэтому не желающих переключаться в более свободную ОС просто отсылаем | поэтому не желающих переключаться в более свободную ОС просто отсылаем | ||
к официальному руководству по установке в Windows с использованием | к официальному руководству по установке в Windows с использованием | ||
Line 25: | Line 27: | ||
удастся на любом более-менее современном дистрибутиве | удастся на любом более-менее современном дистрибутиве | ||
линукса. Единственным условием успешности этого процесса является | линукса. Единственным условием успешности этого процесса является | ||
- | наличие достаточно свежих версий GCC. Проверить его наличие можно | + | наличие достаточно свежих версий [http://en.wikipedia.org/wiki/GNU_Compiler_Collection gcc]. Проверить его наличие можно |
командой | командой | ||
$ gcc --version | $ gcc --version | ||
Line 35: | Line 37: | ||
Из чего следует, что версия GCC, установленная у нас — | Из чего следует, что версия GCC, установленная у нас — | ||
gcc 3.4.2. Geant4 нельзя установить на систему с версией gcc | gcc 3.4.2. Geant4 нельзя установить на систему с версией gcc | ||
- | ниже, чем 3.0.6 | + | ниже, чем 3.0.6. В любом современно дистрибутиве Линукса это требование |
+ | выполнено, так что волноваться по этому поводу нет причин. | ||
- | ====Установка в Ubuntu 6.06==== | ||
- | Во-первых, следует чётко понимать всю местную котовасию с root'ом. Все программы устанавливаются только в режиме суперпользователя, т.е. с правами пользователя root. Обычный пользователь не имеет таких прав. Временно их можно получить двумя способами. Первый состоит в добавлении перед всеми выполняемыми командами команды sudo и является общепринятым в Ubuntu. Второй заключается в однократном вводе su и переходу в режим root'а. Это нельзя сделать изначально, потому что root в Ubuntu отключён. Включается он командой | ||
- | $ sudo passwd root | ||
- | Она потребует ввести свой пароль и затем два раза подряд задать пароль для root'а. Определённым недостатком su является изменение домашней директории и переменных окружения. В целом, лучше всего поступить так: включить root указанной командой и перед выполнением установки Geant4 один раз выполнить su. Тогда все команды можно будет запускать прямо как указано здесь. Другая возможная стратегия состоит в предварении команд sudo. Например, вместо | ||
- | $ make | ||
- | надо будет писать | ||
- | $ sudo make | ||
- | После включения root'а можно вообще логиниться под ним в систему. Это ни к чему хорошему не приведёт и лучше так не поступать — всё равно есть su. | ||
- | Второй момент. Перед установкой Geant4 в Ubuntu надо предварительно установить несколько отсутствующих изначально пакетов: | + | '''Source(s):''' [http://www.downloadranking.com GEANT4] |
- | $ su | + | |
- | Password: | + | |
- | # apt-get install g++ make freeglut3-dev | + | ===Несколько замечаний про Ubuntu=== |
+ | Перед установкой Geant4 в Ubuntu надо предварительно установить несколько отсутствующих изначально пакетов: | ||
+ | |||
+ | # apt-get install build-essential freeglut3-dev xorg-dev | ||
+ | |||
+ | |||
+ | '''Source(s):''' [http://www.downloadranking.com GEANT4] | ||
+ | |||
+ | ==Подготовка== | ||
+ | |||
+ | Нам понадобится несколько файлов. | ||
+ | |||
+ | ===Математическая библиотека CLHEP=== | ||
+ | |||
+ | CLHEP (A Class Library for High Energy Physics) содержит | ||
+ | базовые операции для | ||
+ | манипуляций с векторами, матрицами, случайными числами и т. п. | ||
+ | <!--Lupus-->Содержит описание стандартных математических объектов, часто используемых в ФВЭ: | ||
+ | *3-векторы и 4-векторы | ||
+ | *действия с матрицами | ||
+ | *геометрические объекты и преобразования | ||
+ | *генераторы случайных чисел | ||
+ | *система единиц и основные физические константы | ||
+ | <!--/Lupus--> | ||
+ | |||
+ | Эту библиотеку нам придется установить из исходного кода. Соответствующий | ||
+ | архив можно взять здесь: http://proj-clhep.web.cern.ch/proj-clhep/, | ||
+ | по ссылке Downloading / Latest source code. | ||
+ | |||
+ | Обычно доступно сразу несколько версий CLHEP, и на ее сайте | ||
+ | ничего не сказано о том, какую версию использовать для | ||
+ | работы с Geant4. В действительности, последняя версия Clhep | ||
+ | не всегда совместима с Geant4 — могут возникать различные | ||
+ | непонятные проблемы: ошибки компиляции, утечки памяти, и т. д. | ||
+ | Лучше всего скачивать ту версию CLHEP, с которой был протестирован Geant. | ||
+ | Это написано на [http://geant4.web.cern.ch/geant4/support/download.shtml сайте загрузки Geant] | ||
+ | в разделе '''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. | ||
+ | Их нужно точно так же скачать, нажав на соответствующие кнопки. | ||
+ | |||
+ | ==Установка== | ||
+ | |||
+ | В дальнейшем полагаем, что у нас есть директория <tt>~/geantfiles/</tt> в которую | ||
+ | были загружены все перечисленные выше файлы. | ||
===CLHEP=== | ===CLHEP=== | ||
- | Математическая библиотечка CLHEP содержит базовые операции для | + | Будем устанавливать библиотеку в директорию <tt>/usr/local/CLHEP</tt>. |
- | манипуляций с векторами, матрицами, случайными числами и т. п. Обычно | + | |
- | в один момент времени доступно несколько версий CLHEP, и на ее сайте | + | Переходим в <tt>~/geantfiles/</tt>: |
- | ничего не сказано на предмет того, какую версию использовать для | + | $ cd ~/geantfiles |
- | работы с G4. На самом деле, не всегда последняя версия Clhep | + | и выполняем следующие команды: |
- | совместима с Geant — например, если вы попытаетесь собрать | + | $ tar xzf clhep-2.0.3.1.tgz |
- | <tt>geant4.7</tt> с <tt>clhep-2.0</tt>, то неприятным сюрпризом для | + | $ cd 2.0.3.1/CLHEP |
- | вас окажутся утечки памяти в физических процессах, такие, что при | + | Далее переходим в режим администратора |
- | числе PrimaryEvents 1×10<sup>6</sup> использование памяти будет в | + | $ su (или sudo -s) |
- | районе 500 Mb. Так что лучше всего будет на домашней страничке Geant | + | Password: |
- | выяснить, какая версия clhep была использованна для тестирования | + | и продолжаем: |
- | последнего релиза Geant4 и воспользоваться именно ей. | + | # ./configure --prefix=/usr/local/CLHEP --disable-shared |
+ | # make && make install | ||
+ | |||
+ | Здесь мы отключили компиляцию динамических библиотек по | ||
+ | причинам, которые станут ясны несколько позднее. | ||
+ | |||
+ | ===Geant4: распаковка=== | ||
+ | |||
+ | Мы будем устанавливать Geant в директорию <tt>/usr/local/geant4</tt>. Сначала | ||
+ | мы распакуем архив в эту папку, а потом запустим скрипт '''Configure''', | ||
+ | который сделает всё остальное. | ||
+ | |||
+ | # cd ~/geantfiles | ||
+ | # tar xzf geant4.8.2.p01.gtar.gz -C /usr/local | ||
+ | # cd /usr/local | ||
+ | |||
+ | Теперь пишем "mv ge" и нажимаем табуляцию. Строчка развернётся до | ||
+ | |||
+ | # mv geant4.8.2.p01 | ||
+ | |||
+ | <tt>geant4.8.2.p01</tt> -- так называлась папка внутри архива. | ||
+ | Дописываем через пробел "geant4" и нажимаем '''Enter''': | ||
+ | |||
+ | # mv geant4.8.2.p01 geant4 | ||
+ | |||
+ | Тем самым мы переименовываем её | ||
+ | в <tt>geant4</tt>, как и хотели. | ||
+ | |||
+ | ===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=== |
- | clhep-1.9.2.2, которую можно скачать [http://cern.ch/clhep/clhep-1.9.2.2.tgz здесь]. | + | |
- | Сборка Clhep — процесс прямолинейный. Предполагая, что | + | Переходим обратно: |
- | устанавливать ее вы будете в <tt>/usr/local/CLHEP</tt>, необходимо | + | # cd /usr/local/geant4 |
- | выполнить следующие команды (в режиме суперпользователя): | + | |
- | $ tar xzf clhep-1.9.2.2 | + | |
- | $ cd 1.9.2.2/CLHEP | + | |
- | $ ./configure --prefix=/usr/local/CLHEP --disable-shared | + | |
- | $ make && make install | + | |
- | Здесь мы отключили компиляцию динамических библиотек по причинам, которые станут ясны несколько позднее. | + | |
- | Все. | + | |
- | ===Configure=== | + | Теперь запускаем собственно скрипт '''Configure''': |
- | Секрет быстрой и безболезненной установки Geant4 — скрипт | + | # ./Configure -build |
- | '''Configure''', находящийся в корневой директории пакета. | + | |
- | С сайта CERN скачивается последняя версия | + | Его работа состоит в том, что он задаст вам несколько |
- | Geant4. На текущий момент (Tue Jan 17 2006) таковая — | + | |
- | geant4.8.0, которую можно скачать [http://geant4.cern.ch/source/source/geant4.8.0.gtar.gz здесь]. Распаковывается: | + | |
- | $ tar xzf geant4.8.0.gtar.gz -С <директория инсталляции> | + | |
- | $ cd <директория инсталляции>/geant4.8.0 | + | |
- | Здесь <tt><директория инсталляции></tt> это место, где будет | + | |
- | установлен Geant. Например, <tt>/usr/local</tt>. Всю дальнейшую работу | + | |
- | за нас сделает '''Configure''', который запускается командой <tt>./Configure | + | |
- | -build</tt>. Его работа состоит в том, что он задаст вам несколько | + | |
вопросов и на основании ваших ответов создаст конфигурацию для | вопросов и на основании ваших ответов создаст конфигурацию для | ||
установки и использований Geant4. Итак, первые несколько экранов | установки и использований Geant4. Итак, первые несколько экранов | ||
Line 116: | Line 186: | ||
Следующий вопрос касается портабельности сгенерированных | Следующий вопрос касается портабельности сгенерированных | ||
Configure скриптов, которые будут в дальнейшем использоваться | Configure скриптов, которые будут в дальнейшем использоваться | ||
- | при компиляции программ на основе Geant. | + | при компиляции программ на основе 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] | Do you expect to run these scripts and binaries on multiple machines? [n] | ||
На этот вопрос стоит ответить y, если вы планируете использовать | На этот вопрос стоит ответить y, если вы планируете использовать | ||
- | одну и ту же установку Geant по сети, или, скажем, просто захотите | + | одну и ту же установку Geant4 по сети, или, скажем, просто захотите |
скопировать его с одной машины на другую. На уже откомпилированные | скопировать его с одной машины на другую. На уже откомпилированные | ||
программы ограничения ответа n не распространяются, но и ответ | программы ограничения ответа n не распространяются, но и ответ | ||
Line 126: | Line 205: | ||
'''Enter''' | '''Enter''' | ||
- | Where is Geant4 source installed? [/soft/GEANT4] | + | Where is Geant4 source installed? [/usr/local/geant4] |
Где находится исходный код Geant. Ответ по умолчанию подходит. | Где находится исходный код Geant. Ответ по умолчанию подходит. | ||
- | |||
Specify the path where Geant4 libraries and source files should be | Specify the path where Geant4 libraries and source files should be | ||
- | installed. [/soft/GEANT4] | + | installed. [/usr/local/geant4] |
- | + | Куда будет установлен ''Geant4''. Так как мы планируем устанавливать его | |
- | Куда будет установлен ''Geant4''. Так как мы планируем устанавлнивать его | + | |
в ту же самую директорию, куда и распаковали, то соглашаемся с | в ту же самую директорию, куда и распаковали, то соглашаемся с | ||
предложенным вариантом (нажатием '''Enter''') | предложенным вариантом (нажатием '''Enter''') | ||
- | + | Do you want to copy all Geant4 headers | |
- | Do you want to copy all Geant4 headers | + | |
in one directory? [n] | in one directory? [n] | ||
'''Configure''' любезно предлагает скопировать все заголовочные файлы ''Geant4'' | '''Configure''' любезно предлагает скопировать все заголовочные файлы ''Geant4'' | ||
в одну папку. В принципе это может оказаться в один момент очень | в одну папку. В принципе это может оказаться в один момент очень | ||
удобно, так что отвечаем '''y'''. | удобно, так что отвечаем '''y'''. | ||
- | |||
Please, specify default directory where ALL the Geant4 data is installed: | Please, specify default directory where ALL the Geant4 data is installed: | ||
- | G4LEVELGAMMADATA: /soft/GEANT4/data/PhotonEvaporation2.0 | + | G4LEVELGAMMADATA: /usr/local/geant4/data/PhotonEvaporation2.0 |
- | G4RADIOACTIVEDATA: /soft/GEANT4/data/RadiativeDecay3.0 | + | G4RADIOACTIVEDATA: /usr/local/geant4/data/RadioactiveDecay3.1 |
- | G4LEDATA: /soft/GEANT4/data/G4EMLOW3.0 | + | G4LEDATA: /usr/local/geant4/data/G4EMLOW4.2 |
- | NeutronHPCrossSections: /soft/GEANT4/data/G4NDL3.7 | + | NeutronHPCrossSections: /usr/local/geant4/data/G4NDL3.10 |
- | G4ELASTICDATA: /soft/GEANT4/data/G4ELASTIC1.1 | + | You will be asked about customizing these next. |
- | You will be asked about customizing these next. | + | |
- | [/soft/GEANT4/data] | + | [/usr/local/geant4/data] |
- | Directory /soft/GEANT4/data doesn't exist. Use that name anyway? [n] y | + | Нажимаем '''Enter''', ибо в предыдущем пункте мы распаковали файлы как раз в указываемое место. |
+ | Please, specify where CLHEP is installed: | ||
- | Please, specify default directory where the Geant4 data is installed: | + | CLHEP_BASE_DIR: |
- | 1) G4LEVELGAMMADATA: /soft/GEANT4/data/PhotonEvaporation | + | |
+ | Пишем "/usr/local/CLHEP" и жмём '''Enter'''. | ||
+ | You can customize paths and library name of you CLHEP installation: | ||
- | 2) G4RADIOACTIVEDATA: /soft/GEANT4/data/RadiativeDecay | + | 1) CLHEP_INCLUDE_DIR: /usr/local/CLHEP/include |
+ | 2) CLHEP_LIB_DIR: /usr/local/CLHEP/lib | ||
+ | 3) CLHEP_LIB: CLHEP | ||
- | 3) G4LEDATA: /soft/GEANT4/data/G4EMLOW3.0 | + | You |
+ | To modify default settings, select number above (e.g. 2) | ||
- | 4) NeutronHPCrossSections: /soft/GEANT4/data/G4NDL3.7 | ||
- | |||
- | 5) G4ELASTICDATA: /soft/GEANT4/data/G4ELASTIC1.1 | ||
- | |||
- | To modify default settings, select number above (e.g. 2) | ||
[Press [Enter] for default settings] | [Press [Enter] for default settings] | ||
- | + | Жмём '''Enter'''. | |
- | В этой серии вопросов нам предлагается ответить, где будут | + | |
- | установленны файлы данных, используемые некоторыми процессами | + | |
- | Geant4. Я предлагаю согласиться со значениями по умолчанию, нажав | + | |
- | '''Enter''' в ответ на первый вопрос, ответив '''y''' на второй и | + | |
- | снова '''Enter''' на третий. | + | |
- | + | ||
- | Please, specify where CLHEP is installed (set by default): | + | |
- | + | ||
- | CLHEP_BASE_DIR: /usr/local | + | |
- | + | ||
- | According to it will be set: | + | |
- | + | ||
- | CLHEP_INCLUDE_DIR | + | |
- | CLHEP_LIB_DIR | + | |
- | + | ||
- | You will be asked about customizing these next. | + | |
- | [/usr/local] | + | |
- | + | ||
- | Здесь необходимо указать, где был установлен CLHEP. Введите имя | + | |
- | директории, которую вы выбрали на предыдущем этапе (<tt>/usr/local/CLHEP</tt>), и нажмите | + | |
- | '''Enter'''. Затем вас попросят уточнить детали ее расположения, и вам | + | |
- | снова достаточно будет согласиться с предложениями по умолчанию. | + | |
- | + | ||
By default 'static' (.a) libraries are built. | By default 'static' (.a) libraries are built. | ||
Line 216: | Line 269: | ||
неудобным в каких-то случаях. На Athlon 1700+ с 512 Мб памяти | неудобным в каких-то случаях. На Athlon 1700+ с 512 Мб памяти | ||
использование глобальных (больших) библиотек никак не замедляет работу | использование глобальных (больших) библиотек никак не замедляет работу | ||
- | с Geant4. | + | с Geant4. Итак, '''y'''. |
Granular libraries are used by defaults, you asked to build global | Granular libraries are used by defaults, you asked to build global | ||
Line 404: | Line 457: | ||
- | Creating configuration setup file... | + | Stripping down executable paths... |
+ | |||
+ | Creating configuration setup file... | ||
WARNING: the generated configuration file | WARNING: the generated configuration file | ||
can be edited if necessary! | can be edited if necessary! | ||
You can introduce any change to the configuration file | You can introduce any change to the configuration file | ||
- | /soft/GEANT4/.config/bin/Linux-g++/config.sh before the final installation. | + | /usr/local/geant4/.config/bin/Linux-g++/config.sh before the final installation. |
- | To do so, use a shell escape now (e.g. !vi /soft/GEANT4/.config/bin/Linux-g++/config.sh). | + | 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: | Press [Enter] to start installation or use a shell escape to edit config.sh: | ||
- | О да. Готово. Нажимаем '''Enter''' и ждем несколько часов. Затем, если | + | О да. Готово. Нажимаем '''Enter''' и ждем несколько часов. |
- | компиляция завершится успешно, то последним шагом в установке GEANT4 с | + | |
- | вашей стороны будет команда <tt>./Configure -install</tt>. | + | |
- | Единственное, если вы все-таки указали ему, что хотели бы использовать | + | ===После чая=== |
+ | Если компиляция завершится успешно, то последним шагом в установке GEANT4 с | ||
+ | вашей стороны будет команда | ||
+ | # ./Configure -install | ||
+ | |||
+ | Наконец, добавляем в файлик <tt>~/.bash_profile</tt> ссылочку на сгенерированный '''Configure''' скрипт env.sh: | ||
+ | # exit | ||
+ | $ echo . /usr/local/geant4/.config/bin/Linux-g++/env.sh >> ~/.bash_profile | ||
+ | |||
+ | Если не заработает с <tt>.bash_profile</tt> (шансы 50/50), то вызов env.sh нужно поместить в файл <tt>~/.bashrc</tt>. | ||
+ | |||
+ | Прогоняем его, дабы всё заработало уже сейчас: | ||
+ | $ . ~/.bash_profile | ||
+ | |||
+ | Если вы все-таки указали ему, что хотели бы использовать | ||
GEANT в виде динамических библиотек, то, возможно, вам понадобится | GEANT в виде динамических библиотек, то, возможно, вам понадобится | ||
указать их месторасположение динамическому линкеру. Для этого можно | указать их месторасположение динамическому линкеру. Для этого можно | ||
сделать, например, так: | сделать, например, так: | ||
- | $ su | + | $ sudo -s |
+ | Password: | ||
# echo $G4INSTALL/lib/Linux-g++ > /etc/ld.so.conf.d/GEANT.conf | # echo $G4INSTALL/lib/Linux-g++ > /etc/ld.so.conf.d/GEANT.conf | ||
# /sbin/ldconfig | # /sbin/ldconfig | ||
- | Теперь уже точно все. Не забудьте добавить в свой файлик <tt>~/.bash_profile</tt> ссылочку на сгенерированный '''Configure''' скрипт env.sh: | + | ===Проверка=== |
- | . /soft/GEANT4/.config/bin/Linux-g++/env.sh | + | Перейдём в папку с примером: |
- | + | $ cd /usr/local/geant4/examples/novice/N03 | |
- | От души поздравляю! | + | Скомпилируем и запустим пример. |
+ | $ make && exampleN03 | ||
+ | Вводим: | ||
+ | $ Idle> /run/beamOn | ||
+ | На другом окне должна появиться кривая зелёная линия. Если она появилась, то всё прошло успешно. От души поздравляю! |
Current revision
Содержание |
Введение
Пошаговое руководство по установке 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
На другом окне должна появиться кривая зелёная линия. Если она появилась, то всё прошло успешно. От души поздравляю!