SetupAndUseGdml

Revision as of 16:47, 14 Feb 2006
217.20.209.178 (Talk | contribs)

← Go to previous diff
Current revision
213.131.7.83 (Talk | contribs)

Line 1: Line 1:
===Что такое GDML=== ===Что такое GDML===
-GDML — это аббревиатура, образованная от слов Geometry Description Markup Language. То бишь, язык разметки описания геометрии. [http://cern.ch/gdml Домашняя страничка GDML]. В принципе, это независимый от [[GEANT4]] проект, но нам неизвестны случаи его использования отдельно от последнего. GDML позволяет описывать геометрию и материалы в файлах XML, что оказывается очень удобным, так как защищает от целого ряда ошибок, возникающих при попытке сделать то же самое в коде на Си++. Кроме того заманчива сама идея изменять геометрию вашей установки на Geant без перекомпиляции программы. 
-А какие перспективы открываются, если поразмыслить на предмет конвертации в GDML существующих форматов файлов из разнообразных 3D-моделлеров и CAD-ов…+GDML — это аббревиатура, образованная от слов Geometry
 +Description Markup Language. То бишь, язык разметки описания
 +геометрии. [http://cern.ch/gdml Домашняя страничка GDML]. В принципе,
 +это независимый от [[GEANT4]] проект, но нам неизвестны случаи его
 +использования отдельно от последнего. GDML позволяет описывать
 +геометрию и материалы в файлах XML, что оказывается очень удобным, так
 +как защищает от целого ряда ошибок, возникающих при попытке сделать то
 +же самое в коде на Си++. Кроме того заманчива сама идея изменять
 +геометрию вашей установки на Geant без перекомпиляции программы.
-К сожалению, установка GDML — мероприятие сопряженное с множеством трудностей. Связаны они, прежде всего, с тем, что код библиотеки GDML содержит некоторые синтаксические элементы, которые, строго говоря, не являются валидными, но GCC версий 3.x не обращал на них внимание. С выходом версии 4, однако, этой вольнице пришел конец, и лишние точки-с-запятой, щедро разбросанные там и сям в коде GDML, считаются им за ошибки. Собственно, удаление этих лишних знаков пунктуации и является самой длительной и неприятной операцией при установке его на современные системы, которые все уже давно перешли на GCC 4.+А какие перспективы открываются, если поразмыслить на предмет
 +конвертации в GDML существующих форматов файлов из разнообразных
 +3D-моделлеров и CAD-ов…
 + 
 +К сожалению, установка GDML — мероприятие сопряженное с
 +множеством трудностей. Связаны они, прежде всего, с тем, что код
 +библиотеки GDML содержит некоторые синтаксические элементы, которые,
 +строго говоря, не являются валидными, но GCC версий 3.x не обращал на
 +них внимание. С выходом версии 4, однако, этой вольнице пришел конец,
 +и лишние точки-с-запятой, щедро разбросанные там и сям в коде GDML,
 +считаются им за ошибки. Собственно, удаление этих лишних знаков
 +пунктуации и является самой длительной и неприятной операцией при
 +установке его на современные системы, которые все уже давно перешли на
 +GCC 4.
 + 
 +<em>В данном документе будет описываться процесс установки GDML в
 +Линуксе. На других системах поэкспериментировать мне не довелось,
 +вполне возможно, что там все будет работать, что называется,
 +&laquo;прямо-из-коробки&raquo; (дословный перевод замечательного
 +выражения out-of-the-box, русского аналога которому я не могу
 +припомнить).</em>
 + 
 +===Xerces===
 + 
 +Для работы CppGDML&nbsp;&mdash; так называется библиотека,
 +обеспечивающая работу [[GEANT4]] с GDML&nbsp;&mdash; требуется внешний
 +XML-парсер Xerces-C++. Это разработка Apache Foundation, известной
 +также своим веб-сервером. Xerces существует для Си++ и для Java, нам
 +нужнее первый. В линуксах, доступных мне, в списке стандартных пакетов
 +есть только Xerces-java, так что собирать его Си++-версию мне пришлось
 +самому. Есть вероятность, что в вашей системе будет возможность
 +установить Xerces-C++ из стандартного менеджера пакетов, не возясь с
 +компиляцией.
 + 
 +Исходники берутся
 +[http://www.apache.org/dist/xml/xerces-c/xerces-c-current.tar.gz тут]
 +Почему-то разработчики проигнорировали существующие в линуксе традиции
 +обустройства окружения для сборки программ, и обычной
 +последовательностью из трех команд здесь не обойтись. Пользователям
 +систем на основе RPM можно посоветовать воспользоваться входящим в
 +комплект поставки файлом <tt>xerces-c.spec</tt>, чтобы создать с его
 +помощью готовый к установке rpm в полностью автоматическом режиме,
 +остальным же остается посоветовать попробовать установить себе rpm и
 +rpmbuild, благо я не встречал ныне линуксов, где так или иначе нельзя
 +пользоваться удобствами rpm.
 + 
 + # rpmbuild -bb xerces-c.spec
 + 
 +Эта команда собирает пакет xerces. Чтобы его установить сделайте так:
 + 
 + # rpm -i /usr/src/redhat/RPMS/`uname -m`/xerces-c*.rpm
 + 
 +Понятно, обе эти команды должны выполняться из-под рута.
 + 
 +===CppGDML===
 + 
 +Здесь все сложнее. Скачав из Интернета
 +[http://service-spi.web.cern.ch/service-spi/app/releases/GDML/downloads/GDML_2_4_0.tar.gz
 +файл] с дистрибутивом системы, мы распаковываем его в какую-нибудь
 +директорию.
 + 
 + $ tar xzf GDML_2_4_0.tar.gz -C /geant4
 + 
 +Затем вам понадобится наложить патч, который можно скачать
 +[http://vserv.sinp.msu.ru/temp/gdml-patch.gz здесь]. Для этого:
 + 
 + $ cd /geant4/CPPGDML
 + $ gunzip -c <путь-где-вы-скачали-патчик> | patch -p1
 + 
 +Все оказалось проще, чем я предполагал. Процесс внесения изменений,
 +отраженных в этом патче, занял у меня пару дней, вам же достаточно
 +теперь воспользоваться 50-килобайтным патчиком. А дальше все
 +стандартно:
 + 
 + $ cd /geant4/CPPGDML
 + $ export XERCESCROOT=/usr
 + $ ./configure
 + $ make
 + $ su
 + # make install
 + 
 +<span style="color: red;">Предупреждение: накладывать на исходники
 +CppGDML какие-либо патчи надо лишь в том случае, если вы планируете
 +воспользоваться GCC4 для его сборки. С третьей версией все работает и
 +безо всяких изменений.</span>
 + 
 +===Тюнинг===
 + 
 +Скомпилировали, установили, но все еще ничего не работает&nbsp;&mdash;
 +мне понадобилось удалить все динамические библиотеки, которые создает
 +CppGDML при установке, чтобы удовлетворить линкер.
 + 
 + # rm /usr/local/lib/libG4Processor.so
 + /usr/local/lib/libG4Subscribers.so /usr/local/lib/libG4Writer.so
 + /usr/local/lib/libProcesses.so /usr/local/lib/libSaxana.so
 + /usr/local/lib/libWriter.so
 + 
 +(Это все одна длинная команда) По умолчанию библиотеки устанавливаются
 +в <tt>/usr/local</tt>, если вы модифицировали путь установки, то вам
 +придется удалять их из другого места.
 + 
 +===Использование===
 + 
 +Использование GDML в коде на GEANT4 лежит за пределами этого
 +руководства по установке, мы лишь поясним, как подключать библиотеки к
 +вашей программе. Все достаточно просто. Добавьте в начало мейкфайла
 +следующие строки:
 + 
 + XERCESCROOT=/usr
 +
 + CPPFLAGS+=-I/geant4/CPPGDML/Common/Processes \
 + -I/geant4/CPPGDML/Common/Saxana/ \
 + -I/geant4/CPPGDML/Common/Schema/ \
 + -I/geant4/CPPGDML/Common/Writer/ \
 + -I/geant4/CPPGDML/G4Binding/G4Processor/ \
 + -I/geant4/CPPGDML/G4Binding/G4Subscribers/ \
 + -I/geant4/CPPGDML/G4Binding/G4Writer/
 +
 + EXTRALIBS=-L/usr/local/lib -Wl,--start-group -lG4Subscribers \
 + -lG4Processor -lProcesses -lSaxana -lG4Writer \
 + -lWriter -lxerces-c -lxerces-depdom -Wl,--end-group
 + 
 +Опять же, возможно вам будет необходимо вручную поправить используемые
 +в них пути к заголовочным файлам и бинарным библиотекам.

Current revision

Содержание

Что такое GDML

GDML — это аббревиатура, образованная от слов Geometry Description Markup Language. То бишь, язык разметки описания геометрии. Домашняя страничка GDML (http://cern.ch/gdml). В принципе, это независимый от GEANT4 проект, но нам неизвестны случаи его использования отдельно от последнего. GDML позволяет описывать геометрию и материалы в файлах XML, что оказывается очень удобным, так как защищает от целого ряда ошибок, возникающих при попытке сделать то же самое в коде на Си++. Кроме того заманчива сама идея изменять геометрию вашей установки на Geant без перекомпиляции программы.

А какие перспективы открываются, если поразмыслить на предмет конвертации в GDML существующих форматов файлов из разнообразных 3D-моделлеров и CAD-ов…

К сожалению, установка GDML — мероприятие сопряженное с множеством трудностей. Связаны они, прежде всего, с тем, что код библиотеки GDML содержит некоторые синтаксические элементы, которые, строго говоря, не являются валидными, но GCC версий 3.x не обращал на них внимание. С выходом версии 4, однако, этой вольнице пришел конец, и лишние точки-с-запятой, щедро разбросанные там и сям в коде GDML, считаются им за ошибки. Собственно, удаление этих лишних знаков пунктуации и является самой длительной и неприятной операцией при установке его на современные системы, которые все уже давно перешли на GCC 4.

В данном документе будет описываться процесс установки GDML в Линуксе. На других системах поэкспериментировать мне не довелось, вполне возможно, что там все будет работать, что называется, «прямо-из-коробки» (дословный перевод замечательного выражения out-of-the-box, русского аналога которому я не могу припомнить).

Xerces

Для работы CppGDML — так называется библиотека, обеспечивающая работу GEANT4 с GDML — требуется внешний XML-парсер Xerces-C++. Это разработка Apache Foundation, известной также своим веб-сервером. Xerces существует для Си++ и для Java, нам нужнее первый. В линуксах, доступных мне, в списке стандартных пакетов есть только Xerces-java, так что собирать его Си++-версию мне пришлось самому. Есть вероятность, что в вашей системе будет возможность установить Xerces-C++ из стандартного менеджера пакетов, не возясь с компиляцией.

Исходники берутся тут (http://www.apache.org/dist/xml/xerces-c/xerces-c-current.tar.gz) Почему-то разработчики проигнорировали существующие в линуксе традиции обустройства окружения для сборки программ, и обычной последовательностью из трех команд здесь не обойтись. Пользователям систем на основе RPM можно посоветовать воспользоваться входящим в комплект поставки файлом xerces-c.spec, чтобы создать с его помощью готовый к установке rpm в полностью автоматическом режиме, остальным же остается посоветовать попробовать установить себе rpm и rpmbuild, благо я не встречал ныне линуксов, где так или иначе нельзя пользоваться удобствами rpm.

# rpmbuild -bb xerces-c.spec

Эта команда собирает пакет xerces. Чтобы его установить сделайте так:

# rpm -i /usr/src/redhat/RPMS/`uname -m`/xerces-c*.rpm

Понятно, обе эти команды должны выполняться из-под рута.

CppGDML

Здесь все сложнее. Скачав из Интернета [http://service-spi.web.cern.ch/service-spi/app/releases/GDML/downloads/GDML_2_4_0.tar.gz файл] с дистрибутивом системы, мы распаковываем его в какую-нибудь директорию.

$ tar xzf GDML_2_4_0.tar.gz -C /geant4

Затем вам понадобится наложить патч, который можно скачать здесь (http://vserv.sinp.msu.ru/temp/gdml-patch.gz). Для этого:

$ cd /geant4/CPPGDML
$ gunzip -c <путь-где-вы-скачали-патчик> | patch -p1

Все оказалось проще, чем я предполагал. Процесс внесения изменений, отраженных в этом патче, занял у меня пару дней, вам же достаточно теперь воспользоваться 50-килобайтным патчиком. А дальше все стандартно:

$ cd /geant4/CPPGDML
$ export XERCESCROOT=/usr
$ ./configure
$ make 
$ su
# make install

Предупреждение: накладывать на исходники CppGDML какие-либо патчи надо лишь в том случае, если вы планируете воспользоваться GCC4 для его сборки. С третьей версией все работает и безо всяких изменений.

Тюнинг

Скомпилировали, установили, но все еще ничего не работает — мне понадобилось удалить все динамические библиотеки, которые создает CppGDML при установке, чтобы удовлетворить линкер.

# rm /usr/local/lib/libG4Processor.so
/usr/local/lib/libG4Subscribers.so  /usr/local/lib/libG4Writer.so 
/usr/local/lib/libProcesses.so /usr/local/lib/libSaxana.so 
/usr/local/lib/libWriter.so

(Это все одна длинная команда) По умолчанию библиотеки устанавливаются в /usr/local, если вы модифицировали путь установки, то вам придется удалять их из другого места.

Использование

Использование GDML в коде на GEANT4 лежит за пределами этого руководства по установке, мы лишь поясним, как подключать библиотеки к вашей программе. Все достаточно просто. Добавьте в начало мейкфайла следующие строки:

XERCESCROOT=/usr

CPPFLAGS+=-I/geant4/CPPGDML/Common/Processes \
-I/geant4/CPPGDML/Common/Saxana/ \
-I/geant4/CPPGDML/Common/Schema/ \ 
-I/geant4/CPPGDML/Common/Writer/ \
-I/geant4/CPPGDML/G4Binding/G4Processor/ \
-I/geant4/CPPGDML/G4Binding/G4Subscribers/ \
-I/geant4/CPPGDML/G4Binding/G4Writer/ 

EXTRALIBS=-L/usr/local/lib -Wl,--start-group -lG4Subscribers \ 
-lG4Processor -lProcesses -lSaxana -lG4Writer \
-lWriter -lxerces-c -lxerces-depdom -Wl,--end-group

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

Edit page