1./ set ns [new Simulator] set nf [open lab1.nam w] $ns namtrace - all $nf set tf [open lab1.tr w] $ns trace - all $tf proc finish {} { global ns nf tf $ns flush - trace close $nf close $tf exec nam lab1.nam & exit 0 } set n0 [$ns node] set n2 [$ns node] set n3 [$ns node] $ns duplex - link $n0 $n2 200Mb 10ms DropTail $ns duplex - link $n2 $n3 1Mb 1000ms DropTail $ns queue - limit $n0 $n2 10 set udp0 [new Agent/UDP] $ns attach - agent $n0 $udp0 set cbr0 [new Application/Traffic/CBR] $cbr0 set packetsize_ 500 $cbr0 set interval_ 0.005 $cbr0 attach - agent $udp0 set null0 [new Agent/Null] $ns attach - agent $n3 $null0 $ns connect $udp0 $null0 $ns at 0.1 "$cbr0 start" $ns at 1.0 "finish" $ns run 2./ set ns [new Simulator] set nf [open lab2.nam w] $ns namtrace - all $nf set tf [open lab2.tr w] $ns trace - all $tf set n0 [$ns node] set n1 [$ns node] set n2 [$ns node] set n3 [$ns node] set n4 [$ns node] set n5 [$ns node] $ns duplex - link $n0 $n4 1005Mb 1ms DropTail $ns duplex - link $n1 $n4 50Mb 1ms DropTail $ns duplex - link $n2 $n4 2000Mb 1ms DropTail $ns duplex - link $n3 $n4 200Mb 1ms DropTail $ns duplex - link $n4 $n5 1Mb 1ms DropTail set p1 [new Agent/Ping] $ns attach - agent $n0 $p1 $p1 set packetSize_ 50000 $p1 set interval_ 0.0001 set p2 [new Agent/Ping] $ns attach - agent $n1 $p2 set p3 [new Agent/Ping] $ns attach - agent $n2 $p3 $p3 set packetSize_ 30000 $p3 set interval_ 0.00001 set p4 [new Agent/Ping] $ns attach - agent $n3 $p4 set p5 [new Agent/Ping] $ns attach - agent $n5 $p5 $ns queue - limit $n0 $n4 5 $ns queue - limit $n2 $n4 3 $ns queue - limit $n4 $n5 2 Agent/Ping instproc recv {from rtt} { $self instvar node_ puts "node [$node_ id] recieved answer from $from with round trip time $rtt msec" } $ns connect $p1 $p5 $ns connect $p3 $p4 proc finish {} { global ns nf tf $ns flush - trace close $nf close $tf exec nam lab2.nam & exit 0 } $ns at 0.1 "$p1 send" $ns at 0.2 "$p1 send" $ns at 0.3 "$p1 send" $ns at 0.4 "$p1 send" $ns at 0.5 "$p1 send" $ns at 0.6 "$p1 send" $ns at 0.7 "$p1 send" $ns at 0.8 "$p1 send" $ns at 0.9 "$p1 send" $ns at 1.0 "$p1 send" $ns at 0.1 "$p3 send" $ns at 0.2 "$p3 send" $ns at 0.3 "$p3 send" $ns at 0.4 "$p3 send" $ns at 0.5 "$p3 send" $ns at 0.6 "$p3 send" $ns at 0.7 "$p3 send" $ns at 0.8 "$p3 send" $ns at 0.9 "$p3 send" $ns at 1.0 "$p3 send" $ns at 2.0 "finish" $ns run 3./ set ns [new Simulator] set tf [open lab3.tr w] $ns trace - all $tf set nf [open lab3.nam w] $ns namtrace - all $nf set n0 [$ns node] $n0 color "magenta" $n0 label "src1" set n1 [$ns node] set n2 [$ns node] $n2 color "magenta" $n2 label "src2" set n3 [$ns node] $n3 color "blue" $n3 label "dest2" set n4 [$ns node] set n5 [$ns node] $n5 color "blue" $n5 label "dest1" $ns make - lan "$n0 $n1 $n2 $n3 $n4" 100Mb 100ms LL Queue/DropTail Mac/802_3 $ns duplex - link $n4 $n5 1Mb 1ms DropTail set tcp0 [new Agent/TCP] $ns attach - agent $n0 $tcp0 set ftp0 [new Application/FTP] $ftp0 attach - agent $tcp0 $ftp0 set packetSize_ 500 $ftp0 set interval_ 0.0001 set sink5 [new Agent/TCPSink] $ns attach - agent $n5 $sink5 $ns connect $tcp0 $sink5 set tcp2 [new Agent/TCP] $ns attach - agent $n2 $tcp2 set ftp2 [new Application/FTP] $ftp2 attach - agent $tcp2 $ftp2 set packetSize_ 600 $ftp2 set interval_ 0.001 set sink3 [new Agent/TCPSink] $ns attach - agent $n3 $sink3 $ns connect $tcp2 $sink3 set file1 [open file1.tr w] $tcp0 attach $file1 set file2 [open file2.tr w] $tcp2 attach $file2 $tcp0 trace cwnd_ $tcp2 trace cwnd_ proc finish {} { global ns nf tf $ns flush - trace close $tf close $nf exec nam lab3.nam & exit 0 } $ns at 0.1 "$ftp0 start" $ns at 5 "$ftp0 stop" $ns at 7 "$ftp0 start" $ns at 0.2 "$ftp2 start" $ns at 8 "$ftp2 stop" $ns at 14 "$ftp0 stop" $ns at 10 "$ftp2 start" $ns at 15 "$ftp2 stop" $ns at 16 "finish" $ns run 4./ import java.util.*; public class CRC{ private final int gp[]={1,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,1}; int i; int j; void div(int a[],int k){ for(i=0;i<k;i++){ if(a[i]==1){ for(j=0;j<gp.length;j++){ a[i+j]=a[i+j]^gp[j]; } } } } public static void main(String args[]){ int i,j; Scanner sc = new Scanner(System.in); CRC ob = new CRC(); System.out.print("Enter the length of data frame:"); int msgLen=sc.nextInt(); int a[] = new int[200]; int b[] = new int[200]; System.out.println("Enter the Message bits (0/1):"); for(i=0;i<msgLen;i++){ a[i]=sc.nextInt(); } for(i=0;i<16;i++){ a[msgLen+i]=0; } int totalLen=msgLen+16; for(i=0;i<totalLen;i++){ b[i]=a[i]; } ob.div(a,msgLen); for(i=0;i<totalLen;i++){ a[i]=a[i]^b[i]; } System.out.print("Data to be transmitted:"); for(i=0;i<totalLen;i++){ System.out.print(a[i]+" "); } System.out.println(); int recieved[]=new int[200]; System.out.println("Enter the Recieved data bits:"); for(i=0;i<totalLen;i++){ recieved[i]=sc.nextInt(); } ob.div(recieved,msgLen); boolean error=false; for(i=0;i<totalLen;i++){ if(recieved[i]!=0){ error=true; break; } } if(error) System.out.println("Error detected in recieved data"); else System.out.println("no error in recieved data"); } } 5./ a #include<stdio.h> int main() { int i,w,f,frames[50]; printf("Enter window size:"); scanf("%d",&w); printf("Enter the number og frames to transmit:"); scanf("%d",&f); printf("Enter %d frames:",f); for(i=1;i<=f;i++) scanf("%d",&frames[i]); printf("With sliding window protocol the frames will be sent in the following manner(assuming no corruption ogf frames) \ n \ n"); printf("After sending %d gframes at each stage sender waits for acknowledgement sent by the receiver \ n \ n",w); for(i=1;i<=f;i++){ if(i%w==0){ printf("%d \ n",frames[i]); printf("Ack nowledgement of above frames sent is received by sender \ n \ n"); } else printf("%d \ n",frames[i]); } if(f%w!=0) printf(" \ nAcknowledgement og above frames sent is received by sender \ n"); return 0; } 5./b #include<stdio.h> int main() { int windowsize,sent=0,ack,i; printf("Enter window size:"); scanf("%d",&windowsize); while(1) { for(i=0;i<windowsize;i++) { printf("Frame %d has been transmitted \ n",sent); sent++; if(sent==windowsize) break; } printf(" \ nPlease enter the last Acknowledgement received \ n"); scanf("%d",&ack); if(ack==windowsize) break; else sent=ack; } return 0; }