电路测试

#include <iostream>
#include <mpi.h>
#include <stdio.h>
#include <cstdio>

using namespace std;

int main(int argc,char* argv[])
{
    int i;
    int id;
    int p;
    void check_circuit(int,int);

    MPI_Init(&argc,&argv);
    MPI_Comm_rank(MPI_COMM_WORLD,&id);
    MPI_Comm_size(MPI_COMM_WORLD,&p);

    for(i=id;i<65536;i+=p)
    {
        check_circuit(id,i);
    }
    printf("Process %d is done\n",id);
    fflush(stdout);
    MPI_Finalize();

    return 0;
}


#define EXTRACT_BIT(n,i) ((n&(1<<i))?1:0)

void check_circuit(int id,int z)
{
    int v[16];
    int i;
    for(i=0;i<16;i++)
    {
        v[i] = EXTRACT_BIT(z,i);
    }

    if((v[0] || v[1]) && (!v[1] || !v[3]) && (v[2] || v[3])
       && (!v[3] || !v[4]) && (v[4] || !v[5])
       && (v[5] || !v[6]) && (v[5] || v[6])
       && (v[6] || !v[15]) && (v[7] || !v[8])
       && (!v[7] || !v[13]) && (v[8] || v[9])
       && (v[8] || !v[9]) && (!v[9] || !v[10])
       && (v[9] || v[11]) && (v[10] || v[11])
       && (v[12] || v[13]) && (v[13] || !v[14])
       && (v[14] || v[15]))
    {
        printf("%d)%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d\n",id,
               v[0],v[1],v[2],v[3],v[4],v[5],v[6],v[7],v[8],v[9],v[10],
               v[11],v[12],v[13],v[14],v[15]);
        fflush(stdout);
    }
}

 

 

加入计数和时间:

#include <iostream>
#include <mpi.h>
#include <stdio.h>
#include <cstdio>

using namespace std;

int main(int argc,char* argv[])
{
    int global_solutions;
    int i;
    int id;
    int p;
    double elapsed_time;
    int solutions;
    int check_circuit(int,int);

    MPI_Init(&argc,&argv);
    MPI_Barrier(MPI_COMM_WORLD);
    elapsed_time = -MPI_Wtime();
    MPI_Comm_rank(MPI_COMM_WORLD,&id);
    MPI_Comm_size(MPI_COMM_WORLD,&p);
    solutions = 0;

    for(i=id;i<65536;i+=p)
    {
        solutions += check_circuit(id,i);
    }

    MPI_Reduce(&solutions,&global_solutions,1,MPI_INT,MPI_SUM,0,MPI_COMM_WORLD);
    elapsed_time += MPI_Wtime();
    printf("Process %d is done\n",id);
    fflush(stdout);
    MPI_Finalize();
    if(id == 0)
    {
        printf("There are %d different solutions\n",global_solutions);
    }
    printf("loss time:%f\n",elapsed_time);
    return 0;
}


#define EXTRACT_BIT(n,i) ((n&(1<<i))?1:0)

int check_circuit(int id,int z)
{
    int v[16];
    int i;
    for(i=0;i<16;i++)
    {
        v[i] = EXTRACT_BIT(z,i);
    }

    if((v[0] || v[1]) && (!v[1] || !v[3]) && (v[2] || v[3])
       && (!v[3] || !v[4]) && (v[4] || !v[5])
       && (v[5] || !v[6]) && (v[5] || v[6])
       && (v[6] || !v[15]) && (v[7] || !v[8])
       && (!v[7] || !v[13]) && (v[8] || v[9])
       && (v[8] || !v[9]) && (!v[9] || !v[10])
       && (v[9] || v[11]) && (v[10] || v[11])
       && (v[12] || v[13]) && (v[13] || !v[14])
       && (v[14] || v[15]))
    {
        printf("%d)%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d\n",id,
               v[0],v[1],v[2],v[3],v[4],v[5],v[6],v[7],v[8],v[9],v[10],
               v[11],v[12],v[13],v[14],v[15]);
        fflush(stdout);
        return 1;
    }
    else
    {
        return 0;
    }
}

 

posted on 2013-12-04 11:06  Ja °  阅读(231)  评论(0编辑  收藏  举报

导航