OpendTect  7.0
Public Member Functions | Private Member Functions | Private Attributes | List of all members
SeisZAxisStretcherNew Class Reference
Inheritance diagram for SeisZAxisStretcherNew:
[legend]

Public Member Functions

 SeisZAxisStretcherNew (const IOObj &in, const IOObj &out, const TrcKeyZSampling &outcs, ZAxisTransform &, bool forward, const VelocityDesc *=nullptr)
 
 ~SeisZAxisStretcherNew ()
 
bool isOK () const
 
void setUdfVal (float val)
 
uiString uiMessage () const override
 will be message() again in 7.x More...
 
uiString uiNrDoneText () const override
 will be nrDoneText() in 7.x More...
 
- Public Member Functions inherited from ParallelTask
virtual ~ParallelTask ()
 
void doParallel (bool yn)
 
bool execute () override
 
virtual bool executeParallel (bool parallel)
 
std::int64_t nrDone () const override
 May be -1, i.e. class does not report nrdone. More...
 
std::int64_t totalNr () const override
 
- Public Member Functions inherited from ReportingTask
virtual ~ReportingTask ()
 
void getProgress (const ReportingTask &)
 
- Public Member Functions inherited from Task
virtual ~Task ()
 
virtual void controlWork (Control)
 
virtual void enableWorkControl (bool=true)
 Must be called before execute() More...
 
virtual uiRetVal errorWithDetails () const
 
virtual Control getState () const
 
bool workControlEnabled () const
 
- Public Member Functions inherited from NamedCallBacker
 NamedCallBacker (const char *nm=0)
 
 NamedCallBacker (const NamedCallBacker &)
 
virtual Notifier< NamedCallBacker > & objectToBeDeleted () const
 
bool operator== (const NamedCallBacker &oth) const
 
bool operator== (const NamedObject &oth) const
 
- Public Member Functions inherited from CallBacker
 CallBacker ()
 
 CallBacker (const CallBacker &)
 
virtual ~CallBacker ()
 
bool attachCB (const NotifierAccess &, const CallBack &, bool onlyifnew=false) const
 
bool attachCB (const NotifierAccess *notif, const CallBack &cb, bool onlyifnew=false) const
 
void detachAllNotifiers () const
 Call from the destructor of your inherited object. More...
 
void detachCB (const NotifierAccess &, const CallBack &) const
 
void detachCB (const NotifierAccess *notif, const CallBack &cb) const
 
virtual bool isCapsule () const
 
bool isNotifierAttached (const NotifierAccess *) const
 Only for debugging purposes, don't use. More...
 
void stopReceivingNotifications () const
 
virtual CallBackertrueCaller ()
 
- Public Member Functions inherited from NamedObject
 NamedObject (const char *nm=nullptr)
 
 NamedObject (const NamedObject &oth)
 
virtual ~NamedObject ()
 
virtual BufferString getName () const
 
bool getNameFromPar (const IOPar &)
 
const name_typename () const override
 
NamedObjectoperator= (const NamedObject &)
 
bool operator== (const NamedObject &oth) const
 
virtual void setName (const char *nm)
 
- Public Member Functions inherited from ObjectWithName
virtual ~ObjectWithName ()
 
bool hasName (const char *nm) const
 
bool hasName (const name_type &nm) const
 
void putNameInPar (IOPar &) const
 

Private Member Functions

bool doFinish (bool) override
 
bool doPrepare (int) override
 
bool doWork (od_int64, od_int64, int) override
 
bool getInputTrace (SeisTrc &)
 
bool init ()
 
bool loadTransformChunk (int firstinl)
 
od_int64 nrIterations () const override
 
bool selfStretchVelocity (const SeisTrc &, int icomp, SeisTrc &) const
 
void setRanges ()
 
void setWorkers (const VelocityDesc &)
 
void stretch (const SeisTrc &, int icomp, const MathFunction< float, float > &intrcfunc, ZAxisTransformSampler &, float *tmpptr, SeisTrc &) const
 
bool stretchVelocity (const SeisTrc &, int icomp, SeisTrc &) const
 

Private Attributes

bool autotransform_ = false
 
TrcKeySampling curhrg_
 
Seis::GeomType geomtype_
 
const IOObjinpobj_
 
const bool ist2d_
 
uiString msg_
 
int nrthreads_ = 0
 
int nrwaiting_ = 0
 
