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

Function item class. More...

#include <funitem.h>

Inheritance diagram for FunItem:

Classes

struct  DataErrorStruct
 Data error structure. More...
 

Public Types

enum  { Type = UserType + Function }
 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

 FunItem ()
 Constructor.
 
 FunItem (const FunItem &a)
 Copy constructor.
 
 FunItem (const KConfigGroup *plo, const QUrl &urlPlo, unsigned color=0, Symbol symbol=SolidLine, QGraphicsItem *parent=nullptr)
 Constructor.
 
 FunItem (const QUrl &url, const QString &name, 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.
 
virtual ~FunItem ()
 Destructor.
 
virtual QRectF boundingRect () const override
 Calculates bounding rectangle.
 
int calcTable () const
 Calculates function value table.
 
int calcTable (bool logX) const
 Calculates function value table.
 
double deltaT () const
 Returns argument step size.
 
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 function value table to file.
 
const QLibrary * libY () const
 Returns pointer to library for y function.
 
void limits (double &xMin, double &xMax, double &yMin, double &yMax, bool logX) const
 Calculates minimum and maximum values.
 
QString nameY () const
 Returns y function name.
 
virtual void paint (QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget=nullptr) override
 Paints item.
 
double * parY ()
 Returns y function parameter array pointer.
 
void setDashOffset ()
 Sets offset for dashed lines.
 
void setDeltaT (double deltaT)
 Sets argument step size.
 
bool setFuncY (const QUrl &url, const QString &name)
 Resolves y function address.
 
virtual void setPar (int i, double value, bool yFunc=true)
 Sets parameter.
 
void setTMax (double xMax)
 Sets maximum argument value.
 
void setTMin (double xMin)
 Sets minimum argument value.
 
virtual QPainterPath shape () const override
 Returns the shape of the plot item.
 
double tMax () const
 Returns maximum argument value.
 
double tMin () const
 Returns minimum argument value.
 
const double * tValues () const
 Returns pointer to argument value array.
 
virtual int type () const override
 Returns specific QGraphicsItem type number.
 
const QUrl & urlY () const
 Returns URL of y function library.
 
void writePlo (KConfigGroup *plo, const QUrl &urlPlo, bool absolute, char format, int precision) const
 Writes into plot file.
 
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 void calcTable (const double *x, double *values, double(*func)(double, const double *), const double *par, int n)
 Calculates function value table.
 
static bool errorStructChanged (const DataErrorStruct &e1, const DataErrorStruct &e2)
 Checks data error structures for differences.
 
static int fit (const QList< const ArrayItem * > *aList, QList< FunItem * > *fList, const bool *bFit, double *par, QVector< double > *resVector=nullptr, QVector< double > *sigma=nullptr, FunItem::DataErrorStruct *err=nullptr, bool nonLin=true, double tol=1e-14, int itMax=100, LMFit *lm=nullptr, double *chiSquare=nullptr, double *corr=nullptr, double *parErr=nullptr, double *avgErr=nullptr, QObject *parent=nullptr)
 Performs fit of parameters of a set of functions to a set of arrays.
 
static bool parChanged (const double *p1, const double *p2)
 Checks parameter arrays for differences.
 
static QString parToString (const double *par, char format, int precision)
 Converts parameter array to string.
 
static void stringToPar (const QString &s, double *par)
 Converts string to parameter array values.
 
- 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.
 

Public Attributes

double(* funcY )(double, const double *)
 y function.
 

Static Public Attributes

static const int NumParMax = 20
 Dimension of parameter arrays.
 

Protected Member Functions

void init ()
 Performs initialization.
 
void paintCond (QPainter *painter) const
 Paints or calculates bounding area.
 
void unload ()
 Unloads y function library.
 
- 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
 
double m_tMin
 
double m_tMax
 
double m_deltaT
 
double tMino
 
double tMaxo
 
double deltaTo
 
double(* funcYo )(double, const double *)
 
double m_parY [NumParMax]
 
double parYo [NumParMax]
 
QVector< double > m_tValues
 
QVector< double > m_yValues
 
QString m_nameY
 
QUrl m_urlY
 
QLibrary * m_libY
 
- 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

Function item class.

Class for function items showing ordinary functions 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 FunItem for function type().

Constructor & Destructor Documentation

◆ FunItem() [1/3]

FunItem::FunItem ( const FunItem & a)

Copy constructor.

Parameters
asource item.

◆ FunItem() [2/3]

FunItem::FunItem ( const KConfigGroup * plo,
const QUrl & urlPlo,
unsigned color = 0,
Symbol symbol = SolidLine,
QGraphicsItem * parent = nullptr )

Constructor.

Initializes corresponding to plot file.

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

◆ FunItem() [3/3]

FunItem::FunItem ( const QUrl & url,
const QString & name,
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
urlURL of the function library.
namefunction name.
colorcolor for function 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, 0 for automatic.
visibletrue for visible item.
fillStylefill style.
xOffsetoffset for x values.
yOffsetoffset for x values.
relSizerelative size of lines or symbols.

Member Function Documentation

◆ boundingRect()

virtual QRectF FunItem::boundingRect ( ) const
overridevirtual

Calculates bounding rectangle.

Reimplemented in ParFunItem.

◆ calcTable() [1/3]

int FunItem::calcTable ( ) const

Calculates function value table.

Returns
number of rows.

◆ calcTable() [2/3]

int FunItem::calcTable ( bool logX) const

Calculates function value table.

Parameters
logXtrue for logarithmic steps
Returns
number of rows.

◆ calcTable() [3/3]

static void FunItem::calcTable ( const double * x,
double * values,
double(* func )(double, const double *),
const double * par,
int n )
static

Calculates function value table.

Parameters
xarray with argument values.
valuesarray for function values.
funcfunction.
parparameter array.
nnumber of values.

◆ errorStructChanged()

static bool FunItem::errorStructChanged ( const DataErrorStruct & e1,
const DataErrorStruct & e2 )
static

Checks data error structures for differences.

Parameters
e1first data error structure.
e2second data error structure.
Returns
true for different structure contents.

◆ exponent()

void FunItem::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 FunItem::exportTable ( QTextStream & stream,
char separator,
char format,
int precision ) const

Exports function value table to file.

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

◆ fit()

static int FunItem::fit ( const QList< const ArrayItem * > * aList,
QList< FunItem * > * fList,
const bool * bFit,
double * par,
QVector< double > * resVector = nullptr,
QVector< double > * sigma = nullptr,
FunItem::DataErrorStruct * err = nullptr,
bool nonLin = true,
double tol = 1e-14,
int itMax = 100,
LMFit * lm = nullptr,
double * chiSquare = nullptr,
double * corr = nullptr,
double * parErr = nullptr,
double * avgErr = nullptr,
QObject * parent = nullptr )
static

Performs fit of parameters of a set of functions to a set of arrays.

Parameters
aListarray item list.
fListfunction item list.
bFitarray containing true values for parameters to be fitted.
parparameter array.
resVectorarray for weighted residuals.
sigmaarray for data errors.
errarray of structures containing the data error settings.
nonLintrue for nonlinear fit.
toltolerance value for stopping nonlinear fit iterations.
itMaxmaximum number of nonlinear fit iterations.
lmobject for Levenberg-Marquardt fits.
chiSquarechi-square.
corrarray for parameter correlation matrix.
parErrarray for parameter erros.
avgErraverage error.
parentparent object for lm.
Returns
error code.

◆ limits()

void FunItem::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.

◆ paint()

virtual void FunItem::paint ( QPainter * painter,
const QStyleOptionGraphicsItem * option,
QWidget * widget = nullptr )
overridevirtual

Paints item.

Reimplemented in ParFunItem.

◆ paintCond()

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

Paints or calculates bounding area.

Parameters
painterQPainter object, 0 for calculating bounding area.

◆ parChanged()

static bool FunItem::parChanged ( const double * p1,
const double * p2 )
static

Checks parameter arrays for differences.

Parameters
p1first parameter array.
p2second parameter array.
Returns
true for different array contents.

◆ parToString()

static QString FunItem::parToString ( const double * par,
char format,
int precision )
static

Converts parameter array to string.

Parameters
parparameter array.
formatC format character.
precisionnumber of digits.
Returns
space separated string.

◆ setDeltaT()

void FunItem::setDeltaT ( double deltaT)
inline

Sets argument step size.

Parameters
deltaTstep size.

◆ setFuncY()

bool FunItem::setFuncY ( const QUrl & url,
const QString & name )

Resolves y function address.

Parameters
urlurl of the function library.
namefunction name.
Returns
true for success.

◆ setPar()

virtual void FunItem::setPar ( int i,
double value,
bool yFunc = true )
virtual

Sets parameter.

Parameters
iparameter index.
valuevalue.
yFunctrue for y value function.

Reimplemented in ParFunItem.

◆ setTMax()

void FunItem::setTMax ( double xMax)
inline

Sets maximum argument value.

Parameters
xMaxmaximum value.

◆ setTMin()

void FunItem::setTMin ( double xMin)
inline

Sets minimum argument value.

Parameters
xMinmaximum value.

◆ stringToPar()

static void FunItem::stringToPar ( const QString & s,
double * par )
static

Converts string to parameter array values.

Parameters
sstring.
parparameter array.

◆ type()

virtual int FunItem::type ( ) const
inlineoverridevirtual

Returns specific QGraphicsItem type number.

Reimplemented in ParFunItem.

◆ writePlo()

void FunItem::writePlo ( KConfigGroup * plo,
const QUrl & urlPlo,
bool absolute,
char format,
int precision ) const

Writes into plot file.

Parameters
ploKConfigGroup object.
urlPloURL of plot file.
absolutetrue to save absolute paths.
formatC format character.
precisionnumber of digits.

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