#include <stdio.h>
#include <stdlib.h>
#include <math.h>
void plotResults(double* xData, double* yData, int dataSize);
int main() {
int i = 0;
int nIntervals = 100;
double intervalSize = 1.0;
double stepSize = intervalSize/nIntervals;
double* xData = (double*) malloc((nIntervals+1)*sizeof(double));
double* yData = (double*) malloc((nIntervals+1)*sizeof(double));
xData[0] = 0.0;
double x0 = 0.0;
for (i = 0; i < nIntervals; i++) {
x0 = xData[i];
xData[i+1] = x0 + stepSize;
}
for (i = 0; i <= nIntervals; i++) {
x0 = xData[i];
yData[i] = sin(x0)*cos(10*x0);
}
plotResults(xData,yData,nIntervals);
return 0;
}
void plotResults(double* xData, double* yData, int dataSize) {
FILE *gnuplotPipe,*tempDataFile;
char *tempDataFileName;
double x,y;
int i;
tempDataFileName = "tempData";
gnuplotPipe = popen("c:\\gnuplot\\bin\\pgnuplot -persist","w");
if (gnuplotPipe) {
fprintf(gnuplotPipe,"plot \"%s\" with lines\n",tempDataFileName);
fflush(gnuplotPipe);
tempDataFile = fopen(tempDataFileName,"w");
for (i=0; i <= dataSize; i++) {
x = xData[i];
y = yData[i];
fprintf(tempDataFile,"%lf %lf\n",x,y);
}
fclose(tempDataFile);
printf("press enter to continue...");
getchar();
remove(tempDataFileName);
fprintf(gnuplotPipe,"exit \n");
} else {
printf("gnuplot not found...");
}
}
This code should run as is. Of course, feel free to take the plot function and use it in your own codes.
Cite as:
Saad, T. "Calling Gnuplot from c Using Pipes... Again!".
Weblog entry from
Please Make A Note.
http://pleasemakeanote.blogspot.com/2009/05/calling-gnuplot-from-c-using-pipes.html
please ny 1 can help me hw to call/plot graph in gnuplot in c using a DAT file. that is i am having a DAT file. nw i want graph of that DAT file using c code.please give me sm tips.
ReplyDeleteI need more help to understand many of the lines that you share, for instance , I have not idea what is double* xData = (double*) malloc((nIntervals+1)*sizeof(double));
ReplyDeletedouble* yData = (double*) malloc((nIntervals+1)*sizeof(doubl