12 January 2011 Geant4 Advanced Visualization J. Perl 1 DAWN OpenGL How to Control the Drawing Style and Filtering of Detector Geometry and Trajectories,

Slides:



Advertisements
Similar presentations
Working with Profiles in IX1D v 3 – A Tutorial © 2006 Interpex Limited All rights reserved Version 1.0.
Advertisements

2D Graphics Drawing Things. Graphics In your GUI, you might want to draw graphics E.g. draw lines, circles, shapes, draw strings etc The Graphics class.
Microsoft® Office Outlook® 2003 Training
11 January 2011 Geant4 Visualization Commands J. Perl 1 DAWN OpenGL Geant4 Visualization Commands Basic Visualization Commands Makoto Asai (SLAC) slides.
Introduction to Geant4 Visualization
Road Map Introduction to object oriented programming. Classes
12 Dec 2006 J. Perl Recent Developments in Geant4 Vis 1 HepRep/WIRED DAWN OpenGL Recent Developments in Geant4 Visualization Geant4 Lecture Course Tsukuba,
Automating Tasks With Macros
April 2007 J. Perl Geant4 Review 2007: Visualization 1 HepRep/HepRApp DAWN OpenGL Geant4 Review 2007: Visualization Geant4 Review April at CERN.
15 Sept 2007 J. Perl Overview of Geant4 Visualization 1 HepRep/HepRApp DAWN OpenGL Overview of Geant4 Visualization Geant4 Mini-Tutorial Hebden Bridge.
12 May 2007 Geant4 Advanced Visualization J. Perl 1 DAWN OpenGL How to Control the Drawing Style and Filtering of Detector Geometry and Trajectories Geant4.
14 User Documents and Examples I SLAC Geant4 Tutorial 3 November 2009 Dennis Wright Geant4 V9.2.p02.
12 May 2007 J. Perl Future Plans for Geant4 Visualization 1 HepRep/HepRApp DAWN OpenGL Future Plans for Geant4 Visualization What’s Planned for the Next.
18th September 2007New Features in G4 Visualisation Hebden Bridge 1 Visualisation New or improved features 2007 Smooth trajectories Event keeping Picking.
Geant4 Visualization Review
11 May 2007 J. Perl How to Make a Movie 1 Geant4 Visualization Special Topic: How to Make a Movie Joseph Perl SLAC.
A Guide to Oracle9i1 Creating an Integrated Database Application Chapter 8.
12 May 2007 Geant4 Visualization Commands J. Perl 1 DAWN OpenGL Geant4 Visualization Commands Basic Visualization Commands Joseph Perl, SLAC HepRep/HepRApp.
4 November 2009 Geant4 Advanced Visualization J. Perl 1 DAWN OpenGL How to Control the Drawing Style and Filtering of Detector Geometry and Trajectories.
Introduction to a Programming Environment
Inventory Throughout this slide show there will be hyperlinks (highlighted in blue) follow the hyperlinks to navigate to the specified Topic or Figure.
1 Chapter 20 — Creating Web Projects Microsoft Visual Basic.NET, Introduction to Programming.
Key Applications Module Lesson 12 — Word Essentials
Chapter 9 Introduction to ActionScript 3.0. Chapter 9 Lessons 1.Understand ActionScript Work with instances of movie clip symbols 3.Use code snippets.
Creating a MagicInfo Pro Screen Template
Starting Chapter 4 Starting. 1 Course Outline* Covered in first half until Dr. Li takes over. JAVA and OO: Review what is Object Oriented Programming.
EnSight analyze, visualize, communicate EnSight 6.x Advanced Training Part 1 Instructors: Mike Krogh, Anders Grimsrud.
- Circle markers produced by TAsimage: They do not match was is produced on screen. The line width is too thick. Some other markers need to be tune a bit.
XP New Perspectives on Microsoft Access 2002 Tutorial 51 Microsoft Access 2002 Tutorial 5 – Enhancing a Table’s Design, and Creating Advanced Queries and.
Zubanov Alexei, 2006 Aug 07 – Sep 28 QtROOT package extension with Coin3D lib.
Java Programming, 3e Concepts and Techniques Chapter 3 Section 65 – Manipulating Data Using Methods – Java Applet.
Visualisation and (G)UI Authors: Hajime Yoshida and Satoshi Tanaka.
Moodle (Course Management Systems). Assignments 1 Assignments are a refreshingly simple method for collecting student work. They are a simple and flexible.
ANSYS Fundamentals This document contains no technical data subject to the EAR or the ITAR.
06/10/ Working with Data. 206/10/2015 Learning Objectives Explain the circumstances when the following might be useful: Disabling buttons and.
GUI development with Matlab: GUI Front Panel Components 1 GUI front panel components In this section, we will look at -GUI front panel components -Programming.
S. Guatelli, CPS Innovations, Knoxville, 13 th -21 st January Brachytherapy exercise.
XP Tutorial 7New Perspectives on HTML and XHTML, Comprehensive 1 Working with Cascading Style Sheets Tutorial 7.
CS 320 Assignment 1 Rewriting the MISC Osystem class to support loading machine language programs at addresses other than 0 1.
Maria Grazia Pia Detector Response Acknowledgements: A. Lechner, J. Apostolakis, M. Asai, G. Cosmo, A. Howard.
Geant4 Visualization 1 OpenGL DAWN VRML. Visualization Visualization Seeing what one does usually helps One can visualize geometry, hits, trajectories.
WIRED 4 An extensible generic Event Display Mark Donszelmann SLAC, Stanford, U.S.A. CHEP2004, 27 september – 1 october Interlaken, Switzerland.
7 June 2005 Visualization & GGE Demo J. Perl 1 HepRep/WIRED DAWN OpenGL Geant4 Visualization & GGE Demo Joseph Perl, SLAC.
3D Viewers Two main uses: –Detector/event exploration – interactivity priority (15fps min). –Generate presentation material (still/movie renders) – quality.
12 October 2006 G4Vis: Status, New Features and Issues 1 HepRep/WIRED DAWN OpenGL G4Vis: Status, New Features and Issues Geant4 Collaboration Workshop.
1 Class Diagrams. 2 Overview Class diagrams are the most commonly used diagrams in UML. Class diagrams are for visualizing, specifying and documenting.
Programming with Java © 2002 The McGraw-Hill Companies, Inc. All rights reserved. 1 McGraw-Hill/Irwin Chapter 5 Creating Classes.
C++ / G4MICE Course Session 5 Materials in G4MICE Units in G4MICE Visualisation in G4MICE G4MICE Modelling.
Graphics Concepts CS 2302, Fall /17/20142 Drawing in Android.
CS-1030 Dr. Mark L. Hornick 1 Basic C++ State the difference between a function/class declaration and a function/class definition. Explain the purpose.
May 20, 2005Wah-kai Ngai1 Basic Visualization Tutorial Using Geant4.
EDT Chapter 41 Using Layers Chapter 4 Sacramento City College EDT 310.
Geant4 examples Sébastien Incerti On behalf of the Geant4 collaboration with special thanks to Luciano Pandola, INFN.
LAYERS AND OBJECT PROPERTIES. Topics OBJECT PROPERTIES LAYERS OBJECTS AND LAYERS Creating and Naming Layers Making a Layer Current Sorting Layers Controlling.
Visualisation, (G)UI and Analysis The full set of lecture notes of this Geant4 Course is available at
June 4-8, G4 Paris Visualization II P. Gueye/J. Perl 1 DAWN OpenGL Geant4 Visualization Commands Basic Visualization Commands Paul Guèye, HU Courtesy:
CIS 205—Web Design & Development Flash Chapter 3 Working with Symbols and Interactivity.
© Execview Ltd 2015: all rights reserved Execview Scorecard Training/Reference Guide 2013 Key functions guide for Scorecard administrators.
1 CW11 Visualizing ACE3P Results in ParaView Greg Schussman Menlo Park, CA October 10, 2011.
Solid Modeling SolidWorks Layout ENGR 1182 SolidWorks 01.
Starting with an example PART I Set your environment up and get a Geant4 example.
Trajectory and Hit Visualisation Jane Tinslay, SLAC October 2006.
New and Recent Features of Geant4 Visualisation 2016 Sep 2016John Allison -- G4 Workshop Ferrara1.
Visualisation and (G)UI
Unit Six: Labels In this unit… Review Adding Text to Maps
Geant4 Visualization Commands
Geant4 Advanced Visualization
Chapter 3 Creating and Editing Sketched Features
WIRED 4 Event Display Linear Collider Simulation Workshop
Advanced Tips and Tricks
Presentation transcript:

12 January 2011 Geant4 Advanced Visualization J. Perl 1 DAWN OpenGL How to Control the Drawing Style and Filtering of Detector Geometry and Trajectories, plus a few other topics Geant4 Advanced Visualization Joseph Perl, SLAC HepRep/HepRApp Geant4 v9.4

12 January Geant4 Advanced Visualization J. PerlContents Visualization Attributes Visualization Attributes to control color, line style, etc. to control color, line style, etc. to represent particle type, charge, etc. to represent particle type, charge, etc. Trajectory Modeling Trajectory Modeling Advanced Trajectory Modeling Advanced Trajectory Modeling Trajectory and Hit Filtering Trajectory and Hit Filtering Additional Topics Additional Topics Controlling level of detail in geometry Controlling level of detail in geometry Section planes Section planes Reviewing kept events Reviewing kept events Standalone visualization Standalone visualization

12 January Geant4 Advanced Visualization J. Perl How this Document Fits with Other Tutorial Materials This presentation can be used on its own, but gives the most comprehensive introduction to Geant4 visualization when used as part of the following full set of documents: This presentation can be used on its own, but gives the most comprehensive introduction to Geant4 visualization when used as part of the following full set of documents: Introduction to Geant4 Visualization Introduction to Geant4 Visualization Introduction to Geant4 Visualization Introduction to Geant4 Visualization Geant4 Installation Guides Geant4 Installation Guides Geant4 Installation Guides Geant4 Installation Guides Geant4 Visualization Tutorial using the HepRApp HepRep Browser Geant4 Visualization Tutorial using the HepRApp HepRep Browser Geant4 Visualization Tutorial using the HepRApp HepRep Browser Geant4 Visualization Tutorial using the HepRApp HepRep Browser Geant4 Visualization Tutorial using the DAWN Event Display Geant4 Visualization Tutorial using the DAWN Event Display Geant4 Visualization Tutorial using the DAWN Event Display Geant4 Visualization Tutorial using the DAWN Event Display Geant4 Visualization Tutorial using the OpenGL Event Display Geant4 Visualization Tutorial using the OpenGL Event Display Geant4 Visualization Tutorial using the OpenGL Event Display Geant4 Visualization Tutorial using the OpenGL Event Display Geant4 Visualization Commands Geant4 Visualization Commands Geant4 Visualization Commands Geant4 Visualization Commands Geant4 Advanced Visualization Geant4 Advanced Visualization Geant4 Advanced Visualization Geant4 Advanced Visualization See the URLS at the end of this presentation See the URLS at the end of this presentation

