casa  $Rev:20696$
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines
Public Member Functions | Private Attributes
casa::LELBinary< T > Class Template Reference

This LEL class handles numerical binary operators. More...

#include <LELBinary.h>

Inheritance diagram for casa::LELBinary< T >:
casa::LELInterface< T >

List of all members.

Public Member Functions

 LELBinary (const LELBinaryEnums::Operation op, const CountedPtr< LELInterface< T > > &pLeftExpr, const CountedPtr< LELInterface< T > > &pRightExpr)
 Constructor takes operation and left and right expressions to be operated upon.
 ~LELBinary ()
 Destructor.
virtual void eval (LELArray< T > &result, const Slicer &section) const
 Recursively evaluate the expression.
virtual LELScalar< T > getScalar () const
 Recursively efvaluate the scalar expression.
virtual Bool prepareScalarExpr ()
 Do further preparations (e.g.
virtual String className () const
 Get class name.
virtual Bool lock (FileLocker::LockType, uInt nattempts)
 Handle locking/syncing of a lattice in a lattice expression.
virtual void unlock ()
virtual Bool hasLock (FileLocker::LockType) const
virtual void resync ()

Private Attributes

LELBinaryEnums::Operation op_p
 
   

CountedPtr< LELInterface< T > > pLeftExpr_p
CountedPtr< LELInterface< T > > pRightExpr_p

Detailed Description

template<class T>
class casa::LELBinary< T >

This LEL class handles numerical binary operators.

Intended use:

Internal

 <h3>Review Status</h3><dl><dt>Date Reviewed:<dd>yyyy/mm/dd</dl> 

Prerequisite

Etymology

This derived LEL letter class handles numerical binary operators

Synopsis

This LEL letter class is derived from LELInterface. It is used to construct LEL objects that apply numerical binary operators to Lattice expressions. They operate on numerical Lattice (Float,Double,Complex,DComplex) expressions and return the same numerical type. The available C++ operators are +,-,*,/ with equivalents in the enum of ADD, SUBTRACT, MULTIPLY, and DIVIDE.

A description of the implementation details of the LEL classes can be found in Note 216

Example

Examples are not very useful as the user would never use these classes directly. Look in LatticeExprNode.cc to see how it invokes these classes. Examples of how the user would indirectly use this class (through the envelope) are:

    IPosition shape(2,5,10);
    ArrayLattice<Float> x(shape); x.set(1.0);
    ArrayLattice<Float> y(shape); y.set(2.0);
    ArrayLattice<Float> z(shape); 
    z.copyData(x+y);                 // z = x + y;
    z.copyData(x-y);                 // z = x - y;
    z.copyData(x*y);                 // z = x * y;
    z.copyData(x/y);                 // z = x / y;

Motivation

Numerical binary operations are a basic mathematical expression.

Definition at line 101 of file LELBinary.h.


Constructor & Destructor Documentation

template<class T >
casa::LELBinary< T >::LELBinary ( const LELBinaryEnums::Operation  op,
const CountedPtr< LELInterface< T > > &  pLeftExpr,
const CountedPtr< LELInterface< T > > &  pRightExpr 
)

Constructor takes operation and left and right expressions to be operated upon.

template<class T >
casa::LELBinary< T >::~LELBinary ( )

Destructor.


Member Function Documentation

template<class T >
virtual String casa::LELBinary< T >::className ( ) const [virtual]

Get class name.

Implements casa::LELInterface< T >.

template<class T >
virtual void casa::LELBinary< T >::eval ( LELArray< T > &  result,
const Slicer section 
) const [virtual]

Recursively evaluate the expression.

Implements casa::LELInterface< T >.

template<class T >
virtual LELScalar<T> casa::LELBinary< T >::getScalar ( ) const [virtual]

Recursively efvaluate the scalar expression.

Implements casa::LELInterface< T >.

template<class T >
virtual Bool casa::LELBinary< T >::hasLock ( FileLocker::LockType  ) const [virtual]

Reimplemented from casa::LELInterface< T >.

template<class T >
virtual Bool casa::LELBinary< T >::lock ( FileLocker::LockType  ,
uInt  nattempts 
) [virtual]

Handle locking/syncing of a lattice in a lattice expression.

Reimplemented from casa::LELInterface< T >.

template<class T >
virtual Bool casa::LELBinary< T >::prepareScalarExpr ( ) [virtual]

Do further preparations (e.g.

optimization) on the expression.

Implements casa::LELInterface< T >.

template<class T >
virtual void casa::LELBinary< T >::resync ( ) [virtual]

Reimplemented from casa::LELInterface< T >.

template<class T >
virtual void casa::LELBinary< T >::unlock ( ) [virtual]

Reimplemented from casa::LELInterface< T >.


Member Data Documentation

template<class T >
LELBinaryEnums::Operation casa::LELBinary< T >::op_p [private]

   

Definition at line 139 of file LELBinary.h.

template<class T >
CountedPtr<LELInterface<T> > casa::LELBinary< T >::pLeftExpr_p [private]

Definition at line 140 of file LELBinary.h.

template<class T >
CountedPtr<LELInterface<T> > casa::LELBinary< T >::pRightExpr_p [private]

Definition at line 141 of file LELBinary.h.


The documentation for this class was generated from the following file: