libkpl  6.0
A Library for Graphical Presentation of Data Sets and Functions
SplineItem Class Reference

Spline item class. More...

#include <splineitem.h>

Inheritance diagram for SplineItem:

Public Types

enum  { Type = UserType + Spline }
 Specific QGraphicsItem type number for function type() More...
 
- Public Types inherited from KplItem
enum  FillStyle {
  NoBrush , SolidPattern , HorPattern , VerPattern ,
  CrossPattern , BDiagPattern , FDiagPattern , DiagCrossPattern
}
 Fill styles. More...
 
enum  ItemType {
  Frame = 1 , Array , Function , ParFunction ,
  Spline , Array3D , Function3D , Legend ,
  Text , Line , Arrow , Arc ,
  Rectangle , Ellipse , Image , ScaleBar
}
 Item types. More...
 
enum  PenType { FramePen , GridPen , DataPen }
 Pen types. More...
 
enum  Symbol {
  Invisible = -17 , FilledOctagon , FilledHourglass , FilledTriangle ,
  FilledSquare , FilledDiamond , FilledCircle , Umbrella ,
  Ypsilon , Plus , Cross , OpenOctagon ,
  OpenHourglass , OpenTriangle , OpenSquare , OpenDiamond ,
  Dot , OpenCircle , SolidLine , DashLine1 ,
  DashLine2 , DotLine1 , DashLine3 , DashDotLine ,
  DashLine4 , DashLine5 , DotLine2
}
 Symbol types. More...
 

Public Member Functions

 SplineItem (int degree=3, int derivOrder=0, double xLow=0, unsigned color=0, Symbol symbol=SolidLine, double fx=1, double fy=1, QGraphicsItem *parent=nullptr, double xMin=0, double xMax=0, double deltaX=0, bool visible=true, FillStyle fillStyle=NoBrush, double xOffset=0, double yOffset=0, double relSize=1)
 Constructor.
 
 SplineItem (const SplineItem &a)
 Copy constructor.
 
 SplineItem (const KConfigGroup *plo, unsigned color=0, Symbol symbol=SolidLine, QGraphicsItem *parent=nullptr)
 Constructor.
 
virtual ~SplineItem ()
 Destructor.
 
virtual QRectF boundingRect () const override
 Calculates bounding rectangle.
 
int calcTable (bool logX) const
 Calculates spline value table.
 
int calcTable (const double *x, double *values, int n=1, int derivOrder=0, double xLow=0) const
 Calculates spline value table.
 
void copySpline (const SplineItem *a)
 Copies spline data.
 
int degree () const
 Returns degree of spline.
 
double deltaX () const
 Returns argument step size.
 
int derivOrder () const
 Returns order of derivative.
 
void exponent (int &expX, int &expY, double &fx, double &fy, bool logX) const
 Calculates normalization factors.
 
void exportTable (QTextStream &stream, char separator, char format, int precision) const
 Exports spline value table to file.
 
int fit (const ArrayItem *ai, double xMin, double xMax, double *chiSquare=nullptr, int *numKnots=nullptr, double smooth=0, FunItem::DataErrorStruct *err=nullptr, double *avgErr=nullptr)
 Performs smoothing spline fit.
 
int fit (const double *x, const double *y, const double *errors, int n, double xMin, double xMax, double *chiSquare=nullptr, int *numKnots=nullptr, double smooth=0, FunItem::DataErrorStruct *err=nullptr, double *avgErr=nullptr)
 Performs smoothing spline fit.
 
int interpolation (const double *x, const double *y, int n, double xMin, double xMax)
 Performs interpolating (non-smoothing) spline fit.
 
void limits (double &xMin, double &xMax, double &yMin, double &yMax, bool logX) const
 Calculates minimum and maximum values.
 
int numKnots () const
 Returns number of knots.
 
virtual void paint (QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget=nullptr) override
 Paints item.
 
int roots (QVector< double > &zero, int derivOrder=0, double offset=0) const
 Finds roots of a cubic spline or its derivatives.
 
void setDashOffset ()
 Sets offset for dashed lines.
 
void setDegree (int degree)
 Sets degree of spline.
 
void setDeltaX (double deltaX)
 Sets argument step size.
 
void setDerivOrder (int derivOrder)
 Sets order of derivative.
 
void setXLow (double xLow)
 Sets lower x limit for spline integral.
 
void setXMax (double xMax)
 Sets maximum argument value.
 
void setXMin (double xMin)
 Sets minimum argument value.
 
virtual QPainterPath shape () const override
 Returns the shape of the plot item.
 
virtual int type () const override
 Returns specific QGraphicsItem type number.
 
void writePlo (KConfigGroup *plo, char format, int precision) const
 Writes into plot file.
 