TrcKeyZSampling outcs_
 
const IOObjoutobj_
 
Threads::ConditionVar readerlock_
 
Threads::ConditionVar readerlockmodel_
 
SeisTrcReaderseisreader_ = nullptr
 
SeisTrcWriterseiswriter_ = nullptr
 
SeisSequentialWritersequentialwriter_ = nullptr
 
double srd_
 
const UnitOfMeasuresrduom_
 
int totalnr_ = -1
 
float udfval_ = mUdf(float)
 
Vel::Workervintworker_ = nullptr
 
int voiid_ = -1
 
bool waitforall_ = false
 
Vel::Workerworker_ = nullptr
 
const ZDomain::Infozdomaininfo_ = nullptr
 
RefMan< ZAxisTransformztransform_
 

Additional Inherited Members

- Public Types inherited from Task
enum  Control { Run , Pause , Stop }
 
- Public Types inherited from ObjectWithName
typedef OD::String name_type
 
- Static Public Member Functions inherited from ParallelTask
static uiString sPosFinished ()
 
static uiString sTrcFinished ()
 
- Static Public Member Functions inherited from Task
static uiString stdNrDoneText ()
 
static uiString uiStdNrDoneText ()
 
- Static Public Member Functions inherited from CallBacker
static void createReceiverForCurrentThread ()
 
static void removeReceiverForCurrentThread ()
 
- Public Attributes inherited from ReportingTask
Notifier< ReportingTaskprogressUpdated
 
- Protected Member Functions inherited from ParallelTask
 ParallelTask (const char *nm=0)
 
 ParallelTask (const ParallelTask &)
 
void addToNrDone (std::int64_t increment)
 
std::int64_t calculateThreadSize (std::int64_t totalnr, int nrthreads, int thread) const
 
virtual int maxNrThreads () const
 
virtual int minThreadSize () const
 
void quickAddToNrDone (std::int64_t loopidx)
 
void resetNrDone ()
 
virtual bool stopAllOnFailure () const
 
- Protected Member Functions inherited from ReportingTask
 ReportingTask (const char *nm=nullptr)
 
void incrementProgress ()
 
ProgressMeterprogressMeter () const
 
void reportProgressFinished ()
 
void reportProgressStarted ()
 
void resetProgress ()
 
void setProgressMeter (ProgressMeter *) override
 Must be called before execute() More...
 
void updateProgressMeter (bool forced=false, std::int64_t *totalnr=0)
 
void updateReportedName ()
 
- Protected Member Functions inherited from Task
 Task (const char *nm=nullptr)
 
virtual bool shouldContinue ()
 
- Protected Member Functions inherited from NamedCallBacker
void sendDelNotif () const
 
- Protected Attributes inherited from Task
Control control_
 
Threads::ConditionVarworkcontrolcondvar_
 
- Protected Attributes inherited from NamedCallBacker
Threads::Atomic< bool > delalreadytriggered_
 
Notifier< NamedCallBackerdelnotif_
 
- Protected Attributes inherited from NamedObject
BufferString name_
 

Detailed Description

brief Stretches the zaxis from the input cube with a ZAxisTransform and writes it out into another volume.

<>

Constructor & Destructor Documentation

◆ SeisZAxisStretcherNew()

SeisZAxisStretcherNew::SeisZAxisStretcherNew ( const IOObj in,
const IOObj out,
const TrcKeyZSampling outcs,
ZAxisTransform ,
bool  forward,
const VelocityDesc = nullptr 
)

◆ ~SeisZAxisStretcherNew()

SeisZAxisStretcherNew::~SeisZAxisStretcherNew ( )

Member Function Documentation

◆ doFinish()

bool SeisZAxisStretcherNew::doFinish ( bool  success)
overrideprivatevirtual

Called after all doWork have finished.

Parameters
successindicates whether all doWork returned true.

Reimplemented from ParallelTask.

◆ doPrepare()

bool SeisZAxisStretcherNew::doPrepare ( int  nrthreads)
overrideprivatevirtual

Called once, before any doWork is called.

Reimplemented from ParallelTask.

◆ doWork()

bool SeisZAxisStretcherNew::doWork ( od_int64  ,
od_int64  ,
int   
)
overrideprivate

◆ getInputTrace()

bool SeisZAxisStretcherNew::getInputTrace ( SeisTrc )
private

◆ init()

