TE-SEM6_PL-04
(Programming Laboratory IV)
------------------------------
Practicals List:
-----------------------------
1]. Implementation of Packet sniffer. Program should identify header of each protocol.Use multi-core programming.
2]. Consider the network id 192.168.4.0 or such relevant IP and create four subnets namely
A, B, C, D. Assign the subnet mask. Write a Python \ C++ program to Perform the
following operations (use overloading if applicable).
a) Ping the machine of same subnet.
b) Ping the machine in subnet A from machine of subnet B.
c) Analyze the output of the above sub assignments.
3]. Write C++ Program with GUI to capture using remotely placed camera and read
uncompressed TIFF Image to perform following functions (Menu Driven) Use of
Overloading and Morphism is expected. Image Frame1 is used for displaying Original Image
and Image Frame 2 is used for displaying the action performed.
4]. Write a C++ program to read the HTTP header and analyze the parameters
5]. Installing and configure DHCP server and write a program (C++\Python\Java) to install the software on remote machine.
6]. Design and Setup LAN with Star topology to access Storage Area Network (SAN). The SAN must have DSP data, Text Data, Multimedia Data available for the access.
Assignments Group B (Any Six Assignments, All assignments to be covered in the Batch)
(within 6 assignments atleast two assignments from DSP)
1]. Write a Python program to grab the image from Camera and apply the edge detection algorithm(overloaded with Sobel variants, Others) to find the edges use BBB / ARM Cortex A5/A9/M4 Mobile Boards . Store the Images in SAN (for BIGDATA analitics)
2]. Implementation of streaming video server and displaying video at client side using Java. Videos are stored using SAN (BIGDATA)
3]. Simulation of WAN (RIP) using packet tracer/Network Simulator 3 (NS3)or higher equivalent.
4]. Study and perform Linux networking commands emulation using Python or C++.
5]. Write FTP/Telnet program using socket programming for TCP using C++
6]. Write TFTP program using socket programming for UDP using C++
7]. Create TCP/IP packet using standard TCP/IP include files and send it to the server using c++.
8]. Implement any congestion control algorithm for TCP using Python
9]. Implementation of Concurrent Text Conferencing application using Python or Java
10]. Implementation of Concurrent Proxy server program using Python or Java
11]. Implementation of Multithreaded web server. Check the functionality of web server in LAN and through the ADSL router using NAT.
12]. Implement a program for remote print manager to print documents on remote printer. (IP based printer) using Python
13]. Implementation of sliding window protocol using C++.
14]. Implementation of distance vector routing algorithm using C++.
15]. Implementing video conferencing system. Use VoIP protocol. Use Python or Java.
16]. Configure and setup network with optical router.
17]. (Refer Assignment 3 of Group A) Write a C++/ Python program to generate a Sign wave of Programmable frequency and capture samples at programmable frequency (Max up as per Nyquist Sampling Theorem) and reconstruct the Sign wave using collected Samples using ARM Cortex A5/A9. Use oscilloscope to calculate signal frequency. Write your observations. Store a Data file in SAN (BIGDATA)
18]. (Refer Assignment 3 of Group A) Write a C++/ Python program to generate a Square wave of programmable frequency. Write a function to generate Pole-Zero Diagram using multicore programming.
19]. (Refer Assignment 3 of Group A) Write a C++/ Python program to capture signal using ARM Cortex A5/A9/M4 ADC and signal generator, generate/construct a Square/Sine wave of programmable frequency and voltage Draw Voltage (y-axis) and Time (x-axis) graph. Write a function to emulate simple RC filter with R being Trim-pot(GUI meter) of 10K and C = 0.1 microFarad. Write a program to generate a Voltage-Time response curve with reference to change in R. Draw the resultant outcome graph. Store the data in SAN (BIGDATA)
Assignment Group C: Advance Technology Assignments (Any One)
1]. To create a network with three nodes and establish a TCP connection between node 0 and node 1 such that node 0 will send TCP packet to node 2 via node 1 using NS3 or higher equivalent.
2]. To create scenario of different network topology used in LAN using TCP/UDP and analysis how FTP will run over it in NS3 or higher equivalent.
3]. Designing IPv6 network and/or configuration of Dual stack IPv6 and IPv4 network.
4]. Controlling presentation slides with hands by identifying movements through Camera.
5]. Installation and setup to control the remote machine.
6]. Network Boot operations through Programming.
======================
Grp A 1].
======================
******************************************************************************
Assignment no. : A-1
Title : Implementation of Packet sniffer. Program should identify header of each protocol.Use
multi-core programming.
Roll no. :
Batch :
******************************************************************************
import socket
from struct import *
s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_TCP)
i=0
while (i<500): # change this value for no of packets
pack = s.recvfrom(20000)
#Get the single element from the tuple
packet = pack[0]
#Extract the first 20 bytes
data = packet[0:20]
# Now we have to unpack each element from this raw data
ip_header_data = unpack('!BBHHHBBH4s4s', data)
#To the the ip version we have to shift
#the first element 4 bits right. Because in the first element
#is stored the ip version and the header lenght in this way
#first four bits are ip version and the last 4 bites are
#the header lenght
ip_version = ip_header_data[0] >> 4
#Now to get the header lenght we use "and" operation to make the
#Ip versional bits equal to zero, in order to the the desired data
IHL = ip_header_data[0] & 0x0F
#Diferentiated services doesn't need any magic opperations,
#so we jus grab it from the tuple
diff_services = ip_header_data[1]
#Total lenght is also easy to extract
total_length = ip_header_data[2]
#The same goes for identification
id_ = ip_header_data[3]
#The "Flags" and Fragment Offset are situated in a sinle
#element from the forth element of the tuple.
#Flag is 3 bits (Most significant), so we make "and" with 1110 0000 0000 0000(=0xE000)
#to leave 3 most significant bits and then shift them right 13 positions
flags = ip_header_data[4] & 0xE000 >> 13
#The next elements are easy to get
TTL = ip_header_data[5]
protocol = ip_header_data[6]
checksum = ip_header_data[7]
source = ip_header_data[8]
destinat = ip_header_data[9]
#and the rest data from the "packet" variable is the payload so we
#extract it also
payload = packet[20:]
print "___________NEW_PACKET__________________________"
print "Version: %s \n\rHeader lenght: %s" %(ip_version,IHL)
print "Diferentiated services: %s \n\rID: %s" %(diff_services, id_)
print "Flags: %s \n\rTTL: %s \n\rProtocol: %s" %(flags,TTL,protocol)
print "Checksum: %s \n\rSource: %s \n\rDestination: %s" %(checksum, socket.inet_ntoa(source),socket.inet_ntoa(destinat))
#print "Payload: %s" %(payload)
i = i + 1
===========================
OUTPUT
===========================
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$ python sniffer.py
___________NEW_PACKET__________________________
Version: 4
Header lenght: 5
Diferentiated services: 0
ID: 49742
Flags: 0
TTL: 64
Protocol: 6
Checksum: 37377
Source: 173.194.117.95
Destination: 192.168.2.182
___________NEW_PACKET__________________________
Version: 4
Header lenght: 5
Diferentiated services: 0
ID: 49743
Flags: 0
TTL: 64
Protocol: 6
Checksum: 37376
Source: 173.194.117.95
Destination: 192.168.2.182
___________NEW_PACKET__________________________
Version: 4
Header lenght: 5
Diferentiated services: 0
ID: 49744
Flags: 0
TTL: 64
Protocol: 6
Checksum: 37375
Source: 173.194.117.95
Destination: 192.168.2.182
======================
Grp A 2].
======================
******************************************************************************
Assignment no. : A-2
Title : Consider the network id 192.168.4.0 or such relevant IP and create four subnets namely
A, B, C, D. Assign the subnet mask. Write a Python \ C++ program to Perform the
following operations (use overloading if applicable).
a) Ping the machine of same subnet.
b) Ping the machine in subnet A from machine of subnet B.
c) Analyze the output of the above sub assignments.
Roll no. :
Batch :
******************************************************************************
import os, sys, socket, struct, select, time
# From /usr/include/linux/icmp.h; your milage may vary.
ICMP_ECHO_REQUEST = 8 # Seems to be the same on Solaris.
def checksum(source_string):
"""
I'm not too confident that this is right but testing seems
to suggest that it gives the same answers as in_cksum in ping.c
"""
sum = 0
countTo = (len(source_string)/2)*2
count = 0
while count<countTo:
thisVal = ord(source_string[count + 1])*256 + ord(source_string[count])
sum = sum + thisVal
sum = sum & 0xffffffff # Necessary?
count = count + 2
if countTo<len(source_string):
sum = sum + ord(source_string[len(source_string) - 1])
sum = sum & 0xffffffff # Necessary?
sum = (sum >> 16) + (sum & 0xffff)
sum = sum + (sum >> 16)
answer = ~sum
answer = answer & 0xffff
# Swap bytes. Bugger me if I know why.
answer = answer >> 8 | (answer << 8 & 0xff00)
return answer
def receive_one_ping(my_socket, ID, timeout):
"""
receive the ping from the socket.
"""
timeLeft = timeout
while True:
startedSelect = time.time()
whatReady = select.select([my_socket], [], [], timeLeft)
howLongInSelect = (time.time() - startedSelect)
if whatReady[0] == []: # Timeout
return
timeReceived = time.time()
recPacket, addr = my_socket.recvfrom(1024)
icmpHeader = recPacket[20:28]
type, code, checksum, packetID, sequence = struct.unpack(
"bbHHh", icmpHeader
)
if packetID == ID:
bytesInDouble = struct.calcsize("d")
timeSent = struct.unpack("d", recPacket[28:28 + bytesInDouble])[0]
return timeReceived - timeSent
timeLeft = timeLeft - howLongInSelect
if timeLeft <= 0:
return
def send_one_ping(my_socket, dest_addr, ID):
"""
Send one ping to the given >dest_addr<.
"""
dest_addr = socket.gethostbyname(dest_addr)
# Header is type (8), code (8), checksum (16), id (16), sequence (16)
my_checksum = 0
# Make a dummy heder with a 0 checksum.
header = struct.pack("bbHHh", ICMP_ECHO_REQUEST, 0, my_checksum, ID, 1)
bytesInDouble = struct.calcsize("d")
data = (192 - bytesInDouble) * "Q"
data = struct.pack("d", time.time()) + data
# Calculate the checksum on the data and the dummy header.
my_checksum = checksum(header + data)
# Now that we have the right checksum, we put that in. It's just easier
# to make up a new header than to stuff it into the dummy.
header = struct.pack(
"bbHHh", ICMP_ECHO_REQUEST, 0, socket.htons(my_checksum), ID, 1
)
packet = header + data
my_socket.sendto(packet, (dest_addr, 1)) # Don't know about the 1
def do_one(dest_addr, timeout):
"""
Returns either the delay (in seconds) or none on timeout.
"""
icmp = socket.getprotobyname("icmp")
try:
my_socket = socket.socket(socket.AF_INET, socket.SOCK_RAW, icmp)
except socket.error, (errno, msg):
if errno == 1:
# Operation not permitted
msg = msg + (
" - Note that ICMP messages can only be sent from processes"
" running as root."
)
raise socket.error(msg)
raise # raise the original error
my_ID = os.getpid() & 0xFFFF
send_one_ping(my_socket, dest_addr, my_ID)
delay = receive_one_ping(my_socket, my_ID, timeout)
my_socket.close()
return delay
def verbose_ping(dest_addr, timeout = 2, count = 4):
"""
Send >count< ping to >dest_addr< with the given >timeout< and display
the result.
"""
for i in xrange(count):
print "ping %s..." % dest_addr,
try:
delay = do_one(dest_addr, timeout)
except socket.gaierror, e:
print "failed. (socket error: '%s')" % e[1]
break
if delay == None:
print "failed. (timeout within %ssec.)" % timeout
else:
delay = delay * 1000
print "get ping in %0.4fms" % delay
if __name__ == '__main__':
verbose_ping("heise.de")
verbose_ping("google.com")
verbose_ping("a-test-url-taht-is-not-available.com")
verbose_ping("192.168.2.183")
************** OUTPUT*******************
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$ python pi.py
ping heise.de... get ping in 394.4390ms
ping heise.de... get ping in 398.0720ms
ping heise.de... get ping in 345.6831ms
ping heise.de... get ping in 350.9300ms
ping google.com... get ping in 120.7960ms
ping google.com... get ping in 109.7860ms
ping google.com... get ping in 87.3210ms
ping google.com... get ping in 111.5770ms
ping a-test-url-taht-is-not-available.com... failed. (socket error: 'No address associated with hostname')
ping 192.168.2.183... get ping in 0.6080ms
ping 192.168.2.183... get ping in 0.6380ms
ping 192.168.2.183... get ping in 0.6349ms
ping 192.168.2.183... get ping in 0.5720ms
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
======================
Grp A 3].
======================
//=======================================================
//Menu.cpp
//=======================================================
#include<iostream>
#include<stdio.h>
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
#include <opencv2\core\core.hpp>
using namespace std;
using namespace cv;
class m enu
{
public: void mstd();
};
void menu::mstd()
{
IplIm age *Image1= cvLoadIm age ("bett er.jpg",1);
CvScalar M eanScal ar;
CvScalar StandardDevi ationScal ar;
cvAvgSdv(Image1, &MeanScalar, &St andardDeviationScalar) ;
printf("Blue Channel Avg is : %.f\n",M eanScal ar. val[0]);
printf("Blue Channel Standard Deviation is :%. f\n",StandardDevi ationScalar. val[0]);
printf("Green Channel Avg is : %. f\n",MeanS calar. val [1]);
printf("Green Channel Standard Deviation is : %. f\n",StandardDeviationScalar. val[1]);
printf("R ed Channel Avg is : %. f\n",MeanScalar. val[2]);
printf("R ed Channel Standard Deviation is :%. f\n",StandardDeviationS calar. val[2]);
}
cvNamedWindow( "better", 1);
cvShowIm age( "bett er", Image1);
cvWaitKey(0) ;
int main()
{
menu m;
int a;
Mat imgOriginal = imread( "better.jpg", 1 );
do
{
cout<<" Please Select Your Choice\n 1. MEAN & STD DEVIATION\n 2. Histo\n 3.
Rotate\n 4. Contrast\n 5. Sharpen\n 6. Blur\n 7. Exit\nEnter Your Choice...!!!\n";
cin>> a;
swit ch(a)
{
cas e 1: m.mstd();
cas e 2:
{Mat src, dst;
/// Load image
src = imread( "better.jpg", 1 );;
i f( !src.data )
{ return -1; }
/// Separate the im age in 3 places ( B, G and R )
vector < Mat > bgr_planes;
split( src, bgr_planes );
/// Est ablish the number of bins
int histSize = 256;
/// Set the ranges ( for B,G,R) )
float range[] = { 0, 256 } ;
const fl oat* histRange = { range };
bool uni form = true; bool accumul ate = false;
Mat b_hist, g_hist, r_hist;
/// Compute the histograms:
calcHist( &bgr_planes[0], 1, 0, M at(), b_hist, 1, &histSi ze, &histRange, uniform, accumulate );
calcHist( &bgr_planes[1], 1, 0, M at(), g_hist, 1, &histSi ze, &histRange, uniform, accumulate );
calcHist( &bgr_planes[2], 1, 0, M at(), r_hist, 1, &histSize, &histRange, uni form, accumulat e );
// Draw the histograms for B, G and R
int hist_w = 512; int hist_h = 400;
int bin_w = cvRound( (double) hist_w/histSize );
Mat histImage( hist_h, hist_w, CV_8UC3, Scal ar( 0,0,0) );
/// Normalize the result to [ 0, histImage.rows ]
normalize(b_hist, b_hist, 0, histImage.rows, NORM_MINMAX, -1, Mat() );
normalize(g_hist, g_hist, 0, histImage.rows, NORM_MINMAX, -1, Mat() );
normalize(r_hist, r_hist, 0, hist Im age.rows, NORM_MINMAX, -1, M at () );
/// Draw for each channel
for( int i = 1; i < histSize; i++ )
{
line( hist Im age, Point( bin_w*(i -1), hist_h - cvRound(b_hist. at < float > (i-1)) ) ,
Point( bin_w*(i), hist_h - cvRound(b_hist.at < float > (i )) ),
Scalar( 255, 0, 0), 2, 8, 0 );
line( hist Im age, Point( bin_w*(i -1), hist_h - cvRound(g_hist. at < float > (i-1)) ) ,
Point( bin_w*(i), hist_h - cvRound(g_hist.at < float > (i )) ),
Scalar( 0, 255, 0), 2, 8, 0 );
line( hist Im age, Point( bin_w*(i -1), hist_h - cvRound(r_hist.at < float > (i -1)) ) ,
Point( bin_w*(i), hist_h - cvRound(r_hist.at < fl oat > (i)) ),
Scalar( 0, 0, 255), 2, 8, 0 );
}/// Display
nam edWindow("calcHist Demo", CV_WINDOW_AUTOSIZE );
imshow("calcHist Demo", histImage );
waitKey(0);
return 0;
}
case 3:
{
// Load the image
Mat imgOriginal = imread( "bett er.jpg", 1 );
//show the original image
const char* pzOriginalImage = "Original Image";
namedWindow( pzOriginalImage, CV_WINDOW_AUTOSIZE );;
imshow( pzOriginalImage, imgOriginal );
const char* pzRotatedIm age = "Rotated Image";
namedWindow( pzRotatedImage, CV_WINDOW_AUTOSIZE );
int iAngl e = 180;
createTrackbar("Angle", pzRotatedImage, &iAngle, 360);
int iImageHi eght = imgOriginal.rows / 2;
int iImageWidth = imgOriginal.cols / 2;
whil e (t rue)
{
M at matRotation = getRotationMatrix2D( Point(iIm ageWidth, iImageHieght), (iAngl e - 180), 1 );
// Rotate the image
Mat imgRotated;
warpAffine( imgOriginal, imgRotated, matRotation, imgOriginal.size() );
imshow( pzRotatedImage, imgRotated );
int iRet = waitKey(30);
i f ( iRet == 27 )
{
break;
}
}
ret urn 0;
}
case 4:
{
Mat img = imread("better.jpg", CV_LOAD_IM AGE_COLOR); //open and read the image
i f (img.empty())
{cout << "Image cannot be loaded..!!" << endl;
ret urn -1;
}
Mat imgH;
img.convertTo(imgH, -1, 2, 0); //increas e the contrast (doubl e)
Mat imgL;
img.convertTo(imgL, -1, 0.5, 0); //decreas e the contrast (halve)
//create windows
namedWindow("Original Image", CV_WINDOW_AUTOSIZE);
namedWindow("High Contrast", CV_WINDOW_AUTOSIZE);
namedWindow("Low Contrast", CV_WINDOW_AUTOSIZE);
//show the image
imshow("Original Image", img);
imshow("High Contrast", imgH);
imshow("Low Contrast", imgL);
waitKey(0); //wait for key press
destroyAllWindows(); //destroy all open windows
ret urn 0;
}
case 5:
{
Mat image,result;
try
{
image = imread("bett er.jpg");
i f(!im age.data)
{
throw 1;
}
}
catch(int i)
{
cout << "Image is unable to reae" << endl;
}
waitKey(0);
{
result.create(image.size(), image.type());
//For all rows except first and last
for(int i=1;i < im age.rows-1;i++)
{
const uchar *previous = image.ptr < const uchar > (i-1);
const uchar *next = image.ptr < const uchar > (i+1);
const uchar *current = image.ptr < const uchar >(i);
uchar *output = res ult.ptr < uchar > (i);//For all columns except first and last
for(int a=3;a < (image. cols -1)*3;a++)
{
output[a] = cv::saturat e_cast < uchar >(5*current[a]-current[a-1]-current[a+1]-previous [a]-next[a]);
}
}
result.row(0).s etTo(cv::Scal ar(0));
result.row(result.rows-1).setTo(cv::Scalar(0));
result.col(0).setTo(cv::Scalar(0));
result.col(result.cols-1).setTo(cv::Scal ar(0));
namedWindow("Original");
imshow("Original",image);
namedWindow("Duplicate");
imshow("Duplicat e",result);
}
}
case 6:
{
//create 2 empty windows
namedWindow( "Original Im age" , CV_WINDOW_AUTOSIZE );
namedWindow( "Smoothed Image" , CV_WINDOW_AUTOSIZE );
// Load an image from fi le
Mat src = imread( "better.jpg", 1 );
//show the loaded image
imshow( "Original Im age", src );
Mat dst;
char zBuffer[35];
for ( int i = 1; i < 31; i = i + 2 )
{
//copy the text to the "zBuffer"
_snprint f_s(zBu ffer, 35,"Kernel Size : %d x %d", i, i);
//smooth the image in the "src" and s ave it to "dst"
blur( src, dst, Size( i, i ) );
//put the text in the "zBuffer" to the "dst" image
putText( dst, zBuffer, Point( src.cols/4, src.rows/8), CV_FONT_HERSHEY_COMPLEX, 1,
Scalar(255, 255, 255) );
//show the blurred image with the text
imshow( "Smoothed Image", dst );//wait for 2 seconds
int c = wait Key(2000);
//if the "esc" key is pressed during the wait, return
i f (c == 27)
{
ret urn 0;
}
}
//make the "dst" image, black
dst = Mat::zeros( src.size(), src.type() );
//copy the text to the "zBuffer"
_snprint f_s(zBu ffer, 35,"Press Any Key to Exit");
//put the text in the "zBuffer" to the "dst" image
putText( dst, zBuffer, Point( src.cols/4, src.rows / 2), CV_FONT_HERSHEY_COMPLEX,
1, Scalar(255, 255, 255) );
//show the black image with the text
imshow( "Smoothed Image", dst );
//wait for a key press infinitely
waitKey(0);
ret urn 0;
}
case 7: exit (0);
}
}while(-1);
}
//=======================================================
//Mstd.cpp
//=======================================================
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
#include <iostream>
#include <stdio.h>
void main8888()
{
IplImage *Image1=cvLoadImage ("better.jpg",1);
CvScal ar MeanScalar;
CvScal ar StandardDeviationScalar;
cvAvgSdv(Im age1, &MeanScalar, &StandardDeviationScal ar) ;
print f("Blue Channel Avg is : %. f\n",MeanScalar. val[0]);
print f("Blue Channel Standard Deviation is : %. f\n",StandardDeviationScalar. val [0]);
print f("Green Channel Avg is : %.f\ n",MeanScalar. val[1]);print f("Green Channel Standard Devi ation is : %. f\n",StandardDeviationScalar. val [1]);
print f("Red Channel Avg is : %. f\n",MeanS calar. val [2]);
print f("Red Channel Standard Deviation is :%.f\n",StandardDeviationScalar. val[2]);
cvNam edWindow( "better", 1);
cvShowImage( "better", Im age1);
cvWaitKey(0) ;
}
//=======================================================
//histo.cpp
//=======================================================
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
#include <iostream>
#include <stdio.h>
using namespace std;
using namespace cv;
/**
* @function main
*/
int main7878789( int argc, char** argv )
{
M at src, dst;
/// Load image
s rc = imread( "better.jpg", 1 );;
i f( !src.data )
{ return -1; }
/// Separate the image in 3 places ( B, G and R )
vector < Mat > bgr_planes;
split( src, bgr_pl anes );
/// Establish the number of bins
int histSize = 256;
/// Set the ranges ( for B,G,R) )
float range[] = { 0, 256 } ;
const float* histRange = { range };
bool uniform = true; bool accumulate = false;
M at b_hist, g_hist, r_hist;
/// Compute the histograms:
calcHist( &bgr_planes[0], 1, 0, M at(), b_hist, 1, &histSi ze, &histRange, uniform, accumulate );
calcHist( &bgr_planes[1], 1, 0, M at(), g_hist, 1, &histSi ze, &histRange, uniform, accumulate );calcHist( &bgr_planes[2], 1, 0, M at(), r_hist, 1, &histSize, &histRange, uni form, accumulat e );
// Draw the histograms for B, G and R
int hist_w = 512; int hist_h = 400;
int bin_w = cvRound( (double) hist_w/histSize );
M at histImage( hist_h, hist_w, CV_8UC3, Scalar( 0,0,0) );
/// Normalize the result to [ 0, histImage.rows ]
normalize(b_hist, b_hist, 0, histImage.rows, NORM_MINMAX, -1, Mat() );
normalize(g_hist, g_hist, 0, histImage.rows, NORM_MINMAX, -1, Mat() );
normalize(r_hist, r_hist, 0, histImage.rows, NORM_MINMAX, -1, Mat() );
/// Draw for each channel
for( int i = 1; i < histSize; i++ )
{
line( histImage, Point( bin_w*(i-1), hist_h - cvRound(b_hist.at < float >(i-1)) ) ,
Point( bin_w*(i), hist_h - cvRound(b_hist.at < float >(i)) ),
Scalar( 255, 0, 0), 2, 8, 0 );
line( histImage, Point( bin_w*(i-1), hist_h - cvRound(g_hist.at < float >(i-1)) ) ,
Point( bin_w*(i), hist_h - cvRound(g_hist.at < float > (i )) ),
Scalar( 0, 255, 0), 2, 8, 0 );
line( histImage, Point( bin_w*(i-1), hist_h - cvRound(r_hist.at < fl oat > (i-1)) ) ,
Point( bin_w*(i), hist_h - cvRound(r_hist.at < fl oat > (i)) ),
Scalar( 0, 0, 255), 2, 8, 0 );
}
/// Display
namedWindow("calcHist Demo", CV_WINDOW_AUTOSIZE );
imshow("calcHist Demo", histImage );
waitKey(0);
return 0;
}
//=======================================================
//rotate. cpp
//=======================================================
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
using namespace cv;
int main7894( int argc, char** argv )
{
// Load the image
M at imgOriginal = imread( "bett er.jpg", 1 );
//show the original image
const char* pzOriginalImage = "Original Image";namedWindow( pzOriginalImage, CV_WINDOW_AUTOSIZE );;
imshow( pzOriginalImage, imgOriginal );
const char* pzRotatedIm age = "Rotated Image";
namedWindow( pzRotatedImage, CV_WINDOW_AUTOSIZE );
int iAngl e = 180;
createTrackbar("Angle", pzRotatedImage, &iAngle, 360);
int iIm ageHieght = imgOriginal.rows / 2;
int iIm ageWidth = imgOriginal.cols / 2;
whil e (true)
{
M at matRotation = getRotationMatrix2D( Point(iIm ageWidth, iImageHieght), (iAngl e - 180), 1 );
// Rotate the image
M at imgRotat ed;
warpA ffi ne( imgOriginal, imgRotat ed, matRotation, imgOriginal.si ze() );
imshow( pzRotatedImage, imgRotated );
int iRet = waitKey(30);
i f ( iRet == 27 )
{
break;
}
}
return 0;
}
//=======================================================
//contrast. cpp
//=======================================================
#include "opencv2/highgui/highgui.hpp"
using namespace cv;
using namespace std;
int main69( int argc, const char** argv )
{
M at img = imread("better.jpg", CV_LOAD_IMAGE_COLOR );
i f (img.empty())
{
cout << "Image cannot be loaded..!!" << endl;
return -1;
}
M at imgH;
img.convertTo(imgH, -1, 2, 0); //increase the contrast (double)
M at imgL;
img.convertTo(imgL, -1, 0.5, 0); //decrease the contrast (halve)//creat e windows
namedWindow("Original Im age", CV_WINDOW_AUTOSIZE);
namedWindow("High Contrast", CV_WINDOW_AUTOSIZE);
namedWindow("Low Contrast", CV_WINDOW_AUTOS IZE);
//show the image
imshow("Original Im age", img);
imshow("High Contrast", imgH);
imshow("Low Contrast", imgL);
waitKey(0); //wait for key press
destroyAllWindows(); //destroy all open windows
return 0;
}
//=======================================================
//sharp.cpp
//=======================================================
#include <iostream>
#include <opencv2\core\core.hpp>
#include <opencv2\highgui\highgui.hpp>
using namespace std;
using namespace cv;
void Sharpen(Mat &image,Mat& result)
{
result. create(image.size(), image.type());
//For all rows except first and last
for(int i=1; i < im age.rows-1;i++)
{
const uchar *previous = image.ptr < const uchar >(i-1);
const uchar *next = im age.pt r < const uchar > (i+1);
const uchar *current = image.ptr < const uchar > (i);
uchar *output = result.ptr < uchar > (i);
//For all columns except fi rst and l ast
for(int a=3; a < (image.cols -1)*3;a++)
{
output[a] = cv::saturat e_cast < uchar > (5*current[a]-current[a-1]-current [a+1]-previous[a]-next[a]);
}
}
result.row(0).setTo(cv::Scalar(0));
result.row(result.rows-1).s etTo(cv::Scal ar(0));
result. col (0).setTo(cv::Scalar(0));
result. col (result.cols-1).setTo(cv::Scalar(0));namedWindow("Original");
imshow("Original",image);
namedWindow("Dupli cate");
imshow("Dupli cate",result);
}
int main45655()
{
M at image,result;
t ry
{
image = imread("better.jpg");
i f(!image.dat a)
{
throw 1;
}
}
catch(int i)
{
cout << "Image is unable to reae" << endl;
}
Sharpen(image,result);
waitKey(0);
}
//=======================================================
//blur.cpp
//=======================================================
#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"
using namespace cv;
int main342( int argc, char** argv )
{
//creat e 2 empty windows
namedWindow( "Original Image" , CV_WINDOW_AUTOSIZE );
namedWindow( "Smoothed Image" , CV_WINDOW_AUTOSIZE );
// Load an image from file
M at src = imread( "better.jpg", 1 );
//show the loaded image
imshow( "Original Image", src );
M at dst;
char zBuffer[35];for ( int i = 1; i < 31; i = i + 2 )
{
//copy the text to the "zBuffer"
_snprint f_s (zBuffer, 35,"Kernel Size : %d x %d", i, i);
//smooth the im age in the "src" and save it to "dst"
blur( s rc, dst, Size( i, i ) );
//put the text in the "zBuffer" to the "dst" image
putText( dst, zBu ffer, Point( src.cols/4, src.rows/8), CV_FONT_HERSHEY_COMPLEX, 1,
Scalar(255, 255, 255) );
//show the blurred image with the text
imshow( "Smoothed Image", dst );
//wait for 2 s econds
int c = waitKey(2000);
//i f the "esc" key is press ed during the wait, return
i f (c == 27)
{
return 0;
}
}
//make the "dst" image, black
dst = Mat::zeros( src.size(), src.type() );
//copy the text to the "zBuffer"
_snprint f_s (zBuffer, 35,"Press Any Key to Exit");
//put the text in the "zBuffer" to the "dst" image
putText( dst, zBu ffer, Point( src.cols/4, src.rows / 2), CV_FONT_HERSHEY_C OMPLEX, 1,
Scalar(255, 255, 255) );
//show the black image with the t ext
imshow( "Smoothed Image", dst );
//wait for a key press infinit ely
waitKey(0);
return 0;
}
======================
Grp A 4].
======================
******************************************************************************
Assignment no. : A-4
Title : Write a C++ program to read the HTTP header and analyze the parameters
Roll no. :
Batch :
******************************************************************************
#include <winsock2.h>
#include <windows.h>
#include <iostream>
#pragma comment(lib,"ws2_32.lib")
using namespace std;
int main (){
WSADATA wsaData;
if (WSAStartup(MAKEWORD(2,2), &wsaData) != 0) {
cout << "WSAStartup failed.\n";
system("pause");
return 1;
}
SOCKET Socket=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
struct hostent *host;
host = gethostbyname("www.google.com");
SOCKADDR_IN SockAddr;
SockAddr.sin_port=htons(80);
SockAddr.sin_family=AF_INET;
SockAddr.sin_addr.s_addr = *((unsigned long*)host->h_addr);
cout << "Connecting...\n";
if(connect(Socket,(SOCKADDR*)(&SockAddr),sizeof(SockAddr)) != 0){
cout << "Could not connect";
system("pause");
return 1;
}
cout << "Connected.\n";
send(Socket,"GET / HTTP/1.1\r\nHost: www.google.com\r\nConnection: close\r\n\r\n", strlen("GET / HTTP/1.1\r\nHost: www.google.com\r\nConnection: close\r\n\r\n"),0);
char buffer[10000];
int nDataLength;
while ((nDataLength = recv(Socket,buffer,10000,0)) > 0){
int i = 0;
while (buffer[i] >= 32 || buffer[i] == '\n' || buffer[i] == '\r') {
cout << buffer[i];
i += 1;
}
}
closesocket(Socket);
WSACleanup();
system("pause");
return 0;
}
/******* OUTPUT ********
D:\>bcc32 w.cpp
Borland C++ 5.5.1 for Win32 Copyright (c) 1993, 2000 Borland
w.cpp:
Warning W8004 w.cpp 41: 'nDataLength' is assigned a value that is never used in
function main()
Turbo Incremental Link 5.00 Copyright (c) 1997, 2000 Borland
Fatal: Could not open w.exe (program still running?)
D:\>w
Connecting...
Connected.
HTTP/1.1 302 Found
Cache-Control: private
Content-Type: text/html; charset=UTF-8
Location: http://www.google.co.in/?gfe_rd=cr&ei=xFimVOToFsGAvASbvIHICw
Content-Length: 261
Date: Fri, 02 Jan 2015 08:37:24 GMT
Server: GFE/2.0
Alternate-Protocol: 80:quic,p=0.02
Connection: close
<HTML><HEAD><meta http-equiv="content-type" content="text/html;charset=utf-8">
<TITLE>302 Moved</TITLE></HEAD><BODY>
<H1>302 Moved</H1>
The document has moved
<A HREF="http://www.google.co.in/?gfe_rd=cr&ei=xFimVOToFsGAvASbvIHICw">here<
/A>.
</BODY></HTML>
Press any key to continue . . .
*/
======================
Grp A 6].
======================
/*---------------------------------------------------------------------------------------------------------------------
Group:A
Assignment No: 6
Roll No:
Title:Design and Setup LAN with Star topology to access Storage Area Network (SAN). The SAN
must have DSP data, Text Data, Multimedia Data available for the access.
---------------------------------------------------------------------------------------------------------------------*/
Title:-
Design and Setup LAN with Star topology to access Storage Area Network (SAN). The SAN must have DSP data, Text Data, Multimedia Data available for the access.
Pre-requisites :-
Storage area network.
Star Topology.
Objective :-
To Configure SAN using Star Topology.
Index Terms :-
Network Topology
A network topology is the basic design of a computer network. It is very much like a map of a road. It details how key network components such as nodes and links are interconnected.
Star Topology:
All devices connected with a Star setup communicate through a central Hub by cable segments. Signals are transmitted and received through the Hub. It is the simplest and the oldest and all the telephone switches are based on this. In a star topology, each network device has a home run of cabling back to a network hub, giving each device a separate connection to the network. So, there can be multiple connections in parallel.
Advantages
Network administration and error detection is easier because problem is isolated to central node
Networks runs even if one host fails
Expansion becomes easier and scalability of the network increases
More suited for larger networks
Storage Area Network
The term SAN designates a new type of storage architecture in which the storage systems
are attached to a high speed network dedicated exclusively to storage. It involves a whole
new network totally distinct from existing communication networks, as is illustrated in
Figure1. The application servers (usually UNIX or Windows NT based) access the storage
resource through the SAN. Most of the local storage resources are off–loaded from the
applications servers, are managed separately from them, and are consolidated at the data
centre, site, or enterprise level.
The term SAN refers both to the high speed network infrastructure and thewhole storage architecture, including servers, storage subsystems and management software.
Fibre Channel is currently the preferred technology for implementing SAN architecture. The
technology is open, widely accepted, and is defined by ANSI standards. To simplify the
migration and integration of legacy equipment, SAN infrastructure based on Fibre Channel
technology supports multiple protocols. For example, the infrastructure can convey SCSI
protocols, widely used in UNIX and Intel based servers, ESCON for IBM mainframes, and IP
to offer networking capability. But the purpose of SAN is not to replace LANs. All these
protocols can simultaneously use the same cables.
Benefits Of SAN:
1. Cost reduction
2. Easy administration
3. High security andavailability
4. Improved performance
5. Quick evolution capability
SAN design using Star topology
Topology is usually described in terms of how the switches are interconnected, such as ring, core-edge, and edge-core-edge or fully meshed. At this point the focus is on switch topology with Sls.
Storage Switches
Storage switches are basic building blocks to storage network topology. Each switch consists of
several ports interconnected by a switch construct. The basic function of a storage switch is to
forward frames among the ports according to the protocol supported by the storage network. In a
Fibre Channel Network, the switch obeys the rules specified by the FC-SW standard to handle the
frames. In an iSCSI storage network, the switching is typically done at the Ethernet layer
according to the Ethernet bridging standards, such as 802.1D or the IP layer. Although the
specific protocols are different, the various types of storage switches share the common basic
structure. However, because of the difference in network protocols, different types of switches are
still required: Fibre Channel switches for FC SANs, the Ethernet switches or IP routers for iSCSI
network. New multiservice switches are being developed to help the convergence of heterogeneous storage networks running multiple network protocols.
The control unit, which is either attached directly to the switch fabric or attached via a
dedicated control interconnection network, and provides control plane and management plane functions to the rest of the system.
The service or interworking units that provide the processing power for complicated service
functions or interworking functions. The user traffic from the line interface units that require special processing is often groomed into the service/interworking units for further processing.
The service unit can operate in a one-arm fashion, or have its own external line interfaces.
One example is an iSCSI Ethernet service card on a Fibre Channel director switch. The iSCSI service card provides interworking between Fibre Channel and iSCSI as well as the Ethernet interface to the iSCSI network.
Lastly, the switch fabric is the central unit that ties all the units together and provides the
means for passing traffic among the units. Most popular switching fabric technologies
employed by recent storage switches include shared memory switches, digital crossbar
switches and analog crosspoint switches. There are examples of large storage switches that
are put together using smaller switch elements in a multistage fashion.
Methodology to Build SAN Configurations
Step 1 Collect the Data
Identify all the servers, applications, and data–sets
Get characteristics of each data–set
Step 2 :Size the Servers and Storage Systems
Create connectivity matrix and data–set maps
Configure each disk array
Identify hot–spots
Configure the libraries
Step 3: Design the SAN Topology
Start with an empty map
The following sequence is recommended in conjunction with the above template:
1. Group servers by location and function.
2. Group arrays and libraries by location and function.
3. Identify site boundaries, distance information, rooms, etc.
4. Draw existing SAN infrastructure (in the case of an upgrade).
5. Draw interconnection of arrays (e.g. Symmetrix and SRDF).
6. Identify servers with multipathing software.
Analyze the structure of the SAN to be designed
Interconnect hardware according to your connectivity matrix
Check performance constraints
Identify zones to be defined in the SAN
Determine whether there is a need for zoning:
• to simulate independent islands
• to isolate areas to meet customer’s requirements
• to share the infrastructure with servers and storage not approved by Bull.
Specify the LUN management tools
Document which LUN access control product will be used:
1. S@N.IT!
2. Volume Logix (Symmetrix)
3. Access Logix (DAS 4500)
4. A combination of all three
5. None (acceptable for 2–node clusters – otherwise risky).
Check multipathing risks
The interconnection of devices creates more connections than required in the connectivity
matrix. Check that these extra connections do not lead to operational problems.
If there are problems:
• use zoning or masking to resolve them
and/or
• modify LUN assignment to array ports
and/or
• modify cabling.
Check list:
• is LUN visible through multiple ports?
• are there multiple copies of the LUN (in the same array, or in other arrays)?
• are there servers with multiple HBA (with or without multipathing software)?
Consolidate all the information
Create a topology map with all the interconnections and zones.
Draw up a list of the required hardware to prepare ordering with NOEMIE (HBA, hubs,
switches, bridges, cables, etc.).
Draw up a consolidated definition of LUN visibility (bindings) to array ports.
Define zones and LUN masking for servers to ensure correct operation of servers.
Step 5 Determine a Management Policy
Draw the management infrastructure
List all the software to be installed and identify all the components to prepare NOEMIE
ordering. The list should include:
• array management
• library management
• SAN infrastructure device management
• backup management
• resource access control
• SAN management
• HA and clustering management
• an updated topology map.
Step 6 Write a Consolidated Report
Prepare a proposal for your customer that includes:
• an explanation of the proposed solution
• a list of hardware and software (derived from NOEMIE)
• the data–set distribution on the arrays
• a topology map
• all the sizing and performance data.
Make sure the following information is available for the installation phase:
• disk array configuration
• zoning and masking requirements
• software installation procedure.
Conclusion :-
Thus,we have studied how to configured and setup star topology in LAN to access SAN data.
======================
Grp B 1].
======================
import cv2
import numpy
cap = cv2.VideoCapture(0)
cap.set(3, 960)
cap.set(4, 544)
r, frame = cap.read()
img = cv2.GaussianBlur(frame,(3,3),0)
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
scale = 1
delta = 0
ddepth = cv2.CV_16S
grad_x = cv2.Sobel(gray,ddepth,1,0,ksize = 3, scale = scale, delta = delta,borderType = cv2.BORDER_DEFAULT)
grad_y = cv2.Sobel(gray,ddepth,0,1,ksize = 3, scale = scale, delta = delta, borderType = cv2.BORDER_DEFAULT)
abs_grad_x = cv2.convertScaleAbs(grad_x)
abs_grad_y = cv2.convertScaleAbs(grad_y)
dst = cv2.addWeighted(abs_grad_x,0.5,abs_grad_y,0.5,0)
cv2.imwrite("123.jpg", dst)
cv2.imwrite("456.jpg", frame)
print("GoodBye...")
--------------------------------------------------------------------------------------------------------------------
Assignment :- B-3
Title :- Simulation of WAN (RIP) using packet tracer/Network Simulator 3
(NS3)or higher
equivalent.
Roll_No. :-
--------------------------------------------------------------------------------------------------------------------*/
Title:-
Configure and setup network with optical router.
Pre-requisites :-
·
RIP Protocol
·
WAN Network
·
NS3
Objective :-
To simulate WAN using Packet Tracer/NS3.
Index Terms :-
Routing Information
Protocol -
The Routing Information Protocol (RIP) is one of the oldest
distance-vector routing protocols, which employs the hop count as a routing
metric. It is an Open Standard Routing Protocol. RIP prevents routing loops by
implementing a limit on the number of hops allowed in a path from the source to
a destination. The maximum number of hops allowed for RIP is 15. This hop
limit, however, also limits the size of networks that RIP can support. A hop
count of 16 is considered an infinite distance, in other words the route is
considered unreachable. RIP implements the split horizon, route poisoning and
holddown mechanisms to prevent incorrect routing information from being
propagated.
Originally, each RIP router transmitted full updates every 30
seconds. In most current networking environments, RIP is not the preferred
choice for routing as its time to converge and scalability are poor compared to
EIGRP, OSPF, or IS-IS (the latter two being link-state routing protocols), and
a hop limit severely limits the size of network it can be used in. However, it
is easy to configure, because RIP does not require any parameters on a router
unlike other protocols.
RIP uses the User Datagram Protocol (UDP) as its transport
protocol, and is assigned the reserved port number 520. Rip has two versions-
RIPv1 and RIPv2, running on Ipv4 and RIPng running on Ipv6.
RIP version 1 (RIPv1) -
The original specification of RIP, defined in RFC 1058, was
published in 1988 and uses classful routing. The periodic routing updates do not
carry subnet information, lacking support for variable length subnet masks
(VLSM). This limitation makes it impossible to have different-sized subnets
inside of the same network class. In other words, all subnets in a network
class must have the same size. There is also no support for router
authentication, making RIP vulnerable to various attacks. RIPv1 uses Broadcast
IP 255.255.255.255 for communication.
RIP version 2 (RIPv2) -
Due to the deficiencies
of the original RIP specification, RIP version 2 (RIPv2) was developed in 1993
and last standardized in 1998. It included the ability to carry subnet
information, thus supporting Classless Inter-Domain Routing (CIDR). To maintain
backward compatibility, the hop count limit of 15 remained. RIPv2 has facilities
to fully interoperate with the earlier specification if all Must Be Zero
protocol fields in the RIPv1 messages are properly specified. In addition, a
compatibility switch feature allows fine-grained interoperability adjustments.
In an effort to avoid
unnecessary load on hosts that do not participate in routing, RIPv2 multicasts
the entire routing table to all adjacent routers at the address 224.0.0.9, as
opposed to RIPv1 which uses broadcast. Unicast addressing is still allowed for
special applications. (MD5) authentication for RIP was introduced in 1997.
RIPv2 is Internet Standard STD56 (which is RFC 2453). Route tags were also
added in RIP version 2. This functionality allows a distinction between routes
learned from the RIP protocol and routes learned from other protocols.
RIP next generation
(RIPng) -
RIPng (RIP next generation), defined in RFC 2080,[7] is an
extension of RIPv2 for support of IPv6, the next generation Internet Protocol.
The main differences between RIPv2 and RIPng are:
·
Support of IPv6 networking.
·
While RIPv2 supports RIPv1 updates authentication, RIPng does not.
IPv6 routers were, at the time, supposed to use IPsec for authentication.
·
RIPv2 encodes the next-hop into each route entry, RIPng requires
specific encoding of the next hop for a set of route entries.
RIPng sends updates on UDP port 521 using the multicast group
FF02::9.
For implementing RIP protocol between two routers, we can use any
of the network simulation tools available -
·
Packet Tracer
·
GNS
·
NFS
Packet Tracer -
Cisco Packet Tracer is a powerful network simulation program that
allows us to experiment with network behavior. Packet Tracer provides
simulation, visualization, authoring, assessment, and collaboration
capabilities and facilitates the teaching and learning of complex technology
concepts.
Packet Tracer supplements physical equipment by allowing us to
create a network with an almost unlimited number of devices, encouraging
practice, discovery, and troubleshooting.
Commands for implementing RIP between two routers
hostname – This command is used to change the name of a router.
interface – This command is used to assign IP address to an
interface.
router rip – This command enables a RIP routing
process, which places us in router configuration mode.
network – This command associates a network with a RIP routing
process.
Implementing RIP using Packet Tracer –
Configurations on Router 1 -
System Bootstrap, Version 12.3(8r)T8, RELEASE SOFTWARE (fc1) Cisco
1841 (revision 5.0) with 114688K/16384K bytes of memory.
Self decompressing the image :
##########################################################################
[OK]
Restricted Rights Legend
Use, duplication, or disclosure by the Government is subject to
restrictions as set forth in subparagraph (c) of the Commercial Computer
Software - Restricted Rights clause at FAR sec. 52.227-19 and subparagraph (c)
(1) (ii) of the Rights in Technical Data and Computer Software clause at DFARS
sec. 252.227-7013.
cisco Systems, Inc.
170 West Tasman Drive
San Jose, California 95134-1706
Cisco IOS Software, 1841 Software (C1841-ADVIPSERVICESK9-M),
Version 12.4(15)T1, RELEASE SOFTWARE (fc2)
Copyright (c) 1986-2007 by Cisco Systems, Inc.
Compiled Wed 18-Jul-07 04:52 by pt_team
Image text-base: 0x60080608, data-base: 0x6270CD50
This product contains cryptographic features and is subject to
United States and local country laws governing import, export, transfer and
use. Delivery of Cisco cryptographic products does not imply third-party
authority to import, export, distribute or use encryption. Importers,
exporters, distributors and users are responsible for compliance with U.S. and
local country laws. By using this product you agree to comply with applicable
laws and regulations. If you are unable to comply with U.S. and local laws,
return this product immediately.
A summary of U.S. laws governing Cisco cryptographic products may
be found at:
http://www.cisco.com/wwl/export/crypto/tool/stqrg.html
If you require further assistance please contact us by sending
email to export@cisco.com.
Cisco 1841 (revision 5.0) with 114688K/16384K bytes of memory.
Processor board ID FTX0947Z18E
M860 processor: part number 0, mask 49
2 FastEthernet/IEEE 802.3 interface(s)
191K bytes of NVRAM.
63488K bytes of ATA CompactFlash (Read/Write)
Cisco IOS Software, 1841 Software (C1841-ADVIPSERVICESK9-M),
Version 12.4(15)T1, RELEASE SOFTWARE (fc2)
Technical Support: http://www.cisco.com/techsupport
Copyright (c) 1986-2007 by Cisco Systems, Inc.
Compiled Wed 18-Jul-07 04:52 by pt_team
--- System Configuration Dialog ---
Continue with configuration dialog? [yes/no]: n
Press RETURN to get started!
Router>enable
Router#config terminal
Enter configuration commands, one per line. End with CNTL/Z.
Router(config)#interface fastEthernet 0/0
Router(config-if)#ip address 192.168.1.1 255.255.255.0
Router(config-if)#no shutdown
%LINK-5-CHANGED: Interface FastEthernet0/0, changed state to up
%LINEPROTO-5-UPDOWN: Line protocol on Interface FastEthernet0/0,
changed state to up
Router(config-if)#exit
Router(config)#interface fastEthernet 0/1
Router(config-if)#ip address 192.168.2.1 255.255.255.0
Router(config-if)#no shutdown
%LINK-5-CHANGED: Interface FastEthernet0/1, changed state to up
Router(config-if)#exit
Router(config)#interface Serial 0/0/0
Router(config-if)#ip address 192.168.3.1 255.255.255.0
Router(config-if)#no shutdown
%LINK-5-CHANGED: Interface Serial0/0/0, changed state to up
%LINEPROTO-5-UPDOWN: Line protocol on Interface Serial0/0/0,
changed state to up
Router(config-if)#exit
Router(config)#router rip
Router(config-router)#network 192.168.3.0
Router(config-router)#network 192.168.4.0
Router(config-router)#exit
Router(config)#exit
%SYS-5-CONFIG_I: Configured from console by console
Router#show ip protocols
Routing Protocol is "rip"
Sending updates every 30 seconds, next due in 5 seconds
Invalid after 180 seconds, hold down 180, flushed after 240
Outgoing update filter list for all interfaces is not set
Incoming update filter list for all interfaces is not set
Redistributing: rip
Default version control: send version 1, receive any version
Interface Send Recv Triggered RIP Key-chain
Serial0/0/0 1 2 1
Automatic network summarization is in effect
Maximum path: 4
Routing for Networks:
192.168.3.0
192.168.4.0
Passive Interface(s):
Routing Information Sources:
Gateway Distance Last Update
Distance: (default is 120)
Router#
Configurations on Router 2 -
System Bootstrap, Version 12.3(8r)T8, RELEASE SOFTWARE (fc1) Cisco
1841 (revision 5.0) with 114688K/16384K bytes of memory.
Self decompressing the image :
##########################################################################
[OK]
Restricted Rights Legend
Use, duplication, or disclosure by the Government is subject to
restrictions as set forth in subparagraph (c) of the Commercial Computer
Software - Restricted Rights clause at FAR sec. 52.227-19 and subparagraph (c)
(1) (ii) of the Rights in Technical Data and Computer Software clause at DFARS
sec. 252.227-7013.
cisco Systems, Inc.
170 West Tasman Drive
San Jose, California 95134-1706
Cisco IOS Software, 1841 Software (C1841-ADVIPSERVICESK9-M),
Version 12.4(15)T1, RELEASE SOFTWARE (fc2)
Technical Support: http://www.cisco.com/techsupport
Copyright (c) 1986-2007 by Cisco Systems, Inc.
Compiled Wed 18-Jul-07 04:52 by pt_team
Image text-base: 0x60080608, data-base: 0x6270CD50
This product contains cryptographic features and is subject to
United States and local country laws governing import, export, transfer and
use. Delivery of Cisco cryptographic products does not imply third-party
authority to import, export, distribute or use encryption. Importers,
exporters, distributors and users are responsible for compliance with U.S. and
local country laws. By using this product you agree to comply with applicable
laws and regulations. If you are unable to comply with U.S. and local laws,
return this product immediately.
A summary of U.S. laws governing Cisco cryptographic products may
be found at:
http://www.cisco.com/wwl/export/crypto/tool/stqrg.html
If you require further assistance please contact us by sending
email to
export@cisco.com.
Cisco 1841 (revision 5.0) with 114688K/16384K bytes of memory.
Processor board ID FTX0947Z18E
M860 processor: part number 0, mask 49
2 FastEthernet/IEEE 802.3 interface(s)
191K bytes of NVRAM.
63488K bytes of ATA CompactFlash (Read/Write)
Cisco IOS Software, 1841 Software (C1841-ADVIPSERVICESK9-M),
Version 12.4(15)T1, RELEASE SOFTWARE (fc2)
Technical Support: http://www.cisco.com/techsupport
Copyright (c) 1986-2007 by Cisco Systems, Inc.
Compiled Wed 18-Jul-07 04:52 by pt_team
--- System Configuration Dialog ---
Continue with configuration dialog? [yes/no]: n
Press RETURN to get started!
Router>enable
Router#config terminal
Enter configuration commands, one per line. End with CNTL/Z.
Router(config)#interface fastEthernet 0/1
Router(config-if)#ip address 192.168.2.1 255.255.255.0
Router(config-if)#no shutdown
%LINK-5-CHANGED: Interface FastEthernet0/1, changed state to up
Router(config-if)#exit
Router(config)#interface fastEthernet 0/0
Router(config-if)#ip address 192.168.1.1 255.255.255.0
Router(config-if)#no shutdown
%LINK-5-CHANGED: Interface FastEthernet0/0, changed state to up
%LINEPROTO-5-UPDOWN: Line protocol on Interface FastEthernet0/0,
changed state to up
Router(config-if)#exit
Router(config)#interface Serial 0/0/0
Router(config-if)#ip address 192.168.4.1 255.255.255.0
Router(config-if)#no shutdown
%LINK-5-CHANGED: Interface Serial0/0/0, changed state to up
%LINEPROTO-5-UPDOWN: Line protocol on Interface Serial0/0/0,
changed state to up
Router(config-if)#exit
Router(config)#router rip
Router(config-router)#network 192.168.3.0
Router(config-router)#network 192.168.4.0
Router(config-router)#exit
Router(config)#exit
Router#
%SYS-5-CONFIG_I: Configured from console by console
Router#show ip protocols
Routing Protocol is "rip"
Sending updates every 30 seconds, next due in 19 seconds
Invalid after 180 seconds, hold down 180, flushed after 240
Outgoing update filter list for all interfaces is not set
Incoming update filter list for all interfaces is not set
Redistributing: rip
Default version control: send version 1, receive any version
Interface Send Recv Triggered RIP Key-chain
Serial0/0/0 1 2 1
Automatic network summarization is in effect
Maximum path: 4
Routing for Networks:
192.168.3.0
192.168.4.0
Passive Interface(s):
Routing Information Sources:
Gateway Distance Last Update
Distance: (default is 120)
Router#
Conclusion :-
Thus, we have simulate the WAN(RIP) network using packet
tracer/NS3.
======================
Grp B 4].
======================
/*-------------------------------------------------------------------------------------------------------
Group : B
Assignment no : 4
Title : Study and perform Linux networking commands emulation using Python or C++.
Batch :
Roll No :
-----------------------------------------------------------------------------------------------------------*/
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
using namespace std;
int main ()
{
int ch;
do{
cout<<endl<<"menu" << endl;
cout<<endl<<"1.hostname" <<endl;
cout<<endl<<"2.ifconfig" <<endl;
cout<<endl<<"3.traceroute" << endl;
cout<<endl<<"4.nslookup" << endl;
cout<<endl<<"5.ping" << endl;
cout<<endl<<"6.exit" << endl;
cin>>ch;
switch(ch)
{
case 1: cout<<"\n";
system("hostname"); // Give hostname of machine
break;
case 2 :
system(" ifconfig"); //This will simply list all information on all network devices currently up.
break;
case 3 :
system("traceroute www.google.com "); // displays each host that a packet travels
break; //through as it tries to reach its destination
case 4 : system(" nslookup 64.57.102.34 "); //nslookup will translate a an IP address to domain name
break;
case 5 : system(" ping 192.168.1.67"); // Way to see if a machine is up and connected to the network
break;
case 6 : cout << "exit" << endl;
break;
default :
cout << "Invalid choice" << endl;
}
}while( ch!=5);
return 0;
}
/*----------------------------------------output-----------------------------------
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$g++ netcmd.cpp -o netcmd
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$./netcmd
menu
1.hostname
2.ifconfig
3.traceroute
4.nslookup
5.ping
6.exit
1
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC
menu
1.hostname
2.ifconfig
3.traceroute
4.nslookup
5.ping
6.exit
2
eth0 Link encap:Ethernet HWaddr b8:ac:6f:bc:72:27
inet addr:192.168.1.66 Bcast:192.168.255.255 Mask:255.255.0.0
inet6 addr: fe80::baac:6fff:febc:7227/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:6034 errors:0 dropped:0 overruns:0 frame:0
TX packets:118 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:414448 (414.4 KB) TX bytes:15201 (15.2 KB)
Interrupt:18
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:65536 Metric:1
RX packets:161 errors:0 dropped:0 overruns:0 frame:0
TX packets:161 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:11399 (11.3 KB) TX bytes:11399 (11.3 KB)
vmnet1 Link encap:Ethernet HWaddr 00:50:56:c0:00:01
inet addr:172.16.170.1 Bcast:172.16.170.255 Mask:255.255.255.0
inet6 addr: fe80::250:56ff:fec0:1/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:90 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
vmnet8 Link encap:Ethernet HWaddr 00:50:56:c0:00:08
inet addr:172.16.201.1 Bcast:172.16.201.255 Mask:255.255.255.0
inet6 addr: fe80::250:56ff:fec0:8/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:88 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
menu
1.hostname
2.ifconfig
3.traceroute
4.nslookup
5.ping
6.exit
3
traceroute to www.google.com (216.58.220.36), 30 hops max, 60 byte packets
1 192.168.1.100 (192.168.1.100) 0.317 ms 0.314 ms 0.319 ms
2 * * *
3 10.81.252.78 (10.81.252.78) 2.749 ms 4.106 ms 4.103 ms
4 117.211.127.42 (117.211.127.42) 28.052 ms 28.056 ms 29.007 ms
5 218.248.181.22 (218.248.181.22) 30.000 ms 29.995 ms 28.721 ms
6 74.125.48.138 (74.125.48.138) 79.174 ms 77.384 ms 77.524 ms
7 209.85.241.52 (209.85.241.52) 42.569 ms 42.534 ms 42.550 ms
8 209.85.251.95 (209.85.251.95) 42.532 ms 42.511 ms 216.239.50.171 (216.239.50.171) 49.745 ms
9 209.85.255.43 (209.85.255.43) 49.714 ms 49.712 ms 50.172 ms
10 maa03s18-in-f4.1e100.net (216.58.220.36) 42.786 ms 46.926 ms 42.384 ms
menu
1.hostname
2.ifconfig
3.traceroute
4.nslookup
5.ping
6.exit
4
Server: 127.0.1.1
Address: 127.0.1.1#53
Non-authoritative answer:
34.102.57.64.in-addr.arpa name = slackware.com.
Authoritative answers can be found from:
menu
1.hostname
2.ifconfig
3.traceroute
4.nslookup
5.ping
6.exit
5
PING 192.168.1.67 (192.168.1.67) 56(84) bytes of data.
64 bytes from 192.168.1.67: icmp_seq=1 ttl=64 time=0.228 ms
64 bytes from 192.168.1.67: icmp_seq=2 ttl=64 time=0.128 ms
64 bytes from 192.168.1.67: icmp_seq=3 ttl=64 time=0.107 ms
64 bytes from 192.168.1.67: icmp_seq=4 ttl=64 time=0.140 ms
64 bytes from 192.168.1.67: icmp_seq=5 ttl=64 time=0.126 ms
64 bytes from 192.168.1.67: icmp_seq=6 ttl=64 time=0.130 ms
64 bytes from 192.168.1.67: icmp_seq=7 ttl=64 time=0.136 ms
64 bytes from 192.168.1.67: icmp_seq=8 ttl=64 time=0.134 ms
64 bytes from 192.168.1.67: icmp_seq=9 ttl=64 time=0.136 ms
64 bytes from 192.168.1.67: icmp_seq=10 ttl=64 time=0.124 ms
64 bytes from 192.168.1.67: icmp_seq=11 ttl=64 time=0.128 ms
64 bytes from 192.168.1.67: icmp_seq=12 ttl=64 time=0.105 ms
64 bytes from 192.168.1.67: icmp_seq=13 ttl=64 time=0.128 ms
^Z
[1]+ Stopped ./4
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
*/
======================
Grp B 5].
======================
#---------------------------------------------------------------------------#
Group B
Assignment 05
Aim:Write FTP/Telnet program using socket programming for TCP using C++
Roll_No:
#--------------------------------------------------------------------------#
//FTPSERVER
import java.net.*;
import java.io.*;
import java.util.*;
public class FTPServer
{
public static void main(String args[]) throws Exception
{
ServerSocket soc=new ServerSocket(5217);
System.out.println("FTP Server Started on Port Number 5217");
while(true)
{
System.out.println("Waiting for Connection ...");
transferfile t=new transferfile(soc.accept());
}
}
}
class transferfile extends Thread
{
Socket ClientSoc;
DataInputStream din;
DataOutputStream dout;
transferfile(Socket soc)
{
try
{
ClientSoc=soc;
din=new DataInputStream(ClientSoc.getInputStream());
dout=new DataOutputStream(ClientSoc.getOutputStream());
System.out.println("FTP Client Connected ...");
start();
}
catch(Exception ex)
{
}
}
void SendFile() throws Exception
{
String filename=din.readUTF();
File f=new File(filename);
if(!f.exists())
{
dout.writeUTF("File Not Found");
return;
}
else
{
dout.writeUTF("READY");
FileInputStream fin=new FileInputStream(f);
int ch;
do
{
ch=fin.read();
dout.writeUTF(String.valueOf(ch));
}
while(ch!=-1);
fin.close();
dout.writeUTF("File Receive Successfully");
}
}
void ReceiveFile() throws Exception
{
String filename=din.readUTF();
if(filename.compareTo("File not found")==0)
{
return;
}
File f=new File(filename);
String option;
if(f.exists())
{
dout.writeUTF("File Already Exists");
option=din.readUTF();
}
else
{
dout.writeUTF("SendFile");
option="Y";
}
if(option.compareTo("Y")==0)
{
FileOutputStream fout=new FileOutputStream(f);
int ch;
String temp;
do
{
temp=din.readUTF();
ch=Integer.parseInt(temp);
if(ch!=-1)
{
fout.write(ch);
}
}while(ch!=-1);
fout.close();
dout.writeUTF("File Send Successfully");
}
else
{
return;
}
}
public void run()
{
while(true)
{
try
{
System.out.println("Waiting for Command ...");
String Command=din.readUTF();
if(Command.compareTo("GET")==0)
{
System.out.println("\tGET Command Received ...");
SendFile();
continue;
}
else if(Command.compareTo("SEND")==0)
{
System.out.println("\tSEND Command Receiced ...");
ReceiveFile();
continue;
}
else if(Command.compareTo("DISCONNECT")==0)
{
System.out.println("\tDisconnect Command Received ...");
System.exit(1);
}
}
catch(Exception ex)
{
}
}
}
}
___________________________________________________________________
OUTPUT
___________________________________________________________________
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$javac FTPServer.java
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$java FTPServer
FTP Server Started on Port Number 5217
Waiting for Connection ...
FTP Client Connected ...
Waiting for Connection ...
Waiting for Command ...
SEND Command Receiced ...
Waiting for Command ...
GET Command Received ...
Waiting for Command ...
Disconnect Command Received ...
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
//FTPCLIENT
import java.net.*;
import java.io.*;
import java.util.*;
class FTPClient
{
public static void main(String args[]) throws Exception
{
Socket soc=new Socket("127.0.0.1",5217);
transferfileClient t=new transferfileClient(soc);
t.displayMenu();
}
}
class transferfileClient
{
Socket ClientSoc;
DataInputStream din;
DataOutputStream dout;
BufferedReader br;
transferfileClient(Socket soc)
{
try
{
ClientSoc=soc;
din=new DataInputStream(ClientSoc.getInputStream());
dout=new DataOutputStream(ClientSoc.getOutputStream());
br=new BufferedReader(new InputStreamReader(System.in));
}
catch(Exception ex)
{
}
}
void SendFile() throws Exception
{
String filename;
System.out.print("Enter File Name :");
filename=br.readLine();
File f=new File(filename);
if(!f.exists())
{
System.out.println("File not Exists...");
dout.writeUTF("File not found");
return;
}
dout.writeUTF(filename);
String msgFromServer=din.readUTF();
if(msgFromServer.compareTo("File Already Exists")==0)
{
String Option;
System.out.println("File Already Exists. Want to OverWrite (Y/N) ?");
Option=br.readLine();
if(Option=="Y")
{
dout.writeUTF("Y");
}
else
{
dout.writeUTF("N");
return;
}
}
System.out.println("Sending File ...");
FileInputStream fin=new FileInputStream(f);
int ch;
do
{
ch=fin.read();
dout.writeUTF(String.valueOf(ch));
}
while(ch!=-1);
fin.close();
System.out.println(din.readUTF());
}
void ReceiveFile() throws Exception
{
String fileName;
System.out.print("Enter File Name :");
fileName=br.readLine();
dout.writeUTF(fileName);
String msgFromServer=din.readUTF();
if(msgFromServer.compareTo("File Not Found")==0)
{
System.out.println("File not found on Server ...");
return;
}
else if(msgFromServer.compareTo("READY")==0)
{
System.out.println("Receiving File ...");
File f=new File(fileName);
if(f.exists())
{
String Option;
System.out.println("File Already Exists. Want to OverWrite (Y/N) ?");
Option=br.readLine();
if(Option=="N")
{
dout.flush();
return;
}
}
FileOutputStream fout=new FileOutputStream(f);
int ch;
String temp;
do
{
temp=din.readUTF();
ch=Integer.parseInt(temp);
if(ch!=-1)
{
fout.write(ch);
}
}while(ch!=-1);
fout.close();
System.out.println(din.readUTF());
}
}
public void displayMenu() throws Exception
{
while(true)
{
System.out.println("[ MENU ]");
System.out.println("1. Send File");
System.out.println("2. Receive File");
System.out.println("3. Exit");
System.out.print("\nEnter Choice :");
int choice;
choice=Integer.parseInt(br.readLine());
if(choice==1)
{
dout.writeUTF("SEND");
SendFile();
}
else if(choice==2)
{
dout.writeUTF("GET");
ReceiveFile();
}
else
{
dout.writeUTF("DISCONNECT");
System.exit(1);
}
}
}
}
___________________________________________________
OUTPUT
___________________________________________________
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$ javac FTPClient.java
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$ java FTPClient
[ MENU ]
1. Send File
2. Receive File
3. Exit
Enter Choice :1
Enter File Name :file1.txt
Sending File ...
File Send Successfully
[ MENU ]
1. Send File
2. Receive File
3. Exit
Enter Choice :2
Enter File Name :file2.txt
Receiving File ...
File Receive Successfully
[ MENU ]
1. Send File
2. Receive File
3. Exit
Enter Choice :3
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
======================
Grp B 6].
======================
/*================================================================
Assignment No.B-6
Title :Write TFTP
program using socket
programming for UDP
using C++
Batch :
Roll no:-
=============================================================*/
//Server side
Input:
import java.io.*;
import java.net.*;
class TFTPServer
{
public static void main(String args[]) throws
Exception
{
DatagramSocket serverSocket = new
DatagramSocket(5000);
File toSend = new
File("toSend.txt");
byte[] sendData = new byte[1024];
byte[] receiveData = new
byte[1024];
FileInputStream fis = new
FileInputStream(toSend);
BufferedInputStream bis = new
BufferedInputStream(fis);
bis.read(sendData,0,(int)toSend.length());
while(true)
{
DatagramPacket receivePacket
=
new
DatagramPacket(receiveData, receiveData.length);
serverSocket.receive(receivePacket);
InetAddress IPAddress =
receivePacket.getAddress();
int port =
receivePacket.getPort();
DatagramPacket sendPacket =
new
DatagramPacket(sendData, sendData.length, IPAddress, port);
serverSocket.send(sendPacket);
}
}
}
Input File:
toSend.txt
Contents of file:
Hello... PVGCOE...
OUTPUT:
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
cd Desktop/server/
gescoe@gescoe-Vostro-230:~/Desktop/server$
javac
TFTPServer.java
gescoe@gescoe-Vostro-230:~/Desktop/server$
java
TFTPServer
//Client side
Input:
import java.io.*;
import java.net.*;
class TFTPClient
{
public static void main(String args[])
throws
Exception
{
File toReceive = new
File("received.txt");
FileOutputStream fos = new
FileOutputStream(toReceive);
BufferedOutputStream bos = new
BufferedOutputStream(fos);
DatagramSocket clientSocket = new
DatagramSocket();
InetAddress IPAddress =
InetAddress.getByName("localhost");
byte[] sendData = new byte[1024];
byte[] receiveData = new byte[1024];
DatagramPacket sendPacket = new
DatagramPacket(sendData,
sendData.length, IPAddress, 5000);
DatagramPacket receivePacket = new
DatagramPacket(receiveData,
receiveData.length);
clientSocket.send(sendPacket);
clientSocket.receive(receivePacket);
receiveData =
receivePacket.getData();
String sent = new String(receiveData);
fos.write(receiveData,0,sent.length());
System.out.println("File received
from server, with the
contents:\n"+sent);
}
}
Outsput file:
received.txt
Contents of file:
Hello... PVGCOE...
Output:
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
javac TFTPClient.java
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
java TFTPClient
File received from
server, with the contents:
Hello... PVGCOE...
======================
Grp B 9].
======================
/*=======================================================================
Assignment :- B-9
Title :- Implementation of
Concurrent Text Conferencing application using Python or Java.
Roll No :-
=======================================================================*/
/* Server */
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.net.SocketAddress;
import java.util.ArrayList;
public class Main
{
public static void main(String[] args) throws IOException
{
try
{
final int PORT = 5677; //SET NEW CONSTANT VARIABLE: PORT
ServerSocket server = new ServerSocket(PORT); //SET PORT NUMBER
System.out.println("Waiting for clients..."); //AT THE
START PRINT THIS
while (true)//WHILE THE PROGRAM IS RUNNING
{
Socket s = server.accept(); //ACCEPT SOCKETS(CLIENTS) TRYING TO
CONNECT
System.out.println("Client connected from " +
s.getLocalAddress()
.getHostName()); // TELL THEM THAT THE CLIENT CONNECTED
Client chat = new Client(s); //CREATE A NEW CLIENT OBJECT
Thread t = new Thread(chat); //MAKE A NEW THREAD
t.start(); //START THE THREAD
}
}
catch (Exception e)
{
System.out.println("An error occured."); //IF AN ERROR
OCCURED THEN PRINT IT
e.printStackTrace();
}
}
}
/* Client */
import java.io.PrintWriter;
import java.net.Socket;
import java.util.Scanner;
public class Client implements Runnable
{
private Socket socket; //SOCKET INSTANCE VARIABLE
public Client(Socket s)
{
socket = s; //INSTANTIATE THE SOCKET
}
@Override
public void run() //(IMPLEMENTED FROM THE RUNNABLE INTERFACE)
{
try //HAVE TO HAVE THIS FOR THE in AND out VARIABLES
{
Scanner in = new Scanner(socket.getInputStream());
//GET THE SOCKETS INPUT STREAM (THE STREAM THAT YOU
WILL GET WHAT THEY TYPE FROM)
PrintWriter out = new PrintWriter(socket.
getOutputStream());
//GET THE SOCKETS OUTPUT STREAM (THE STREAM YOU WILL SEND
INFORMATION TO THEM FROM)
while (true)//WHILE THE PROGRAM IS RUNNING
{
if (in.hasNext())
{
String input = in.nextLine();
//IF THERE IS INPUT THEN MAKE A NEW VARIABLE input AND READ WHAT
THEY TYPED
System.out.println("Client Said: " + input)
//PRINT IT OUT TO THE SCREEN
out.println("You Said: " + input);
//RESEND IT TO THE CLIENT
out.flush(); //FLUSH THE STREAM
}
}
}
catch (Exception e)
{
e.printStackTrace();
//MOST LIKELY THERE WONT BE AN ERROR BUT ITS GOOD TO CATCH
}
}
}
/* OUTPUT
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$javac Main.java
Client.java
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$java Main Client
Waiting for clients...
Client connected from localhost
Client Said: hii
hi
Client Said: hello
Client Said: assignment 3
*/
======================
Grp B 10].
======================
*================================================================
Assignment No.B(10)
Title :Implementation of
Concurrent Proxy server
program using
Python or Java.
Roll No. :
Batch :
=============================================================*/
import select
import socket
import sys
import os
import fcntl
import logging
USAGE = "usage:
python simpleproxy.py
proxyhost:proxyport
desthost:destport"
class
ProxyConnection(object):
# enable a buffer on connections with this
many bytes
MAX_BUFFER_SIZE = 1024
# ProxyConnection class forwards data
between a client and a
destination socket
def
__init__(self,proxyserver,listensock,servaddr):
self.proxyserver = proxyserver
self.servaddr = servaddr # the server
address
#
open client and server sockets
self.clisock, self.cliaddr =
listensock.accept() #
client socket and address
self.clisock.setblocking(0)
self.servsock =
socket.socket(socket.AF_INET,
socket.SOCK_STREAM) # server socket
self.servsock.setblocking(0)
# buffers for data recieved from a
socket
self.buffers = { self.clisock:bytes(),
self.servsock:bytes()
}
self.connected = False # is the
server socket connected
yet
# register sockets with server and
enable read operations
self.proxyserver.registerSocket(self.clisock,self)
self.proxyserver.registerSocket(self.servsock,self)
self.proxyserver.activateRead(self.clisock)
self.proxyserver.activateRead(self.servsock)
# return the socket on the "other
end"
of the connection
def other(self,socket):
if socket == self.clisock:
return self.servsock
else:
return self.clisock
# connect to the server connection
def connect(self):
# have to use socket's connect_ex
because the connect is
asynchronous and won't suceed immediately
self.servsock.connect_ex(self.servaddr)
# read data in from a socket
def readfrom(self,s):
# is the connection being opened by the
server responding to the
connect?
if s == self.servsock and not
self.connected:
self.proxyserver.connection_count
+=
1
logging.getLogger("simpleproxy")
\
.info("opened connection
from %s, connection
count now
%d"%(str(self.cliaddr),self.proxyserver.connection_count))
self.connected = True
return
# read from the socket
capacity =
ProxyConnection.MAX_BUFFER_SIZE
- len(self.buffers[s])
try:
data = s.recv(capacity)
except Exception as ex:
data = ""
# if the read failed, close the socket
(this happens when the
client or server closes the connection)
if len(data) == 0:
self.close()
return
# buffer the read data
self.buffers[s] += data
self.proxyserver.activateWrite(self.other(s))
# disable further reads if buffer is
full
capacity -= len(data)
if capacity <= 0:
self.proxyserver.deactivateRead(s)
# write data out to a socket
def writeto(self,s):
# get the buffer containing data to be
read
buf = self.buffers[self.other(s)]
# write it to the socket
written = s.send(buf)
# remove written data from the buffer
buf = buf[written:]
self.buffers[self.other(s)] = buf
# disable further writes if the buffer
is empty
if len(buf) == 0:
self.proxyserver.deactivateWrite(s)
# enable reads if data was written
if written:
self.proxyserver.activateRead(self.other(s))
# close the connection sockets
def close(self):
for sock in
[self.clisock,self.servsock]:
if sock:
self.proxyserver.deactivateRead(sock)
self.proxyserver.deactivateWrite(sock)
sock.close()
self.proxyserver.unregisterSocket(sock,self)
self.proxyserver.connection_count -= 1
logging.getLogger("simpleproxy")
\
.info("closed connection
from %s, connection
count now
%d"%(self.cliaddr,self.proxyserver.connection_count))
class
ProxyServer(object):
def
__init__(self,host,port,serverhost,serverport):
self.address = (host,port)
self.server = (serverhost,serverport)
self.listensock =
socket.socket(socket.AF_INET,
socket.SOCK_STREAM)
self.listensock.setsockopt(socket.SOL_SOCKET,
socket.SO_REUSEADDR,
1)
self.listensock.bind(self.address)
self.listensock.listen(5)
self.connections = {} #
map from a socket to a
ProxyConnection
self.readsockets = [] #
all sockets which can be
read
self.writesockets = [] #
all sockets which can be
written
self.allsockets = [self.listensock] #
all opened sockets
self.connection_count = 0 #
count of all active
connections
def run(self):
loop = 0
while True:
# block until there is some
activity
on one of the sockets,
timeout every 60 seconds by default
r, w, e = select.select(
[self.listensock]+self.readsockets,
self.writesockets,
self.allsockets,
60)
loop += 1
# handle any reads
for s in r:
if s is self.listensock:
# open a new connection
self.open()
else:
if s in self.connections:
self.connections[s].readfrom(s)
# handle any writes
for s in w:
if s in self.connections:
self.connections[s].writeto(s)
# handle errors (close connections)
for s in e:
if s in self.connections:
self.connections[s].close()
self.sock.close()
self.sock = None
def activateRead(self,sock):
if not sock in self.readsockets:
self.readsockets.append(sock)
def deactivateRead(self,sock):
if sock in self.readsockets:
self.readsockets.remove(sock)
def activateWrite(self,sock):
if not sock in self.writesockets:
self.writesockets.append(sock)
def deactivateWrite(self,sock):
if sock in self.writesockets:
self.writesockets.remove(sock)
def registerSocket(self,sock,conn):
self.connections[sock] = conn
self.allsockets.append(sock)
def unregisterSocket(self,sock,conn):
del self.connections[sock]
self.allsockets.remove(sock)
# open a new proxy connection from the
listening socket
def open(self):
conn =
ProxyConnection(self,self.listensock,self.server)
conn.connect()
if __name__ ==
'__main__':
try:
proxy =
sys.argv[1].split(":")
dest = sys.argv[2].split(":")
proxyhost = proxy[0]
proxyport = int(proxy[1])
serverhost = dest[0]
serverport = int(dest[1])
except:
print(USAGE)
sys.exit(-1)
logger = logging.getLogger('simpleproxy')
logger.setLevel(logging.INFO)
hdlr = logging.StreamHandler()
hdlr.setLevel(logging.INFO)
hdlr.setFormatter(logging.Formatter('%(asctime)s
- %(name)s -
%(levelname)s -
%(message)s'))
logger.addHandler(hdlr)
server =
ProxyServer(proxyhost,proxyport,serverhost,serverport)
server.run()
OUTPUT:
Server:
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$python
simpleproxy.py
localhost:8080 localhost:23
2015-03-19 14:07:18,155
- simpleproxy - INFO -
opened connection from
('127.0.0.1', 44167), connection count now 1
2015-03-19 14:08:00,242
- simpleproxy - INFO -
closed connection from
('127.0.0.1', 44167), connection count now 0
Client:
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
telnet localhost
8080
Trying 127.0.0.1...
Connected to localhost.
Escape character is
'^]'.
Ubuntu 14.04 LTS
gescoe-Vostro-230 login:
gescoe
Password:
Last login: Thu Mar 19
14:06:11 IST 2015 from
localhost on pts/23
Welcome to Ubuntu 14.04
LTS (GNU/Linux
3.13.0-24-generic
x86_64)
* Documentation: https://help.ubuntu.com/
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
exit
logout
Connection closed by
foreign host.
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
======================
Grp B 11].
======================
*================================================================
Assignment No.B(11)
Title :Implementation of
Multithreaded web server. Check the functionality of web server in
LAN and through the ADSL
router using NAT.
Roll No. :
Batch :
=============================================================*/
//Server2.java
import java.io.*;
import java.net.*;
public class Server2 {
public static void
main(String args[]) {
int port = 6789;
Server2 server = new
Server2( port );
server.startServer();
}
// declare a server
socket and a client socket for the server;
// declare the number of
connections
ServerSocket echoServer
= null;
Socket clientSocket =
null;
int numConnections = 0;
int port;
public Server2( int port
) {
this.port = port;
}
public void stopServer()
{
System.out.println(
"Server cleaning up." );
System.exit(0);
}
public void
startServer() {
// Try to open a server
socket on the given port
// Note that we can't
choose a port less than 1024 if we are not
// privileged users
(root)
try {
echoServer = new
ServerSocket(port);
}
catch (IOException e) {
System.out.println(e);
}
System.out.println(
"Server is started and is waiting for connections." );
System.out.println(
"With multi-threading, multiple connections are allowed." );
System.out.println(
"Any client can send -1 to stop the server." );
// Whenever a connection
is received, start a new thread to process the connection
// and wait for the next
connection.
while ( true ) {
try {
clientSocket =
echoServer.accept();
numConnections ++;
Server2Connection
oneconnection = new Server2Connection(clientSocket, numConnections, this);
new
Thread(oneconnection).start();
}
catch (IOException e) {
System.out.println(e);
}
}
}
}
class Server2Connection
implements Runnable {
BufferedReader is;
PrintStream os;
Socket clientSocket;
int id;
Server2 server;
public Server2Connection(Socket
clientSocket, int id, Server2 server) {
this.clientSocket =
clientSocket;
this.id = id;
this.server = server;
System.out.println(
"Connection " + id + " established with: " + clientSocket
);
try {
is = new
BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
os = new
PrintStream(clientSocket.getOutputStream());
} catch (IOException e)
{
System.out.println(e);
}
}
public void run() {
String line;
try {
boolean serverStop =
false;
while (true) {
line = is.readLine();
System.out.println(
"Received " + line + " from Connection " + id +
"." );
int n =
Integer.parseInt(line);
if ( n == -1 ) {
serverStop = true;
break;
}
if ( n == 0 ) break;
os.println(""
+ n*n );
}
System.out.println(
"Connection " + id + " closed." );
is.close();
os.close();
clientSocket.close();
if ( serverStop )
server.stopServer();
} catch (IOException e)
{
System.out.println(e);
}
}
}
//Client.java
import java.io.*;
import java.net.*;
public class Client {
public static void
main(String[] args) {
String hostname =
"192.168.1.81";
int port = 6789;
// declaration section:
// clientSocket: our
client socket
// os: output stream
// is: input stream
Socket clientSocket =
null;
DataOutputStream os =
null;
BufferedReader is =
null;
// Initialization
section:
// Try to open a socket
on the given port
// Try to open input and
output streams
try {
clientSocket = new
Socket(hostname, port);
os = new
DataOutputStream(clientSocket.getOutputStream());
is = new
BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
} catch
(UnknownHostException e) {
System.err.println("Don't
know about host: " + hostname);
} catch (IOException e)
{
System.err.println("Couldn't
get I/O for the connection to: " + hostname);
}
// If everything has
been initialized then we want to write some data
// to the socket we have
opened a connection to on the given port
if (clientSocket == null
|| os == null || is == null) {
System.err.println(
"Something is wrong. One variable is null." );
return;
}
try {
while ( true ) {
System.out.print(
"Enter an integer (0 to stop connection, -1 to stop server): " );
BufferedReader br = new
BufferedReader(new InputStreamReader(System.in));
String keyboardInput =
br.readLine();
os.writeBytes(
keyboardInput + "\n" );
int n =
Integer.parseInt( keyboardInput );
if ( n == 0 || n == -1 )
{
break;
}
String responseLine =
is.readLine();
System.out.println("Server
returns its square as: " + responseLine);
}
// clean up:
// close the output
stream
// close the input
stream
// close the socket
os.close();
is.close();
clientSocket.close();
} catch
(UnknownHostException e) {
System.err.println("Trying
to connect to unknown host: " + e);
} catch (IOException e)
{
System.err.println("IOException:
" + e);
}
}
}
OUTPUT:-
ON SERVER:
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
cd Desktop/kd
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~/Desktop/kd$
javac Server2.java
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~/Desktop/kd$
java Server2
Server is started and is
waiting for connections.
With multi-threading,
multiple connections are allowed.
Any client can send -1
to stop the server.
Connection 1 established
with: Socket[addr=/192.168.1.80,port=43452,localport=6789]
Received 5 from
Connection 1.
Received 2 from
Connection 1.
Connection 2 established
with: Socket[addr=/192.168.1.74,port=33825,localport=6789]
Received 2 from Connection
2.
Connection 3 established
with: Socket[addr=/192.168.1.79,port=60690,localport=6789]
Received 654 from
Connection 3.
Received -1 from
Connection 1.
Connection 1 closed.
Server cleaning up.
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~/Desktop/kd$
Client 1
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
cd Desktop/
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$javac
Client.java
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$java
Client
Enter an integer (0 to
stop connection, -1 to stop server): 5
Server returns its
square as: 25
Enter an integer (0 to
stop connection, -1 to stop server): 2
Server returns its
square as: 4
Enter an integer (0 to
stop connection, -1 to stop server): -1
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~/Desktop$
Client 2
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
cd Desktop/
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$javac
Client.java
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$java
Client
Enter an integer (0 to
stop connection, -1 to stop server): 2
Server returns its
square as: 4
Enter an integer (0 to
stop connection, -1 to stop server): 9
Server returns its
square as: null
Enter an integer (0 to
stop connection, -1 to stop server):
Client 3
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
cd Desktop/
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~/Desktop$
javac Client.java
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~/Desktop$
java Client
Enter an integer (0 to
stop connection, -1 to stop server): 654
Server returns its
square as: 427716
Enter an integer (0 to
stop connection, -1 to stop server): 5
Server returns its
square as: null
Enter an integer (0 to
stop connection, -1 to stop server):
======================
Grp B 12].
======================
*================================================================
Assignment No.B(12)
Title :Implement a
program for remote print manager to print documents on remote printer. (IP
based printer) using
Python
Roll No. :
Batch :
=============================================================*/
#manager demo.py
from multiprocessing
import Process, Queue, managers
from
multiprocessing.managers import SyncManager
import time
class MyObject():
def __init__( self, p, f
):
self.parameter = p
self.processor_function
= f
class MyServer():
def __init__(self,
server_info, obj):
print '=== Launching
Server ... ====='
(ip, port, pw) =
server_info
self.object = obj
#Parameters for task processing
#Define queues
self._process_queue =
Queue() #Queue of tasks to be processed
self._results_queue =
Queue() #Queue of processed tasks to be stored
#Set up IS_Manager class
and register server functions
class
IS_Manager(managers.BaseManager): pass
IS_Manager.register('get_processQ',
callable=self.get_process_queue)
IS_Manager.register('get_resultsQ',
callable=self.get_results_queue)
IS_Manager.register('get_object',
callable=self.get_object)
#Initialize manager and
server
self.manager =
IS_Manager(address=(ip, port), authkey=pw)
self.server =
self.manager.get_server()
self.server_process =
Process( target=self.server.serve_forever )
self.server_process.start()
def
get_process_queue(self): return self._process_queue
def
get_results_queue(self): return self._results_queue
def get_object(self):
return self.object
def runUntilDone(self,
task_list):
#Fill the initial queue
for t in task_list:
self._process_queue.put(t)
#Main loop
total_tasks =
len(task_list)
while not
self._results_queue.qsize()==total_tasks:
time.sleep(.5)
print
self._process_queue.qsize(), '\t', self._results_queue.qsize()
if not
self._results_queue.empty():
print '\t',
self._results_queue.get()
#Do stuff
pass
class MyClient():
def __init__(self,
server_info):
(ip, port, pw) =
server_info
print '=== Launching
Client ... ====='
class IS_Manager(managers.BaseManager):
pass
IS_Manager.register('get_processQ')
IS_Manager.register('get_resultsQ')
IS_Manager.register('get_object')
#Set up manager, pool
print '\tConnecting to
server...'
manager =
IS_Manager(address=(ip, port), authkey=pw)
manager.connect()
self._process_queue =
manager.get_processQ()
self._results_queue =
manager.get_resultsQ()
self.object =
manager.get_object()
print '\tConnected.'
def
runUntilDone(self):#, parameters):
print 'Starting client
main loop...'
#Main loop
while 1:
if self._process_queue.empty():
print 'I\'m bored here!'
time.sleep(.5)
else:
task =
self._process_queue.get()
print task, '\t',
self.object.processor_function( task, self.object.parameter )
print 'Client process is
quitting. Bye!'
self._clients_queue.get()
======================
Grp B 13].
======================
/*========================================================
Assignment No.B(13)
Title :Implementation of
sliding window protocol using C++.
Roll No. :
Batch :
=========================================================*/
#include<iostream>
using namespace std;
int main()
{
char sender[50],
receiver[50];
int i,winsize;
cout<<"\n
ENTER THE WINDOWS SIZE : ";
cin>> winsize;
cout<<"\n
SENDER WINDOW IS EXPANDED TO STORE MESSAGE OR
WINDOW";
cout<<"\n
ENTER THE DATA TO BE SENT: ";
cin>>sender;
for(i=0;i<winsize;i++)
receiver[i] = sender[i];
receiver[i] = NULL;
cout<<"\n
MESSAGE SEND BY THE SENDER:\n";
cout<<sender;
cout<<"\n
WINDOW SIZE OF RECEIVER IS EXPANDED\n";
cout<<"\n
ACKNOWLEDGEMENT FROM RECEIVER \n";
for(i=0;i<winsize;i++);
cout<<"\n
ACK:"<<i;
cout<<"\n
MESSAGE RECEIVED BY RECEIVER IS : ";
cout<<receiver;
cout<<"\n
WINDOW SIZE OF RECEIVER IS SHRINKED \n";
return 0;
}
output;-
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
cd Desktop/
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$g++
p.cpp -o p
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$./p
ENTER THE WINDOWS SIZE :
3
SENDER WINDOW IS
EXPANDED TO STORE MESSAGE OR WINDOW
ENTER THE DATA TO BE
SENT: hello
MESSAGE SEND BY THE
SENDER:
hello
WINDOW SIZE OF RECEIVER
IS EXPANDED
ACKNOWLEDGEMENT FROM
RECEIVER
ACK:3
MESSAGE RECEIVED BY
RECEIVER IS : hel
WINDOW SIZE OF RECEIVER
IS SHRINKED
======================
Grp B 14].
======================
/*========================================================
Assignment No.B(14)
Title : Implementation
of distance vector routing algorithm using C++
Roll No. :
Batch :
=========================================================*/
#include<stdio.h>
struct node
{
unsigned dist[20];
unsigned from[20];
}rt[10];
int main()
{
int dmat[20][20];
int n,i,j,k,count=0;
printf("\nEnter the
number of nodes : ");
scanf("%d",&n);
printf("\nEnter the
cost matrix :\n");
for(i=0;i<n;i++)
for(j=0;j<n;j++)
{
scanf("%d",&dmat[i][j]);
dmat[i][i]=0;
rt[i].dist[j]=dmat[i][j];
rt[i].from[j]=j;
}
do
{
count=0;
for(i=0;i<n;i++)
for(j=0;j<n;j++)
for(k=0;k<n;k++)
if(rt[i].dist[j]>dmat[i][k]+rt[k].dist[j])
{
rt[i].dist[j]=rt[i].dist[k]+rt[k].dist[j];
rt[i].from[j]=k;
count++;
}
}while(count!=0);
for(i=0;i<n;i++)
{
printf("\n\nState
value for router %d is \n",i+1);
for(j=0;j<n;j++)
{
printf("\t\nnode %d
via %d Distance%d",j+1,rt[i].from[j]+1,rt[i].dist[j]);
}
}
printf("\n\n");
}
Output:-
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
cd Desktop
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$g++
router.cpp -o router
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$./router
Enter the number of
nodes : 4
Enter the cost matrix :
3 7 4 9
1 5 2 7
6 7 3 7
1 5 3 2
State value for router 1
is
node 1 via 1 Distance0
node 2 via 2 Distance7
node 3 via 3 Distance4
node 4 via 4 Distance9
State value for router 2
is
node 1 via 1 Distance1
node 2 via 2 Distance0
node 3 via 3 Distance2
node 4 via 4 Distance7
State value for router 3
is
node 1 via 1 Distance6
node 2 via 2 Distance7
node 3 via 3 Distance0
node 4 via 4 Distance7
State value for router 4
is
node 1 via 1 Distance1
node 2 via 2 Distance5
node 3 via 3 Distance3
node 4 via 4 Distance0
======================
Grp B 16].
======================
\*----------------------------------------------------------------------------------------------------------------------
Assignment :- B-16
Title :- Configure and setup network with optical router.
Roll_No. :-
------------------------------------------------------------------------------------------------------------------------*/
Title :-
Configure and setup network
with optical router.
Pre-requisites :-
·
D-Link Router.
·
Lan Connectivity.
Objective :-
To Setting up the network with optical router.
Index Terms :-
Optical Router :-
Optical Routing is a novel method of creating transparent optical
connections between network nodes using a flow-based approach. An IP flow is a
collection of IP packets going from the same source to
the same destination: the exchange of IP packets is the mechanism that allows
the transport of information over the Internet.
Currently a packet has to traverse a certain number of routers,
before reaching its destination and the network routers must analyze each
packet and forward it towards the direction of the destination node. However
since a flow is defined as a sequence of packets going from the same source to
the same destination, if the router recognises the flow it could create a
short-cut by creating a “switched” connection allowing all the packets
belonging to the same IP flow to proceed directly towards the correct direction
without being analyzed one after the other. This general idea is known as IP
switching.
If the shortcut however occurs at an optical level, the process
becomes Optical IP Switching. The advantage of OIS comes from the fact that
today packets are transmitted optically between two points but at each routing
station they have
to be converted into electrical signal, routed and converted back
into optical to
continue their travel over the optical fiber. If instead the
router is able to recognise a flow, it could create a shortcut (“cut-through
connection”) directly at the optical level, and all the packets belonging to
the same flow could be directed to the right destination without the
optical-to-electrical conversion process. This would save time, energy, memory
and processing resources on the router.
A basic implementation of the OIS concept sees an optical router
that monitors IP traffic and if a flow appears with specific characteristics
the router establishes an optical cut-through path between its upstream and
downstream neighbours, requesting the upstream node to place all the packets
belonging to the flow into the new path. The newly generated trail bypasses the
IP layer of the router, as the packets transparently flow from the upstream to
the downstream neighbour. Following a similar procedure the path can then be
extended to more than three nodes, but this decision is always autonomously
taken by each router and depends on the traffic encountered and on the
resources locally available. Since an optical link however can carry several
gigabits of data per second, it may be difficult
to find a flow that alone can exploit the bandwidth offered by an
optical trail. For this reason, aggregating more IP flows into the same
dedicated path is essential for the performance of an OIS network. The
aggregation introduces a trade-off between the number of IP flows that can be
aggregated together and the length of the optical trail that accommodates them.
In order to achieve good performance only optical flows sharing a significant
amount of network hops should be aggregated into the same path. A core node
implementing optical IP switching must be endowed with electrical processing
and memory resources (as a standard IP router), a variable number of optical
transceivers and an optical switching element (usually a MEMS based device). An edge node instead
does not need an optical switching device because it could only function as
source or destination of the optical flow.
The control protocol nearest to OIS is probably GMPLS, which is being standardized by the IETF. GMPLS aims at creating end-to-end
connections after an explicit request from a customer or a network engineering
service. This constitutes the main difference with OIS where the optical trials
are automatically triggered by the encountered traffic; they are initially
generated between three adjacent nodes, and then extended following a
distributed decision.
Nowadays, wireless networks are widely applied in
workplace or at home. It does bring a lot of convenience in internet access.
However, it’s a little bit tricky to set up a wireless network, particularly
for someone who does this for the first time. This article provides
instructions on how to setup a wireless environment. This instruction is based
on D-Link that is a portable and stable wireless router.
Step :- 1
Get to know your router.
·
LAN ports (1-4): connect devices such as computers.
·
Internet port: connect cable or DSL modem.
·
USB: can be used to connect a USB flash drive.
·
Reset button: restore the router to its default settings.
·
Power receptor port: connect supplied power adapter.
Step :- 2
Get devices connected. Turn the power off on your router (D-Link) and modem (cable or DSL). Plug an Ethernet cable into the Internet port on the router, and plug the other end into the Ethernet port on your modem.Plug another Ethernet cable into one of the four LAN ports on the router, and plug the other end into the Ethernet port on your computer. Turn on the power on router and modem.
Step :- 3
Connect to configuration utility. Open
Internet Explorer and input the IP address of your router. In the login window,
select admin as user name and leave password blank by default. Press log in to
enter the web-based configuration utility.
Step :- 4
Configure internet connection. In
the configuration utility, click the SETUP menu on the top, and the INTERNET
menu on the left. Then click Internet Connection Setup Wizard to configure
internet connection for router.
Step :- 5
Following the wizard to configure the internet
connection.There will be 5 steps included in the wizard.
·
Set a new password for Admin user.
·
Select appropriate time zone for your location.
·
Select internet connection type. Here select DHCP
Connection (Dynamic IP Address).
·
Clone Your PC’s MAC Address.
·
Save settings and reboot the router.After rebooting, the router
should be able to access the internet.
Step :- 6
Launch wireless setting. Log
into configuration utility again.Click the SETUP menu on the top, and the
WIRELESS SETTING menu on the left,then click Manual Wireless Network Setup. The
wireless setting window will appear.
Step :- 7
Configure the wireless settings. After this step, the router will be ready for wireless
client to connect.
·
Wireless network name (SSID): enter a name for the wireless
network. This name will be used in wireless client to connect the router.
·
Security mode: select WPA-personal.
·
WPA mode: select Auto (WPA or WPA2).
·
Cipher type: select AES.
·
Pre-shared key: create a key for wireless client to connect the
router.
·
Leave other settings by default and click Save Settings.
Step :- 8
Access a wireless network. In the computer which needs to access internet by the
wireless network, create a wireless connection by scanning the name (SSID) of
the wireless network and setting its connection properties. For example, in Windows
7, select Start menu->Control Panel->Network and Internet->Network and
Sharing Center->Connect to a network.
·
Security type: select WPA2-Personal.
·
Encryption type: AES.
·
Network security key: enter the pre-shared key.
·
Click OK.
Conclusion :-
Thus , we have configured and setup the network using optical
router.
======================
Grp B 17].
======================
--------------------
sine wave
--------------------
#!/usr/bin/python
import sys
import os
import time
#================================================================
DAC_D0 = (1 * 32) + 12
DAC_D1 = (1 * 32) + 13
DAC_D2 = (1 * 32) + 14
DAC_D3 = (1 * 32) + 15
DAC_D4 = (1 * 32) + 16
DAC_D5 = (1 * 32) + 17
DAC_D6 = (1 * 32) + 18
DAC_D7 = (1 * 32) + 19
#================================================================
DACBits = [
DAC_D0,
DAC_D1,
DAC_D2,
DAC_D3,
DAC_D4,
DAC_D5,
DAC_D6,
DAC_D7
]
#================================================================
SYSFS_GPIO_DIR = "/sys/class/gpio"
#================================================================
# 100 Sample Values
DAC_Table = [
255, 255, 254, 253, 251, 249, 247, 243, 240, 236, 231, 226, 221,
215, 209, 203, 196, 189,182, 175, 167, 159, 151, 144, 136, 127,
119, 111, 104, 96, 88, 80, 73, 66, 59, 52, 46, 40, 34, 29, 24,
19, 15, 12, 8, 6, 4, 2, 1, 0, -1, 0, 1, 2, 4, 6, 8, 12, 15, 19,
24, 29, 34, 40, 46, 52, 59, 66, 73, 80, 88, 96, 104, 111, 119,
127, 136, 144, 151, 159, 167, 175, 182, 189, 196, 203, 209, 215,
221, 226, 231, 236, 240, 243, 247, 249, 251, 253, 254, 255 ]
#================================================================
def DACWriteBit(pin, val):
GPIO.setup(pin, GPIO.OUT)
if (val == "1"):
GPIO.output(pin, GPIO.HIGH)
else:
GPIO.output(pin, GPIO.LOW)
return
#================================================================
def DACWrite(val):
DACWriteBit(DAC_D0, val[7])
DACWriteBit(DAC_D1, val[6])
DACWriteBit(DAC_D2, val[5])
DACWriteBit(DAC_D3, val[4])
DACWriteBit(DAC_D4, val[3])
DACWriteBit(DAC_D5, val[2])
DACWriteBit(DAC_D6, val[1])
DACWriteBit(DAC_D7, val[0])
return
#================================================================
SYSFS_GPIO_DIR = "/sys/class/gpio"
#================================================================
def gpioExport (gpio):
try:
fo = open(SYSFS_GPIO_DIR + "/export","w")
fo.write(gpio)
fo.close()
return
except IOError:
return
#================================================================
def gpioUnexport (gpio):
try:
fo = open(SYSFS_GPIO_DIR + "/unexport","w")
fo.write(gpio)
fo.close()
return
except IOError:
return
#================================================================
def gpioSetDir (gpio, flag):
try:
fo = open(SYSFS_GPIO_DIR + "/gpio" + gpio + "/direction" ,"w")
fo.write(flag)
fo.close()
return
except IOError:
return
#================================================================
def gpioSetVal (gpio, val):
try:
fo = open(SYSFS_GPIO_DIR + "/gpio" + gpio + "/value" ,"w")
fo.write(val)
fo.close()
return
except IOError:
return
#================================================================
def DACSetAll (val):
f0 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D0) + "/value" ,"w")
f1 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D1) + "/value" ,"w")
f2 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D2) + "/value" ,"w")
f3 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D3) + "/value" ,"w")
f4 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D4) + "/value" ,"w")
f5 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D5) + "/value" ,"w")
f6 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D6) + "/value" ,"w")
f7 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D7) + "/value" ,"w")
f0.write(val[7])
f1.write(val[6])
f2.write(val[5])
f3.write(val[4])
f4.write(val[3])
f5.write(val[2])
f6.write(val[1])
f7.write(val[0])
f0.close()
f1.close()
f2.close()
f3.close()
f4.close()
f5.close()
f6.close()
return
#================================================================
def DACExit (gpio):
gpioUnexport(gpio)
return
#================================================================
def DACInit (gpio):
gpioExport(gpio)
gpioSetDir(gpio, flag="out")
return
#================================================================
def DACInitAll():
for i in range(0, 8):
DACInit(str(DACBits[i]))
return
#================================================================
def DACExitAll():
for i in range(0, 8):
DACExit(str(DACBits[i]))
return
#================================================================
print "\nPython Program to generate Sine Wave using DAC\n"
print "-----------------------------------------------\n"
DACInitAll()
while(True):
for val in DAC_Table:
#print "val = %s" %val
bin_val = str('{:08b}'.format(val))
DACSetAll(bin_val)
exit()
----------------------
square wave
---------------------
#!/usr/bin/python
import sys
import time
import select
#===============================================================================
DAC_D0 = (1 * 32) + 12
DAC_D1 = (1 * 32) + 13
DAC_D2 = (1 * 32) + 14
DAC_D3 = (1 * 32) + 15
DAC_D4 = (1 * 32) + 16
DAC_D5 = (1 * 32) + 17
DAC_D6 = (1 * 32) + 18
DAC_D7 = (1 * 32) + 19
#===============================================================================
DACBits = [
DAC_D0,
DAC_D1,
DAC_D2,
DAC_D3,
DAC_D4,
DAC_D5,
DAC_D6,
DAC_D7
]
#===============================================================================
SYSFS_GPIO_DIR = "/sys/class/gpio"
#===============================================================================
def gpioExport (gpio):
try:
fo = open(SYSFS_GPIO_DIR + "/export","w")
fo.write(gpio)
fo.close()
return
except IOError:
return
#===============================================================================
def gpioUnexport (gpio):
try:
fo = open(SYSFS_GPIO_DIR + "/unexport","w")
fo.write(gpio)
fo.close()
return
except IOError:
return
#===============================================================================
def gpioSetDir (gpio, flag):
try:
fo = open(SYSFS_GPIO_DIR + "/gpio" + gpio + "/direction" ,"w")
fo.write(flag)
fo.close()
return
except IOError:
return
#===============================================================================
def gpioSetVal (gpio, val):
try:
fo = open(SYSFS_GPIO_DIR + "/gpio" + gpio + "/value" ,"w")
fo.write(val)
fo.close()
return
except IOError:
return
#===============================================================================
def DACSetAll (val):
f0 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D0) + "/value" ,"w")
f1 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D1) + "/value" ,"w")
f2 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D2) + "/value" ,"w")
f3 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D3) + "/value" ,"w")
f4 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D4) + "/value" ,"w")
f5 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D5) + "/value" ,"w")
f6 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D6) + "/value" ,"w")
f7 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D7) + "/value" ,"w")
f0.write(val[7])
f1.write(val[6])
f2.write(val[5])
f3.write(val[4])
f4.write(val[3])
f5.write(val[2])
f6.write(val[1])
f7.write(val[0])
f0.close()
f1.close()
f2.close()
f3.close()
f4.close()
f5.close()
f6.close()
return
#===============================================================================
def DACExit (gpio):
gpioUnexport(gpio)
return
#===============================================================================
def DACInit (gpio):
gpioExport(gpio)
gpioSetDir(gpio, flag="out")
return
#===============================================================================
def DACOn (gpio):
gpioSetVal(gpio, val="1")
return
#===============================================================================
def DACOff (gpio):
gpioSetVal(gpio, val="0")
return
#===============================================================================
def DACInitAll():
for i in range(0, 8):
DACInit(str(DACBits[i]))
return
#===============================================================================
def DACExitAll():
for i in range(0, 8):
DACExit(str(DACBits[i]))
return
#===============================================================================
try:
print "\nPython Program to generate Square Wave using DAC\n"
print "-----------------------------------------------\n"
DACInitAll()
while(True):
bin_val = "00000000"
DACSetAll(bin_val)
bin_val = "11111111"
DACSetAll(bin_val)
exit()
except KeyboardInterrupt:
f0.close()
f1.close()
f2.close()
f3.close()
f4.close()
f5.close()
f6.close()
f7.close()
DACExitAll()
print "Program Exit due to CTRL-C"
exit()
sys.exit(0)
======================
Grp B 18].
======================
#include<iostream>
#include<omp.h>
#include<math.h>
using namespace std;
int neg1=0,neg2=0,a=-1,b=-1;
int main()
{
float A1,B1,C1;
float A2,B2,C2;
double pole1,zero1,pole2,zero2;
cout<<"\n Enter First Equation :";
cout<<"\n Enter 'a' :";
cin>>A1;
cout<<"\n Enter 'b' :";
cin>>B1;
cout<<"\n Enter 'c' :";
cin>>C1;
cout<<"\n Enter Second Equation :";
cout<<"\n Enter 'a' :";
cin>>A2;
cout<<"\n Enter 'b' :";
cin>>B2;
cout<<"\n Enter 'c' :";
cin>>C2;
float temp1,temp2,numerator1,numerator2;
#pragma omp parallel
{
int threads= omp_get_num_threads();
// Zero calculation
if(omp_get_thread_num()==0 && a<0)
{
a++;
cout<<"\n Thread A is Caculating Zero. (TID: "<<omp_get_thread_num()<<" )";
temp1=(B1*B1)-(4*A1*C1);
if(temp1<0)
{
neg1=1;
temp1=-temp1;
}
temp1=sqrt(temp1);
numerator1=temp1;
if(!neg1)
{
zero1=(-B1+ numerator1)/2*A1;
zero2=(-B1- numerator1)/2*A1;
}
else
{
temp1=2*A1;
}
}
// Pole calculation
if(omp_get_thread_num()==1 && b<0)
{
b++;
cout<<"\n Thread B is Caculating Pole. (TID: "<<omp_get_thread_num()<<" )";
temp2=(B2*B2)-(4*A2*C2);
if(temp2<0)
{
neg2=1;
temp2=-temp2;
}
temp2=sqrt(temp2);
numerator2=temp2;
if(!neg2)
{
pole1=(-B2+ numerator2)/2*A2;
pole2=(-B2- numerator2)/2*A2;
}
else
{
temp2=2*A2;
}
}
}
if(!neg1)
{
cout<<"\n Zero 1 is :"<<zero1;
cout<<"\n Zero 2 is :"<<zero2;
}
else
{
cout<<"\n Zero 1 is : "<<-B1/temp1<<" +i "<<numerator1/temp1;
cout<<"\n Zero 2 is : "<<-B1/temp1<<" -i "<<numerator1/temp1<<endl;
}
if(!neg2)
{
cout<<"\n Pole 1 is :"<<pole1;
cout<<"\n Pole 2 is :"<<pole2<<endl;
}
else
{
cout<<"\n Pole 1 is : "<<-B2/temp2<<" +i "<<numerator2/temp2;
cout<<"\n Pole 2 is : "<<-B2/temp2<<" -i "<<numerator2/temp2<<endl;
}
return 0;
}
***********************
output
**********************
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$ g++ -fopenmp polezero.cpp -o pz
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$ ./pz
Enter First Equation :
Enter 'a' :1
Enter 'b' :1.5
Enter 'c' :0.6
Enter Second Equation :
Enter 'a' :1
Enter 'b' :-1
Enter 'c' :0.5
Thread B is Caculating Pole. (TID:
Thread A is Caculating Zero. (TID: 0 )1 )
Zero 1 is : -0.75 +i 0.193649
Zero 2 is : -0.75 -i 0.193649
Pole 1 is : 0.5 +i 0.5
Pole 2 is : 0.5 -i 0.5
ccpvg@ccpvg-HP-Compaq-4000-Pro-SFF-PC:~$
======================
Grp B 19].
======================
ASSIGNME NT NO. B19
TITLE: Construct a Square wave of programmabl e frequency and draw voltage (y-axis) and
time (x-axis) graph.
PROBLEM STATEMENT:
Write a Python program to capture signal using ARM Cortex A5/A9/M4 ADC and signal
generat or, generat e/construct a Square/Sine wave of programmabl e frequency and voltage Draw
Voltage (y-axis) and Time (x-axis ) graph.
OBJECTIVE:
1. To learn the concept of signal generation.
2. To learn the basi c concept of ADC
3. To learn the basi c about BBB/ ARM Cortex A5/A9/M4.
PRIREQUISITES:
Software: Fedora/ Ubuntu.
Hardware: Signal generator, resisters, BBB et c.
THEORY:
Square waves: Like sine waves, square waves are described in terms of period, frequency and
amplitude
Peak am plitude, V p , and peak-to-peak amplitude, V pp , are measured as you might expect.
However, the rms amplitude, V rms , is greater than that of a sine wave. Rem ember that the rms
amplitude is the DC voltage which will deliver the sam e power as the signal. If a square wave
supply is connected across a lamp, the current flows fi rst one way and then the other. The current
switches di rection but its magnitude remains the sam e. In other words, the square wave delivers
its maximum power throughout the cycle so that V rms is equal to V p . (If this is confusing, don't
worry, the rms amplitude of a square wave is not something you need to think about very often.)
Although a square wave may change very rapidly from its minimum to maximum voltage, this
change cannot be instaneous. The rise time of the signal is defined as the time taken for the
voltage to change from 10% to 90% of its maximum value. Rise times are usually very short,with durations measured in nanoseconds (1 ns = 10 -9 s), or microseconds (1 μs = 10 -6 s), as
indicat ed in the graph.
Signal generators, also known variously as function generators, RF and microwave signal
generat ors, pitch generators, arbitrary waveform generators, digital pattern generators or
frequency generators are el ectronic devices that generate repeating or non-repeating electroni c
signals (in either the analog or digit al domains). They are generally us ed in designing, testing,
troubleshooting, and repairing el ectroni c or electro acoustic devices; though they often have
artistic uses as well.
There are many di fferent types of signal generators, with different purposes and applications
(and at varying levels of expense); in general, no device is suitable for all possible appli cations.
Traditionally, signal generators have been embedded hardware units, but since the age of
multimedia-PCs, flexible, programm able software tone generat ors have also been availabl e.
A function generator is a device which produces simpl e repetitive waveforms. Such devi ces
cont ain an electronic oscillator, a circuit that is capable of creating a repetitive waveform.
(Modern devices m ay use digital signal processing to synthesize waveforms, followed by a
digital to analog converter, or DAC, to produce an analog output ). The most common waveform
is a sine wave, but sawtooth, st ep (pulse), square, and triangul ar waveform oscillators are
commonly available as are arbitrary waveform generators (AWGs). If the oscillator operates
above the audio frequency range (>20 kHz), the generator will often include some sort of
modulation function such as amplitude modul ation (AM), frequency modulation (FM), or phase
modulation (PM) as well as a second os cillator that provides an audio frequency modulation
waveform.
Steps:
1.
2.
3.
4.
5.
6.
7.
Make the connections as shown in figure.
Give input as square wave from signal Generator. Also give input frequency.
Give the output of signal generator to P9 pin no 40 of BBB.
Access BBB through Minicom.
Run the python code in operating system of BBB.
Observe the value of volt age.
Draw tim e Vs voltage graphConclusion: - In this way we perform the construction of a Square wave of programm able
frequency using signal generator and drawn voltage (y-axis) and time (x-axis ) graph.Program:
#!/usr/bin/python
import sys
import time
import sel ect
import sys
import time
import sel ect
#===================================================
import Adafruit_BBIO.ADC as ADC
ADC_IN_1 = "P9_39"
ADC_IN_2 = "P9_40"
#===================================================
ADC_INP UT = ADC_IN_2
#===================================================
DAC_D0
=
(1 * 32) + 12
DAC_D1
=
(1 * 32) + 13
DAC_D2
=
(1 * 32) + 14
DAC_D3
=
(1 * 32) + 15
DAC_D4
=
(1 * 32) + 16
DAC_D5
=
(1 * 32) + 17
DAC_D6
=
(1 * 32) + 18
DAC_D7
=
(1 * 32) + 19
#===================================================
DACBits = [
DAC_D0,
DAC_D1,
DAC_D2,
DAC_D3,
DAC_D4,
DAC_D5,
DAC_D6,
DAC_D7
]
#===================================================
SYSFS_GPIO_DIR = "/sys/ cl ass/gpio"
#===================================================
def gpioExport (gpio):
try:
fo = open(SYSFS_GPIO_DIR + "/ export","w")
fo.write(gpio)
fo.close()
return
except IOError:
return
#===================================================
def gpioUnexport (gpio):
try:
fo = open(SYSFS_GPIO_DIR + "/unexport","w")
fo.write(gpio)fo.close()
return
except IOError:
return
#===================================================
def gpioSetDir (gpio, fl ag):
try:
fo = open(SYSFS_GPIO_DIR + "/gpio" + gpio + "/direction" ,"w")
fo.write(flag)
fo.close()
return
except IOError:
return
#===================================================
def gpioSetVal (gpio, val):
try:
fo = open(SYSFS_GPIO_DIR + "/gpio" + gpio + "/value" ,"w")
fo.write(val)
fo.close()
return
except IOError:
return
#===================================================
def DACSetAll (val):
f0 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D0) + "/value" ,"w")
f1 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D1) + "/value" ,"w")
f2 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D2) + "/value" ,"w")
f3 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D3) + "/value" ,"w")
f4 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D4) + "/value" ,"w")
f5 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D5) + "/value" ,"w")
f6 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D6) + "/value" ,"w")
f7 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D7) + "/value" ,"w")
f0.write(val[7])
f1.write(val[6])
f2.write(val[5])
f3.write(val[4])
f4.write(val[3])
f5.write(val[2])
f6.write(val[1])
f7.write(val[0])
f0.close()
f1.close()
f2.close()
f3.close()
f4.close()
f5.close()f6.close()
return
#===================================================
def DACExit (gpio):
gpioUnexport(gpio)
return
#===================================================
def DACInit (gpio):
gpioExport(gpio)
gpioSetDir(gpio, flag="out")
return
#===================================================
def DACInitAll():
for i in range(0, 8):
DACInit(str(DACBits[i]))
return
#===================================================
def DACExitAll():
for i in range(0, 8):
DACExit(str(DACBits[i]))
return
#===================================================
try:
print "\nPython Program to generate Sine Wave using DAC\n"
print "-----------------------------------------------\n"
ADC.setup()
DACInitAll()
while(True):
value = ADC.read_raw(ADC_INPUT)
value = int(value)
value = value >> 2
print "Adc val = [%d]" %value
bin_val = str('{:08b}'.format(value))
print "binary val = %s" %bin_val
DACSetAll(bin_val)
#time.sleep(1)
exit()
except KeyboardInt errupt:
DACExitAll()
print "Program Exit due to CTRL-C"
exit()
sys.exit(0)Output:-
Vol tage vs time wave form:-
1.2
1
0.8
0.6
0.4
0.2
0
import Adafruit_BBIO.ADC as ADC
ADC_IN_1 = "P9_39"
ADC_IN_2 = "P9_40"
#===================================================
ADC_INP UT = ADC_IN_2
#===================================================
DAC_D0
=
(1 * 32) + 12
DAC_D1
=
(1 * 32) + 13
DAC_D2
=
(1 * 32) + 14
DAC_D3
=
(1 * 32) + 15
DAC_D4
=
(1 * 32) + 16
DAC_D5
=
(1 * 32) + 17
DAC_D6
=
(1 * 32) + 18
DAC_D7
=
(1 * 32) + 19
#===================================================
DACBits = [
DAC_D0,
DAC_D1,
DAC_D2,
DAC_D3,
DAC_D4,
DAC_D5,
DAC_D6,
DAC_D7
]
#===================================================
SYSFS_GPIO_DIR = "/sys/ cl ass/gpio"
#===================================================
def gpioExport (gpio):
try:
fo = open(SYSFS_GPIO_DIR + "/ export","w")
fo.write(gpio)
fo.close()
return
except IOError:
return
#===================================================
def gpioUnexport (gpio):
try:
fo = open(SYSFS_GPIO_DIR + "/unexport","w")
fo.write(gpio)fo.close()
return
except IOError:
return
#===================================================
def gpioSetDir (gpio, fl ag):
try:
fo = open(SYSFS_GPIO_DIR + "/gpio" + gpio + "/direction" ,"w")
fo.write(flag)
fo.close()
return
except IOError:
return
#===================================================
def gpioSetVal (gpio, val):
try:
fo = open(SYSFS_GPIO_DIR + "/gpio" + gpio + "/value" ,"w")
fo.write(val)
fo.close()
return
except IOError:
return
#===================================================
def DACSetAll (val):
f0 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D0) + "/value" ,"w")
f1 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D1) + "/value" ,"w")
f2 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D2) + "/value" ,"w")
f3 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D3) + "/value" ,"w")
f4 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D4) + "/value" ,"w")
f5 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D5) + "/value" ,"w")
f6 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D6) + "/value" ,"w")
f7 = open(SYSFS_GPIO_DIR + "/gpio" + str(DAC_D7) + "/value" ,"w")
f0.write(val[7])
f1.write(val[6])
f2.write(val[5])
f3.write(val[4])
f4.write(val[3])
f5.write(val[2])
f6.write(val[1])
f7.write(val[0])
f0.close()
f1.close()
f2.close()
f3.close()
f4.close()
f5.close()f6.close()
return
#===================================================
def DACExit (gpio):
gpioUnexport(gpio)
return
#===================================================
def DACInit (gpio):
gpioExport(gpio)
gpioSetDir(gpio, flag="out")
return
#===================================================
def DACInitAll():
for i in range(0, 8):
DACInit(str(DACBits[i]))
return
#===================================================
def DACExitAll():
for i in range(0, 8):
DACExit(str(DACBits[i]))
return
#===================================================
try:
print "\nPython Program to generate Sine Wave using DAC\n"
print "-----------------------------------------------\n"
ADC.setup()
DACInitAll()
while(True):
value = ADC.read_raw(ADC_INPUT)
value = int(value)
value = value >> 2
print "Adc val = [%d]" %value
bin_val = str('{:08b}'.format(value))
print "binary val = %s" %bin_val
DACSetAll(bin_val)
#time.sleep(1)
exit()
except KeyboardInt errupt:
DACExitAll()
print "Program Exit due to CTRL-C"
exit()
sys.exit(0)Output:-
Vol tage vs time wave form:-
1.2
1
0.8
0.6
0.4
0.2
0
======================
Grp C 3].
======================
********************************************************************************
Group : c
Assignment No : 3
Title : Designing IPv6 network and/or configuration of
Dual stack IPv6 and IPv4 network.
Roll No:
********************************************************************
Pre-requisite :
1. IPV4
2. IPV6
3. Dual stack concept.
Index Terms :
IPV4 :
Internet Protocol
version 4 (IPv4) is the fourth version in the development of the Internet
Protocol (IP) Internet, and routes most traffic on the Internet.[1] However, a
successor protocol, IPv6, has been defined and is in various stages of
production deployment.IPv4 is a connectionless protocol for use on
packet-switched networks. It operates on a best effort delivery model, in that
it does not guarantee delivery, nor does it assure proper sequencing or
avoidance of duplicate delivery. These aspects, including data integrity, are
addressed by an upper layer transport protocol, such as the Transmission
Control Protocol (TCP).IPv4 uses 32-bit (four-byte) addresses, which limits the
address space to 4294967296 (232) addresses. As addresses were assigned to
users, the number of unassigned addresses decreased.This limitation of IPv4
stimulated the development of IPv6 in the 1990s, which has been in commercial
deployment since 2006.IPv4 reserves special address blocks for private networks
(~18 million addresses) and multicast addresses (~270 million addresses).
IPV4 ADDRESS
REPRESENTATION :
IPv4 addresses may be
written in any notation expressing a 32-bit integer value, but for human
convenience, they are most often written in the dot-decimal notation, which
consists of four octets of the address expressed individually in decimal and
separated by periods.An IP address followed by a slash(/) and a number (i.e.
127.0.0.1/8 ) indicates a block of addresses using a subnet mask.
Class A—The leading bit is set to 0, a 7-bit number,
and a 24-bit local host address. Up to 125 class A networks can be defined,
with up to 16,777,214 hosts per network.
Class B—The two highest-order bits are set to 1 and 0,
a 14-bit network number, and a 16-bit local host address. Up to 16,382 class B
networks can be defined, with up to 65,534 hosts per network.
Class C—The three leading bits are set to 1, 1, and 0, a
21-bit network number, and an 8-bit local host address. Up to 2,097,152 class C
networks can be defined, with up to 254 hosts per network.
Class D—The four highest-order bits are set to 1, 1, 1,
and 0. Class D is used as a multicast address.
Header
The IPv4 packet header
consists of 14 fields, of which 13 are required. The 14th field is optional
(red background in table) and aptly named: options. The fields in the header
are packed with the most significant byte first (big endian), and for the
diagram and discussion, the most significant bits are considered to come first
(MSB 0 bit numbering). The most significant bit is numbered 0, so the version
field is actually found in the four most significant bits of the first byte.
IPV6 :
Internet Protocol
version 6 (IPv6) is the most recent version of the Internet Protocol (IP), the
communications protocol that provides an identification and location system for
computers on networks and routes traffic across the Internet. IPv6 was
developed by the Internet Engineering Task Force (IETF) to deal with the
long-anticipated problem of IPv4 address exhaustion. IPv6 is intended to
replace IPv4.
Every device on the
Internet is assigned an IP address for identification and location definition.
With the rapid growth of the Internet after commercialization in the 1990s, it
became evident that far more addresses than the IPv4 address space has
available were necessary to connect new devices in the future. By 1998, the
Internet Engineering Task Force (IETF) had formalized the successor protocol.
IPv6 uses a 128-bit address, allowing 2128, or approximately 3.4×1038
addresses, or more than 7.9×1028 times as many as IPv4, which uses 32-bit
addresses and provides approximately 4.3 billion addresses. The two protocols
are not designed to be interoperable, complicating the transition to IPv6.
However, several IPv6 transition mechanisms have been devised to permit
communication between IPv4 and IPv6 hosts.
IPV6 ADDRESS
REPRESENTATION :
Packet Format :
An IPv6 packet has two
parts: a header and payload.
The header consists of a
fixed portion with minimal functionality required for all packets and may be
followed by optional extensions to implement special features.The fixed header
occupies the first 40 octets (320 bits) of the IPv6 packet. It contains the
source and destination addresses, traffic classification options, a hop
counter, and the type of the optional extension or payload which follows the
header. This Next Header field tells the receiver how to interpret the data
which follows the header. If the packet contains options, this field contains
the option type of the next option. The "Next Header" field of the
last option, points to the upper-layer protocol that is carried in the packet's
payload.
Dual stack:
Dual stack is a transition
technology in which IPv4 and IPv6 operate in tandem over shared or dedicated
links. In a dual-stack network, both IPv4 and IPv6 are fully deployed across
the infrastructure, so that configuration and routing protocols handle both
IPv4 and IPv6 addressing and adjacencies.
Although dual-stack may
appear to be an ideal solution, it presents two major deployment challenges to
enterprises and ISPs:
• It requires a current network infrastructure
that is capable of deploying IPv6. In many cases, however, the current network
may not be ready and may require hardware and software upgrades.
• IPv6 needs to be activated on almost all the
network elements. To meet this requirement, the existing network may need to be
redesigned, posing business continuity challenges.
Dual stack is the most
direct approach to making IPv6 nodes compatible with IPv4 nodes. The best way
for an IPv6 node to be compatible with an IPv4 node is to maintain a complete
IPv4 stack. A network node that supports both IPv4 and IPv6 is called a dual
stack node. A dual stack node configured with an IPv4 address and an IPv6
address can have both IPv4 and IPv6 packets transmitted.
For an upper layer
application supporting both IPv4 and IPv6, either TCP or UDP can be selected at
the transport layer, while IPv6 stack is preferred at the network layer.
Dual-stack:
In dual-stack
configuration, the device is configured for both IPv4 and IPv6 network stacks.
The dual-stack configuration can be implemented on a single interface or with
multiple interfaces. In this configuration, the device decides how to send the
traffic based on the destination address of the other device.
As of IOS 12.2(2), Cisco
is IPv6-ready. To support dual-stack routing on a single interface, you need to
configure IPv6 on your routing device.
The following commands
allow for forwarding of IPv6 data packets:
Router1> enable
Router1# configure
terminal
Router1(config)# ipv6
unicast-routing
Router1(config)#
interface ethernet0
Router1(config-if)# ip
address 192.168.75.1 255.255.255.0
Router1(config-if)# ipv6
address 2123:AFFF::192:168:75:1/120
Router1(config-if)# exit
Router1(config)# exit
Router1# copy
running-config startup-config
Tunneling:
Tunneling refers to
passing IPv6 data over an IPv4 network by placing the IPv6 packet into the data
section of an IPv4 packet, as shown in Figure 4-2. The four main types of
tunneling are
Manual IPv6-to-IPv4
tunneling encapsulates an IPv6 packet in an IPv4 packet. So as to not fragment
the packet from adding the IPv4 header to it, the data packet needs to be
reduced by 20 bytes if the IPv4 has an optional protocol field, or 20 octets if
it does not, as well as require routers support both IP stacks.
Dynamic 6-to-4 tunneling
routes data between is lands of IPv6 routers across your network.
Intra-Site Automatic
Tunnel Addressing Protocol (ISATAP) tunneling uses the existing IPv4 network as
the link layer of the IPv6 network and routes the data between the IP networks
via routers supporting both IP stacks.
Teredo tunneling
performs the tunneling work at the dual-stacked host on either end of the
connection rather than at a gateway router.
No comments :
Post a Comment