xdsopl-qsstv/qwt/qwt_transform.cpp

166 wiersze
3.2 KiB
C++

/* -*- mode: C++ ; c-file-style: "stroustrup" -*- *****************************
* Qwt Widget Library
* Copyright (C) 1997 Josef Wilgen
* Copyright (C) 2002 Uwe Rathmann
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the Qwt License, Version 1.0
*****************************************************************************/
#include "qwt_transform.h"
#include "qwt_math.h"
#if QT_VERSION < 0x040601
#define qExp(x) ::exp(x)
#endif
//! Smallest allowed value for logarithmic scales: 1.0e-150
const double QwtLogTransform::LogMin = 1.0e-150;
//! Largest allowed value for logarithmic scales: 1.0e150
const double QwtLogTransform::LogMax = 1.0e150;
//! Constructor
QwtTransform::QwtTransform()
{
}
//! Destructor
QwtTransform::~QwtTransform()
{
}
/*!
\param value Value to be bounded
\return value unmodified
*/
double QwtTransform::bounded( double value ) const
{
return value;
}
//! Constructor
QwtNullTransform::QwtNullTransform():
QwtTransform()
{
}
//! Destructor
QwtNullTransform::~QwtNullTransform()
{
}
/*!
\param value Value to be transformed
\return value unmodified
*/
double QwtNullTransform::transform( double value ) const
{
return value;
}
/*!
\param value Value to be transformed
\return value unmodified
*/
double QwtNullTransform::invTransform( double value ) const
{
return value;
}
//! \return Clone of the transformation
QwtTransform *QwtNullTransform::copy() const
{
return new QwtNullTransform();
}
//! Constructor
QwtLogTransform::QwtLogTransform():
QwtTransform()
{
}
//! Destructor
QwtLogTransform::~QwtLogTransform()
{
}
/*!
\param value Value to be transformed
\return log( value )
*/
double QwtLogTransform::transform( double value ) const
{
return ::log( value );
}
/*!
\param value Value to be transformed
\return exp( value )
*/
double QwtLogTransform::invTransform( double value ) const
{
return qExp( value );
}
/*!
\param value Value to be bounded
\return qBound( LogMin, value, LogMax )
*/
double QwtLogTransform::bounded( double value ) const
{
return qBound( LogMin, value, LogMax );
}
//! \return Clone of the transformation
QwtTransform *QwtLogTransform::copy() const
{
return new QwtLogTransform();
}
/*!
Constructor
\param exponent Exponent
*/
QwtPowerTransform::QwtPowerTransform( double exponent ):
QwtTransform(),
d_exponent( exponent )
{
}
//! Destructor
QwtPowerTransform::~QwtPowerTransform()
{
}
/*!
\param value Value to be transformed
\return Exponentiation preserving the sign
*/
double QwtPowerTransform::transform( double value ) const
{
if ( value < 0.0 )
return -qPow( -value, 1.0 / d_exponent );
else
return qPow( value, 1.0 / d_exponent );
}
/*!
\param value Value to be transformed
\return Inverse exponentiation preserving the sign
*/
double QwtPowerTransform::invTransform( double value ) const
{
if ( value < 0.0 )
return -qPow( -value, d_exponent );
else
return qPow( value, d_exponent );
}
//! \return Clone of the transformation
QwtTransform *QwtPowerTransform::copy() const
{
return new QwtPowerTransform( d_exponent );
}