Project

General

Profile

Old LArSoftWiki » History » Version 128

Gianluca Petrillo, 05/20/2014 04:24 PM

1 87 Lynn Garren
{{>toc}}
2 87 Lynn Garren
3 29 Erica Snider
h1. LArSoftWiki
4 99 Erica Snider
5 124 Erica Snider
6 125 Erica Snider
7 54 Erica Snider
The LArSoft software is designed to work for all planned and running liquid argon experiments at Fermilab. It is written in C++ and built on the "ROOT":http://root.cern.ch data analysis software, and the "art":https://cdcvs.fnal.gov/projects/art/wiki analysis framework supported by the Fermilab Scientific Computing Division for intensity frontier experiments.
8 1 Brian Rebel
9 126 Erica Snider
  * *[[ Quick-start guide to using and developing LArSoft code ]]*
10 92 Erica Snider
11 1 Brian Rebel
12 1 Brian Rebel
h1. Preliminaries
13 54 Erica Snider
14 99 Erica Snider
15 64 Erica Snider
* Fermilab computing accounts:  see the [[larsoftsvn:Fermilab Computing Access]] page if you need an account.
16 73 Erica Snider
* See [[larsoftsvn:Load Balanced Access to General Purpose VMs]] for information on accessing experiment VMs at Fermilab (e.g., lbnegpvm0X, uboonegpvm0X, etc., collectively known as GPCF.).
17 54 Erica Snider
* See the [[LArSoftWiki#documentation|documentation section below]] for information on working with LArSoft, and using git, git flow, mrb and other tools you will need.
18 73 Erica Snider
* *[[ Supported platforms ]]*
19 1 Brian Rebel
* To join the LArSoft mailing list, please follow "these instructions":http://listserv.fnal.go/users/asp#subscribe%20to%20list using the list name LARSOFT
20 103 Erica Snider
* To get write access to the repositories, send email to rs@fnal.gov, echurch@fnal.gov, greenlee@fnal.gov, trj@fnal.gov.
21 1 Brian Rebel
22 35 Erica Snider
h2. Where to find the software
23 65 Erica Snider
24 91 Erica Snider
* [[ LArSoft repositories, packages and dependencies | What are the repository names and what is in them?]]
25 128 Gianluca Petrillo
* LArSoft module [[ moduleAuthors | authors ]] and [[Librarians|librarians]]
26 97 Erica Snider
* [[ The Fermilab core LArSoft installation | The core LArSoft installation at Fermilab ]]
27 85 Erica Snider
* [[ Experiment-specific code and re-factoring ]]
28 86 Erica Snider
* [[ Sub-package locations ]] (e.g., in which repository can I find the @HitFinder@ sub-package?)
29 81 Erica Snider
* [[ Download instructions ]]
30 110 Lynn Garren
* [[ LArSoft cvmfs ]]
31 65 Erica Snider
32 104 Brian Rebel
h3. "LArSoft Doxygen":http://nusoft.fnal.gov/larsoft/doxsvn/html/index.html
33 50 Erica Snider
34 50 Erica Snider
35 77 Erica Snider
h1. Releases
36 1 Brian Rebel
37 94 Erica Snider
[[LArSoft release list|List of LArSoft releases.]] (Temporarily includes lbnecode and uboonecode)
38 117 Lynn Garren
[[LArSoft release management]] (instructions for the release manager)
39 119 Gianluca Petrillo
[[Breaking Changes]] (or "after the update my code shows 179 compiling errors! HEEELP!!")
40 94 Erica Snider
41 94 Erica Snider
42 1 Brian Rebel
h1. Documentation
43 32 Erica Snider
44 69 Erica Snider
h2. Overview of the user and developer environment
45 69 Erica Snider
46 69 Erica Snider
* [[ The user environment ]] 
47 83 Erica Snider
* [[ The developer environment ]]
48 69 Erica Snider
49 69 Erica Snider
50 69 Erica Snider
51 60 Erica Snider
h2. Working with LArSoft
52 60 Erica Snider
53 107 Erica Snider
h3. How to use the repositories and the build system
54 107 Erica Snider
55 80 Erica Snider
  * *[[ Quick-start guide to using and developing LArSoft code ]]*
56 71 Erica Snider
  * [[ LArSoft repositories, packages and dependencies ]]
57 118 Erica Snider
  * [[The rules and guidelines|Coding guidelines]] 
58 1 Brian Rebel
59 107 Erica Snider
h3. The framework and the LArSoft suite
60 107 Erica Snider
61 1 Brian Rebel
  * [[larsoftsvn:Using the Framework]]
62 68 Erica Snider
  * "ART Tutorial":http://oink.fnal.gov/
63 68 Erica Snider
  * [[larsoftsvn:NuSoft and LArSoft|nutools and LArSoft]]
64 68 Erica Snider
  * [[Using LArSoft on the GPVM nodes]]
65 120 Erica Snider
  * [[larsoftsvn:Package Documentation]]
66 107 Erica Snider
  * [[larsoftsvn:Geometry]]
67 107 Erica Snider
  * [[larsoftsvn:Reconstruction]]
68 107 Erica Snider
  * [[larsoftsvn:Simulation]]
69 107 Erica Snider
  * [[larsoftsvn:Space Points]]
70 107 Erica Snider
  * [[larsoftsvn:Seed Finding and Bezier Tracking]]
71 107 Erica Snider
  * [[larsoftsvn:Optical Simulations]]
72 107 Erica Snider
73 108 Erica Snider
  * "Past LArSoft meeting presentations -- A wealth of physics/technical information (some of which may be out of date since the transition to git / mrb / ups).":https://cdcvs.fnal.gov/redmine/projects/larsoftsvn/documents
74 1 Brian Rebel
75 1 Brian Rebel
76 1 Brian Rebel
77 68 Erica Snider
78 75 Erica Snider
h2. Links to the tools used to work with the software
79 1 Brian Rebel
80 71 Erica Snider
git and git flow:
81 67 Erica Snider
* [[cet-is-public:git flow quick start]] (edited 2/4/2013).
82 98 Erica Snider
* [[cet-is-public:GitTipsAndTricks|Git Tips and Tricks]] (Note that "git help" works, but "man git" and "git help <command>" does not on any of the gpvm machines. Nor do any of the "git <command> -h" commands.) For the purposes of LArSoft development, please please ignore the workflow advice as anything other than an example of how to use various git commands to do specific tasks.
83 1 Brian Rebel
84 72 Erica Snider
Understanding CMakeLists.txt and product_deps files
85 71 Erica Snider
* [[cet-is-public:Cetbuildtools cmake modules]]:  such as @cet_make@ and @cet_add_compiler_flags@. Used in @CMakeLists.txt@ files throughout LArSoft
86 71 Erica Snider
* [[cet-is-public:Art cmake modules]]: such as @art_make@ and @simple_plugin@. Used in @CMakeLists.txt@ files throughout LArSoft
87 71 Erica Snider
* [[cet-is-public:Defining products in the CET build environment]]: explains the @product_deps@ file
88 71 Erica Snider
* [[cet-is-public:AddingProductDependencies|Adding Product Dependencies]]: how to edit the @product_deps@ and @CMakeLists.txt@ files to add dependencies
89 71 Erica Snider
* [[cet-is-public:CodeTips|Various helpful tips for coding in the CET C++ environment]]: things you hope you never need to know
90 71 Erica Snider
* [[cet-is-public:Building your own code with cmake]]:  pointer to a _really_ simple example
91 67 Erica Snider
92 71 Erica Snider
mrb and ups:
93 32 Erica Snider
*  mrb : the multi-repository build tool
94 1 Brian Rebel
*  Re-locatable ups
95 72 Erica Snider
* [[cet-is-public:AboutQualifiers|About qualifiers]]:  the things after "-q" in setup <prod> <ver> -q <qual>
96 33 Erica Snider
97 33 Erica Snider
98 112 William Seligman
h1. How-to
99 112 William Seligman
100 112 William Seligman
* [[ AnalysisExample | Getting started with an analysis task ]]
101 121 Erica Snider
* [[ Running Jobs ]]
102 33 Erica Snider
103 33 Erica Snider
104 33 Erica Snider
h2. Advanced technical how-to's
105 33 Erica Snider
106 33 Erica Snider
h2. Release procedures
107 110 Lynn Garren
108 110 Lynn Garren
h2. [[ LArSoft cvmfs ]]
109 110 Lynn Garren
110 1 Brian Rebel
111 1 Brian Rebel
h1. Walk-through exercises
112 1 Brian Rebel
113 75 Erica Snider
h1. LArSoft code management and distribution
114 1 Brian Rebel
115 103 Erica Snider
* [[Adding / removing users]]
116 75 Erica Snider
* [[Admin scripts]]
117 1 Brian Rebel
* [[LArSoft release management]] 
118 1 Brian Rebel
* [[Procedure to create a new version of larsoft_data]]
119 1 Brian Rebel
* [[Installation procedures]]
120 1 Brian Rebel
* [[Nightly builds]]
121 1 Brian Rebel
* [[Integration build and test system]]
122 1 Brian Rebel
* [[Release notes template]]
123 125 Erica Snider
124 125 Erica Snider
h1. Legacy Redmine project sites
125 125 Erica Snider
126 125 Erica Snider
These were the sites used when LArSoft was developed under cvs and svn + SoftRelTools, respectively:
127 125 Erica Snider
128 125 Erica Snider
[[larsoft-cvs:| LArSoft-cvs wiki for the legacy cvs-based LArSoft project]]
129 125 Erica Snider
[[larsoftsvn:| LArSoft-svn wiki for the legacy svn-based LArSoft project]]
130 125 Erica Snider
131 125 Erica Snider
As of Jan 24, 2014, LArSoft transitioned from svn / SRT to git / mrb / ups, but we retain the legacy projects for historical reasons.
132 33 Erica Snider
133 51 Erica Snider
h1. Working areas
134 34 Erica Snider
135 1 Brian Rebel
136 115 Erica Snider
[[ Detailed documentation on using and developing LArSoft code ]] : under development -- not a resource
137 1 Brian Rebel
138 1 Brian Rebel
[[ Draft quick start revisions ]]
139 1 Brian Rebel
140 116 Gianluca Petrillo
[[ Profiling LArSoft ]]
141 116 Gianluca Petrillo
142 123 Gianluca Petrillo
[[Random number generators in art]]
143 123 Gianluca Petrillo
144 127 Gianluca Petrillo
[[Debugging LArSoft]]
145 127 Gianluca Petrillo
146 115 Erica Snider
Old pages that are no longer relevant or maintainted:
147 1 Brian Rebel
148 115 Erica Snider
* [[Beta re-factoring]]
149 101 Erica Snider
* *Beta testers:  [[ Special instructions for beta testers | read this first ]]*
150 1 Brian Rebel
* *[[ Special instructions for beta testers ]]*
151 115 Erica Snider
* [[LArSoft production transition timeline|Timeline for the production migration to git / mrb / ups]]
152 115 Erica Snider
* [[ Production transition checklist ]]