gnuplotでline 0: warning: Skipping data file with no valid points とエラーが表示されます。
数値計算をしたデータをcsvファイルで出力し、そのファイルをgnuplotでグラフにしようとしているのですが、
powershell
1line 0: warning: Skipping data file with no valid points 2line 0: warning: Skipping data file with no valid points 3line 0: warning: Skipping data file with no valid points
という表示が出てグラフが出力されません。
解決方法がわかる方いらっしゃいましたら、回答よろしくお願いします。
エラーが出るソースコードを以下に貼ります。
task.c
1#include <stdio.h> 2#include <stdlib.h> 3#define GNUPLOT_PATH "C:/gnuplot/bin/gnuplot.exe" 4#define FILE_PATH "./plot.csv" 5#define J_MAX 100 6 7int main() 8{ 9 int n_max; 10 double dx = 0.01, dt = 0.01, c = 0.5, time = 0.0; 11 double c_fl, t_max; 12 double u[J_MAX+1], u_nn[J_MAX+1], u_ex[J_MAX+1], px[J_MAX+1]; 13 printf("Input n_max: "); 14 scanf("%d", &n_max); 15 c_fl = c * dt / dx; 16 t_max = (float)n_max * dt; 17 18 for (int j = 0; j <= J_MAX; j++) 19 { 20 px[j] = dx * j; 21 if (px[j] >= 0.2 && px[j] <= 0.4) 22 u[j] = 1.0; 23 else 24 u[j] = 0.0; 25 } 26 27 for (int n = 0; n < n_max; n++) 28 { 29 for (int j = 0; j < J_MAX; j++) 30 { 31 u_nn[j] = u[j] + c_fl * (u[j+1] - u[j]); 32 u[j] = u_nn[j]; 33 } 34 time += dt; 35 } 36 37 printf("t = %.2f\n", time); 38 39 for (int j = 0; j <= J_MAX; j++) 40 { 41 px[j] = j * dx; 42 if (px[j] >= 0.2+c*t_max && px[j] <= 0.4+c*t_max) 43 u_ex[j] = 1.0; 44 else 45 u_ex[j] = 0.0; 46 } 47 48 49 FILE *fp; 50 fp = fopen(FILE_PATH, "w"); 51 if (fp == NULL) 52 { 53 fprintf(stderr, "Oops, i can't find %s.", FILE_PATH); 54 exit(EXIT_FAILURE); 55 } 56 57 for (int j = 0; j < J_MAX; j++) 58 { 59 fprintf(fp, "%f, %f, %f\n", px[j], u[j], u_ex[j]); 60 } 61 62 63 FILE *gp; 64 gp = _popen(GNUPLOT_PATH, "w"); 65 if (gp == NULL) 66 { 67 fprintf(stderr, "Oops, I can't find %s.", GNUPLOT_PATH); 68 exit(EXIT_FAILURE); 69 } 70 // gnuplotにコマンドを送る 71 fprintf(gp, "set xrange [-2.0:2.0]\n"); 72 fprintf(gp, "set yrange [-2.0:2.0]\n"); 73 fprintf(gp, "set xlabel 'x'\n"); 74 fprintf(gp, "set ylabel 'u(x,t)'\n"); 75 fprintf(gp, "plot 'plot.csv' using 1:2 with lines\n"); 76 fprintf(gp, "replot 'plot.csv' using 1:3 with lines\n"); 77 fflush(gp); // バッファに格納されているデータを吐き出す(必須) 78 getchar(); // 入力待ち 79 _pclose(gp); 80 fclose(fp); 81 exit(EXIT_SUCCESS); 82}
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/05/25 10:53
2019/05/25 11:28
2019/05/25 11:44
2019/05/25 11:46 編集
2019/05/26 06:32
2019/05/26 23:46