12 January Geant4 Advanced Visualization J. Perl Visualization Attributes

12 January Geant4 Advanced Visualization J. Perl Two Kinds of Visualization Attributes G4VisAttributes - carry standard drawing information: G4VisAttributes - carry standard drawing information: Color Color Visible/Invisible Visible/Invisible Wireframe/Solid, etc. Wireframe/Solid, etc. HepRep-Style Attributes - carry arbitrary, user-defined information: HepRep-Style Attributes - carry arbitrary, user-defined information: for trajectories: for trajectories: momentum momentum particle type, etc. particle type, etc. for hits: for hits: energy energy electronics channel number, etc. electronics channel number, etc. for geometry volumes: for geometry volumes: logical volume name logical volume name material, etc. material, etc.

12 January Geant4 Advanced Visualization J. Perl G4VisAttributes G4VisAttributes - carry standard drawing information: G4VisAttributes - carry standard drawing information: Color Color Visible/Invisible Visible/Invisible Wireframe/Solid Wireframe/Solid etc. etc. For the first half of Geant4’s life, these were the only kind of Visualization Attributes For the first half of Geant4’s life, these were the only kind of Visualization Attributes

12 January Geant4 Advanced Visualization J. Perl LineStyle: WireFrame or Solid WireFrame Solid

12 January Geant4 Advanced Visualization J. Perl Setting Geometry Vis Attributes from C++ Create G4VisAttributes object and assign it to a volume: Create G4VisAttributes object and assign it to a volume: experimentalHall_logical -> SetVisAttributes (G4VisAttributes::Invisible) experimentalHall_logical -> SetVisAttributes (G4VisAttributes::Invisible)

12 January Geant4 Advanced Visualization J. Perl Setting Geometry Vis Attributes from Commands You can control the color, linewidth and other attributes of detailed geometry drawing using /vis/geometry commands such as: You can control the color, linewidth and other attributes of detailed geometry drawing using /vis/geometry commands such as: /vis/geometry/set/colour blue /vis/geometry/set/colour blue For the full set of options, see the built-in command guidance. For the full set of options, see the built-in command guidance. A few more examples: A few more examples: Change the line style of a particular volume to dashed Change the line style of a particular volume to dashed /vis/geometry/set/lineStyle dashed /vis/geometry/set/lineStyle dashed Change the line width of all volumes to 3 Change the line width of all volumes to 3 /vis/geometry/set/lineWidth all 3 /vis/geometry/set/lineWidth all 3 Change the number of line segments used to approximate a circle for all volumes to 100 Change the number of line segments used to approximate a circle for all volumes to 100 /vis/geometry/set/forceLineSegmentsPerCircle all /vis/geometry/set/forceLineSegmentsPerCircle all 0 100

12 January Geant4 Advanced Visualization J. Perl Setting Overall Vis Attributes from Commands While the previously shown /vis/geometry commands allow the most detailed control over geometry drawing, the /vis/viewer commands allow you to control a few overall settings /vis/viewer/set/style wireframe /vis/viewer/set/globalLineWidthScale etc. see online command guidance for details Watch out for fact that interactive commands do not override C++ or /vis/geometry commands that have the “force” prefix, such as: experimentalHallVisAtt->SetForceWireframe(true) or /vis/geometry/set/forceSolid experimentalHall

12 January Geant4 Advanced Visualization J. Perl HepRep-Style Attributes HepRep-Style Attributes - carry arbitrary, user-defined information: HepRep-Style Attributes - carry arbitrary, user-defined information: for trajectories: for trajectories: momentum momentum particle type, etc. particle type, etc. for hits: for hits: energy energy electronics channel number, etc. electronics channel number, etc. for geometry volumes: for geometry volumes: logical volume name logical volume name material, etc. material, etc. These attributes were added to Geant4 over the last few years to support advanced features in the HepRep browsers (HepRApp, Wired4 and FRED). These attributes were added to Geant4 over the last few years to support advanced features in the HepRep browsers (HepRApp, Wired4 and FRED). display the attributes when you click on the graphics object display the attributes when you click on the graphics object perform cuts on these values perform cuts on these values label objects by these values label objects by these values

12 January Geant4 Advanced Visualization J. Perl HepRApp: Pick to Show Physics Attributes Picked on this volume to show Material Density Radlen etc Picked on this trajectory to show Particle ID Charge Momentum etc.

12 January 2011 Geant4 Advanced Visualization J. Perl 13 HepRApp: Labeling by Any Attribute

12 January 2011 Geant4 Advanced Visualization J. Perl 14 HepRApp: Cut by Any Attribute

12 January Geant4 Advanced Visualization J. Perl HepRep Attributes beyond the HepRep Browsers Other visualization drivers can also use the HepRep-style attributes: Open Inventor will show the attributes when you click on the relevant object OpenGL also does this, with attributes shown in standard output window Advanced visualization features described later in this presentation also use HepRep attributes and work for all Geant4 visualization drivers: Trajectory Modeling Trajectory and Hit Filtering

