ランダムに作られた点で、-1<x<1 -1<y<1を満たし、(0,0)から一定の距離離れている点はクラス1、一定の距離の範囲内にある点はクラス0として分けられた複数の点をファイルから読み込み、それぞれのクラスごとに色分けして描画するプログラムを作ったのですが、本来表示されるべきの右下4分の1しか表示されません。
なぜそうなるのか教えてくださると助かります。
c
1コード 2#include<stdio.h> 3#include<stdlib.h> 4#include<GL/glut.h> 5#define NUM_DATA 2002 6#define NUM_SAMPLE 901 7#define NUM_CLASS 2 8#define NUM_PLOTDATA 40000 9 10 11double tr_d[NUM_SAMPLE*NUM_CLASS][3]; 12double te_d[NUM_DATA - NUM_SAMPLE*NUM_CLASS][3]; 13 14void display(void){ 15 int i; 16 glClear(GL_COLOR_BUFFER_BIT); 17 for(i=0; i<NUM_SAMPLE*NUM_CLASS; i++){ 18 glPointSize(2); 19 if(tr_d[i][2] == 1){ 20 glColor3d(1.0,0.0,0.0); 21 }else{ 22 glColor3d(0.0,1.0,0.0); 23 } 24 glBegin(GL_POINTS); 25 glVertex2d(tr_d[i][0],tr_d[i][1]); 26 glEnd(); 27 } 28 glPointSize(5); 29 glBegin(GL_POINTS); 30 glVertex2d(1.0,1.0); 31 glEnd(); 32 glBegin(GL_POINTS); 33 glVertex2d(-1.0,-1.0); 34 glEnd(); 35 glFlush(); 36} 37 38 39void init(void){ 40 glClearColor(1.0, 1.0, 1.0, 1.0); 41} 42 43void resize(int w, int h){ 44 glViewport(0,0,w,h); 45 glLoadIdentity(); 46 glOrtho(-w/200.0, w/200.0, -h/200.0, h/200.0, -1.0, 1.0); 47} 48 49void read_file(){ 50 int i,j; 51 int index1 = 0; 52 int index2 = 0; 53 FILE *fp; 54 fp = fopen("donuts2.txt", "r"); 55 56 if(fp == NULL){ 57 printf("no such file\n"); 58 exit(1); 59 } 60 61 for(i=1; i<=NUM_DATA*NUM_CLASS; i++){ 62 if(i%10 == 0){ 63 for(j=0; j<3; j++){ 64 fscanf(fp, "%lf", &te_d[index1][j]); 65 } 66 index1++; 67 } 68 else{ 69 for(j=0; j<3; j++){ 70 fscanf(fp, "%lf", &tr_d[index2][j]); 71 } 72 index2++; 73 } 74 } 75} 76 77int main(int argc, char *argv[]){ 78 read_file(); 79 glutInit(&argc, argv); 80 glutInitDisplayMode(GLUT_RGBA); 81 glutCreateWindow(argv[0]); 82 glutReshapeFunc(resize); 83 glutDisplayFunc(display); 84 init(); 85 glutMainLoop(); 86 87 return 0; 88} 89 90 91
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。