Friday, December 25, 2015

Parallel Computing

Parallel computing is collection of processing elements that communicate and co-operate to solve large problems fast. It is the use of two or more processors (cores, computers) in combination to solve a single problem.

Examples of Parallel System:
An example of parallel computing would be two servers that share the workload of routing mail, managing connections to an accounting system or database, solving a mathematical problem etc. Supercomputers are usually placed in parallel system architecture, Terminals connected to single server.

Advantages of Parallel System:
They provide concurrency, help in taking advantage of non-local resources, It is cost saving.
It is overcoming memory constraints. It saves time and money. It has global address space which provides a user-friendly programming perspective to memory.

Disadvantages of Parallel System:
Primary disadvantage is the lack of scalability between memory and CPUs.
Programmer responsibility for synchronization constructs that ensure "correct" access of global memory.
It becomes increasingly difficult and expensive to design and produce shared memory machines with ever increasing numbers of processors.

Types of Parallel Computing:
·         Data-parallel: Same operations on different data. It is also called SIMD.
·         SPMD: Same program, different data.
MIMD: Different programs, different data

_________________________________________________________________________________
Arslan ud Din Shafiq
COMSATS Institute of Information Technology
CS Department

Distributed Computing

A distributed system is a software system in which components located on networked computers communicate and coordinate their actions by passing messages. The components interact with each other in order to achieve a common goal.

Examples of Distributed System:  
World Wide Web, Sharing Clusters, Network of workstations, Network of branch office computers, Network of embedded systems, New Cell processor (PlayStation 3) etc are examples of distributed system.

Advantages of Distributed System:
Distributed Systems are information sharing, resource sharing, extensible, shorter response time and higher output, higher reliability, better flexibility’s in meeting user’s needs, better price/performance ratio, scalability, transparency.

Disadvantages of Distributed System:
Distributed systems have difficulties of developing distributed software, networking problem, security problems, performance is less, openness, less reliability and less fault tolerance. 

Types of Distributed Computing:
·         Host-Based Hierarchy
·         Decentralized Stand-Alone System
·         Peer-to-Peer LAN-based System
·         Hybrid Enterprise-wide System
·         Client-Server System
·         Internet-centric Computing Systems

Goals of Distributed System:
In distributed system, we work to achieve the following goals:
·        Transparency
·        Openness
·        Reliability
·        Performance
·        Scalability

_________________________________________________________________________________

Arslan ud Din Shafiq
COMSATS Institute of Information Technology
CS Department

Friday, April 17, 2015

Queues Implementation using Single Link List

Queues Implementation using Single Link List

#include <iostream>
using namespace std;
struct Node {
int value;
Node *next;
};
int main(){
int menu;
int sel;
int count=0;
struct Node *p = new Node;
struct Node *head = new Node;

for( int i=0;i<=79;i++){
cout<<'*';
}
cout<<"                     Built & Designed by Arslan Malik Aareez"<<endl;
cout<<"                          www.CWorldbyAS.blogspot.com"<<endl;
cout<<"                     Facebook : www.facebook.com/arslan.ud.din"<<endl;
cout<<"                     Twitter  : www.twitter.com/itsaareez"<<endl;
for( int i=0;i<=79;i++){
cout<<'*';
}

    ask:
    
cout<<"1. Insert\n2. Delete\n3. Print\n4. Exit"<<endl;
    cin>>menu;
    switch(menu){
     case 1:
     count++;
     cout<<"Enter Value to insert : ";
     cin>>p->value;
     p->next = NULL;
     head = p;
     system("cls");
     cout<<"Do you want to enter any other value?\n\n1. Yes\n2. No";
     cin>>sel;
            system("cls");
     while (sel!=2){
  struct Node *q = new Node;
count++;
     cout<<"Enter Value to insert : ";
     cin>>q->value;
         q->next = NULL;
     p->next = q;
     p = p->next;
     system("cls");
     cout<<"Do you want to enter any other value?\n\n1. Yes\n2. No";
     cin>>sel;
     system("cls");
     }
     goto ask;
     break;
     case 2:
     count--;
     p = head;
     head = p->next;
     p->value = 0;
     p->next = NULL;
     system("cls");
     goto ask;
     break;
    
     case 3:
     system("cls");
     p = head;
     if (count==0){
         system("cls");

cout<<"Queue is empty.";
     }
     else{
cout<<"Your queue has the following values"<<endl;
    
     while (p->next!=NULL){
     cout<<" "<<p->value;
     p = p->next;
     }
     cout<<" "<<p->value;
     }
     cout<<"\n\n";
system("pause");
      system("cls");
goto ask;
break;
    
     case 4:
     return 0;
     break;
    }


}

Stack Implementation using Single Link List

Stack Implementation using Single Link List

#include <iostream>
using namespace std;
struct Node{
int value;
Node *next;

};

int main(){

for( int i=0;i<=79;i++){
cout<<'*';
}
cout<<"                     Built & Designed by Arslan Malik Aareez"<<endl;
cout<<"                          www.CWorldbyAS.blogspot.com"<<endl;
cout<<"                     Facebook : www.facebook.com/arslan.ud.din"<<endl;
cout<<"                     Twitter  : www.twitter.com/itsaareez"<<endl;
for( int i=0;i<=79;i++){
cout<<'*';
}

int menu;
int sel;

struct Node *p = new Node;
struct Node *head = new Node;
struct Node *r = new Node;
head->next = NULL;
head->value=0;
    ask:
cout<<"Enter Your Choice\n"<<endl;
    cout<<"1. Push"<<endl;
    cout<<"2. Pop"<<endl;
    cout<<"3. Print"<<endl;
    cout<<"4. Exit"<<endl;
    cin>>menu;
    system("cls");
switch (menu){
case 1:
cout<<"Enter Value to Push : ";
cin>>p->value;
p->next = NULL;
system("cls");
head = p;
cout<<"Do you want to push another value?"<<endl;
cout<<"1. Yes"<<endl;
cout<<"2. No"<<endl;

cin>>sel;
system("cls");
    while (sel!=2){
     struct Node *q = new Node;
      cout<<"\nEnter Value to Push : ";    
cin>>q->value;
q->next=NULL;
p->next = q;
     p = p->next;
     system("cls");
        cout<<"Do you want to push another value?"<<endl;
        cout<<"1. Yes"<<endl;
        cout<<"2. No"<<endl;
        cin>>sel;
        system("cls");

    }
    goto ask;

break;
case 2:
p = head;
if (p->next==NULL && p->value == 0){
cout<<"\nStack is Empty\n\n";
}
while (p->next!=NULL){
r = p;
p = p->next;
}
r->next = NULL;
p->value = 0;

goto ask;

break;
case 3:
system("cls");
p= head;

cout<<"Stack contains the following values "<<endl;

while (p->next!=NULL){
if (p->value==0)
{
cout<<" ";
}
else
{
cout<<" "<<p->value;
}

p=p->next;

}
cout<<" "<<p->value;
cout<<"\n";
goto ask;

break;

case 4:
return 0;
break;
}


}