12 January Geant4 Advanced Visualization J. Perl Defining Your Own HepRep Attributes While a useful set of attributes is already defined by default in the standard Geant4 trajectory, you are also free to define your own attributes: While a useful set of attributes is already defined by default in the standard Geant4 trajectory, you are also free to define your own attributes: std::map * store = G4AttDefStore::GetInstance("G4Trajectory",isNew); std::map * store = G4AttDefStore::GetInstance("G4Trajectory",isNew); G4String PN("PN"); G4String PN("PN"); (*store)[PN] = G4AttDef(PN,"Particle Name","Physics","","G4String"); (*store)[PN] = G4AttDef(PN,"Particle Name","Physics","","G4String"); G4String IMom("IMom"); G4String IMom("IMom"); (*store)[IMom] = G4AttDef(IMom, "Momentum of track at start of trajectory", "Physics","","G4ThreeVector"); (*store)[IMom] = G4AttDef(IMom, "Momentum of track at start of trajectory", "Physics","","G4ThreeVector"); Then fill the attributes with lines such as: Then fill the attributes with lines such as: std::vector * values = new std::vector ; std::vector * values = new std::vector ; values->push_back(G4AttValue("PN",ParticleName,"")); values->push_back(G4AttValue("PN",ParticleName,"")); s.seekp(std::ios::beg); s.seekp(std::ios::beg); s << G4BestUnit(initialMomentum,"Energy") << std::ends; s << G4BestUnit(initialMomentum,"Energy") << std::ends; values->push_back(G4AttValue("IMom",c,"")); values->push_back(G4AttValue("IMom",c,"")); See geant4/source/tracking/src/G4Trajectory.cc for a good example. See geant4/source/tracking/src/G4Trajectory.cc for a good example.

12 January Geant4 Advanced Visualization J. Perl Trajectory Modeling

12 January Geant4 Advanced Visualization J. Perl Enhanced Trajectory Drawing Ability to change trajectory drawing model through interactive commands Ability to change trajectory drawing model through interactive commands Lets you, for example, Lets you, for example, declare that trajectories should be color-coded by charge, declare that trajectories should be color-coded by charge, then change to have them color-coded by particle type then change to have them color-coded by particle type Eliminates the most common reason users had to code their own trajectory classes Eliminates the most common reason users had to code their own trajectory classes Most examples include a vis.mac that demonstrates some of these features Most examples include a vis.mac that demonstrates some of these features

12 January Geant4 Advanced Visualization J. Perl Creator Process — muIoni — Decay — annihil — eIoni — brem Momentum (MeV) — 0-1 — 1-10 — — — — 50+ Charge — +1 — 0 — -1 Example A01, five events, drawBy various models

12 January Geant4 Advanced Visualization J. Perl Standard Models Supplied with Geant4 drawByCharge drawByCharge  Default model  Colors trajectories according to charge drawByParticleID drawByParticleID  Colors trajectories according to particle type  All trajectories are colored grey by default  Configure to highlight chosen particle types with chosen colors  No limit on the number of particle types that can be highlighted drawByOriginVolume drawByOriginVolume  Colors trajectories according to volume in which they originated  for example, to highlight all particles that backscattered from a particular collimator generic generic  Draws all trajectories the same control over more than just color, including: control over more than just color, including:  Whether to show trajectory as line, step points or both  width of trajectory lines, type of marker to use for points, point size, etc. +1BlueRed 0Green

12 January Geant4 Advanced Visualization J. Perl Model Configuration You can create and configure multiple models through either You can create and configure multiple models through either  Interactive commands  Compiled code Interactive commands Interactive commands Located in /vis/modeling/trajectories directory Located in /vis/modeling/trajectories directory Possible to have multiple instances of given model type Possible to have multiple instances of given model type e.g., toggle between two different ways of coloring by charge e.g., toggle between two different ways of coloring by charge List and select instantiated models with commands: List and select instantiated models with commands:  /vis/modeling/trajectories/list  /vis/modeling/trajectories/select  /vis/modeling/trajectories/select Note that detailed help for a given model is not shown in the help system until you have created an instance of that model Note that detailed help for a given model is not shown in the help system until you have created an instance of that model e.g., only after you do your first: e.g., only after you do your first: /vis/modeling/trajectories/create/drawByCharge /vis/modeling/trajectories/create/drawByCharge will the help system will include details on drawByCharge will the help system will include details on drawByCharge

12 January Geant4 Advanced Visualization J. Perl Trajectory Modeling Examples Example macro #Standard setup /vis/scene/create /vis/open OGLIX /vis/scene/add/volume /vis/scene/add/trajectories /vis/scene/add/hits /vis/viewer/set/lightsThetaPhi /vis/viewer/set/viewpointThetaPhi /vis/viewer/set/style surface /vis/viewer/set/hiddenEdge true #Create drawByParticleID model, highlighting photons /vis/modeling/trajectories/create/drawByParticleID /vis/modeling/trajectories/drawByParticleID-0/set gamma red /run/beamOn 1 … #Create drawByCharge model, coloring neutrals white /vis/modeling/trajectories/create/drawByCharge /vis/modeling/trajectories/drawByCharge-0/set 1 blue /vis/modeling/trajectories/drawByCharge-0/set -1 red /vis/modeling/trajectories/drawByCharge-0/set 0 white /run/beamOn 1a

12 January Geant4 Advanced Visualization J. Perl More Sample Commands: drawByParticleID model # Create a drawByParticleID model named drawByParticleID-0 /vis/modeling/trajectories/create/drawByParticleID # Configure drawByParticleID-0 model /vis/modeling/trajectories/drawByParticleID-0/set gamma red /vis/modeling/trajectories/drawByParticleID-0/set proton yellow /vis/modeling/trajectories/drawByParticleID-0/setRGBA e Note that if you just select drawByParticleID but don’t do any commands to set colors, all particles will be grey. In future releases (starting with 9.4Beta1), default will be better: /vis/modeling/trajectories/drawByParticleID-0/set e- red /vis/modeling/trajectories/drawByParticleID-0/set e+ blue /vis/modeling/trajectories/drawByParticleID-0/set proton cyan /vis/modeling/trajectories/drawByParticleID-0/set gamma green /vis/modeling/trajectories/drawByParticleID-0/set neutron yellow /vis/modeling/trajectories/drawByParticleID-0/set pi+ magenta /vis/modeling/trajectories/drawByParticleID-0/set pi- magenta /vis/modeling/trajectories/drawByParticleID-0/set pi0 magenta

