0

出于物理项目的目的,我正在尝试在 Mac 上的 Xcode 中的 C++ 中使用 fprintf 输出。以前我在 PC 上使用过 Turbo C++,并且没有与我在下面写的类似输出的问题......我正在尝试将数据发送到 .csv 文件以便在 xcel 中创建图形/图表,但调试器讨厌我尝试的输出。有人可以帮助我并告诉我如何将输出从 xcode 发送到 xcel 或 mac 的数字程序中吗?我的代码有什么问题?谢谢我已经束手无策了!

#include <iostream>
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include <time.h>

int main ()
{
    int ia,ja,ib=1,jb=1,n=1,t=1;
    float Ia[25],Ja[25],C[25][25],Wbb[25][25];
    float xl[25][25],xr[25][25],Pr[25][25],Nr[25][25];
    float max,r1,H=0;

    max=RAND_MAX;
    FILE * Project1;
    Project1 = fopen ("Users/Dave/Desktop/Project1.csv","w");

    Ia[n]=3;
    Ja[n]=3;
    for(t=1;t<100;++t) //time step counter
    {
        n=1;
        for(n=1;n<26;++n) //# of states to look at
        {
            ia=Ia[n];
            ja=Ja[n];
            ib=1;

            for(ib=1;ib<6;++ib) //determine I[n]'s C[ia][ja] values (initially will be the same due to ICs)
            {
                jb=1;
                for(jb=1;jb<6;++jb)
                {
                    C[ia][ja]=100*(ia-ib)^2+100*(ja-jb)^2+1;
                }
            }
            fprintf(Project1, "%d,%d,%d,%f\n",n,ia,ja,C[ia][ja]);

            ib=1;
            for(ib=1;ib<6;++ib) //determine Wsrs and delta x's for each system I[n] {
            {
                jb=1;
                for(jb=1;jb<6;++jb)
                {
                    Wbb[ib][jb]=C[ia][ja]/((100)*(ia-ib)^2+100*(ja-jb)^2+1);
                    xl[1][1]=0;
                    xr[ib][jb]=xl[ib][jb]+Wbb[ib][jb];
                    fprintf(Project1,"%d,%d,%f,%f,%f",ib,jb,Wbb[ib][jb],xl[ib][jb],xr[ib][jb]);
                    xl[ib][jb+1]=xr[ib][jb];
                }
            }

            r1=rand()/max; //randomly select new state and determine it's ib,jb value and reassign to new ia, ja at next time step
            ib=1;
            for(ib=1;ib<6;++ib)
            {
                jb=1;
                for(jb=1;jb<6;++jb)
                {
                    if(r1<xr[ib][jb] & r1>xl[ib][jb])
                        Nr[ib][jb]++;
                    Ia[n]=ib;
                    Ja[n]=jb;
                }
            }
        }

        ib=1;
        for(ib=1;ib<6;++ib)
        {
            jb=1;
            for(jb=1;jb<6;++jb)
            {
                Pr[ib][jb]=Nr[ib][jb]/25;
                H=Pr[ib][jb]*log(Pr[ib][jb])+H; //Compute Total Entropy Function of all systems by adding each systems entropy
            }
        }

        fprintf(Project1,"%f",H); //print out the Entropy at each time step
    }   
}
4

1 回答 1

1

所以我看到这里有一些问题,在这一行中你使用了错误的引号:

Project1 = fopen (“Users/Dave/Desktop/Project1.csv”,”w”);

应该:

Project1 = fopen ("Users/Dave/Desktop/Project1.csv","w");

正如有人指出 C++ 没有power运算符,^is a bitwise exclusive or,您需要使用该pow函数,所以这一行:

C[ia][ja]=100*(ia-ib)^2+100*(ja-jb)^2+1;

将会:

C[ia][ja]=100*pow((ia-ib),2)+100*pow((ja-jb),2)+1;

运算符也是&a bitwise and,在以下上下文中,我认为您的意思是&&which 是 a logical and,在这种情况下,他们会做同样的事情:

 if(r1<xr[ib][jb] & r1>xl[ib][jb])

此外,如果您使用 C++ 进行开发,我将使用 C++ 版本的头文件:

#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <ctime>
于 2013-03-18T01:03:37.107 回答