Searching...
Friday, 13 June 2014

PROGRAM IN LINUX C FOR LAMPORT'S LOGICAL CLOCK SYNCHRONIZATION ALGORITHM

6/13/2014 09:45:00 pm

#include<stdio.h>
int maximum(int a, int b)    //to find the maximum timestamp between two events
{
    if (a>b)
        return a;
    else
        return b;
}
int main()
{
    int i,j,k,p1[20],p2[20],e1,e2,dep[20][20];
    printf("enter the events : ");
    scanf("%d %d",&e1,&e2);
    for(i=0;i<e1;i++)
        p1[i]=i+1;

    for(i=0;i<e2;i++)
        p2[i]=i+1;
    printf("enter the dependency matrix:\n");
    printf("\t enter 1 if e1->e2 \n\t enter -1, if e2->e1 \n\t else enter 0 \n\n");
    for(i=0;i<e2;i++)
        printf("\te2%d",i+1);
    for(i=0;i<e1;i++)
    {
        printf("\n e1%d \t",i+1);
        for(j=0;j<e2;j++)
            scanf("%d",&dep[i][j]);

    }
    for(i=0;i<e1;i++)
    {
        for(j=0;j<e2;j++)
        {
            if(dep[i][j]==1)    // if dependency exist (e1->e2) change the timestamp
            {   
                p2[j]=maximum(p2[j],p1[i]+1);
                for(k=j;k<e2;k++)
                    p2[k+1]=p2[k]+1;
            }
            if(dep[i][j]==-1)    // if dependency exist (e2->e1) change the timestamp
            {
                p1[i]=maximum(p1[i],p2[j]+1);
                for(k=i;k<e1;k++)
                    p2[k+1]=p1[k]+1;
            }
        }
    }
    printf("P1 : ");      // print the output
    for(i=0;i<e1;i++)
    {
        printf("%d",p1[i]);
    }
    printf("\nP2 : ");
    for(j=0;j<e2;j++)
        printf("%d",p2[j]);
    printf("\n");
    return 0 ;
}
Next
This is the most recent post.
Older Post

0 comments:

Post a Comment