12 January Geant4 Advanced Visualization J. Perl More Sample Commands: drawByCharge Model and Toggling Between Two Models # Create a drawByCharge model (will get default name of drawCharge-0) /vis/modeling/trajectories/create/drawByCharge # Create another drawByCharge model with an explicit name of testChargeModel /vis/modeling/trajectories/create/drawByCharge testChargeModel # Configure these two drawByCharge models and visualize using either one of them # Configure drawByCharge-0 model /vis/modeling/trajectories/drawByCharge-0/set 1 red /vis/modeling/trajectories/drawByCharge-0/set -1 red /vis/modeling/trajectories/drawByCharge-0/set 0 white # Configure testCharge model (showing different way of setting colors) /vis/modeling/trajectories/testChargeModel/setRGBA /vis/modeling/trajectories/testChargeModel/setRGBA /vis/modeling/trajectories/testChargeModel/setRGBA # List available models /vis/modeling/trajectories/list # select drawByCharge-0 to be current /vis/modeling/trajectories/select drawByCharge-0

12 January Geant4 Advanced Visualization J. Perl Trajectory Modeling by HepRep-Style Attributes /vis/modeling/trajectories/create/drawByAttribute /vis/modeling/trajectories/drawByCharge-0/verbose true /vis/modeling/trajectories/drawByCharge-0/setAttribute CPN /vis/modeling/trajectories/drawByAttribute-0/addValue brem_key eBrem /vis/modeling/trajectories/drawByAttribute-0/addValue annihil_key annihil /vis/modeling/trajectories/drawByAttribute-0/addValue decay_key Decay /vis/modeling/trajectories/drawByAttribute-0/addValue muIon_key muIoni /vis/modeling/trajectories/drawByAttribute-0/addValue eIon_key eIoni /vis/modeling/trajectories/drawByAttribute-0/brem_key/setLineColour red /vis/modeling/trajectories/drawByAttribute-0/annihil_key/setLineColour green /vis/modeling/trajectories/drawByAttribute-0/decay_key/setLineColour cyan /vis/modeling/trajectories/drawByAttribute-0/eIon_key/setLineColour yellow /vis/modeling/trajectories/drawByAttribute-0/muIon_key/setLineColour magenta Draw by the attribute called CPN Configure visualisation parameters Select relevant attribute values For even greater flexibility, you can model the trajectory based on any of the HepRep-style attributes, whether it is one of the default ones or an attribute that you have defined for yourself. For even greater flexibility, you can model the trajectory based on any of the HepRep-style attributes, whether it is one of the default ones or an attribute that you have defined for yourself. E.g., set color based the value of the attribute CPN (for “creator process name”) E.g., set color based the value of the attribute CPN (for “creator process name”)

12 January Geant4 Advanced Visualization J. Perl Creator Process — muIoni — Decay — annihil — eIoni — brem Momentum (MeV) — 0-1 — 1-10 — — — — 50+ Example A01, five events, drawByAttribute models

12 January Geant4 Advanced Visualization J. Perl Trajectory Lines, Step Points, Regular and Smooth Yellow are the actual step points used by Geant4 Magenta are auxiliary points added just for purposes of visualization

12 January Geant4 Advanced Visualization J. Perl Modeling Trajectory as Line, Step Points or Both In the discussion of models up to now, we’ve only shown you how to set the color, but a model can include many more options including whether to show the trajectory as a line, a set of step points or both: setDrawLine * Set draw line command setDrawLine * Set draw line command setLineVisible * Set line visibility command setLineVisible * Set line visibility command setLineColour * Set colour through a string setLineColour * Set colour through a string setLineColourRGBA * Set colour through red, green, blue and alpha components setLineColourRGBA * Set colour through red, green, blue and alpha components setDrawStepPts * Set draw step points command setDrawStepPts * Set draw step points command setStepPtsVisible * Set step points colour command setStepPtsVisible * Set step points colour command setStepPtsColour * Set colour through a string setStepPtsColour * Set colour through a string setStepPtsColourRGBA * Set colour through red, green, blue and alpha components setStepPtsColourRGBA * Set colour through red, green, blue and alpha components setStepPtsSize * Set step points colour command setStepPtsSize * Set step points colour command setStepPtsType * Set step points type. setStepPtsType * Set step points type. setStepPtsFillStyle * Set step fill style type. setStepPtsFillStyle * Set step fill style type. (the following items relate to special kind of points discussed later under “smooth trajectory”) (the following items relate to special kind of points discussed later under “smooth trajectory”) setDrawAuxPts * Set draw auxiliary points command setDrawAuxPts * Set draw auxiliary points command setAuxPtsVisible * Set auxiliary points visibility command setAuxPtsVisible * Set auxiliary points visibility command setAuxPtsColour * Set colour through a string setAuxPtsColour * Set colour through a string setAuxPtsColourRGBA * Set colour through red, green, blue and alpha components setAuxPtsColourRGBA * Set colour through red, green, blue and alpha components setAuxPtsSize * Set auxiliary points size command setAuxPtsSize * Set auxiliary points size command setAuxPtsType * Set auxiliary points type. setAuxPtsType * Set auxiliary points type. setAuxPtsFillStyle * Set auxiliary fill style. setAuxPtsFillStyle * Set auxiliary fill style.