double xLow () const
 Returns lower x limit for spline integral.
 
double xMax () const
 Returns maximum argument value.
 
double xMin () const
 Returns minimum argument value.
 
double * xValues () const
 Returns pointer to x function value array.
 
double * yValues () const
 Returns pointer to y function value array.
 
- Public Member Functions inherited from ScaledItem
 ScaledItem ()
 Constructor.
 
 ScaledItem (const ScaledItem &a)
 Copy constructor.
 
 ScaledItem (const KConfigGroup *plo, Symbol symbol, unsigned color, QGraphicsItem *parent)
 Constructor.
 
 ScaledItem (FillStyle fillStyle, Symbol symbol, unsigned color, double fx, double fy, double xOffset, double yOffset, double relSize, QGraphicsItem *parent)
 Constructor.
 
virtual ~ScaledItem ()
 Destructor.
 
unsigned color () const
 Returns color.
 
FillStyle fillStyle () const
 Returns fill style.
 
bool isNormalized (double fx, double fy) const
 Checks if both normalization factors are equal to given values.
 
void normalize (double fx, double fy)
 Sets normalization factors.
 
double normX () const
 Returns normalization factor for x values.
 
double normY () const
 Returns normalization factor for y values.
 
QPixmap pixmap () const
 Returns decoration pixmap for item list.
 
void readPlo (const KConfigGroup *plo, Symbol symbol, unsigned color)
 Initializes corresponding to plot file.
 
void setColor (unsigned color)
 Sets color.
 
void setFillStyle (FillStyle style)
 Sets fill style.
 
void setNormX (double fx)
 Sets normalization factor for x values.
 
void setNormY (double fy)
 Sets normalization factor for y values.
 
void setProperties (const QTransform &m)
 Sets properties according to transformation matrix.
 
void setSize ()
 Sets size according to transformation matrix.
 
void setSymbol (Symbol symbol)
 Sets symbol type.
 
void setXOffset (double xOffset)
 Sets offset for x values.
 
void setYOffset (double yOffset)
 Sets offset for y values.
 
Symbol symbol () const
 Returns symbol type.
 
void update ()
 Applies changes and forces redrawing.
 
void updateGeometry ()
 Updates geometry.
 
void writePlo (KConfigGroup *plo, bool visible) const
 Writes into plot file.
 
double xOffset () const
 Returns offset for x values.
 
double yOffset () const
 Returns offset for y values.
 
- Public Member Functions inherited from KplItem
 KplItem (double relSize=1)
 Constructor.
 
 KplItem (const KplItem &a)
 Copy constructor.
 
 KplItem (const KConfigGroup *plo)
 Constructor.
 
virtual ~KplItem ()
 Destructor.
 
void readPlo (const KConfigGroup *plo)
 Initializes corresponding to plot file.
 
double relSize () const
 Returns relative size of item.
 
void setRelSize (double relSize)
 Sets relative size of item.
 
void writePlo (KConfigGroup *plo, bool visible=true) const
 Writes into plot file.
 

Static Public Member Functions

static int sortArrays (const double *x0, const double *y0, const double *errors0, int &n, FunItem::DataErrorStruct *err, double *x, double *y, double *errors)
 Sorts arrays and calculates error column.
 
- Static Public Member Functions inherited from ScaledItem
static void exponent (double a, int &iExp, double &f)
 Calculates normalization factor.
 
static bool limits (double &xMin, double &xMax, const double *values, int n)
 Calculates minimum and maximum values of an array.
 
- Static Public Member Functions inherited from KplItem
static QUrl absoluteUrl (const QString &path, const QUrl &urlPlo)
 Constructs absolute file URL.
 
static QBrush createBrush (unsigned color, FillStyle fillStyle=NoBrush)
 Creates brush.
 
static QPen createPen (double width, unsigned color, PenType penType, Symbol symbol)
 Creates pen.
 
static void paintSymbol (QPainter *painter, const QRectF &rect, Symbol symbol=OpenCircle)
 Paints symbol.
 
static QPixmap pixmap (Symbol symbol)
 Returns black decoration pixmap of plot symbol for use in dialog GUI.
 
static QPixmap pixmap (QPen pen, Symbol symbol=SolidLine)
 Returns decoration pixmap of plot symbol for use in item lists.
 
static QString path (const QUrl &urlPlo, const QUrl &url, bool absolute=false)
 Constructs absolute or (if possible) relative file path.
 
static void resetDashOffset ()
 Resets offset for dashed lines.
 
static unsigned rgb (const QString &color)
 Converts rgb string to QRgb.
 
static unsigned rgbQt1 (unsigned rgb)
 Converts QRgb to Qt1 QRgb.
 

Protected Member Functions

