2

我最近创建了一个程序,它计算通过管道的流量并逐行生成输出的散点图。我对 C 的了解是初级的(从 python 开始),我觉得我可能使代码过于复杂。因此,我问是否有人可以替代以下代码。也欢迎对代码结构等提出批评!

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>

#define PI 3.1415926

double 
flow_rate(double diameter, double k, double slope){
    double area, w_perimeter, hyd_rad, fr;

    area = (PI*pow(diameter,2.0))/8.0;
    w_perimeter = (PI*diameter)/2.0;
    hyd_rad = area/w_perimeter;

    fr = (1.0/k)*area*pow(hyd_rad,(2.0/3.0))*pow(slope,(1.0/2.0));

return fr;
}

int 
main(int argc, char **argv) {
    double avg_k=0.0312, min_slope=0.0008;
    float s3_diameter; 
    int i=0, num=0, flow_array[6] ,rows, align=29;
    char graph[] = "                             ";
    char graph_temp[]= "                             ";

    printf("\nFlow Rate (x 10^-3) m^3/s\n");

    for (s3_diameter=0.50;s3_diameter>0.24;s3_diameter-=0.05){
        flow_array[i] = (1000*(flow_rate(s3_diameter, avg_k, min_slope))+0.5);
        i += 1;
    }

    for (rows=30;rows>0;rows--){
        strcpy(graph_temp,graph);
        for (num=0;num<6;num++){
            if (rows==flow_array[num] && rows%5==0){
                graph_temp[align] = '*';
                printf("%d%s\n",rows,graph_temp);
                align -= 5;
                break;
            }
            else if (rows==flow_array[num]){
                graph_temp[align] = '*';
                printf("|%s\n",graph_temp);
                align -= 5;
                break;
            }
            else {
                if (rows%5==0 && num==5){
                    printf("%d%s\n",rows,graph_temp);
                } 
                else if (rows%5!=0 && num==5){
                    printf("|%s\n",graph_temp);
                }
            }
        }
    }

    printf("|----2----3----3----4----4----5----\n");
    printf("     5    0    5    0    5    0\n");
    printf("       Diameter (x 10^-2) m\n");

    return 0;
}

输出如下。

Flow Rate (x 10^-3) m^3/s
30                             
|                             
|                             
|                             
|                             
25                             
|                             
|                             
|                             *                             
|                             
20                             
|                             
|                             
|                        *    
|                             
15                             
|                             
|                             
|                   *         
|                             
10                             
|              *              
|                             
|                             
|         *                   
5                             
|    *                        
|                             
|                             
|                             
|----2----3----3----4----4----5----
     5    0    5    0    5    0
       Diameter (x 10^-2) m
4

1 回答 1

0

GNUPlot 是迄今为止用 C 绘制图形最简单的方法。它可以从简单的绘图绘制到复杂的 3d 图形,甚至提供 ASCII Art 输出(如果确实需要 ASCII 输出)

您可以在此处找到有关如何在 C 程序中使用 GNUPlot 的更多信息:http: //ndevilla.free.fr/gnuplot/

于 2013-05-15T10:35:15.143 回答