bool SeisZAxisStretcherNew::init ( )
private

◆ isOK()

bool SeisZAxisStretcherNew::isOK ( ) const

◆ loadTransformChunk()

bool SeisZAxisStretcherNew::loadTransformChunk ( int  firstinl)
private

◆ nrIterations()

od_int64 SeisZAxisStretcherNew::nrIterations ( ) const
inlineoverrideprivatevirtual
Returns
the number of times the process should be run.

Implements ParallelTask.

◆ selfStretchVelocity()

bool SeisZAxisStretcherNew::selfStretchVelocity ( const SeisTrc ,
int  icomp,
SeisTrc  
) const
private

◆ setRanges()

void SeisZAxisStretcherNew::setRanges ( )
private

◆ setUdfVal()

void SeisZAxisStretcherNew::setUdfVal ( float  val)

◆ setWorkers()

void SeisZAxisStretcherNew::setWorkers ( const VelocityDesc )
private

◆ stretch()

void SeisZAxisStretcherNew::stretch ( const SeisTrc ,
int  icomp,
const MathFunction< float, float > &  intrcfunc,
ZAxisTransformSampler ,
float *  tmpptr,
SeisTrc  
) const
private

◆ stretchVelocity()

bool SeisZAxisStretcherNew::stretchVelocity ( const SeisTrc ,
int  icomp,
SeisTrc  
) const
private

◆ uiMessage()

uiString SeisZAxisStretcherNew::uiMessage ( ) const
overridevirtual

will be message() again in 7.x

Reimplemented from Task.

◆ uiNrDoneText()

uiString SeisZAxisStretcherNew::uiNrDoneText ( ) const
overridevirtual

will be nrDoneText() in 7.x

Reimplemented from Task.

Member Data Documentation

◆ autotransform_

bool SeisZAxisStretcherNew::autotransform_ = false
private

◆ curhrg_

TrcKeySampling SeisZAxisStretcherNew::curhrg_
private

◆ geomtype_

Seis::GeomType SeisZAxisStretcherNew::geomtype_
private

◆ inpobj_

const IOObj& SeisZAxisStretcherNew::inpobj_
private

◆ ist2d_

const bool SeisZAxisStretcherNew::ist2d_
private

◆ msg_

uiString SeisZAxisStretcherNew::msg_
private

◆ nrthreads_

int SeisZAxisStretcherNew::nrthreads_ = 0
private

◆ nrwaiting_

int SeisZAxisStretcherNew::nrwaiting_ = 0
private

◆ outcs_

TrcKeyZSampling SeisZAxisStretcherNew::outcs_
private

◆ outobj_

const IOObj& SeisZAxisStretcherNew::outobj_
private

◆ readerlock_

Threads::ConditionVar SeisZAxisStretcherNew::readerlock_
private

◆ readerlockmodel_

Threads::ConditionVar SeisZAxisStretcherNew::readerlockmodel_
private

◆ seisreader_

SeisTrcReader* SeisZAxisStretcherNew::seisreader_ = nullptr
private

◆ seiswriter_

SeisTrcWriter* SeisZAxisStretcherNew::seiswriter_ = nullptr
private

◆ sequentialwriter_

SeisSequentialWriter* SeisZAxisStretcherNew::sequentialwriter_ = nullptr
private

◆ srd_

double SeisZAxisStretcherNew::srd_
private

◆ srduom_

const UnitOfMeasure* SeisZAxisStretcherNew::srduom_
private

◆ totalnr_

int SeisZAxisStretcherNew::totalnr_ = -1
private

◆ udfval_

float SeisZAxisStretcherNew::udfval_ = mUdf(float)
private

◆ vintworker_

Vel::Worker* SeisZAxisStretcherNew::vintworker_ = nullptr
private

◆ voiid_

int SeisZAxisStretcherNew::voiid_ = -1
private

◆ waitforall_

bool SeisZAxisStretcherNew::waitforall_ = false
private

◆ worker_

Vel::Worker* SeisZAxisStretcherNew::worker_ = nullptr
private

◆ zdomaininfo_

const ZDomain::Info* SeisZAxisStretcherNew::zdomaininfo_ = nullptr
private

◆ ztransform_

RefMan<ZAxisTransform> SeisZAxisStretcherNew::ztransform_
private

Generated at for the OpendTect seismic interpretation project. Copyright (C): dGB Beheer B.V. 1995-2024