void paintCond (QPainter *painter) const
 Paints or calculates bounding area.
 
- Protected Member Functions inherited from ScaledItem
double length (const double *x, const double *y, int n) const
 Calculates line length.
 
void plotArray (QPainter *painter, const double *x, const double *y, int n) const
 Plots array.
 
void setProperties ()
 Sets properties according to transformation matrix.
 
- Protected Member Functions inherited from KplItem
QPen & changePenWidth (QPen &pen, double width) const
 Changes pen width.
 
QPen createPen (QGraphicsItem *item, unsigned color=0, PenType penType=DataPen, Symbol symbol=SolidLine) const
 Creates pen for plot item.
 
double penWidth (const QGraphicsItem *item, PenType penType=DataPen) const
 Calculates pen width for plot item.
 

Protected Attributes

bool logXo
 
int m_degree
 
int m_numKnots
 
int m_derivOrder
 
int degreeo
 
int numKnotso
 
int derivOrdero
 
double m_xMin
 
double m_xMax
 
double m_deltaX
 
double m_xLow
 
double xMino
 
double xMaxo
 
double deltaXo
 
double xLowo
 
QVector< double > m_xValues
 
QVector< double > m_yValues
 
QVector< double > t
 
QVector< double > c
 
- Protected Attributes inherited from ScaledItem
FillStyle m_fillStyle
 
Symbol m_symbol
 
unsigned m_color
 
double m_normX
 
double m_normY
 
double m_xOffset
 
double m_yOffset
 
double dydx
 
double myDashOffset
 
QPen m_pen
 
QPainterPath bPath
 
QRectF bRect
 
QRectF symbRect
 
QTransform m_matrix
 
- Protected Attributes inherited from KplItem
double m_relSize
 

Additional Inherited Members

- Static Protected Member Functions inherited from KplItem
static double parentWidth (const QGraphicsItem *item)
 Returns width of item's parent frame or width of scene if the item has no parent item.
 
static double penWidthFactor (PenType penType)
 Returns factor to calculate pen width from frame width.
 
- Static Protected Attributes inherited from KplItem
static double m_dashOffset
 

Detailed Description

Spline item class.

Class for smoothing spline items for plotting spline interpolations, derivatives or integrals by lines or markers.

Author
Werner Stille

Member Enumeration Documentation

◆ anonymous enum

anonymous enum

Specific QGraphicsItem type number for function type()

Enumerator
Type 

Specific QGraphicsItem type number of SplineItem for function type().

Constructor & Destructor Documentation

◆ SplineItem() [1/2]

SplineItem::SplineItem ( int degree = 3,
int derivOrder = 0,
double xLow = 0,
unsigned color = 0,
Symbol symbol = SolidLine,
double fx = 1,
double fy = 1,
QGraphicsItem * parent = nullptr,
double xMin = 0,
double xMax = 0,
double deltaX = 0,
bool visible = true,
FillStyle fillStyle = NoBrush,
double xOffset = 0,
double yOffset = 0,
double relSize = 1 )

Constructor.

Initializes corresponding to arguments.

Parameters
degreedegree of spline.
derivOrderorder of derivative.
xLowlower x limit for spline integral.
colorcolor for plot.
symbolsymbol type.
fxnormalization factor for x values.
fynormalization factor for y values.
parentpointer to parent item.
xMinminimum argument value.
xMaxmaximum argument value.
deltaXargument step size.
visibletrue for visible item.
fillStyle> 0 for filled polygon representation.
xOffsetoffset for x values.
yOffsetoffset for x values.
relSizerelative size of lines or symbols.

◆ SplineItem() [2/2]

SplineItem::SplineItem ( const KConfigGroup * plo,
unsigned color = 0,
Symbol symbol = SolidLine,
QGraphicsItem * parent = nullptr )

Constructor.

Initializes corresponding to plot file.

Parameters
plopointer to KConfigGroup object containing item data.
colordefault color for function plot.
symboldefault symbol type.
parentpointer to parent item.

Member Function Documentation

◆ calcTable() [1/2]

int SplineItem::calcTable ( bool logX) const

Calculates spline value table.

Parameters
logXtrue for logarithmic steps
Returns
number of rows.

◆ calcTable() [2/2]

int SplineItem::calcTable ( const double * x,
double * values,
int n = 1,
int derivOrder = 0,
double xLow = 0 ) const

Calculates spline value table.

Parameters
xarray with x values.
valuesarray for y values.
nnumber of points.
derivOrderorder of derivative.
xLowlower x limit in case of spline integral.
Returns
error code.

◆ copySpline()

void SplineItem::copySpline ( const SplineItem * a)

Copies spline data.

Parameters
apointer to source item.

◆ exponent()

void SplineItem::exponent ( int & expX,
int & expY,
double & fx,
double & fy,
bool logX ) const

Calculates normalization factors.

Parameters
expXreference to logarithm of x normalization factor.
expYreference to logarithm of x normalization factor.
fxreference to x normalization factor.
fyreference to y normalization factor.
logXtrue for logarithmic x axis.

◆ exportTable()

void SplineItem::exportTable ( QTextStream & stream,
char separator,
char format,
int precision ) const

Exports spline value table to file.

Parameters
streamstream for output file.
separatorcolumn separator character.
formatC format character.
precisionnumber of digits.

◆ fit() [1/2]

int SplineItem::fit ( const ArrayItem * ai,
double xMin,
double xMax,
double * chiSquare = nullptr,
int * numKnots = nullptr,
double smooth = 0,
FunItem::DataErrorStruct * err = nullptr,
double * avgErr = nullptr )

Performs smoothing spline fit.

Parameters
aipointer to array item.
xMinlower boundary of approximation interval.
xMaxupper boundary of approximation interval.
chiSquarechi-square.
numKnotsnumber of knots.
smoothsmoothing factor.
errpointer to structure containing the data error settings.
avgErraverage error.
Returns
error code.

◆ fit() [2/2]

int SplineItem::fit ( const double * x,
const double * y,
const double * errors,
int n,
double xMin,
double xMax,
double * chiSquare = nullptr,
int * numKnots = nullptr,
double smooth = 0,
FunItem::DataErrorStruct * err = nullptr,
double * avgErr = nullptr )

Performs smoothing spline fit.

Parameters
xarray with x values.
yarray with y values.
errorsarray with error values.
nnumber of points.
xMinlower boundary of approximation interval.
xMaxupper boundary of approximation interval.
chiSquarechi-square.
numKnotsnumber of knots.
smoothsmoothing factor.
errpointer to structure containing the data error settings.
avgErraverage error.
Returns
error code.

◆ interpolation()

int SplineItem::interpolation ( const double * x,
const double * y,
int n,
double xMin,
double xMax )

Performs interpolating (non-smoothing) spline fit.

Parameters
xarray with x values.
yarray with y values.
nnumber of points.
xMinlower boundary of approximation interval.
xMaxupper boundary of approximation interval.
Returns
error code.

◆ limits()

void SplineItem::limits ( double & xMin,
double & xMax,
double & yMin,
double & yMax,
bool logX ) const

Calculates minimum and maximum values.

Parameters
xMinreference to minimum of x values.
xMaxreference to maximum of x values.
yMinreference to minimum of y values.
yMaxreference to maximum of y values.
logXtrue for logarithmic x axis.

◆ paintCond()

void SplineItem::paintCond ( QPainter * painter) const
protected

Paints or calculates bounding area.

Parameters
painterQPainter object, 0 for calculating bounding area.

◆ roots()

int SplineItem::roots ( QVector< double > & zero,
int derivOrder = 0,
double offset = 0 ) const

Finds roots of a cubic spline or its derivatives.

Parameters
zeroarray for roots.
derivOrderorder of derivative.
offsetvalue of the spline or derivative.
Returns
error code.

◆ setDegree()

void SplineItem::setDegree ( int degree)
inline

Sets degree of spline.

Parameters
degreedegree.

◆ setDeltaX()

void SplineItem::setDeltaX ( double deltaX)
inline

Sets argument step size.

Parameters
deltaXstep size.

◆ setDerivOrder()

void SplineItem::setDerivOrder ( int derivOrder)
inline

Sets order of derivative.

Parameters
derivOrderorder.

◆ setXLow()

void SplineItem::setXLow ( double xLow)
inline

Sets lower x limit for spline integral.

Parameters
xLowlower x limit.

◆ setXMax()

void SplineItem::setXMax ( double xMax)
inline

Sets maximum argument value.

Parameters
xMaxmaximum argument value.

◆ setXMin()

void SplineItem::setXMin ( double xMin)
inline

Sets minimum argument value.

Parameters
xMinminimum argument value.

◆ sortArrays()

static int SplineItem::sortArrays ( const double * x0,
const double * y0,
const double * errors0,
int & n,
FunItem::DataErrorStruct * err,
double * x,
double * y,
double * errors )
static

Sorts arrays and calculates error column.

Parameters
x0array with x values.
y0array with y values.
errors0array with error values.
nnumber of points.
errpointer to structure containing the data error settings.
xarray for sorted x values.
yarray for y values.
errorsarray for error values.
Returns
error code.

◆ writePlo()

void SplineItem::writePlo ( KConfigGroup * plo,
char format,
int precision ) const

Writes into plot file.

Parameters
ploKConfigGroup object.
formatC format character.
precisionnumber of digits.

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