12 January Geant4 Advanced Visualization J. Perl Sample Commands: generic trajectory model # Create a generic model (will get default name of generic-0) # From here we can set overall defaults for things like line color, # whether to show step points or just the trajectory line, etc. /vis/modeling/trajectories/create/generic # Configure the generic model to colour all trajectories cyan and to show step points /vis/modeling/trajectories/generic-0/default/setDrawStepPts true /vis/modeling/trajectories/generic-0/default/setStepPtsSize 16 /vis/modeling/trajectories/generic-0/default/setLineColour cyan /vis/modeling/trajectories/generic-0/default/setStepPtsColour red

12 January Geant4 Advanced Visualization J. Perl Advanced Trajectory Modeling

12 January Geant4 Advanced Visualization J. Perl Controlling Model from Compiled Code Instantiate model Instantiate model Configure model Configure model Register with visualization manager Register with visualization manager main.cc // Create and initialise visualization manager G4VisManager* visManager = new G4VisExecutive; visManager->Initialize(); // Create new drawByParticleID model G4TrajectoryDrawByParticleID* model = new G4TrajectoryDrawByParticleID; // Configure model model->SetDefault("cyan"); model->Set("gamma", "green"); model->Set("e+", "magenta"); model->Set("e-", G4Color(0.3, 0.3, 0.3)); //Register model with visualization manager visManager->RegisterModel(model);

12 January Geant4 Advanced Visualization J. Perl Defining Your Own Model New trajectory models must inherit from G4VTrajectoryModel and implement these pure virtual methods: New trajectory models must inherit from G4VTrajectoryModel and implement these pure virtual methods: virtual void Draw(const G4VTrajectory&, G4int i_mode = 0) const = 0; virtual void Draw(const G4VTrajectory&, G4int i_mode = 0) const = 0; virtual void Print(std::ostream& ostr) const = 0; virtual void Print(std::ostream& ostr) const = 0; New models can be used directly in compiled code New models can be used directly in compiled code  Need to be registered with visualization manager main.cc // Create custom model MyCustomTrajectoryModel* myModel = new MyCustomTrajectoryModel("custom"); // Configure it if necessary and then register with G4VisManager... visManager->RegisterModel(myModel)

12 January Geant4 Advanced Visualization J. Perl To Make User Defined Model Available from Interactive Commands You will need to write Messenger classes You will need to write Messenger classes Messengers to configure the model should inherit from G4VModelCommand. The concrete trajectory model type should be used for the template parameter Messengers to configure the model should inherit from G4VModelCommand. The concrete trajectory model type should be used for the template parameter and a Factory class and a Factory class A factory class responsible for the model and associated messenger creation must also be written. The factory should inherit from G4VModelFactory. The abstract model type should be used for the template parameter, e.g.: A factory class responsible for the model and associated messenger creation must also be written. The factory should inherit from G4VModelFactory. The abstract model type should be used for the template parameter, e.g.: G4ModelCommandDrawByParticleIDSet.cc class G4ModelCommandDrawByParticleIDSet : public : G4VModelCommand {... }; G4TrajectoryDrawByChargeFactory.cc class G4TrajectoryDrawByChargeFactory : public G4VModelFactory {... };

12 January Geant4 Advanced Visualization J. Perl Construct the Model and Associated Messengers G4TrajectoryDrawByParticleIDFactory.cc ModelAndMessengers G4TrajectoryDrawByParticleIDFactory::Create(const G4String& placement, const G4String& name) { // Create model with given name G4TrajectoryDrawByParticleID* model = new G4TrajectoryDrawByParticleID(name); // Create associated messengers with commands in ``placement'’ command directory. Messengers messengers; messengers.push_back(new G4ModelCommandDrawByParticleIDSet(model, placement));... return ModelAndMessengers(model, messengers); } G4VisExecutive.cc G4VisExecutive::RegisterModelFactories() {... RegisterModelFactory(new G4TrajectoryDrawByParticleIDFactory()); }

12 January Geant4 Advanced Visualization J. Perl Trajectory and Hit Filtering

12 January Geant4 Advanced Visualization J. Perl Trajectory and Hit Filtering Display user-defined subset of trajectories Display user-defined subset of trajectories Solves problems with overly busy graphics or excessively large graphics files Solves problems with overly busy graphics or excessively large graphics files Similar structure to enhanced trajectory drawing Similar structure to enhanced trajectory drawing Set of simple filter models Set of simple filter models Similar Interactive creation/configuration structure Similar Interactive creation/configuration structure chargeFilter chargeFilter  Filters trajectories according to charge particleFilter particleFilter  Filters trajectories according to particle type originVolumeFilter originVolumeFilter  Filters trajectories according to volume in which they originated Project Lead: Jane Tinslay Project Lead: Jane Tinslay

12 January Geant4 Advanced Visualization J. Perl Momentum (MeV) — — — — — — HandsOn5, McGill tutorial, 1000 events, Attribute Filter IMag > 2.5 MeV IMag > 2.5 MeV, particle = gamma

12 January Geant4 Advanced Visualization J. Perl Trajectory Filtering Simplest example: Simplest example: /vis/filtering/trajectories/create/particleFilter /vis/filtering/trajectories/particleFilter-0/add e- will cause everything except electrons to be filtered out You can chain multiple filters You can chain multiple filters e.g., filter out gammas e.g., filter out gammas and filter out particles with momentum less than 100 MeV and filter out particles with momentum less than 100 MeV Two modes of filtering: Two modes of filtering: Important issue when working with those visualization drivers that allow you to turn visibility on and off from the vis application (HepRApp or OpenInventor) Important issue when working with those visualization drivers that allow you to turn visibility on and off from the vis application (HepRApp or OpenInventor) One mode has rejected trajectories marked invisible but still sent to vis app One mode has rejected trajectories marked invisible but still sent to vis app user can toggle them back to visible from within the vis app user can toggle them back to visible from within the vis app but if there is a very large number of these invisible trajectories, application may be slowed down and files may be very large but if there is a very large number of these invisible trajectories, application may be slowed down and files may be very large Other mode has rejected trajectories entirely omitted Other mode has rejected trajectories entirely omitted user cannot toggle them back to visible from within the vis app user cannot toggle them back to visible from within the vis app but application stays fast and files stay small but application stays fast and files stay small

12 January Geant4 Advanced Visualization J. Perl Filtering Example /vis/modeling/trajectories/drawByAttribute-0/setAttribute IMag /vis/modeling/trajectories/drawByAttribute-0/addInterval interval1 0.0 keV 2.5MeV /vis/modeling/trajectories/drawByAttribute-0/addInterval interval2 2.5 MeV 5 MeV /vis/modeling/trajectories/drawByAttribute-0/addInterval interval3 5 MeV 7.5 MeV /vis/modeling/trajectories/drawByAttribute-0/addInterval interval4 7.5 MeV 10 MeV /vis/modeling/trajectories/drawByAttribute-0/addInterval interval5 10 MeV 12.5 MeV /vis/modeling/trajectories/drawByAttribute-0/addInterval interval MeV MeV /vis/modeling/trajectories/drawByAttribute-0/interval1/setLineColourRGBA /vis/modeling/trajectories/drawByAttribute-0/interval2/setLineColourRGBA /vis/modeling/trajectories/drawByAttribute-0/interval3/setLineColourRGBA /vis/modeling/trajectories/drawByAttribute-0/interval4/setLineColourRGBA /vis/modeling/trajectories/drawByAttribute-0/interval5/setLineColourRGBA /vis/modeling/trajectories/drawByAttribute-0/interval6/setLineColourRGBA /vis/filtering/trajectories/create/attributeFilter /vis/filtering/trajectories/attributeFilter-0/setAttribute IMag /vis/filtering/trajectories/attributeFilter-0/addInterval 2.5 MeV 1000 MeV /vis/filtering/trajectories/create/particleFilter /vis/filtering/trajectories/particleFilter-0/add gamma Momentum interval based colour scale Momentum filter Gamma filter Configure visualisation properties Momentum filter

12 January Geant4 Advanced Visualization J. Perl Hit Filtering The Attribute-Based filtering discussed above for Trajectories was implemented generically so that it can a pply to any class which implements the Geant4 generic attributes method: The Attribute-Based filtering discussed above for Trajectories was implemented generically so that it can a pply to any class which implements the Geant4 generic attributes method: Whatever your Hit class, you can basically get interactive hit filtering for free Whatever your Hit class, you can basically get interactive hit filtering for free To activate, add a filter call to G4VVisManager in Draw method of hit class To activate, add a filter call to G4VVisManager in Draw method of hit class const std::map * GetAttDefs() const; std::vector * CreateAttValues() const; const std::map * GetAttDefs() const; std::vector * CreateAttValues() const; void MyHit::Draw() { … if (! pVVisManager->FilterHit(*this)) return; … void MyHit::Draw() { … if (! pVVisManager->FilterHit(*this)) return; …

12 January Geant4 Advanced Visualization J. Perl Additional Topics

12 January Geant4 Advanced Visualization J. Perl Controlling Detail Level of Detector Geometry By default, /vis/drawVolume will draw the entire detector geometry. This is equivalent to the commands: By default, /vis/drawVolume will draw the entire detector geometry. This is equivalent to the commands: /vis/scene/create /vis/scene/create /vis/scene/add/volume world /vis/scene/add/volume world You can specify additional arguments to limit the amount of geometry detail shown: You can specify additional arguments to limit the amount of geometry detail shown: /vis/scene/add/volume [ ] [ ] [ ] /vis/scene/add/volume [ ] [ ] [ ] 1st parameter: volume name (default "world"). 1st parameter: volume name (default "world"). 2nd parameter: copy number (default -1 meaning first occurrence of physical-volume-name is selected. 2nd parameter: copy number (default -1 meaning first occurrence of physical-volume-name is selected. 3rd parameter: depth of descending geometry hierarchy (default G4Scene::UNLIMITED (-1)). 3rd parameter: depth of descending geometry hierarchy (default G4Scene::UNLIMITED (-1)). Still more arguments can be given to specify a clipping volume. Still more arguments can be given to specify a clipping volume. vis/scene/add/volume world box km will draw the world with the positive octant cut away. vis/scene/add/volume world box km will draw the world with the positive octant cut away.

12 January Geant4 Advanced Visualization J. Perl Even more Control over Level of Detail in Detector Geometry Additional commands allow finer control including whether or not to draw Boolean components, voxels and readout geometries: Additional commands allow finer control including whether or not to draw Boolean components, voxels and readout geometries: /vis/specify [depth-of-descent] [ ] [ ] [ ] /vis/specify [depth-of-descent] [ ] [ ] [ ] /vis/scene/add/logicalVolume [ ] [ ] [ ] /vis/scene/add/logicalVolume [ ] [ ] [ ] Culling allows you to specify that covered daughters or low density volumes are omitted: Culling allows you to specify that covered daughters or low density volumes are omitted: /vis/viewer/set/culling global|coveredDaughters|invisible|density [true|false] [density] [unit] /vis/viewer/set/culling global|coveredDaughters|invisible|density [true|false] [density] [unit] HepRepFile will still include these culled objects, but just make them initially invisible. HepRepFile will still include these culled objects, but just make them initially invisible. Idea is that you might later decide you want to see these. Idea is that you might later decide you want to see these. To really omit them from the HepRepFile, as you may wish to do to make the file smaller: To really omit them from the HepRepFile, as you may wish to do to make the file smaller: /vis/heprep/setCullInvisibles true /vis/heprep/setCullInvisibles true

12 January Geant4 Advanced Visualization J. Perl Section Planes / Cutaways Some drivers allow you to section the view, that is, cut it away along a specified plane (but this generally works only for simple geometries) Some drivers allow you to section the view, that is, cut it away along a specified plane (but this generally works only for simple geometries) /vis/viewer/set/sectionPlane [on|off] [unit of point] /vis/viewer/set/sectionPlane [on|off] [unit of point] e.g., for a y-z plane at x = 1 cm: /vis/viewer/set/sectionPlane on cm e.g., for a y-z plane at x = 1 cm: /vis/viewer/set/sectionPlane on cm 1 0 0

12 January Geant4 Advanced Visualization J. Perl Reviewing Kept Events If you have accumulated several events in your visualization, you can still go back afterwards and view the events individually. For each event, you can execute various vis commands to rotate, zoom, output to a different vis driver, etc. If you have accumulated several events in your visualization, you can still go back afterwards and view the events individually. For each event, you can execute various vis commands to rotate, zoom, output to a different vis driver, etc. /vis/reviewKeptEvents /vis/reviewKeptEvents Each time you type “continue”, you will get to the next kept event. Each time you type “continue”, you will get to the next kept event. To quit reviewing events: To quit reviewing events: /vis/abortReviewKeptEvents /vis/abortReviewKeptEvents and then again type “continue” and then again type “continue” You can also use a command or c++ calls to force keeping of specific events regardless of how visualization is accumulating them. You can also use a command or c++ calls to force keeping of specific events regardless of how visualization is accumulating them. e.g., keep events based on a particular hit or trigger pattern e.g., keep events based on a particular hit or trigger pattern From the command line: From the command line: /event/keepCurrentEvent /event/keepCurrentEvent From C++ From C++ G4EventManager->KeepTheCurrentEvent() G4EventManager->KeepTheCurrentEvent() This feature makes it easy to do a large run and then recall for visualization only those events that are of interest This feature makes it easy to do a large run and then recall for visualization only those events that are of interest

12 January Geant4 Advanced Visualization J. Perl Reviewing Kept Events flagged from C++ If you’re using C++ to flag which events to keep, so that you can do a large run but only visualize a few special events, mix event keeping with the vis disable/enable commands, as follows: If you’re using C++ to flag which events to keep, so that you can do a large run but only visualize a few special events, mix event keeping with the vis disable/enable commands, as follows: /vis/open HepRepFile /vis/open HepRepFile /vis/drawVolume /vis/drawVolume /vis/scene/add/trajectories /vis/scene/add/trajectories /vis/disable /vis/disable /run/beamOn 1000 /run/beamOn 1000 /vis/enable /vis/enable /vis/reviewKeptEvents /vis/reviewKeptEvents In this way, the visualization is disabled when you first run through the 1000 events, and is enabled only when you are reviewing the small number of special events that you flagged from your C++ call: In this way, the visualization is disabled when you first run through the 1000 events, and is enabled only when you are reviewing the small number of special events that you flagged from your C++ call: G4EventManager->KeepTheCurrentEvent() G4EventManager->KeepTheCurrentEvent()

12 January Geant4 Advanced Visualization J. Perl Geant4 Visualization in Standalone Mode The Geant4 Visualization system can be used on its own - without the rest of Geant4. The Geant4 Visualization system can be used on its own - without the rest of Geant4. Build something “by hand” from the Geant4 geometry primitives and placement apparatus, but without any of the main parts of Geant4 such as detector construction, run manager or physics list. Build something “by hand” from the Geant4 geometry primitives and placement apparatus, but without any of the main parts of Geant4 such as detector construction, run manager or physics list. Still preserves all of the interactive apparatus of the visualization system. Still preserves all of the interactive apparatus of the visualization system. See the example: /examples/extended/visualization/standalone See the example: /examples/extended/visualization/standalone // Simple box... pVisManager->Draw(G4Box("box",2*m,2*m,2*m), G4VisAttributes(G4Colour(1,1,0))); // Boolean solid... G4Box boxA("boxA",3*m,3*m,3*m); G4Box boxB("boxB",1*m,1*m,1*m); G4SubtractionSolid subtracted("subtracted_boxes",&boxA,&boxB, G4Translate3D(3*m,3*m,3*m)); pVisManager->Draw(subtracted, G4VisAttributes(G4Colour(0,1,1)), G4Translate3D(-6*m,-6*m,-6*m));

12 January Geant4 Advanced Visualization J. Perl Geant4 Visualization Resources Geant4 Installation Guides  Hands on HepRApp Tutorial  Hands on DAWN Tutorial  Hands on OpenGL Tutorial  Geant4 Visualization Commands  (and.pdf) Geant4 Advanced Visualization  (and.pdf) How to Make a Movie  (and.pdf) Visualization Chapter of the Geant4 User’s Guide for Application Developers  List of Visualization Commands:  AllResources/Control/UIcommands/_vis_.html For Questions or Comments: Geant4 Visualization Online Forum: 