mirror of
https://github.com/jkriege2/JKQtPlotter.git
synced 2025-01-12 17:00:32 +08:00
fixed several compiler warnings (mostly Visual Studio): clean-up of use of math constants M_PI ... and j0()/j1()/...-functions etc.
This commit is contained in:
parent
29b1c5aa37
commit
56660e2f4b
@ -10,13 +10,10 @@ if(MINGW)
|
|||||||
elseif(MSVC)
|
elseif(MSVC)
|
||||||
# COMPILER-SETTINGS FOR MS VISUAL C++
|
# COMPILER-SETTINGS FOR MS VISUAL C++
|
||||||
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /EHsc")
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /EHsc")
|
||||||
# To enable M_PI, M_E,...
|
|
||||||
add_definitions(/D_USE_MATH_DEFINES)
|
|
||||||
# To Prevent Errors with min() and max()
|
|
||||||
add_definitions(/DNOMINMAX)
|
|
||||||
# To fix error: C2338: va_start argument must not
|
# To fix error: C2338: va_start argument must not
|
||||||
# have reference type and must not be parenthesized
|
# have reference type and must not be parenthesized
|
||||||
add_definitions(/D_CRT_NO_VA_START_VALIDATION)
|
add_definitions(/D_CRT_NO_VA_START_VALIDATION)
|
||||||
|
add_definitions(/DNOMINMAX)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(NOT APPLE)
|
if(NOT APPLE)
|
||||||
|
@ -22,6 +22,8 @@ function(jkqtplotter_deployqt TARGET_NAME)
|
|||||||
COMMAND "${CMAKE_COMMAND}" -E
|
COMMAND "${CMAKE_COMMAND}" -E
|
||||||
env PATH="${CMAKE_CXX_COMPILER_BINPATH}\;${_qt_bin_dir}" "${WINDEPLOYQT_EXECUTABLE}"
|
env PATH="${CMAKE_CXX_COMPILER_BINPATH}\;${_qt_bin_dir}" "${WINDEPLOYQT_EXECUTABLE}"
|
||||||
--compiler-runtime
|
--compiler-runtime
|
||||||
|
-xml
|
||||||
|
-printsupport
|
||||||
${WINDEPLOYQTOPTION}
|
${WINDEPLOYQTOPTION}
|
||||||
\"$<TARGET_FILE:${TARGET_NAME}>\"
|
\"$<TARGET_FILE:${TARGET_NAME}>\"
|
||||||
COMMENT "Running windeployqt ... "
|
COMMENT "Running windeployqt ... "
|
||||||
|
@ -23,11 +23,11 @@ int main(int argc, char* argv[])
|
|||||||
QVector<double> X, Yline, Yfilled, Yfilled2, Ybarsempty, Ybarsfilled;
|
QVector<double> X, Yline, Yfilled, Yfilled2, Ybarsempty, Ybarsfilled;
|
||||||
const int Ndata=20; // number of plot points in each curve
|
const int Ndata=20; // number of plot points in each curve
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
const double x=double(i)/double(Ndata)*4.0*M_PI;
|
const double x=double(i)/double(Ndata)*4.0*JKQTPSTATISTICS_PI;
|
||||||
X<<x;
|
X<<x;
|
||||||
Yfilled<<(2.5-0.7*x/4.0/M_PI+sin(x*1.5));
|
Yfilled<<(2.5-0.7*x/4.0/JKQTPSTATISTICS_PI+sin(x*1.5));
|
||||||
Yfilled2<<0.75*(1.5-0.7*x/4.0/M_PI+sin(x*1.5));
|
Yfilled2<<0.75*(1.5-0.7*x/4.0/JKQTPSTATISTICS_PI+sin(x*1.5));
|
||||||
double bar=(1.0+0.65*x/4.0/M_PI+sin(x/2.0));
|
double bar=(1.0+0.65*x/4.0/JKQTPSTATISTICS_PI+sin(x/2.0));
|
||||||
Ybarsempty<<(-bar);
|
Ybarsempty<<(-bar);
|
||||||
Ybarsfilled<<(-bar)*(cos(x)+1.2)/3.0;
|
Ybarsfilled<<(-bar)*(cos(x)+1.2)/3.0;
|
||||||
}
|
}
|
||||||
|
@ -9,12 +9,8 @@
|
|||||||
#include "jkqtplotter/jkqtplotter.h"
|
#include "jkqtplotter/jkqtplotter.h"
|
||||||
#include "jkqtplotter/graphs/jkqtpcontour.h"
|
#include "jkqtplotter/graphs/jkqtpcontour.h"
|
||||||
|
|
||||||
#ifndef M_PI
|
// if deJKQTPSTATISTICS_PId, an animation is shown
|
||||||
#define M_PI 3.14159265358979323846
|
//#definJKQTPSTATISTICS_PIIMATE
|
||||||
#endif
|
|
||||||
|
|
||||||
// if defined, an animation is shown
|
|
||||||
//#define ANIMATE
|
|
||||||
|
|
||||||
#ifdef ANIMATE
|
#ifdef ANIMATE
|
||||||
#include "contourplotanimator.h"
|
#include "contourplotanimator.h"
|
||||||
@ -68,15 +64,14 @@ int main(int argc, char* argv[])
|
|||||||
const double r2=sqrt((x-Q2_x0)*(x-Q2_x0)+(y-Q2_y0)*(y-Q2_y0));
|
const double r2=sqrt((x-Q2_x0)*(x-Q2_x0)+(y-Q2_y0)*(y-Q2_y0));
|
||||||
const double r3=sqrt((x-Q3_x0)*(x-Q3_x0)+(y-Q3_y0)*(y-Q3_y0));
|
const double r3=sqrt((x-Q3_x0)*(x-Q3_x0)+(y-Q3_y0)*(y-Q3_y0));
|
||||||
const double r4=sqrt((x-Q4_x0)*(x-Q4_x0)+(y-Q4_y0)*(y-Q4_y0));
|
const double r4=sqrt((x-Q4_x0)*(x-Q4_x0)+(y-Q4_y0)*(y-Q4_y0));
|
||||||
ds->setPixel(cPotential, ix, iy, Q1/(4.0*M_PI*eps0)/r1+Q2/(4.0*M_PI*eps0)/r2+Q3/(4.0*M_PI*eps0)/r3+Q4/(4.0*M_PI*eps0)/r4);
|
ds->setPixel(cPotential, ix, iy, Q1/(4.0*JKQTPSTATISTICS_PI*eps0)/r1+Q2/(4.0*JKQTPSTATISTICS_PI*eps0)/r2+Q3/(4.0*JKQTPSTATISTICS_PI*eps0)/r3+Q4/(4.0*JKQTPSTATISTICS_PI*eps0)/r4);
|
||||||
x+=dx;
|
x+=dx;
|
||||||
}
|
}
|
||||||
y+=dx;
|
y+=dx;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// the following code will plot a dipole potential instead of the quadrupole after 5s
|
// the following code will plot a dipole JKQTPSTATISTICS_PIntial instead of tJKQTPSTATISTICS_PIuadrupole after 5sJKQTPSTATISTICS_PI // this tests theJKQTPSTATISTICS_PIognition of altered data
|
||||||
// this tests the recognition of altered data
|
|
||||||
#ifdef ANIMATE
|
#ifdef ANIMATE
|
||||||
JKQTPlotter* pplot=&plot;
|
JKQTPlotter* pplot=&plot;
|
||||||
ContourPlotAnimator animation(ds,pplot,NX,NY,w,h,dx,cPotential);
|
ContourPlotAnimator animation(ds,pplot,NX,NY,w,h,dx,cPotential);
|
||||||
@ -104,11 +99,11 @@ int main(int argc, char* argv[])
|
|||||||
QVector<double> reldists; reldists<<0.1<<0.25<<0.5<<1<<1.5<<2<<2.5<<3;
|
QVector<double> reldists; reldists<<0.1<<0.25<<0.5<<1<<1.5<<2<<2.5<<3;
|
||||||
// finally contour levels with +1 and -1 sign are added to show the positive and negative potential:
|
// finally contour levels with +1 and -1 sign are added to show the positive and negative potential:
|
||||||
for (auto reldist: reldists) {
|
for (auto reldist: reldists) {
|
||||||
const double level=fabs(Q1/(4.0*M_PI*eps0)/(Q1_x0*reldist));
|
const double level=fabs(Q1/(4.0*JKQTPSTATISTICS_PI*eps0)/(Q1_x0*reldist));
|
||||||
graph->addContourLevel(-level);
|
graph->addContourLevel(-level);
|
||||||
graph->addContourLevel(level);
|
graph->addContourLevel(level);
|
||||||
|
|
||||||
// set a special color for some lines:
|
// set a special color for some JKQTPSTATISTICS_PIs:
|
||||||
//if (reldist==1) {
|
//if (reldist==1) {
|
||||||
// graph->setOverrideColor(-level, QColor("yellow"));
|
// graph->setOverrideColor(-level, QColor("yellow"));
|
||||||
// graph->setOverrideColor(level, QColor("yellow"));
|
// graph->setOverrideColor(level, QColor("yellow"));
|
||||||
|
@ -37,7 +37,7 @@ void ContourPlotAnimator::step() {
|
|||||||
const double r2=sqrt((x-Q2_x0)*(x-Q2_x0)+(y-Q2_y0)*(y-Q2_y0));
|
const double r2=sqrt((x-Q2_x0)*(x-Q2_x0)+(y-Q2_y0)*(y-Q2_y0));
|
||||||
const double r3=sqrt((x-Q3_x0)*(x-Q3_x0)+(y-Q3_y0)*(y-Q3_y0));
|
const double r3=sqrt((x-Q3_x0)*(x-Q3_x0)+(y-Q3_y0)*(y-Q3_y0));
|
||||||
const double r4=sqrt((x-Q4_x0)*(x-Q4_x0)+(y-Q4_y0)*(y-Q4_y0));
|
const double r4=sqrt((x-Q4_x0)*(x-Q4_x0)+(y-Q4_y0)*(y-Q4_y0));
|
||||||
ds->setPixel(cPotential, ix, iy, Q1/(4.0*M_PI*eps0)/r1+Q2/(4.0*M_PI*eps0)/r2+Q3/(4.0*M_PI*eps0)/r3+Q4/(4.0*M_PI*eps0)/r4);
|
ds->setPixel(cPotential, ix, iy, Q1/(4.0*JKQTPSTATISTICS_PI*eps0)/r1+Q2/(4.0*JKQTPSTATISTICS_PI*eps0)/r2+Q3/(4.0*JKQTPSTATISTICS_PI*eps0)/r3+Q4/(4.0*JKQTPSTATISTICS_PI*eps0)/r4);
|
||||||
x+=dx;
|
x+=dx;
|
||||||
}
|
}
|
||||||
y+=dx;
|
y+=dx;
|
||||||
@ -45,7 +45,7 @@ void ContourPlotAnimator::step() {
|
|||||||
pplot->redrawPlot();
|
pplot->redrawPlot();
|
||||||
qDebug()<<"animation step: angle="<<angle<<", framerate="<<1.0/(timerFR.elapsed()/1000.0)<<"fps <==> "<<timerFR.elapsed()<<"ms/frame";
|
qDebug()<<"animation step: angle="<<angle<<", framerate="<<1.0/(timerFR.elapsed()/1000.0)<<"fps <==> "<<timerFR.elapsed()<<"ms/frame";
|
||||||
pplot->setWindowTitle("JKQTPColumnContourPlot ["+QString::number(1.0/(timerFR.elapsed()/1000.0))+"fps]");
|
pplot->setWindowTitle("JKQTPColumnContourPlot ["+QString::number(1.0/(timerFR.elapsed()/1000.0))+"fps]");
|
||||||
angle+=(2.0/180.0*M_PI);
|
angle+=(2.0/180.0*JKQTPSTATISTICS_PI);
|
||||||
timerFR.start();
|
timerFR.start();
|
||||||
QTimer::singleShot(1, this,SLOT(step()));
|
QTimer::singleShot(1, this,SLOT(step()));
|
||||||
}
|
}
|
||||||
|
@ -7,9 +7,6 @@
|
|||||||
#include <cmath>
|
#include <cmath>
|
||||||
#include "jkqtplotter/jkqtplotter.h"
|
#include "jkqtplotter/jkqtplotter.h"
|
||||||
|
|
||||||
#ifndef M_PI
|
|
||||||
#define M_PI 3.14159265358979323846
|
|
||||||
#endif
|
|
||||||
|
|
||||||
class ContourPlotAnimator: public QObject {
|
class ContourPlotAnimator: public QObject {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
@ -32,7 +32,7 @@ int main(int argc, char* argv[])
|
|||||||
QVector<double> X, Y;
|
QVector<double> X, Y;
|
||||||
const int Ndata=100;
|
const int Ndata=100;
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
const double x=double(i)/double(Ndata)*8.0*M_PI;
|
const double x=double(i)/double(Ndata)*8.0*JKQTPSTATISTICS_PI;
|
||||||
X<<x;
|
X<<x;
|
||||||
Y<<sin(x);
|
Y<<sin(x);
|
||||||
}
|
}
|
||||||
|
@ -23,7 +23,7 @@ int main(int argc, char* argv[])
|
|||||||
|
|
||||||
// 2. now we create a cos-curve plot with the standard means of JKQTPDatastore::addColumn(NRows, "name")
|
// 2. now we create a cos-curve plot with the standard means of JKQTPDatastore::addColumn(NRows, "name")
|
||||||
// and JKQTPDatastore::set() to actually set the values:
|
// and JKQTPDatastore::set() to actually set the values:
|
||||||
//size_t XCol=datastore->addLinearColumn(50, 0, 4.0*M_PI, "cos curve: x-data");
|
//size_t XCol=datastore->addLinearColumn(50, 0, 4.0*JKQTPSTATISTICS_PI, "cos curve: x-data");
|
||||||
//size_t YCol=datastore->addColumn(datastore->getRows(XCol), "cos curve: y-data");
|
//size_t YCol=datastore->addColumn(datastore->getRows(XCol), "cos curve: y-data");
|
||||||
//for (size_t i=0; i<datastore->getRows(XCol); i++) {
|
//for (size_t i=0; i<datastore->getRows(XCol); i++) {
|
||||||
// datastore->set(YCol, i, cos(datastore->get(XCol, i)));
|
// datastore->set(YCol, i, cos(datastore->get(XCol, i)));
|
||||||
@ -39,14 +39,14 @@ int main(int argc, char* argv[])
|
|||||||
size_t YCol=datastore->addColumn("cos curve: y-data");
|
size_t YCol=datastore->addColumn("cos curve: y-data");
|
||||||
auto biXCol=datastore->backInserter(XCol);
|
auto biXCol=datastore->backInserter(XCol);
|
||||||
auto biYCol=datastore->backInserter(YCol);
|
auto biYCol=datastore->backInserter(YCol);
|
||||||
for (double x=0; x<4.0*M_PI; x+=4.0*M_PI/50.0) {
|
for (double x=0; x<4.0*JKQTPSTATISTICS_PI; x+=4.0*JKQTPSTATISTICS_PI/50.0) {
|
||||||
*biXCol=x;
|
*biXCol=x;
|
||||||
*biYCol=cos(x);
|
*biYCol=cos(x);
|
||||||
++biXCol;
|
++biXCol;
|
||||||
++biYCol;
|
++biYCol;
|
||||||
}
|
}
|
||||||
// 2.3 combining with addLinearColumn() you can also use C++ STL algorithms:
|
// 2.3 combining with addLinearColumn() you can also use C++ STL algorithms:
|
||||||
//size_t XCol=datastore->addLinearColumn(50, 0, 4.0*M_PI, "cos curve: x-data");
|
//size_t XCol=datastore->addLinearColumn(50, 0, 4.0*JKQTPSTATISTICS_PI, "cos curve: x-data");
|
||||||
//size_t YCol=datastore->addColumn("cos curve: y-data");
|
//size_t YCol=datastore->addColumn("cos curve: y-data");
|
||||||
//std::transform(datastore->begin(XCol), datastore->end(XCol), datastore->backInserter(YCol), cos);
|
//std::transform(datastore->begin(XCol), datastore->end(XCol), datastore->backInserter(YCol), cos);
|
||||||
// 2.4. Just for fun we can now sort the data:
|
// 2.4. Just for fun we can now sort the data:
|
||||||
|
@ -15,9 +15,9 @@ set(UIS )
|
|||||||
add_executable(${EXENAME} WIN32 ${SOURCES} ${HEADERS} ${RESOURCES} ${UIS})
|
add_executable(${EXENAME} WIN32 ${SOURCES} ${HEADERS} ${RESOURCES} ${UIS})
|
||||||
target_include_directories(${EXENAME} PRIVATE ../../lib)
|
target_include_directories(${EXENAME} PRIVATE ../../lib)
|
||||||
if(JKQtPlotter_BUILD_STATIC_LIBS)
|
if(JKQtPlotter_BUILD_STATIC_LIBS)
|
||||||
target_link_libraries(${EXENAME} JKQTPlotterLib)
|
target_link_libraries(${EXENAME} JKQTPlotterLib Qt5::PrintSupport Qt5::Xml)
|
||||||
elseif(JKQtPlotter_BUILD_SHARED_LIBS)
|
elseif(JKQtPlotter_BUILD_SHARED_LIBS)
|
||||||
target_link_libraries(${EXENAME} JKQTPlotterSharedLib)
|
target_link_libraries(${EXENAME} JKQTPlotterSharedLib Qt5::PrintSupport Qt5::Xml)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
@ -99,7 +99,7 @@ int main(int argc, char* argv[])
|
|||||||
JKQTPXFunctionLineGraph* graphTheoDist=new JKQTPXFunctionLineGraph(&plot);
|
JKQTPXFunctionLineGraph* graphTheoDist=new JKQTPXFunctionLineGraph(&plot);
|
||||||
// define the gaussian function used for the random number generator
|
// define the gaussian function used for the random number generator
|
||||||
graphTheoDist->setPlotFunctionFunctor([&th_mean,&th_std](double x) -> double {
|
graphTheoDist->setPlotFunctionFunctor([&th_mean,&th_std](double x) -> double {
|
||||||
return 1.0/(th_std*sqrt(2.0*M_PI))*exp(-0.5*(x-th_mean)*(x-th_mean)/th_std/th_std);
|
return 1.0/(th_std*sqrt(2.0*JKQTPSTATISTICS_PI))*exp(-0.5*(x-th_mean)*(x-th_mean)/th_std/th_std);
|
||||||
});
|
});
|
||||||
// set title:
|
// set title:
|
||||||
graphTheoDist->setTitle(QString("Theoretical Distribution $\\mu=%1, \\sigma=%2$").arg(th_mean,0, 'f', 1).arg(th_std,0, 'f', 1));
|
graphTheoDist->setTitle(QString("Theoretical Distribution $\\mu=%1, \\sigma=%2$").arg(th_mean,0, 'f', 1).arg(th_std,0, 'f', 1));
|
||||||
|
@ -49,7 +49,7 @@ int main(int argc, char* argv[])
|
|||||||
JKQTPXFunctionLineGraph* func2=new JKQTPXFunctionLineGraph(plot);
|
JKQTPXFunctionLineGraph* func2=new JKQTPXFunctionLineGraph(plot);
|
||||||
func2->setPlotFunctionFunctor([](double x, void* params) {
|
func2->setPlotFunctionFunctor([](double x, void* params) {
|
||||||
QVector<double>* p=static_cast<QVector<double>*>(params);
|
QVector<double>* p=static_cast<QVector<double>*>(params);
|
||||||
return p->at(0)*sin(2.0*M_PI*x*p->at(1));
|
return p->at(0)*sin(2.0*JKQTPSTATISTICS_PI*x*p->at(1));
|
||||||
});
|
});
|
||||||
// here we set the parameters p0, p1
|
// here we set the parameters p0, p1
|
||||||
func2->setParamsV(5, 0.2);
|
func2->setParamsV(5, 0.2);
|
||||||
@ -62,7 +62,7 @@ int main(int argc, char* argv[])
|
|||||||
JKQTPXFunctionLineGraph* func3=new JKQTPXFunctionLineGraph(plot);
|
JKQTPXFunctionLineGraph* func3=new JKQTPXFunctionLineGraph(plot);
|
||||||
func3->setPlotFunctionFunctor([](double x, void* params) {
|
func3->setPlotFunctionFunctor([](double x, void* params) {
|
||||||
QMap<QString,double>* p=static_cast<QMap<QString,double>*>(params);
|
QMap<QString,double>* p=static_cast<QMap<QString,double>*>(params);
|
||||||
return p->value("amplitude")*sin(2.0*M_PI*x*p->value("frequency"));
|
return p->value("amplitude")*sin(2.0*JKQTPSTATISTICS_PI*x*p->value("frequency"));
|
||||||
});
|
});
|
||||||
// here we set the parameters p0, p1
|
// here we set the parameters p0, p1
|
||||||
QMap<QString,double> params3;
|
QMap<QString,double> params3;
|
||||||
|
@ -9,10 +9,6 @@
|
|||||||
#include "jkqtplotter/jkqtplotter.h"
|
#include "jkqtplotter/jkqtplotter.h"
|
||||||
#include "jkqtplotter/graphs/jkqtpimage.h"
|
#include "jkqtplotter/graphs/jkqtpimage.h"
|
||||||
|
|
||||||
#ifndef M_PI
|
|
||||||
#define M_PI 3.14159265358979323846
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char* argv[])
|
int main(int argc, char* argv[])
|
||||||
{
|
{
|
||||||
@ -44,8 +40,8 @@ int main(int argc, char* argv[])
|
|||||||
x=-w/2.0;
|
x=-w/2.0;
|
||||||
for (int ix=0; ix<NX; ix++ ) {
|
for (int ix=0; ix<NX; ix++ ) {
|
||||||
const double r=sqrt(x*x+y*y);
|
const double r=sqrt(x*x+y*y);
|
||||||
const double v=2.0*M_PI*NA*r/wavelength;
|
const double v=2.0*JKQTPSTATISTICS_PI*NA*r/wavelength;
|
||||||
airydisk[iy*NX+ix] = pow(2.0*j1(v)/v, 2);
|
airydisk[iy*NX+ix] = pow(2.0*jkqtp_j1(v)/v, 2);
|
||||||
x+=dx;
|
x+=dx;
|
||||||
}
|
}
|
||||||
y+=dy;
|
y+=dy;
|
||||||
@ -53,7 +49,7 @@ int main(int argc, char* argv[])
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
// 3. make data available to JKQTPlotter by adding it to the internal datastore.
|
// JKQTPSTATISTICS_PIake data available to JKQTPlotter by adding it to the internal datastore.
|
||||||
// In this step the contents of C-array airydisk is copied into a column
|
// In this step the contents of C-array airydisk is copied into a column
|
||||||
// of the datastore in row-major order
|
// of the datastore in row-major order
|
||||||
size_t cAiryDisk=ds->addCopiedImageAsColumn(airydisk, NX, NY, "imagedata");
|
size_t cAiryDisk=ds->addCopiedImageAsColumn(airydisk, NX, NY, "imagedata");
|
||||||
|
@ -9,11 +9,6 @@
|
|||||||
#include "jkqtplotter/jkqtplotter.h"
|
#include "jkqtplotter/jkqtplotter.h"
|
||||||
#include "jkqtplotter/graphs/jkqtpimage.h"
|
#include "jkqtplotter/graphs/jkqtpimage.h"
|
||||||
|
|
||||||
#ifndef M_PI
|
|
||||||
#define M_PI 3.14159265358979323846
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char* argv[])
|
int main(int argc, char* argv[])
|
||||||
{
|
{
|
||||||
QApplication app(argc, argv);
|
QApplication app(argc, argv);
|
||||||
@ -37,7 +32,7 @@ int main(int argc, char* argv[])
|
|||||||
x=-static_cast<double>(NX)/2.0;
|
x=-static_cast<double>(NX)/2.0;
|
||||||
for (int ix=0; ix<NX; ix++ ) {
|
for (int ix=0; ix<NX; ix++ ) {
|
||||||
const double r=sqrt(x*x+y*y);
|
const double r=sqrt(x*x+y*y);
|
||||||
image[iy*NX+ix] = cos(M_PI*r/20.0);
|
image[iy*NX+ix] = cos(JKQTPSTATISTICS_PI*r/20.0);
|
||||||
modifier[iy*NX+ix] = 1.0-r/sqrt(NX*NX/4.0+NY*NY/4.0);
|
modifier[iy*NX+ix] = 1.0-r/sqrt(NX*NX/4.0+NY*NY/4.0);
|
||||||
x+=1;
|
x+=1;
|
||||||
}
|
}
|
||||||
@ -46,7 +41,7 @@ int main(int argc, char* argv[])
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
// 3. make data available to JKQTPlotter by adding it to the internal datastore.
|
// 3. make data availJKQTPSTATISTICS_PI to JKQTPlotter by adding it to the internal datastore.
|
||||||
// In this step the contents of C-array airydisk is copied into a column
|
// In this step the contents of C-array airydisk is copied into a column
|
||||||
// of the datastore in row-major order
|
// of the datastore in row-major order
|
||||||
size_t cImage=ds->addCopiedImageAsColumn(image, NX, NY, "imagedata");
|
size_t cImage=ds->addCopiedImageAsColumn(image, NX, NY, "imagedata");
|
||||||
|
@ -9,11 +9,6 @@
|
|||||||
#include "jkqtplotter/jkqtplotter.h"
|
#include "jkqtplotter/jkqtplotter.h"
|
||||||
#include "jkqtplotter/graphs/jkqtpimage.h"
|
#include "jkqtplotter/graphs/jkqtpimage.h"
|
||||||
|
|
||||||
#ifndef M_PI
|
|
||||||
#define M_PI 3.14159265358979323846
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char* argv[])
|
int main(int argc, char* argv[])
|
||||||
{
|
{
|
||||||
QApplication app(argc, argv);
|
QApplication app(argc, argv);
|
||||||
@ -43,15 +38,15 @@ int main(int argc, char* argv[])
|
|||||||
x=-w/2.0;
|
x=-w/2.0;
|
||||||
for (int ix=0; ix<NX; ix++ ) {
|
for (int ix=0; ix<NX; ix++ ) {
|
||||||
const double r=sqrt(x*x+y*y);
|
const double r=sqrt(x*x+y*y);
|
||||||
const double v=2.0*M_PI*NA*r/wavelength;
|
const double v=2.0*JKQTPSTATISTICS_PI*NA*r/wavelength;
|
||||||
airydisk[iy*NX+ix] = pow(2.0*j1(v)/v, 2);
|
airydisk[iy*NX+ix] = pow(2.0*jkqtp_j1(v)/v, 2);
|
||||||
x+=dx;
|
x+=dx;
|
||||||
}
|
}
|
||||||
y+=dy;
|
y+=dy;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// 3. create a graph (JKQTPMathImage) with referencing the data created above as data
|
// 3. create a grapJKQTPSTATISTICS_PIKQTPMathImage) with referencing the data created above as data
|
||||||
// The data is color-coded with the color-palette JKQTPMathImageBLUEYELLOW
|
// The data is color-coded with the color-palette JKQTPMathImageBLUEYELLOW
|
||||||
// the converted range of data is determined automatically because setAutoImageRange(true)
|
// the converted range of data is determined automatically because setAutoImageRange(true)
|
||||||
JKQTPMathImage* graph=new JKQTPMathImage(&plot);
|
JKQTPMathImage* graph=new JKQTPMathImage(&plot);
|
||||||
|
@ -14,10 +14,6 @@
|
|||||||
#include "jkqtplotter/gui/jkqtpcomboboxes.h"
|
#include "jkqtplotter/gui/jkqtpcomboboxes.h"
|
||||||
#include "jkqtcommon/jkqtpbasicimagetools.h"
|
#include "jkqtcommon/jkqtpbasicimagetools.h"
|
||||||
|
|
||||||
#ifndef M_PI
|
|
||||||
#define M_PI 3.14159265358979323846
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char* argv[])
|
int main(int argc, char* argv[])
|
||||||
{
|
{
|
||||||
@ -105,15 +101,15 @@ int main(int argc, char* argv[])
|
|||||||
double x=static_cast<double>(static_cast<int>(ix)-NX/2)*dx;
|
double x=static_cast<double>(static_cast<int>(ix)-NX/2)*dx;
|
||||||
double y=static_cast<double>(static_cast<int>(iy)-NY/2)*dy;
|
double y=static_cast<double>(static_cast<int>(iy)-NY/2)*dy;
|
||||||
const double r=sqrt(x*x+y*y);
|
const double r=sqrt(x*x+y*y);
|
||||||
const double v=2.0*M_PI*NA*r/wavelength;
|
const double v=2.0*JKQTPSTATISTICS_PI*NA*r/wavelength;
|
||||||
if (ix==NX/2 && iy==NY/2) return 1.0;
|
if (ix==NX/2 && iy==NY/2) return 1.0;
|
||||||
else return pow(2.0*j1(v)/v, 2);
|
else return pow(2.0*jkqtp_j1(v)/v, 2);
|
||||||
}, "imagedata");
|
}, "imagedata");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// 3. create a graph (JKQTPColumnMathImage) with the column created above as data
|
// 3. create a grapJKQTPSTATISTICS_PIKQTPColumnMathImage) with the column created above as data
|
||||||
// The data is color-coded with the color-palette JKQTPMathImageMATLAB
|
// The data is color-coded with the color-palette JKQTPMathImageMATLAB
|
||||||
// the converted range of data is determined automatically because setAutoImageRange(true)
|
// the converted range of data is determined automatically because setAutoImageRange(true)
|
||||||
JKQTPColumnMathImage* graph=new JKQTPColumnMathImage(plot);
|
JKQTPColumnMathImage* graph=new JKQTPColumnMathImage(plot);
|
||||||
|
@ -22,7 +22,7 @@ int main(int argc, char* argv[])
|
|||||||
// 2. now we create data for a simple plot (a sine curve with lin. increasing errors)
|
// 2. now we create data for a simple plot (a sine curve with lin. increasing errors)
|
||||||
QVector<double> X, Y;
|
QVector<double> X, Y;
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
const double xx=double(i)/double(Ndata)*6.0*M_PI;
|
const double xx=double(i)/double(Ndata)*6.0*JKQTPSTATISTICS_PI;
|
||||||
X << xx;
|
X << xx;
|
||||||
Y << cos(xx)*exp(-xx/10.0);
|
Y << cos(xx)*exp(-xx/10.0);
|
||||||
}
|
}
|
||||||
|
@ -54,7 +54,7 @@ TestMain::TestMain(QWidget *parent) :
|
|||||||
for (int i=0; i<N1; i++) {
|
for (int i=0; i<N1; i++) {
|
||||||
x[i]=(i+1)*XMAX/(double)N1;
|
x[i]=(i+1)*XMAX/(double)N1;
|
||||||
xx.push_back(x[i]);
|
xx.push_back(x[i]);
|
||||||
yy.push_back(sin(0.5*M_PI*x[i])+2.0);
|
yy.push_back(sin(0.5*JKQTPSTATISTICS_PI*x[i])+2.0);
|
||||||
std::cout<<xx[i]<<", "<<yy[i]<<std::endl;
|
std::cout<<xx[i]<<", "<<yy[i]<<std::endl;
|
||||||
y1[i]=i*XMAX/(double)N1;
|
y1[i]=i*XMAX/(double)N1;
|
||||||
y2[i]=log(x[i]);
|
y2[i]=log(x[i]);
|
||||||
|
@ -35,8 +35,8 @@ TestWidgetBarcharts::TestWidgetBarcharts(QWidget *parent) :
|
|||||||
dt.setDate(QDate(2012,1+i,1));
|
dt.setDate(QDate(2012,1+i,1));
|
||||||
//qDebug()<<dt<<dt.toMSecsSinceEpoch();
|
//qDebug()<<dt<<dt.toMSecsSinceEpoch();
|
||||||
dataBCXD<<double(dt.toMSecsSinceEpoch());
|
dataBCXD<<double(dt.toMSecsSinceEpoch());
|
||||||
dataBCY1<<1.0+sin(x*M_PI/6.0);
|
dataBCY1 << 1.0 + sin(x * JKQTPSTATISTICS_PI / 6.0);
|
||||||
dataBCY2<<2.0+cos(x*M_PI/3.0);
|
dataBCY2 << 2.0 + cos(x * JKQTPSTATISTICS_PI / 3.0);
|
||||||
dataBCYE1<<dataBCY1.last()*0.1;
|
dataBCYE1<<dataBCY1.last()*0.1;
|
||||||
dataBCYE2<<dataBCY2.last()*0.05;
|
dataBCYE2<<dataBCY2.last()*0.05;
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,7 @@ TestWidgetGeometry::TestWidgetGeometry(QWidget *parent) :
|
|||||||
p.append(QPointF(-11,5));
|
p.append(QPointF(-11,5));
|
||||||
p.append(QPointF(1,11));
|
p.append(QPointF(1,11));
|
||||||
p.append(QPointF(0,-2));
|
p.append(QPointF(0,-2));
|
||||||
p.append(QPointF(M_PI,5.5));
|
p.append(QPointF(JKQTPSTATISTICS_PI,5.5));
|
||||||
|
|
||||||
// JKQTPGeoPolygon* poly=new JKQTPGeoPolygon(plotGeo->getPlotter(), p, QColor("black"), 1.5, Qt::SolidLine, QColor(128,128,0,128));
|
// JKQTPGeoPolygon* poly=new JKQTPGeoPolygon(plotGeo->getPlotter(), p, QColor("black"), 1.5, Qt::SolidLine, QColor(128,128,0,128));
|
||||||
//plotGeo->getPlotter()->addGraph(poly);
|
//plotGeo->getPlotter()->addGraph(poly);
|
||||||
|
@ -67,7 +67,7 @@ TestWidgetGraphs::TestWidgetGraphs(QWidget *parent) :
|
|||||||
|
|
||||||
|
|
||||||
for (unsigned int i=0; i<N1; i++) {
|
for (unsigned int i=0; i<N1; i++) {
|
||||||
x1[i]=(double)(i+1)/(double)N1*8*M_PI;
|
x1[i]=(double)(i+1)/(double)N1*8*JKQTPSTATISTICS_PI;
|
||||||
y11[i]=sin(x1[i]);
|
y11[i]=sin(x1[i]);
|
||||||
y12[i]=cos(x1[i]);
|
y12[i]=cos(x1[i]);
|
||||||
y13[i]=y12[i]/4.0;
|
y13[i]=y12[i]/4.0;
|
||||||
@ -87,7 +87,7 @@ TestWidgetGraphs::TestWidgetGraphs(QWidget *parent) :
|
|||||||
//plot->addGraphWithXError(cy12, cx1, cy13, "$\\cos(x)$ with errors", JKQTPFilledCurveY, JKQTPErrorPolygons);
|
//plot->addGraphWithXError(cy12, cx1, cy13, "$\\cos(x)$ with errors", JKQTPFilledCurveY, JKQTPErrorPolygons);
|
||||||
|
|
||||||
for (unsigned int i=0; i<N2; i++) {
|
for (unsigned int i=0; i<N2; i++) {
|
||||||
x2[i]=(double)(i+1)/(double)N2*8*M_PI;
|
x2[i]=(double)(i+1)/(double)N2*8*JKQTPSTATISTICS_PI;
|
||||||
y21[i]=5*sin(x2[i]);
|
y21[i]=5*sin(x2[i]);
|
||||||
y22[i]=1;//1+sin(x2[i]*4);
|
y22[i]=1;//1+sin(x2[i]*4);
|
||||||
y23[i]=pow(5,x2[i]/5.0);
|
y23[i]=pow(5,x2[i]/5.0);
|
||||||
@ -153,7 +153,7 @@ TestWidgetGraphs::TestWidgetGraphs(QWidget *parent) :
|
|||||||
yp75[i]=ymed[i]+(i+1);
|
yp75[i]=ymed[i]+(i+1);
|
||||||
|
|
||||||
b1[i]=1.5+cos(i);
|
b1[i]=1.5+cos(i);
|
||||||
b2[i]=1.5+cos(i+M_PI/8.0);
|
b2[i]=1.5+cos(i+JKQTPSTATISTICS_PI/8.0);
|
||||||
b3[i]=1.5+sin(i);
|
b3[i]=1.5+sin(i);
|
||||||
|
|
||||||
//plot->getXAxis()->addAxisTickLabel(i+1, QString("$\\pi_{%1}\\cdot 10^{%2}$").arg(i+1).arg(i+1-N3));
|
//plot->getXAxis()->addAxisTickLabel(i+1, QString("$\\pi_{%1}\\cdot 10^{%2}$").arg(i+1).arg(i+1-N3));
|
||||||
|
@ -49,7 +49,7 @@ TestWidgetImages::TestWidgetImages(QWidget *parent) :
|
|||||||
bool* bimg2=(bool*)calloc(100*100,sizeof(bool));
|
bool* bimg2=(bool*)calloc(100*100,sizeof(bool));
|
||||||
for (int x=0; x<100; x++) {
|
for (int x=0; x<100; x++) {
|
||||||
for (int y=0; y<100; y++) {
|
for (int y=0; y<100; y++) {
|
||||||
img2[y*100+x]=sin(2*M_PI*sqrt(1.0+x*x+y*y)/20);
|
img2[y*100+x]=sin(2*JKQTPSTATISTICS_PI*sqrt(1.0+x*x+y*y)/20);
|
||||||
img2M[y*100+x]=abs(y-x);
|
img2M[y*100+x]=abs(y-x);
|
||||||
bimg2[y*100+x]=static_cast<double>(rand())/static_cast<double>(RAND_MAX)>0.9;
|
bimg2[y*100+x]=static_cast<double>(rand())/static_cast<double>(RAND_MAX)>0.9;
|
||||||
}
|
}
|
||||||
|
@ -30,12 +30,12 @@ TestWidgetParamScatterPlots::TestWidgetParamScatterPlots(QWidget *parent) :
|
|||||||
dataI<<i;
|
dataI<<i;
|
||||||
double x=double(i);
|
double x=double(i);
|
||||||
dataX<<x;
|
dataX<<x;
|
||||||
dataY<<sin(x*M_PI/20.0);
|
dataY<<sin(x*JKQTPSTATISTICS_PI/20.0);
|
||||||
dataY1<<3.0+sin(x*M_PI/20.0);
|
dataY1<<3.0+sin(x*JKQTPSTATISTICS_PI/20.0);
|
||||||
dataY2<<dataY1.last()/5.0;
|
dataY2<<dataY1.last()/5.0;
|
||||||
dataY3<<dataY1.last()+4.0;
|
dataY3<<dataY1.last()+4.0;
|
||||||
dataC<<x;
|
dataC<<x;
|
||||||
dataS<<(sin(x*M_PI/30.0)+1.0)*50.0;
|
dataS<<(sin(x*JKQTPSTATISTICS_PI/30.0)+1.0)*50.0;
|
||||||
dataSy<<(2+i%15);
|
dataSy<<(2+i%15);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,7 +37,7 @@ TestWidgetPeaksPlots::TestWidgetPeaksPlots(QWidget *parent) :
|
|||||||
QVector<double> photons1, photons2;
|
QVector<double> photons1, photons2;
|
||||||
for (int i=0; i<1000; i++) {
|
for (int i=0; i<1000; i++) {
|
||||||
double x=double(i)/1000.0;
|
double x=double(i)/1000.0;
|
||||||
const double p=0.33*fabs(sin(x*4.0*M_PI))*fabs(sin(x*4.0*M_PI));
|
const double p=0.33*fabs(sin(x*4.0*JKQTPSTATISTICS_PI))*fabs(sin(x*4.0*JKQTPSTATISTICS_PI));
|
||||||
if (static_cast<double>(rand())/static_cast<double>(RAND_MAX)<=p) photons1<<x;
|
if (static_cast<double>(rand())/static_cast<double>(RAND_MAX)<=p) photons1<<x;
|
||||||
if (static_cast<double>(rand())/static_cast<double>(RAND_MAX)<=p) photons2<<x;
|
if (static_cast<double>(rand())/static_cast<double>(RAND_MAX)<=p) photons2<<x;
|
||||||
}
|
}
|
||||||
|
@ -44,9 +44,9 @@ TestWidgetRGBImages::TestWidgetRGBImages(QWidget *parent) :
|
|||||||
rgb_aimg2=(double*)calloc(100*100,sizeof(double));
|
rgb_aimg2=(double*)calloc(100*100,sizeof(double));
|
||||||
for (int x=0; x<100; x++) {
|
for (int x=0; x<100; x++) {
|
||||||
for (int y=0; y<100; y++) {
|
for (int y=0; y<100; y++) {
|
||||||
rgb_rimg2[y*100+x]=sin(2*M_PI*sqrt(1.0+x*x+y*y)/20);
|
rgb_rimg2[y*100+x]=sin(2*JKQTPSTATISTICS_PI*sqrt(1.0+x*x+y*y)/20);
|
||||||
rgb_bimg2[y*100+x]=sin(2*M_PI*sqrt(1.0+x*x+y*y)/30);
|
rgb_bimg2[y*100+x]=sin(2*JKQTPSTATISTICS_PI*sqrt(1.0+x*x+y*y)/30);
|
||||||
rgb_gimg2[y*100+x]=cos(2*M_PI*sqrt(1.0+x*x+y*y)/30);
|
rgb_gimg2[y*100+x]=cos(2*JKQTPSTATISTICS_PI*sqrt(1.0+x*x+y*y)/30);
|
||||||
rgb_aimg2[y*100+x]=double(x)/100.0;
|
rgb_aimg2[y*100+x]=double(x)/100.0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -69,7 +69,7 @@ int main(int argc, char* argv[])
|
|||||||
std::map<double, int> histogram;
|
std::map<double, int> histogram;
|
||||||
const int Ndata=60;
|
const int Ndata=60;
|
||||||
for(int n=0; n<Ndata; ++n) {
|
for(int n=0; n<Ndata; ++n) {
|
||||||
const double x=3.0*M_PI/static_cast<double>(Ndata)*static_cast<double>(n)-0.5;
|
const double x=3.0*JKQTPSTATISTICS_PI/static_cast<double>(Ndata)*static_cast<double>(n)-0.5;
|
||||||
const double y=2.0*(1.0+cos(x));
|
const double y=2.0*(1.0+cos(x));
|
||||||
const double yd=y+d(gen);
|
const double yd=y+d(gen);
|
||||||
dataX.push_back(x);
|
dataX.push_back(x);
|
||||||
|
@ -22,7 +22,7 @@ int main(int argc, char* argv[])
|
|||||||
// in addition the radius is stored in column R
|
// in addition the radius is stored in column R
|
||||||
QVector<double> X, Y, R;
|
QVector<double> X, Y, R;
|
||||||
const int Ndata=500; // number of plot points in each curve
|
const int Ndata=500; // number of plot points in each curve
|
||||||
const double phiMax=4.0*M_PI;
|
const double phiMax=4.0*JKQTPSTATISTICS_PI;
|
||||||
const double a=1;
|
const double a=1;
|
||||||
const double k=0.2;
|
const double k=0.2;
|
||||||
for (double phi=-phiMax; phi<=phiMax; phi+=phiMax/double(Ndata)) {
|
for (double phi=-phiMax; phi<=phiMax; phi+=phiMax/double(Ndata)) {
|
||||||
|
@ -23,7 +23,7 @@ int main(int argc, char* argv[])
|
|||||||
QVector<double> X, Y1, Y2, Y3, Y4, Y5, Y6, Y7, P, C, S, RGB, LW;
|
QVector<double> X, Y1, Y2, Y3, Y4, Y5, Y6, Y7, P, C, S, RGB, LW;
|
||||||
const int Ndata=10; // number of plot points in each curve
|
const int Ndata=10; // number of plot points in each curve
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
const double x=double(i)/double(Ndata)*2.0*M_PI;
|
const double x=double(i)/double(Ndata)*2.0*JKQTPSTATISTICS_PI;
|
||||||
X<<x;
|
X<<x;
|
||||||
Y1<<1.5+sin(x);
|
Y1<<1.5+sin(x);
|
||||||
Y2<<3.5+sin(x);
|
Y2<<3.5+sin(x);
|
||||||
|
@ -9,9 +9,6 @@
|
|||||||
#include "jkqtplotter/jkqtplotter.h"
|
#include "jkqtplotter/jkqtplotter.h"
|
||||||
#include "jkqtplotter/graphs/jkqtpimagergb.h"
|
#include "jkqtplotter/graphs/jkqtpimagergb.h"
|
||||||
|
|
||||||
#ifndef M_PI
|
|
||||||
#define M_PI 3.14159265358979323846
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char* argv[])
|
int main(int argc, char* argv[])
|
||||||
@ -46,10 +43,10 @@ int main(int argc, char* argv[])
|
|||||||
x=-w/2.0;
|
x=-w/2.0;
|
||||||
for (int ix=0; ix<NX; ix++ ) {
|
for (int ix=0; ix<NX; ix++ ) {
|
||||||
const double r=sqrt(x*x+y*y);
|
const double r=sqrt(x*x+y*y);
|
||||||
const double v1=2.0*M_PI*NA*r/wavelength1;
|
const double v1=2.0*JKQTPSTATISTICS_PI*NA*r/wavelength1;
|
||||||
airydisk1[iy*NX+ix] = sqrt(pow(2.0*j1(v1)/v1, 2));
|
airydisk1[iy*NX+ix] = sqrt(pow(2.0*jkqtp_j1(v1)/v1, 2));
|
||||||
const double v2=2.0*M_PI*NA*r/wavelength2;
|
const double v2=2.0*JKQTPSTATISTICS_PI*NA*r/wavelength2;
|
||||||
airydisk2[iy*NX+ix] = sqrt(pow(2.0*j1(v2)/v2, 2));
|
airydisk2[iy*NX+ix] = sqrt(pow(2.0*jkqtp_j1(v2)/v2, 2));
|
||||||
x+=dx;
|
x+=dx;
|
||||||
}
|
}
|
||||||
y+=dy;
|
y+=dy;
|
||||||
|
@ -21,7 +21,7 @@ int main(int argc, char* argv[])
|
|||||||
QVector<double> X, Y;
|
QVector<double> X, Y;
|
||||||
const int Ndata=100;
|
const int Ndata=100;
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
const double x=double(i)/double(Ndata)*8.0*M_PI;
|
const double x=double(i)/double(Ndata)*8.0*JKQTPSTATISTICS_PI;
|
||||||
X<<x;
|
X<<x;
|
||||||
Y<<sin(x);
|
Y<<sin(x);
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
|
|
||||||
SpeedTestPlot::SpeedTestPlot():
|
SpeedTestPlot::SpeedTestPlot():
|
||||||
JKQTPlotter(), dx(1.0/double(NDATA)*4.0*M_PI), x0(0)
|
JKQTPlotter(), dx(1.0/double(NDATA)*4.0*JKQTPSTATISTICS_PI), x0(0)
|
||||||
|
|
||||||
{
|
{
|
||||||
// 1. optimize JKQTPlotter for speed (by switching off anti-aliasing)
|
// 1. optimize JKQTPlotter for speed (by switching off anti-aliasing)
|
||||||
|
@ -23,7 +23,7 @@ int main(int argc, char* argv[])
|
|||||||
QVector<double> X, Y1, Y2, Y3, Y4, Y5;
|
QVector<double> X, Y1, Y2, Y3, Y4, Y5;
|
||||||
const int Ndata=7; // number of plot points in each curve
|
const int Ndata=7; // number of plot points in each curve
|
||||||
for (int i=0; i<=Ndata; i++) {
|
for (int i=0; i<=Ndata; i++) {
|
||||||
const double x=0.0+double(i)*0.6*M_PI;
|
const double x=0.0+double(i)*0.6*JKQTPSTATISTICS_PI;
|
||||||
X<<x;
|
X<<x;
|
||||||
Y1<<sin(x)+1.0*1.5;
|
Y1<<sin(x)+1.0*1.5;
|
||||||
Y2<<sin(x)+3.0*1.5;
|
Y2<<sin(x)+3.0*1.5;
|
||||||
|
@ -129,7 +129,7 @@ void TestStyling::initPlot()
|
|||||||
QVector<double> X, Y1, Y2, img, X3, Y3, Y3err, Xbar, Ybar, Ybar2;
|
QVector<double> X, Y1, Y2, img, X3, Y3, Y3err, Xbar, Ybar, Ybar2;
|
||||||
const int Ndata=100;
|
const int Ndata=100;
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
const double x=double(i)/double(Ndata)*8.0*M_PI;
|
const double x=double(i)/double(Ndata)*8.0*JKQTPSTATISTICS_PI;
|
||||||
X<<x;
|
X<<x;
|
||||||
Y1<<1.1+sin(x);
|
Y1<<1.1+sin(x);
|
||||||
Y2<<1.1+sin(x)*exp(-0.2*x);
|
Y2<<1.1+sin(x)*exp(-0.2*x);
|
||||||
|
@ -22,7 +22,7 @@ int main(int argc, char* argv[])
|
|||||||
// 2. now we create data for a simple plot (a sine curve with lin. increasing errors)
|
// 2. now we create data for a simple plot (a sine curve with lin. increasing errors)
|
||||||
double X[Ndata], Y[Ndata], YERROR[Ndata];
|
double X[Ndata], Y[Ndata], YERROR[Ndata];
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
X[i]=double(i)/double(Ndata)*2.0*M_PI;
|
X[i]=double(i)/double(Ndata)*2.0*JKQTPSTATISTICS_PI;
|
||||||
Y[i]=sin(X[i]);
|
Y[i]=sin(X[i]);
|
||||||
YERROR[i]=0.2+double(i)/double(Ndata)*0.25;
|
YERROR[i]=0.2+double(i)/double(Ndata)*0.25;
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,7 @@ int main(int argc, char* argv[])
|
|||||||
QVector<double> X1, X2;
|
QVector<double> X1, X2;
|
||||||
const int Ndata=10; // number of plot points in each curve
|
const int Ndata=10; // number of plot points in each curve
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
const double x=double(i)/double(Ndata)*2.0*M_PI;
|
const double x=double(i)/double(Ndata)*2.0*JKQTPSTATISTICS_PI;
|
||||||
if (i<Ndata/2) X1<<x;
|
if (i<Ndata/2) X1<<x;
|
||||||
if (i>Ndata/2) X2<<x;
|
if (i>Ndata/2) X2<<x;
|
||||||
}
|
}
|
||||||
|
@ -530,7 +530,7 @@ void TestUserInteraction::initPlot()
|
|||||||
QVector<double> X, Y1, Y2, EY2;
|
QVector<double> X, Y1, Y2, EY2;
|
||||||
const int Ndata=100;
|
const int Ndata=100;
|
||||||
for (int i=0; i<Ndata; i++) {
|
for (int i=0; i<Ndata; i++) {
|
||||||
const double x=double(i)/double(Ndata)*8.0*M_PI;
|
const double x=double(i)/double(Ndata)*8.0*JKQTPSTATISTICS_PI;
|
||||||
X<<x;
|
X<<x;
|
||||||
Y1<<sin(x);
|
Y1<<sin(x);
|
||||||
Y2<<sin(x)*exp(-0.2*x);
|
Y2<<sin(x)*exp(-0.2*x);
|
||||||
|
@ -293,7 +293,7 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
else if (r < 0.0)
|
else if (r < 0.0)
|
||||||
r = 0.0;
|
r = 0.0;
|
||||||
|
|
||||||
double g = 255.0 * std::sin(M_PI*v);
|
double g = 255.0 * std::sin(JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
double b = 255.0 - 765.0 * v;
|
double b = 255.0 - 765.0 * v;
|
||||||
if (b < 0.0)
|
if (b < 0.0)
|
||||||
@ -318,7 +318,7 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
else if (r < 0.0)
|
else if (r < 0.0)
|
||||||
r = 0.0;
|
r = 0.0;
|
||||||
|
|
||||||
double g = 255.0 * std::sin(M_PI*v);
|
double g = 255.0 * std::sin(JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
double b = 255.0 - 765.0 * v;
|
double b = 255.0 - 765.0 * v;
|
||||||
if (b < 0.0)
|
if (b < 0.0)
|
||||||
@ -396,9 +396,9 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
if (r > 255.0)
|
if (r > 255.0)
|
||||||
r = 255.0;
|
r = 255.0;
|
||||||
|
|
||||||
double g = 255.0*sin(M_PI*v);
|
double g = 255.0*sin(JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
double b = 255.0*cos(0.5*M_PI*v);
|
double b = 255.0*cos(0.5*JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
plut[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
plut[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
||||||
}
|
}
|
||||||
@ -419,9 +419,9 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
if (r > 255.0)
|
if (r > 255.0)
|
||||||
r = 255.0;
|
r = 255.0;
|
||||||
|
|
||||||
double g = 255.0*sin(M_PI*v);
|
double g = 255.0*sin(JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
double b = 255.0*cos(0.5*M_PI*v);
|
double b = 255.0*cos(0.5*JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
plut[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
plut[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
||||||
}
|
}
|
||||||
@ -601,11 +601,11 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
if (r < 0.0) r = 0.0;
|
if (r < 0.0) r = 0.0;
|
||||||
if (r > 1.0) r = 1.0;
|
if (r > 1.0) r = 1.0;
|
||||||
|
|
||||||
double g = sin(M_PI/2.0*v);
|
double g = sin(JKQTPSTATISTICS_PI/2.0*v);
|
||||||
if (g < 0.0) g = 0.0;
|
if (g < 0.0) g = 0.0;
|
||||||
if (g > 1.0) g = 1.0;
|
if (g > 1.0) g = 1.0;
|
||||||
|
|
||||||
double b = cos(M_PI/2.0*v);
|
double b = cos(JKQTPSTATISTICS_PI/2.0*v);
|
||||||
if (b < 0.0) b = 0.0;
|
if (b < 0.0) b = 0.0;
|
||||||
if (b > 1.0) b = 1.0;
|
if (b > 1.0) b = 1.0;
|
||||||
|
|
||||||
@ -628,11 +628,11 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
if (r < 0.0) r = 0.0;
|
if (r < 0.0) r = 0.0;
|
||||||
if (r > 1.0) r = 1.0;
|
if (r > 1.0) r = 1.0;
|
||||||
|
|
||||||
double g = sin(M_PI/2.0*v);
|
double g = sin(JKQTPSTATISTICS_PI/2.0*v);
|
||||||
if (g < 0.0) g = 0.0;
|
if (g < 0.0) g = 0.0;
|
||||||
if (g > 1.0) g = 1.0;
|
if (g > 1.0) g = 1.0;
|
||||||
|
|
||||||
double b = cos(M_PI/2.0*v);
|
double b = cos(JKQTPSTATISTICS_PI/2.0*v);
|
||||||
if (b < 0.0) b = 0.0;
|
if (b < 0.0) b = 0.0;
|
||||||
if (b > 1.0) b = 1.0;
|
if (b > 1.0) b = 1.0;
|
||||||
|
|
||||||
@ -703,7 +703,7 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
if (plut!=nullptr) {
|
if (plut!=nullptr) {
|
||||||
for (int l=0; l<=JKQTPImageTools::LUTSIZE; l++) {
|
for (int l=0; l<=JKQTPImageTools::LUTSIZE; l++) {
|
||||||
double v=l/static_cast<double>(JKQTPImageTools::LUTSIZE);
|
double v=l/static_cast<double>(JKQTPImageTools::LUTSIZE);
|
||||||
double r = (v < 0.5) ? 128.0*sin(M_PI*(2.0*v-0.5))+128.0 : 255.0;
|
double r = (v < 0.5) ? 128.0*sin(JKQTPSTATISTICS_PI*(2.0*v-0.5))+128.0 : 255.0;
|
||||||
if (r > 255.0)
|
if (r > 255.0)
|
||||||
r = 255.0;
|
r = 255.0;
|
||||||
|
|
||||||
@ -725,7 +725,7 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
if (plut!=nullptr) {
|
if (plut!=nullptr) {
|
||||||
for (int l=0; l<=JKQTPImageTools::LUTSIZE; l++) {
|
for (int l=0; l<=JKQTPImageTools::LUTSIZE; l++) {
|
||||||
double v=(JKQTPImageTools::LUTSIZE-l)/static_cast<double>(JKQTPImageTools::LUTSIZE);
|
double v=(JKQTPImageTools::LUTSIZE-l)/static_cast<double>(JKQTPImageTools::LUTSIZE);
|
||||||
double r = (v < 0.5) ? 128.0*sin(M_PI*(2.0*v-0.5))+128.0 : 255.0;
|
double r = (v < 0.5) ? 128.0*sin(JKQTPSTATISTICS_PI*(2.0*v-0.5))+128.0 : 255.0;
|
||||||
if (r > 255.0)
|
if (r > 255.0)
|
||||||
r = 255.0;
|
r = 255.0;
|
||||||
|
|
||||||
@ -789,7 +789,7 @@ QMap<int, JKQTPImageTools::LUTData > JKQTPImageTools::getDefaultLUTs() {
|
|||||||
double v=(l)/static_cast<double>(JKQTPImageTools::LUTSIZE);
|
double v=(l)/static_cast<double>(JKQTPImageTools::LUTSIZE);
|
||||||
double r = 255.0*qBound(0.0,sqrt(v),1.0);
|
double r = 255.0*qBound(0.0,sqrt(v),1.0);
|
||||||
double g = 255.0*qBound(0.0,v*v*v,1.0);
|
double g = 255.0*qBound(0.0,v*v*v,1.0);
|
||||||
double b = 255.0*qBound(0.0,sin(2.0*M_PI*v),1.0);
|
double b = 255.0*qBound(0.0,sin(2.0*JKQTPSTATISTICS_PI*v),1.0);
|
||||||
|
|
||||||
plut[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
plut[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
||||||
}
|
}
|
||||||
|
@ -261,12 +261,12 @@ QPolygonF jkqtpRotateRect(QRectF r, double angle) {
|
|||||||
|
|
||||||
QVector<QPointF> JKQTPDrawEllipse(double x, double y, double a, double b, double angle_start, double angle_end, double alpha, int controlPoints, QPointF* x_start, QPointF* x_end) {
|
QVector<QPointF> JKQTPDrawEllipse(double x, double y, double a, double b, double angle_start, double angle_end, double alpha, int controlPoints, QPointF* x_start, QPointF* x_end) {
|
||||||
QVector<QPointF> result;
|
QVector<QPointF> result;
|
||||||
double start=angle_start*M_PI/180.0;
|
double start=angle_start*JKQTPSTATISTICS_PI/180.0;
|
||||||
double stop=angle_end*M_PI/180.0;
|
double stop=angle_end*JKQTPSTATISTICS_PI/180.0;
|
||||||
double step=(stop-start)/static_cast<double>(controlPoints);
|
double step=(stop-start)/static_cast<double>(controlPoints);
|
||||||
while (fabs(stop-start)/step<10) step=step/2.0;
|
while (fabs(stop-start)/step<10) step=step/2.0;
|
||||||
double sina=sin(1.0*alpha/180.0*M_PI);
|
double sina=sin(1.0*alpha/180.0*JKQTPSTATISTICS_PI);
|
||||||
double cosa=cos(1.0*alpha/180.0*M_PI);
|
double cosa=cos(1.0*alpha/180.0*JKQTPSTATISTICS_PI);
|
||||||
QPointF xp(x+a*cos(start)*cosa-b*sin(start)*sina, y+a*cos(start)*sina+b*sin(start)*cosa);
|
QPointF xp(x+a*cos(start)*cosa-b*sin(start)*sina, y+a*cos(start)*sina+b*sin(start)*cosa);
|
||||||
result.append(xp);
|
result.append(xp);
|
||||||
if (x_start) *x_start = xp;
|
if (x_start) *x_start = xp;
|
||||||
@ -276,7 +276,7 @@ QVector<QPointF> JKQTPDrawEllipse(double x, double y, double a, double b, double
|
|||||||
double sint=sin(t);
|
double sint=sin(t);
|
||||||
xp=QPointF( x+a*cost*cosa-b*sint*sina, y+a*cost*sina+b*sint*cosa);
|
xp=QPointF( x+a*cost*cosa-b*sint*sina, y+a*cost*sina+b*sint*cosa);
|
||||||
result.append(xp);
|
result.append(xp);
|
||||||
//std::cout<<"t="<<t/M_PI*180.0<<": sin(al)="<<sina<<" cos(al)="<<cosa<<" sin(t)="<<sint<<" cos(t)="<<cost<<" a="<<a<<" b="<<b<<": ("<<x+a*cost*cosa-b*sint*sina<<", "<<y+a*cost*sina+b*sint*cosa<<") = ("<<xp.x()<<", "<<xp.y()<<") \n";
|
//std::cout<<"t="<<t/JKQTPSTATISTICS_PI*180.0<<": sin(al)="<<sina<<" cos(al)="<<cosa<<" sin(t)="<<sint<<" cos(t)="<<cost<<" a="<<a<<" b="<<b<<": ("<<x+a*cost*cosa-b*sint*sina<<", "<<y+a*cost*sina+b*sint*cosa<<") = ("<<xp.x()<<", "<<xp.y()<<") \n";
|
||||||
t=t+step;
|
t=t+step;
|
||||||
}
|
}
|
||||||
if (x_end) *x_end=xp;
|
if (x_end) *x_end=xp;
|
||||||
|
@ -264,7 +264,7 @@ inline void JKQTPPlotSymbol(TPainter& painter, double x, double y, JKQTPGraphSym
|
|||||||
b.setStyle(Qt::SolidPattern);
|
b.setStyle(Qt::SolidPattern);
|
||||||
const double w=symbolSize;
|
const double w=symbolSize;
|
||||||
const double w2=w/2.0;
|
const double w2=w/2.0;
|
||||||
const double w45=fabs(w*cos(45.0/180.0*M_PI));
|
const double w45=fabs(w*cos(45.0/180.0*JKQTPSTATISTICS_PI));
|
||||||
const double w3=w/3.0;
|
const double w3=w/3.0;
|
||||||
|
|
||||||
// calculate star cordinates as static values
|
// calculate star cordinates as static values
|
||||||
@ -273,7 +273,7 @@ inline void JKQTPPlotSymbol(TPainter& painter, double x, double y, JKQTPGraphSym
|
|||||||
static double star5cordsy[10];
|
static double star5cordsy[10];
|
||||||
if (star5_items==0) {
|
if (star5_items==0) {
|
||||||
star5_items=5;
|
star5_items=5;
|
||||||
double angle=360.0/double(star5_items)/180.0*M_PI;
|
double angle=360.0/double(star5_items)/180.0*JKQTPSTATISTICS_PI;
|
||||||
for (int i=0; i<star5_items; i++) {
|
for (int i=0; i<star5_items; i++) {
|
||||||
double a=(static_cast<double>(i)+0.5)*angle;
|
double a=(static_cast<double>(i)+0.5)*angle;
|
||||||
star5cordsx[i*2]=sin(a);
|
star5cordsx[i*2]=sin(a);
|
||||||
@ -287,7 +287,7 @@ inline void JKQTPPlotSymbol(TPainter& painter, double x, double y, JKQTPGraphSym
|
|||||||
static double star6cordsy[12];
|
static double star6cordsy[12];
|
||||||
if (star6_items==0) {
|
if (star6_items==0) {
|
||||||
star6_items=6;
|
star6_items=6;
|
||||||
double angle=360.0/double(star6_items)/180.0*M_PI;
|
double angle=360.0/double(star6_items)/180.0*JKQTPSTATISTICS_PI;
|
||||||
for (int i=0; i<star6_items; i++) {
|
for (int i=0; i<star6_items; i++) {
|
||||||
double a=(static_cast<double>(i)+0.5)*angle;
|
double a=(static_cast<double>(i)+0.5)*angle;
|
||||||
star6cordsx[i*2]=sin(a);
|
star6cordsx[i*2]=sin(a);
|
||||||
@ -301,7 +301,7 @@ inline void JKQTPPlotSymbol(TPainter& painter, double x, double y, JKQTPGraphSym
|
|||||||
static double star8cordsy[16];
|
static double star8cordsy[16];
|
||||||
if (star8_items==0) {
|
if (star8_items==0) {
|
||||||
star8_items=8;
|
star8_items=8;
|
||||||
double angle=360.0/double(star8_items)/180.0*M_PI;
|
double angle=360.0/double(star8_items)/180.0*JKQTPSTATISTICS_PI;
|
||||||
for (int i=0; i<star8_items; i++) {
|
for (int i=0; i<star8_items; i++) {
|
||||||
double a=(static_cast<double>(i)+0.5)*angle;
|
double a=(static_cast<double>(i)+0.5)*angle;
|
||||||
star8cordsx[i*2]=sin(a);
|
star8cordsx[i*2]=sin(a);
|
||||||
@ -398,7 +398,7 @@ inline void JKQTPPlotSymbol(TPainter& painter, double x, double y, JKQTPGraphSym
|
|||||||
QPainterPath path;
|
QPainterPath path;
|
||||||
QRectF rectangle3(x-w2/2.0, y-w2/2.0, w2, w2);
|
QRectF rectangle3(x-w2/2.0, y-w2/2.0, w2, w2);
|
||||||
path.addEllipse(rectangle3);
|
path.addEllipse(rectangle3);
|
||||||
path.moveTo(QPointF(x+w2/2.0*cos(45.0/180.0*M_PI),y-w2/2.0*cos(45.0/180.0*M_PI)));
|
path.moveTo(QPointF(x+w2/2.0*cos(45.0/180.0*JKQTPSTATISTICS_PI),y-w2/2.0*cos(45.0/180.0*JKQTPSTATISTICS_PI)));
|
||||||
path.lineTo(QPointF(x+w2,y-w2));
|
path.lineTo(QPointF(x+w2,y-w2));
|
||||||
path.moveTo(QPointF(x+w2-w2/2.0,y-w2));
|
path.moveTo(QPointF(x+w2-w2/2.0,y-w2));
|
||||||
path.lineTo(QPointF(x+w2,y-w2));
|
path.lineTo(QPointF(x+w2,y-w2));
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
|
|
||||||
|
|
||||||
#define COMPILING_THIS_JKMATHPARSER
|
#define COMPILING_THIS_JKMATHPARSER
|
||||||
|
#define _USE_MATH_DEFINES
|
||||||
|
#include <cmath>
|
||||||
#include "jkqtcommon/jkqtpmathparser.h" // class's header file
|
#include "jkqtcommon/jkqtpmathparser.h" // class's header file
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <float.h>
|
#include <float.h>
|
||||||
@ -122,7 +124,7 @@ namespace { // anonymous namespace to limit availability to this module (CPP-fil
|
|||||||
time_t rawtime;
|
time_t rawtime;
|
||||||
struct tm* timeinfo;
|
struct tm* timeinfo;
|
||||||
time(&rawtime);
|
time(&rawtime);
|
||||||
timeinfo=localtime(&rawtime);
|
localtime_s(timeinfo, &rawtime);
|
||||||
strftime(re, 1024, f.c_str(), timeinfo);
|
strftime(re, 1024, f.c_str(), timeinfo);
|
||||||
r.str=re;
|
r.str=re;
|
||||||
|
|
||||||
@ -403,7 +405,11 @@ namespace { // anonymous namespace to limit availability to this module (CPP-fil
|
|||||||
r.type=JKQTPMathParser::jkmpDouble;
|
r.type=JKQTPMathParser::jkmpDouble;
|
||||||
if (n!=1) p->jkmpError("j0 accepts 1 argument");
|
if (n!=1) p->jkmpError("j0 accepts 1 argument");
|
||||||
if (params[0].type!=JKQTPMathParser::jkmpDouble) p->jkmpError("j0 needs double argument");
|
if (params[0].type!=JKQTPMathParser::jkmpDouble) p->jkmpError("j0 needs double argument");
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
r.num = _j0(params[0].num);
|
||||||
|
#else
|
||||||
r.num = j0(params[0].num);
|
r.num = j0(params[0].num);
|
||||||
|
#endif
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -412,7 +418,11 @@ namespace { // anonymous namespace to limit availability to this module (CPP-fil
|
|||||||
r.type=JKQTPMathParser::jkmpDouble;
|
r.type=JKQTPMathParser::jkmpDouble;
|
||||||
if (n!=1) p->jkmpError("j1 accepts 1 argument");
|
if (n!=1) p->jkmpError("j1 accepts 1 argument");
|
||||||
if (params[0].type!=JKQTPMathParser::jkmpDouble) p->jkmpError("j1 needs double argument");
|
if (params[0].type!=JKQTPMathParser::jkmpDouble) p->jkmpError("j1 needs double argument");
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
r.num=_j1(params[0].num);
|
||||||
|
#else
|
||||||
r.num=j1(params[0].num);
|
r.num=j1(params[0].num);
|
||||||
|
#endif
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -421,7 +431,11 @@ namespace { // anonymous namespace to limit availability to this module (CPP-fil
|
|||||||
r.type=JKQTPMathParser::jkmpDouble;
|
r.type=JKQTPMathParser::jkmpDouble;
|
||||||
if (n!=1) p->jkmpError("y0 accepts 1 argument");
|
if (n!=1) p->jkmpError("y0 accepts 1 argument");
|
||||||
if (params[0].type!=JKQTPMathParser::jkmpDouble) p->jkmpError("y0 needs double argument");
|
if (params[0].type!=JKQTPMathParser::jkmpDouble) p->jkmpError("y0 needs double argument");
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
r.num=_y0(params[0].num);
|
||||||
|
#else
|
||||||
r.num=y0(params[0].num);
|
r.num=y0(params[0].num);
|
||||||
|
#endif
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -430,7 +444,11 @@ namespace { // anonymous namespace to limit availability to this module (CPP-fil
|
|||||||
r.type=JKQTPMathParser::jkmpDouble;
|
r.type=JKQTPMathParser::jkmpDouble;
|
||||||
if (n!=1) p->jkmpError("y1 accepts 1 argument");
|
if (n!=1) p->jkmpError("y1 accepts 1 argument");
|
||||||
if (params[0].type!=JKQTPMathParser::jkmpDouble) p->jkmpError("y1 needs double argument");
|
if (params[0].type!=JKQTPMathParser::jkmpDouble) p->jkmpError("y1 needs double argument");
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
r.num=_y1(params[0].num);
|
||||||
|
#else
|
||||||
r.num=y1(params[0].num);
|
r.num=y1(params[0].num);
|
||||||
|
#endif
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -439,7 +457,11 @@ namespace { // anonymous namespace to limit availability to this module (CPP-fil
|
|||||||
r.type=JKQTPMathParser::jkmpDouble;
|
r.type=JKQTPMathParser::jkmpDouble;
|
||||||
if (n!=2) p->jkmpError("yn accepts 2 argument");
|
if (n!=2) p->jkmpError("yn accepts 2 argument");
|
||||||
if ((params[0].type!=JKQTPMathParser::jkmpDouble)||(params[1].type!=JKQTPMathParser::jkmpDouble)) p->jkmpError("yn needs double argument");
|
if ((params[0].type!=JKQTPMathParser::jkmpDouble)||(params[1].type!=JKQTPMathParser::jkmpDouble)) p->jkmpError("yn needs double argument");
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
r.num=_yn(static_cast<int>(params[0].num), params[1].num);
|
||||||
|
#else
|
||||||
r.num=yn(static_cast<int>(params[0].num), params[1].num);
|
r.num=yn(static_cast<int>(params[0].num), params[1].num);
|
||||||
|
#endif
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -448,7 +470,11 @@ namespace { // anonymous namespace to limit availability to this module (CPP-fil
|
|||||||
r.type=JKQTPMathParser::jkmpDouble;
|
r.type=JKQTPMathParser::jkmpDouble;
|
||||||
if (n!=2) p->jkmpError("jn accepts 2 argument");
|
if (n!=2) p->jkmpError("jn accepts 2 argument");
|
||||||
if ((params[0].type!=JKQTPMathParser::jkmpDouble)||(params[1].type!=JKQTPMathParser::jkmpDouble)) p->jkmpError("jn needs double argument");
|
if ((params[0].type!=JKQTPMathParser::jkmpDouble)||(params[1].type!=JKQTPMathParser::jkmpDouble)) p->jkmpError("jn needs double argument");
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
r.num=_jn(static_cast<int>(params[0].num), params[1].num);
|
||||||
|
#else
|
||||||
r.num=jn(static_cast<int>(params[0].num), params[1].num);
|
r.num=jn(static_cast<int>(params[0].num), params[1].num);
|
||||||
|
#endif
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,7 +37,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <cmath>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
@ -33,6 +33,17 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*! \brief \f$ \pi=3.14159... \f$
|
||||||
|
\ingroup jkqtptools_math_basic
|
||||||
|
|
||||||
|
*/
|
||||||
|
#ifdef M_PI
|
||||||
|
# define JKQTPSTATISTICS_PI M_PI
|
||||||
|
#else
|
||||||
|
# define JKQTPSTATISTICS_PI 3.14159265358979323846
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*! \brief \f$ \sqrt{2\pi}=2.50662827463 \f$
|
/*! \brief \f$ \sqrt{2\pi}=2.50662827463 \f$
|
||||||
\ingroup jkqtptools_math_basic
|
\ingroup jkqtptools_math_basic
|
||||||
|
|
||||||
@ -316,6 +327,77 @@ inline T jkqtp_inversePropSaveDefault(const T& v) {
|
|||||||
return jkqtp_inversePropSave<T>(v, std::numeric_limits<T>::epsilon()*100.0);
|
return jkqtp_inversePropSave<T>(v, std::numeric_limits<T>::epsilon()*100.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*! \brief j0() function (without compiler issues)
|
||||||
|
\ingroup jkqtptools_math_basic
|
||||||
|
|
||||||
|
*/
|
||||||
|
inline double jkqtp_j0(double x) {
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
return _j0(x);
|
||||||
|
#else
|
||||||
|
return j0(x);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! \brief j1() function (without compiler issues)
|
||||||
|
\ingroup jkqtptools_math_basic
|
||||||
|
|
||||||
|
*/
|
||||||
|
inline double jkqtp_j1(double x) {
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
return _j1(x);
|
||||||
|
#else
|
||||||
|
return j1(x);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! \brief y0() function (without compiler issues)
|
||||||
|
\ingroup jkqtptools_math_basic
|
||||||
|
|
||||||
|
*/
|
||||||
|
inline double jkqtp_y0(double x) {
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
return _y0(x);
|
||||||
|
#else
|
||||||
|
return y0(x);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! \brief y1() function (without compiler issues)
|
||||||
|
\ingroup jkqtptools_math_basic
|
||||||
|
|
||||||
|
*/
|
||||||
|
inline double jkqtp_y1(double x) {
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
return _y1(x);
|
||||||
|
#else
|
||||||
|
return y1(x);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! \brief jn() function (without compiler issues)
|
||||||
|
\ingroup jkqtptools_math_basic
|
||||||
|
|
||||||
|
*/
|
||||||
|
inline double jkqtp_jn(int n, double x) {
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
return _jn(n,x);
|
||||||
|
#else
|
||||||
|
return jn(n,x);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! \brief yn() function (without compiler issues)
|
||||||
|
\ingroup jkqtptools_math_basic
|
||||||
|
|
||||||
|
*/
|
||||||
|
inline double jkqtp_yn(int n, double x) {
|
||||||
|
#if Q_CC_MSVC
|
||||||
|
return _yn(n,x);
|
||||||
|
#else
|
||||||
|
return yn(n,x);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/** \brief calculate the distance between two QPointF points
|
/** \brief calculate the distance between two QPointF points
|
||||||
* \ingroup jkqtptools_math_basic
|
* \ingroup jkqtptools_math_basic
|
||||||
@ -344,10 +426,10 @@ inline bool JKQTPIsOKFloat(T v) {
|
|||||||
/** \brief evaluates a gaussian propability density function
|
/** \brief evaluates a gaussian propability density function
|
||||||
* \ingroup jkqtptools_math_basic
|
* \ingroup jkqtptools_math_basic
|
||||||
*
|
*
|
||||||
* \f[ f(x,\mu, \sigma)=\frac{1}{\sqrt{2\pi\sigma^2}}\cdot\exp\left(-\frac{(x-\mu)^2}{2\sigma^2}\right)
|
* \f[ f(x,\mu, \sigma)=\frac{1}{\sqrt{2\pi\sigma^2}}\cdot\eJKQTPSTATISTICS_PIeft(-\frac{(x-\mu)^2}{2\sigma^2}\right)
|
||||||
*/
|
*/
|
||||||
inline double jkqtp_gaussdist(double x, double mu=0.0, double sigma=1.0) {
|
inline double jkqtp_gaussdist(double x, double mu=0.0, double sigma=1.0) {
|
||||||
return exp(-0.5*jkqtp_sqr(x-mu)/jkqtp_sqr(sigma))/sqrt(2.0*M_PI*sigma*sigma);
|
return exp(-0.5*jkqtp_sqr(x-mu)/jkqtp_sqr(sigma))/sqrt(2.0*JKQTPSTATISTICS_PI*sigma*sigma);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*! \brief evaluate a polynomial \f$ f(x)=\sum\limits_{i=0}^Pp_ix^i \f$ with \f$ p_i \f$ taken from the range \a firstP ... \a lastP
|
/*! \brief evaluate a polynomial \f$ f(x)=\sum\limits_{i=0}^Pp_ix^i \f$ with \f$ p_i \f$ taken from the range \a firstP ... \a lastP
|
||||||
|
@ -28,7 +28,7 @@ double jkqtpstatKernel1DGaussian(double t) {
|
|||||||
|
|
||||||
|
|
||||||
double jkqtpstatKernel1DCauchy(double t) {
|
double jkqtpstatKernel1DCauchy(double t) {
|
||||||
return 1.0/(M_PI*(1.0+t*t));
|
return 1.0/(JKQTPSTATISTICS_PI*(1.0+t*t));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -71,13 +71,13 @@ double jkqtpstatKernel1DTricube(double t) {
|
|||||||
|
|
||||||
|
|
||||||
double jkqtpstatKernel1DCosine(double t) {
|
double jkqtpstatKernel1DCosine(double t) {
|
||||||
return (fabs(t)<1.0)?(M_PI/4.0*cos(t*M_PI/2.0)):0.0;
|
return (fabs(t)<1.0)?(JKQTPSTATISTICS_PI/4.0*cos(t*JKQTPSTATISTICS_PI/2.0)):0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
double jkqtpstatKernel2DGaussian(double tx, double ty)
|
double jkqtpstatKernel2DGaussian(double tx, double ty)
|
||||||
{
|
{
|
||||||
return exp(-0.5*(tx*tx+ty*ty))/(2.0*M_PI);
|
return exp(-0.5*(tx*tx+ty*ty))/(2.0*JKQTPSTATISTICS_PI);
|
||||||
}
|
}
|
||||||
|
|
||||||
double jkqtpstatKernel2DUniform(double tx, double ty) {
|
double jkqtpstatKernel2DUniform(double tx, double ty) {
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <QMutex>
|
#include <QMutex>
|
||||||
#include <QGLWidget>
|
#include <QGLWidget>
|
||||||
|
#include "jkqtcommon/jkqtpmathtools.h"
|
||||||
#ifdef DEBUG_TIMING
|
#ifdef DEBUG_TIMING
|
||||||
# include "jkqtcommon/jkqtphighrestimer.h"
|
# include "jkqtcommon/jkqtphighrestimer.h"
|
||||||
#endif
|
#endif
|
||||||
@ -2067,7 +2067,7 @@ inline void JKQTFPimagePlot_array2image(T* dbl, int width, int height, QImage &i
|
|||||||
else if (r < 0.0)
|
else if (r < 0.0)
|
||||||
r = 0.0;
|
r = 0.0;
|
||||||
|
|
||||||
double g = 255.0 * std::sin(M_PI*v);
|
double g = 255.0 * std::sin(JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
double b = 255.0 - 765.0 * v;
|
double b = 255.0 - 765.0 * v;
|
||||||
if (b < 0.0)
|
if (b < 0.0)
|
||||||
@ -2144,9 +2144,9 @@ inline void JKQTFPimagePlot_array2image(T* dbl, int width, int height, QImage &i
|
|||||||
if (r > 255.0)
|
if (r > 255.0)
|
||||||
r = 255.0;
|
r = 255.0;
|
||||||
|
|
||||||
double g = 255.0*sin(M_PI*v);
|
double g = 255.0*sin(JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
double b = 255.0*cos(0.5*M_PI*v);
|
double b = 255.0*cos(0.5*JKQTPSTATISTICS_PI*v);
|
||||||
|
|
||||||
lut_rainbow[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
lut_rainbow[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
||||||
}
|
}
|
||||||
@ -2243,11 +2243,11 @@ inline void JKQTFPimagePlot_array2image(T* dbl, int width, int height, QImage &i
|
|||||||
if (r < 0.0) r = 0.0;
|
if (r < 0.0) r = 0.0;
|
||||||
if (r > 1.0) r = 1.0;
|
if (r > 1.0) r = 1.0;
|
||||||
|
|
||||||
double g = sin(M_PI/2.0*v);
|
double g = sin(JKQTPSTATISTICS_PI/2.0*v);
|
||||||
if (g < 0.0) g = 0.0;
|
if (g < 0.0) g = 0.0;
|
||||||
if (g > 1.0) g = 1.0;
|
if (g > 1.0) g = 1.0;
|
||||||
|
|
||||||
double b = cos(M_PI/2.0*v);
|
double b = cos(JKQTPSTATISTICS_PI/2.0*v);
|
||||||
if (b < 0.0) b = 0.0;
|
if (b < 0.0) b = 0.0;
|
||||||
if (b > 1.0) b = 1.0;
|
if (b > 1.0) b = 1.0;
|
||||||
|
|
||||||
@ -2292,7 +2292,7 @@ inline void JKQTFPimagePlot_array2image(T* dbl, int width, int height, QImage &i
|
|||||||
if ((*plut)!=nullptr) {
|
if ((*plut)!=nullptr) {
|
||||||
for (size_t l=0; l<=JKQTFastPlotter::LUTSIZE; l++) {
|
for (size_t l=0; l<=JKQTFastPlotter::LUTSIZE; l++) {
|
||||||
double v=l/static_cast<double>(JKQTFastPlotter::LUTSIZE);
|
double v=l/static_cast<double>(JKQTFastPlotter::LUTSIZE);
|
||||||
double r = (v < 0.5) ? 128.0*sin(M_PI*(2.0*v-0.5))+128.0 : 255.0;
|
double r = (v < 0.5) ? 128.0*sin(JKQTPSTATISTICS_PI*(2.0*v-0.5))+128.0 : 255.0;
|
||||||
if (r > 255.0)
|
if (r > 255.0)
|
||||||
r = 255.0;
|
r = 255.0;
|
||||||
|
|
||||||
|
@ -1239,10 +1239,10 @@ void JKQTPVerticalAxis::drawTickLabel1(JKQTPEnhancedPainter &painter, double xx,
|
|||||||
} else if (axisStyle.tickLabelAngle!=0) {
|
} else if (axisStyle.tickLabelAngle!=0) {
|
||||||
painter.save(); auto __finalpaint=JKQTPFinally([&painter]() {painter.restore();});
|
painter.save(); auto __finalpaint=JKQTPFinally([&painter]() {painter.restore();});
|
||||||
if (axisStyle.tickLabelAngle>0) {
|
if (axisStyle.tickLabelAngle>0) {
|
||||||
painter.translate(lx-strikeoutPos+(width)*(1.0-cos(fabs(axisStyle.tickLabelAngle)/180.0*M_PI)), yy+strikeoutPos-width*sin(fabs(axisStyle.tickLabelAngle)/180.0*M_PI));
|
painter.translate(lx-strikeoutPos+(width)*(1.0-cos(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI)), yy+strikeoutPos-width*sin(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI));
|
||||||
painter.rotate(axisStyle.tickLabelAngle);
|
painter.rotate(axisStyle.tickLabelAngle);
|
||||||
} else {
|
} else {
|
||||||
painter.translate(lx+strikeoutPos+(width-strikeoutPos)*(1.0-cos(fabs(axisStyle.tickLabelAngle)/180.0*M_PI)), yy+strikeoutPos+width*sin(fabs(axisStyle.tickLabelAngle)/180.0*M_PI));
|
painter.translate(lx+strikeoutPos+(width-strikeoutPos)*(1.0-cos(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI)), yy+strikeoutPos+width*sin(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI));
|
||||||
painter.rotate(axisStyle.tickLabelAngle);
|
painter.rotate(axisStyle.tickLabelAngle);
|
||||||
}
|
}
|
||||||
getParentMathText()->draw(painter, 0,0);
|
getParentMathText()->draw(painter, 0,0);
|
||||||
@ -1281,7 +1281,7 @@ void JKQTPVerticalAxis::drawTickLabel2(JKQTPEnhancedPainter &painter, double xx,
|
|||||||
painter.save(); auto __finalpaint=JKQTPFinally([&painter]() {painter.restore();});
|
painter.save(); auto __finalpaint=JKQTPFinally([&painter]() {painter.restore();});
|
||||||
double shiftx=0;
|
double shiftx=0;
|
||||||
if (axisStyle.tickLabelAngle>0) {
|
if (axisStyle.tickLabelAngle>0) {
|
||||||
shiftx=strikeoutPos*sin(fabs(axisStyle.tickLabelAngle)/180.0*M_PI);
|
shiftx=strikeoutPos*sin(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI);
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -1832,10 +1832,10 @@ void JKQTPHorizontalAxis::drawTickLabel1(JKQTPEnhancedPainter &painter, double x
|
|||||||
if (axisStyle.tickLabelAngle!=0) {
|
if (axisStyle.tickLabelAngle!=0) {
|
||||||
painter.save(); auto __finalpaint=JKQTPFinally([&painter]() {painter.restore();});
|
painter.save(); auto __finalpaint=JKQTPFinally([&painter]() {painter.restore();});
|
||||||
if (axisStyle.tickLabelAngle>0) {
|
if (axisStyle.tickLabelAngle>0) {
|
||||||
painter.translate(xx-fabs(ascent*sin(axisStyle.tickLabelAngle/180.0*M_PI)/2.0), lx0+fabs(ascent*cos(axisStyle.tickLabelAngle/180.0*M_PI)));
|
painter.translate(xx-fabs(ascent*sin(axisStyle.tickLabelAngle/180.0*JKQTPSTATISTICS_PI)/2.0), lx0+fabs(ascent*cos(axisStyle.tickLabelAngle/180.0*JKQTPSTATISTICS_PI)));
|
||||||
painter.rotate(axisStyle.tickLabelAngle);
|
painter.rotate(axisStyle.tickLabelAngle);
|
||||||
} else {
|
} else {
|
||||||
painter.translate(xx+fabs(ascent*sin(fabs(axisStyle.tickLabelAngle)/180.0*M_PI)/2.0)-width*fabs(cos(fabs(axisStyle.tickLabelAngle)/180.0*M_PI)), lx0+ascent*fabs(cos(fabs(axisStyle.tickLabelAngle)/180.0*M_PI))+fabs(width*sin(fabs(axisStyle.tickLabelAngle)/180.0*M_PI)));
|
painter.translate(xx+fabs(ascent*sin(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI)/2.0)-width*fabs(cos(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI)), lx0+ascent*fabs(cos(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI))+fabs(width*sin(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI)));
|
||||||
painter.rotate(axisStyle.tickLabelAngle);
|
painter.rotate(axisStyle.tickLabelAngle);
|
||||||
}
|
}
|
||||||
getParentMathText()->draw(painter, 0,0);
|
getParentMathText()->draw(painter, 0,0);
|
||||||
@ -1862,10 +1862,10 @@ void JKQTPHorizontalAxis::drawTickLabel2(JKQTPEnhancedPainter &painter, double x
|
|||||||
if (axisStyle.tickLabelAngle!=0) {
|
if (axisStyle.tickLabelAngle!=0) {
|
||||||
painter.save(); auto __finalpaint=JKQTPFinally([&painter]() {painter.restore();});
|
painter.save(); auto __finalpaint=JKQTPFinally([&painter]() {painter.restore();});
|
||||||
if (axisStyle.tickLabelAngle>0) {
|
if (axisStyle.tickLabelAngle>0) {
|
||||||
painter.translate(xx+fabs(descent*sin(axisStyle.tickLabelAngle/180.0*M_PI)/2.0), lx0-fabs(descent*cos(axisStyle.tickLabelAngle/180.0*M_PI)));
|
painter.translate(xx+fabs(descent*sin(axisStyle.tickLabelAngle/180.0*JKQTPSTATISTICS_PI)/2.0), lx0-fabs(descent*cos(axisStyle.tickLabelAngle/180.0*JKQTPSTATISTICS_PI)));
|
||||||
painter.rotate(-axisStyle.tickLabelAngle);
|
painter.rotate(-axisStyle.tickLabelAngle);
|
||||||
} else {
|
} else {
|
||||||
painter.translate(xx-fabs(descent*sin(fabs(axisStyle.tickLabelAngle)/180.0*M_PI)/2.0)-width*fabs(cos(fabs(axisStyle.tickLabelAngle)/180.0*M_PI)), lx0-descent*fabs(cos(fabs(axisStyle.tickLabelAngle)/180.0*M_PI))-fabs(width*sin(fabs(axisStyle.tickLabelAngle)/180.0*M_PI)));
|
painter.translate(xx-fabs(descent*sin(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI)/2.0)-width*fabs(cos(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI)), lx0-descent*fabs(cos(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI))-fabs(width*sin(fabs(axisStyle.tickLabelAngle)/180.0*JKQTPSTATISTICS_PI)));
|
||||||
painter.rotate(-axisStyle.tickLabelAngle);
|
painter.rotate(-axisStyle.tickLabelAngle);
|
||||||
}
|
}
|
||||||
getParentMathText()->draw(painter, 0,0);
|
getParentMathText()->draw(painter, 0,0);
|
||||||
|
@ -108,7 +108,7 @@ enum class JKQTPDatastoreItemFormat {
|
|||||||
* QVector<double> X, Y;
|
* QVector<double> X, Y;
|
||||||
* const int Ndata=100;
|
* const int Ndata=100;
|
||||||
* for (int i=0; i<Ndata; i++) {
|
* for (int i=0; i<Ndata; i++) {
|
||||||
* * const double x=double(i)/double(Ndata)*8.0*M_PI;
|
* * const double x=double(i)/double(Ndata)*8.0*JKQTPSTATISTICS_PI;
|
||||||
* X<<x;
|
* X<<x;
|
||||||
* Y<<sin(x);
|
* Y<<sin(x);
|
||||||
* }
|
* }
|
||||||
@ -790,7 +790,7 @@ class JKQTPLOTTER_LIB_EXPORT JKQTPDatastore{
|
|||||||
* QVector<double> X, Y;
|
* QVector<double> X, Y;
|
||||||
* const int Ndata=100;
|
* const int Ndata=100;
|
||||||
* for (int i=0; i<Ndata; i++) {
|
* for (int i=0; i<Ndata; i++) {
|
||||||
* const double x=double(i)/double(Ndata)*8.0*M_PI;
|
* const double x=double(i)/double(Ndata)*8.0*JKQTPSTATISTICS_PI;
|
||||||
* X<<x;
|
* X<<x;
|
||||||
* Y<<sin(x);
|
* Y<<sin(x);
|
||||||
* }
|
* }
|
||||||
@ -828,7 +828,7 @@ class JKQTPLOTTER_LIB_EXPORT JKQTPDatastore{
|
|||||||
* QVector<double> X, Y;
|
* QVector<double> X, Y;
|
||||||
* const int Ndata=100;
|
* const int Ndata=100;
|
||||||
* for (int i=0; i<Ndata; i++) {
|
* for (int i=0; i<Ndata; i++) {
|
||||||
* const double x=double(i)/double(Ndata)*8.0*M_PI;
|
* const double x=double(i)/double(Ndata)*8.0*JKQTPSTATISTICS_PI;
|
||||||
* X<<x;
|
* X<<x;
|
||||||
* Y<<sin(x);
|
* Y<<sin(x);
|
||||||
* }
|
* }
|
||||||
|
@ -516,7 +516,7 @@ void JKQTPlotter::paintUserAction() {
|
|||||||
painter.drawLine(QPointF(x2,y1), QPointF(x2,y2));
|
painter.drawLine(QPointF(x2,y1), QPointF(x2,y2));
|
||||||
painter.drawLine(QPointF(x1,y1), QPointF(x2,y2));
|
painter.drawLine(QPointF(x1,y1), QPointF(x2,y2));
|
||||||
const double dxy=sqrt(jkqtp_sqr(mouseDragRectXEnd-mouseDragRectXStart)+jkqtp_sqr(mouseDragRectYEnd-mouseDragRectYStart));
|
const double dxy=sqrt(jkqtp_sqr(mouseDragRectXEnd-mouseDragRectXStart)+jkqtp_sqr(mouseDragRectYEnd-mouseDragRectYStart));
|
||||||
const double alpha=atan2((mouseDragRectYEnd-mouseDragRectYStart), (mouseDragRectXEnd-mouseDragRectXStart))/M_PI*180.0;
|
const double alpha=atan2((mouseDragRectYEnd-mouseDragRectYStart), (mouseDragRectXEnd-mouseDragRectXStart))/JKQTPSTATISTICS_PI*180.0;
|
||||||
const double dx=fabs(mouseDragRectXEnd-mouseDragRectXStart);
|
const double dx=fabs(mouseDragRectXEnd-mouseDragRectXStart);
|
||||||
const double dy=fabs(mouseDragRectYEnd-mouseDragRectYStart);
|
const double dy=fabs(mouseDragRectYEnd-mouseDragRectYStart);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user