|
ATLAS Offline Software
|
Go to the documentation of this file.
29 #endif // BUILDVP1LIGHT
32 #include <QStringList>
39 #include <Inventor/C/errors/debugerror.h>
40 #include <Inventor/nodes/SoSeparator.h>
41 #include <Inventor/nodes/SoSwitch.h>
42 #include <Inventor/nodes/SoMaterial.h>
45 #include <Inventor/nodes/SoTexture2.h>
53 #endif // BUILDVP1LIGHT
57 #include "GeoModelKernel/Units.h"
58 #define SYSTEM_OF_UNITS GeoModelKernelUnits // --> 'GeoModelKernelUnits::cm'
60 #include "GaudiKernel/SystemOfUnits.h"
61 #define SYSTEM_OF_UNITS Gaudi::Units // --> 'Gaudi::Units::cm'
65 #if defined BUILDVP1LIGHT
75 #endif // BUILDVP1LIGHT
93 #endif // BUILDVP1LIGHT
144 QString safetext(
text());
145 safetext.replace(
' ',
'_');
146 safetext.replace(
'[',
'_');
147 safetext.replace(
']',
'_');
148 safetext.replace(
'/',
'_');
149 safetext.replace(
'.',
'_');
150 safetext.replace(
',',
'_');
151 safetext.replace(
'<',
'_');
152 safetext.replace(
'>',
'_');
153 safetext.replace(
'&',
'_');
231 messageDebug(
"IParticleCollHandle_Jet::setupSettingsFromControllerSpecific()");
242 connect(controller,SIGNAL(cutAllowedPhiChanged(
const QList<VP1Interval>&)),
this,SLOT(
setCutAllowedPhi(
const QList<VP1Interval>&)));
251 connect(controller,SIGNAL(scaleChanged(
const double&)),
this,SLOT(
setScale(
const double&)));
260 connect(controller, SIGNAL(maxRChanged(
const double&)),
this, SLOT(
setMaxR(
const double&)));
265 connect(controller, SIGNAL(bTaggingTaggerChanged(
const QString &)),
this, SLOT(
setBTaggingTagger(
const QString &)));
267 connect(controller, SIGNAL(bTaggingCutChanged(
const double &)),
this, SLOT(
setBTaggingCut(
const double &)));
281 messageVerbose(
"Jet - No collSettingsButton set! Can't call init(), so crash is imminent...");
282 throw std::runtime_error(
"Jet - No collSettingsButton set!");
308 m_d->
scale = isEt ? tmpScale : -tmpScale;
322 if (
jet &&
jet->has3DObjects()) {
323 jet->setScale(tmpScale, isEt);
326 message(
"ERROR Handle of wrong type!");
370 if (
jet &&
jet->has3DObjects()) {
374 message(
"ERROR Handle of wrong type!");
417 if (
jet &&
jet->has3DObjects()) {
422 jet->updateMaterial( randomColors );
425 message(
"ERROR Handle of wrong type!");
437 messageVerbose(
"IParticleCollHandle_Jet::rerandomise() - Returning.");
441 VP1Msg::message(
"'Random jet colours' is not checked. Nothing to do. Returning.");
451 if (
jet &&
jet->has3DObjects()) {
452 jet->rerandomiseMaterial();
454 message(
"ERROR Handle of wrong type!");
468 #if defined BUILDVP1LIGHT
480 QString errMsg =
"Failed to retrieve " +
name();
481 message(
"Error: Could not retrieve collection with key="+
name());
486 message(
"Error: Could not retrieve Jet collection with key="+
name());
491 #endif // BUILDVP1LIGHT
498 if( ! coll->hasStore() ) {
499 message(
"No auxiliary store got associated to the Jet container with key: " +
name());
541 double jEnergy = handle->energyForCuts();
542 double jEnergySqr = jEnergy * jEnergy;
559 double phi = handle->phi();
581 messageVerbose(
"Not a IParticleCollHandle_Jet. Calling base method...");
717 messageVerbose(
"IParticleCollHandle_Jet::updateBTaggingAllJets()");
724 if (
jet &&
jet->has3DObjects()) {
727 message(
"ERROR Handle of wrong type!");
736 messageVerbose(
"IParticleCollHandle_Jet::updateBTaggingSwitchAllJets()");
743 if (
jet &&
jet->has3DObjects()) {
746 message(
"ERROR Handle of wrong type!");
757 messageVerbose(
"IParticleCollHandle_Jet::setBTaggingMaterialChanged()");
772 messageDebug(
"IParticleCollHandle_Jet::persistifiableState() - start...");
798 messageDebug(
"IParticleCollHandle_Jet::persistifiableState() - end.");
808 des.disableUnrestoredChecks();
809 if (
des.version()!=0&&
des.version()!=1) {
810 messageDebug(
"Warning: Ignoring state with wrong version");
816 bool vis =
des.restoreBool();
820 QByteArray extraWidgetState =
des.version()>=1 ?
des.restoreByteArray() : QByteArray();
823 if (extraWidgetState!=QByteArray())
827 messageDebug(
"restoring material collection button...");
830 messageDebug(
"reset all caches storing values for cuts...");
857 str <<
"\""<<
name().toLatin1().data()<<
"\":{";
861 if (handle->visible()) {
863 handle->dumpToJSON(
str);
def retrieve(aClass, aKey=None)
void setExtraWidgetsState(const QByteArray &)
JetCollectionSettingsButton * collSettingsButton
Const iterator class for DataVector/DataList.
SoTexture2 * bTaggingTexture
IParticleCollHandle_Jet(AODSysCommonData *, const QString &name, xAOD::Type::ObjectType type)
Scalar phi() const
phi method
static std::string find_file(const std::string &logical_file_name, const std::string &search_path, SearchType search_type=LocalSearch)
void serialise(const std::vector< const IRoiDescriptor * > &rois, roiserial_type &s)
serialise an entire vector of IRoiDescriptors
void setBTaggingTagger(const QString &)
void messageVerbose(const QString &) const
void setState(const QByteArray &)
Provide specific implementation.
virtual void init(VP1MaterialButtonBase *button=0)
virtual void largeChangesBegin()
void setMaxR(const double &max)
virtual QColor defaultColor() const
const QList< VP1Interval > & getCutAllowedPhi()
static QString str(const QString &s)
void messageDebug(const QString &) const
void setCutAllowedPt(const VP1Interval &)
void setCutAllowedPhi(const QList< VP1Interval > &)
virtual void setupSettingsFromControllerSpecific(const AODSystemController *)
For extensions specific to this collection.
const VP1Interval & getCutAllowedEta()
void resetCachedValuesCuts()
const AODSysCommonData * common() const
virtual bool cut(AODHandleBase *)
QStringList getKeys() const
QList< AODHandleBase * > getHandlesList() const
std::string toString(const Translation3D &translation, int precision=4)
GeoPrimitvesToStringConverter.
SoSwitch * bTaggingSwitch
SoMaterial * bTaggingMaterial
void showParametersChanged(bool)
void setRandomJetColours(const bool &)
void visibilityChanged(bool)
bool contains(const std::string &s, const std::string ®x)
does a string contain the substring
virtual void init(VP1MaterialButtonBase *matBut=0)
QByteArray extraWidgetsState() const
void setBTaggingEnabled(const bool &)
const QString & name() const
virtual void dumpToJSON(std::ofstream &) const
virtual bool cut(AODHandleBase *)
void setCutAllowedEta(const VP1Interval &)
void setBTaggingMaterialChanged(const bool &)
void setBTaggingMaterial(SoMaterial *mat=NULL)
void updateBTaggingSwitchAllJets()
void setupSettingsFromController(const AODSystemController *)
void setScale(const double &s)
IVP1System * systemBase() const
QByteArray persistifiableState() const
Provide specific implementation.
static void messageVerbose(const QString &)
void setBTaggingSkin(const QString &filename)
bool isRandomColors() const
virtual void largeChangesEnd()
Interface for non-const operations on an auxiliary store.
virtual void handleIterationBegin()
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
void collVisibilityChanged(bool)
const JetCollectionSettingsButton & collSettingsButton() const
static QStringList availableCollections(IVP1System *)
IParticleCollHandle_Jet * theclass
void setBTaggingCut(const double &)
static void message(const QString &, IVP1System *sys=0)
void setBTaggingSkinChanged(const bool &ok)
const VP1Interval & getCutAllowedPt()
virtual AODHandleBase * getNextHandle()
SoMaterial * m_jetMaterialDefault
void addHandle(AODHandleBase *)
virtual ~IParticleCollHandle_Jet()
void message(const QString &) const
void update3DObjectsOfAllHandles()
void updateBTaggingAllJets()
std::string bTaggingTagger
Base class for collections holding AOD objects of iParticle type Handles pt etc cuts Local data:
void recheckCutStatusOfAllVisibleHandles()
Jet_v1 Jet
Definition of the current "jet version".
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.