/*
* This file is part of rasdaman community.
*
* Rasdaman community is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Rasdaman community is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with rasdaman community. If not, see .
*
* Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann /
rasdaman GmbH.
*
* For more information please see
* or contact Peter Baumann via .
*/
/*************************************************************
*
* CHANGE HISTORY (append further entries):
* when who what
* ----------------------------------------------------------
* 10-11-08 Shams Created the class
* 14-08-09 Andrei Reimplemented the class
* COMMENTS:
*
************************************************************/
#ifndef _QTMDDCONFIG_HH_
#define _QTMDDCONFIG_HH_
#include "qlparser/qtconst.hh"
#include "rasodmg/dirdecompose.hh"
#include
#ifndef CPPSTDLIB
#include // STL
#else
#include
using namespace std;
#endif
#include
class QtMDDConfig: public QtData
{
private:
int tilingType;
int tileSize;
int borderThreshold;
double interestThreshold;
QtOperation* tileCfg;
QtNode::QtOperationList* box;
std::vector* dDecomp;
int indexType;
int param; // wavelet param
public:
// Constructors
QtMDDConfig();
QtMDDConfig( int tilingType, int tileSize, int borderThreshold,
double interestThreshold, QtOperation* tileCfg,
QtNode::QtOperationList* box,std::vector* dDecomp,
int indexType);
QtMDDConfig( int tilingType, int tileSize, int borderThreshold,
double interestThreshold, QtOperation* tileCfg,
QtNode::QtOperationList* box,std::vector* dDecomp);
QtMDDConfig(int index);
// Getters
int getTileSize();
int getBorderThreshold();
double getInterestThreshold();
std::vector* getDirDecomp();
int getStorageType();
int getWltValue(); // Check return type !
int getIndexType();
int getTilingType();
QtNode::QtOperationList* getBboxList();
QtOperation* getTileCfg();
// Setters
void setBorderThreshold(int threshold);
// Pure virtual methods definition (from class QtData)
virtual QtDataType getDataType() const;
virtual char* getTypeStructure() const;
virtual bool equal(const QtData*) const;
virtual string getSpelling() const;
enum QtIndexConstants
{
r_DEFAULT_INDEX,
r_A_INDEX,
r_D_INDEX,
r_IT_INDEX,
r_RC_INDEX,
r_RD_INDEX,
r_RPT_INDEX,
r_RRPT_INDEX,
r_TC_INDEX
};
enum QtTilingConstants
{
r_DEFAULT_TLG,
r_ALIGNED_TLG,
r_AREAOFINTEREST_TLG,
r_DRLDECOMPSUBTILE_TLG,
r_DRLDECOMP_TLG,
r_REGULAR_TLG,
r_STATISTICSPARAM_TLG,
r_STATISTICS_TLG
};
enum QtStorageConstants
{
r_DEFAULT_STG,
r_ARRAY_STG,
r_AUTO_STG,
r_BMP_STG,
r_DEM_STG ,
r_HDF5_STG,
r_HDF_STG ,
r_JPEG_STG,
r_NTF_STG,
r_PACKBITS_STG,
r_PPM_STG,
r_PNG_STG,
r_RLESEP_STG,
r_RLE_STG,
r_TIFF_STG,
r_TOR_STG ,
r_VFF_STG,
r_WLTCOIFLETINT_STG,
r_WLTDAUBECHIESINT_STG,
r_WLTDAUBECHIES_STG,
r_WLTHAAR_STG,
r_WLTLEASTINT_STG,
r_WLTQHAAR_STG,
r_ZLIBSEP_STG,
r_ZLIB_STG
};
};
#endif