Ai Practical 1
Ai Practical 1
Ai Practical 1
CSE/1604722
PRACTICAL NO.1
AIM: -Introduction of Artificial Intelligence and its application.
1.1 Artificial Intelligence
According to the father of Artificial Intelligence, John McCarthy, it is “The science and
engineering of making intelligent machines, especially intelligent computer programs”.
Artificial Intelligence is a way of making a computer, a computer-controlled robot, or a
software think intelligently, in the similar manner the intelligent humans think.
AI is accomplished by studying how human brain thinks, and how humans learn, decide, and
work while trying to solve a problem, and then using the outcomes of this study as a basis of
developing intelligent software and systems.
1.2 Goals of AI
To Create Expert Systems − The systems which exhibit intelligent behavior, learn,
demonstrate, explain, and advice its users.
To Implement Human Intelligence in Machines − Creating systems that understand, think,
learn, and behave like humans.
1.3 Advantages of Artificial Intelligence
o More powerful are more useful computers
o New and improved interfaces
o Solving new problems
o Better handling of information
o Relieves information overload
o Conversion of information into knowledge
1.4 Disadvantages of Artificial Intelligence
o Increased costs
o Difficulty with software development-slow and expensive
o Few experienced programmers
o Few practical products have reached the market as yet
1.5 Foundation of AI: -
Fig.1.1
1.6 Applications of AI: -
AI has been dominant in various fields such as −
Gaming − AI plays crucial role in strategic games such as chess, poker, tic-tac-toe, etc.,
where machine can think of large number of possible positions based on heuristic
knowledge.
CSE/1604722
Natural Language Processing − It is possible to interact with the computer that understands
natural language spoken by humans.
Expert Systems − There are some applications which integrate machine, software, and
special information to impart reasoning and advising. They provide explanation and advice
to the users.
Vision Systems − These systems understand, interpret, and comprehend visual input on the
computer. For example,
o A spying aeroplane takes photographs, which are used to figure out spatial information or
map of the areas.
o Doctors use clinical expert system to diagnose the patient.
o Police use computer software that can recognize the face of criminal with the stored portrait
made by forensic artist.
Speech Recognition − Some intelligent systems are capable of hearing and comprehending
the language in terms of sentences and their meanings while a human talks to it. It can handle
different accents, slang words, noise in the background, change in human’s noise due to cold,
etc.
Handwriting Recognition − The handwriting recognition software reads the text written on
paper by a pen or on screen by a stylus. It can recognize the shapes of the letters and convert
it into editable text.
Intelligent Robots − Robots are able to perform the tasks given by a human. They have
sensors to detect physical data from the real world such as light, heat, temperature,
movement, sound, bump, and pressure. They have efficient processors, multiple sensors and
huge memory, to exhibit intelligence. In addition, they are capable of learning from their
mistakes and they can adapt to the new environment.
CSE/1604722
PRACTICAL NO.2
AIM: -Implementation of Depth-First Search(DFS).
2.1Depth-First Search
DFS is also an important type of uniform search. DFS visits all the vertices in the graph. This
type of algorithm always chooses to go deeper into the graph. After DFS visited all the
reachable vertices from a particular sources vertices it chooses one of the remaining
undiscovered vertices and continues the search. DFS reminds the space limitation of breath
first search by always generating next a child of the deepest unexpanded nodded. The data
structure stack or (LIFO) is used for DFS. One interesting property of DFS is that, the
discover and finish time of each vertex from a parenthesis structure. If we use one open
parenthesis when a vertex is finished then the result is properly nested set of parenthesis.
2.2 Advantages of Depth-First Search
o DFS consumes very less memory space.
o It will reach at the goal node in a less time period than BFS if it traverses in a right path.
o It may find a solution without examining much of search because we may get the desired
solution in the very first go.
o t takes less memory as compared to BFS as BFS requires entire tree to be stored but this
requires only one path.
o Sometimes solution lies in earlier stages then DFS is better.
o If there are multiple solutions then DFS stops when first solution is found. Where as BFS
gives all the solutions at the same time.
2.3 Disadvantages of Depth-First Search
o There is a possibility that it may go down the left-most path forever. Even a finite graph can
generate an infinite tree.
o It is possible that may states keep reoccurring. There is no guarantee of finding the goal
node.
o Sometimes the states may also enter into infinite loops.
o Depth-First Search is not guaranteed to find the solution.
o And there is no guarantee to find a minimal solution, if more than one solution exists.
2.4 Algorithm of Depth-First Search
1: PUSH the starting node into the stack.
2: If the stack is empty then stop and return failure.
3: If the top node of the stack is the goal node, then stop and return success.
4: Else POP the top node from the stack and process it. Find all its neighbours that are in
ready state and PUSH them into the stack in any order.
5: Go to step 3.
6: Exit.
2.5 Program: -
#include<iostream.h>
#include<conio.h>
#include<stdlib.h>
int cost[10][10],i,j,k,n,stk[10],top,v,visit[10],visited[10];
void main()
{
int m;
clrscr();
cout<<"Enter of vertices";
cin>>n;
cout<<"Enter of edges";
cin>>m;
cout<<"EDGES\n";
for(k=1;k<=m;k++)
{
CSE/1604722
cin>>i>>j;
cost[i][j]=1;
}
cout<<"Enter initial vertex";
cin>>v;
cout<<"Order of Visited vertices\n";
cout<<v<<" ";
visited[v]=1;
k=1;
while(k<n)
{
for(j=n;j>=1;j--)
if(cost[v][j]!=0&& visited[j]!=1&& visit[j]!=1)
{
visit[j]=1;
stk[top]=j;
top++;}
v=stk[--top];
cout<<v<<" ";
k++;
visit[v]=0;
visited[v]=1;
}
getch();
}
Output:-
Fig. 2.1
CSE/1604722
PRACTICAL NO. 3
AIM: -Write a program to implement towers of Hanoi
3.1 Tower of Hanoi
The solution to the Towers of Hanoi puzzle is a classic example of recursion. The ancient
puzzle of the Towers of Hanoi consists of a number of wooden disks mounted on three poles,
which are in turn attached to a baseboard. The disks each have different diameters and a hole
in the middle large enough for the poles to pass through. In the beginning, all the disks are on
the left pole.
The object of the puzzle is to move all the disks over to the right pole, one at a time, so that
they end up in the original order on that pole. You can use the middle pole as a temporary
resting place for disks, but at no time is a larger disk to be on top of a smaller one. It's easy to
solve the Towers of Hanoi with two or three disks, but the process becomes more difficult
with four or more disks.
3.2 Algorithm of Tower of Hanoi
1) If we have only one disk , then it can easily be moved from source to destination peg.
2) If we have 2 disks −
• First, we move the smaller (top) disk to aux peg.
• Then, we move the larger (bottom) disk to destination peg.
• And finally, we move the smaller disk from aux to destination peg.
3) To move n disks from source to destination, The steps to follow are -
• Step 1 − Move n-1 disks from source to aux
• Step 2 − Move nth disk from source to dest
• Step 3 − Move n-1 disks from aux to dest
3.3 Program: -
#include <iostream.h>
#include <conio.h>
void tower(int a,char from,char aux,char to){
if(a==1){
cout<<"\t\tMove disc 1 from "<<from<<" to "<<to<<"\n";
return;
} else{
tower(a-1,from,to,aux);
cout<<"\t\tMove disc "<<a<<" from "<<from<<" to "<<to<<"\n";
tower(a-1,aux,from,to); } }
void main(){
clrscr(); int n;
cout<<"\n\t\t*****Tower of Hanoi*****\n";
cout<<"\t\tEnter number of discs : ";
cin>>n; cout<<"\n\n";
tower(n,'A','B','C');
getch(); }
Output:-
Fig.3.1
CSE/1604722
PRACTICAL NO. 4
AIM: -Write a program to implement water jug problem.
4.1 Water jug problem
Statement :We are given 2 jugs, a 4 liter one and a 3- liter one. Neither has any measuring
markers on it. There is a pump that can be used to fill the jugs with water. How can we get
exactly 2 liters of water in to the 4-liter jugs?
Solution:-
The state space for this problem can be defined as
{ ( i ,j ) i = 0,1,2,3,4 j = 0,1,2,3}
‘i’ represents the number of liters of water in the 4-liter jug and ‘j’ represents the number of
liters of water in the 3-liter jug. The initial state is ( 0,0) that is no water on each jug. The
goal state is to get ( 2,n) for any value of ‘n’.
To solve this we have to make some assumptions not mentioned in the problem. They are
1. We can fill a jug from the pump.
2. We can pour water out of a jug to the ground.
3. We can pour water from one jug to another.
4. There is no measuring device available.
4.2 Program: -
#include<iostream.h>
#include<iomanip.h>
#include<math.h>
#include<conio.h>
int xcapacity;
int ycapacity;
void display(int a, int b,int s);
int min(int d, int f)
{if (d < f)
return d;
else
return f;
} int steps(int n)
{
int x = 0, y = 0, step = 0;
BTCS- 704 Artificial Intelligence Page 6
CSE/1604722
CSE/1604722
int temp;
cout << setw(55) << “ Vessel A Vessel B Steps” << endl; while
(x != n )
{if (x == 0)
{ x = xcapacity;
step += 1;
cout << “Fill X “; display(x, y,step);
} else if (y ==
ycapacity) { y = 0;
step++;
cout << “Empty Y “; display(x, y,step);
}else {
temp = min(ycapacity – y, x);
y = y + temp;
x = x – temp;
step++;
cout << “Pour X in Y”; display(x, y, step);
}}
return step;
}void display(int a, int b,int s)
{cout << setw(16) << a << setw(15) << b << setw(15)<<s<<endl;
} void main()
{
int n, ans;
clrscr();
cout << “Enter the liters(GOAL) of water required to be filled in Vessel
1:”; cin >> n;
cout << “Enter the capacity of the vessel:
“; cin >> xcapacity;
cout << “Enter the capacity of the second 7essel: “;
cin >> ycapacity;
ans = steps(n);
cout << “Steps Required: “ <<
ans; cout<<”pause”;
}
Output:-
Fig.4.1
CSE/1604722
PRACTICAL NO. 5
AIM: -Write a program to implement tic tac toe game for 0 and X.
5.1 Tic Tac Toe
Tic Tac Toe is a child's game played on a 3 by 3 grid. One player, X, starts by placing an X at
an unoccupied grid position. Then the other player, O, places an O at an unoccupied grid
position. Play alternates between X and O until the grid is filled or one player's symbols
occupy an entire line (vertical, horizontal, or diagonal) in the grid.
A tic-tac-toe AI program that never loses. This program uses the minimax algorithm with
alpha-beta pruning to reduce the search space.
1. return a value if a terminal state is found (+10, 0, -10)
2. go through available spots on the board
3. call the minimax function on each available spot (recursion)
4. evaluate returning values from function calls
5. and return the best value
5.2 Minimax Algorithm Visualizations:
The entire algorithm has been divided into five parts. We are assuming that the player is
playing X and the computer is playing O.
A. Check for winning condition.
B. Playing Defensive.
C. The First Move.
D. The Next Move.
E. Some Special Moves.
Fig.5.1
5.3 Program: -
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<iostream.h>
char matrix[3][3]; //intitial matrix declaration
char check(void); // declaration of functions
void init_matrix(void);
void get_player_move(void);
void get_computer_move(void);
void disp_matrix(void);
int main(void)
{
clrscr();
CSE/1604722
char done;
cout<<"Human vs. AI Tic Tac Toe."<<endl;
cout<<"You will be playing against the computer as
'X'"<<endl; done = ' ';
init_matrix();
do {
disp_matrix();
get_player_move();
done = check(); /* check winner */
if(done!= ' ') break; /* if winner found...*/
get_computer_move();
done = check(); /* check for winner again */
} while(done== ' '); if(done=='X')
cout<<"Human won! (but AI very dumb anyway)\n"; else
cout<<"AI so stupid still can win against you..."<<endl; disp_matrix(); /* show
final positions */
return 0;
}
void init_matrix(void) //matrix intitialisation
{
int i, j;
for(i=0; i<3; i++)
for(j=0; j<3; j++) matrix[i][j] = ' ';
}
void get_player_move(void) //call function for player input
{
int x, y;
cout<<"Enter X,Y coordinates for your move: ";
scanf("%d%*c%d", &x, &y);
x--; y--;
if(matrix[x][y]!= ' ')
{
cout<<"Invalid move, try again.\n";
get_player_move();
}
else matrix[x][y] = 'X';
}
void get_computer_move(void) //AI move input
{
int i, j;
for(i=0; i<3; i++)
{
for(j=0;j<3; j++)
if(matrix[i][j]==' ') break;
if(matrix[i][j]==' ') break;
}
if(i*j==9)
{
cout<<"draw\n";
exit(0);
}
else
matrix[i][j] = 'O';
}
void disp_matrix(void) //matrix display
{
int t;
CSE/1604722
Fig. 5.2
Fig. 5.3
CSE/1604722
Fig. 5.4
Fig.5.5
Fig.5.6
CSE/1604722
Fig.5.7
Fig. 5.8
Fig. 5.9
CSE/1604722
Fig. 5.10
Fig. 5.11
CSE/1604722
PRACTICAL NO.6
AIM: -Write a program to implement production system.
6.1 Production System:
Search forms the core of many intelligent processes, it is useful to structure AI programs in a
way that facilitates describing and performing the search process. Production system provides
such structures .In other words the process of solving the problem can usefully be modeled as
production system.
The goal database is the central data structure used by an AI production system. The
production system. The production rules operate on the global database. Each rule has a
precondition that is either satisfied or not by the database. If the precondition is satisfied, the
rule can be applied. Application of the rule changes the database. The control system chooses
which applicable rule should be applied and ceases computation when a termination
condition on the database is satisfied. If several rules are to fire at the same time, the control
system resolves the conflicts.
6.2 Components of production system
o A set of rules of the form Ci → Ai where Ci is the condition part and Ai is the action part.
The condition determines when a given rule is applied, and the action determines what
happens when it is applied.
o One or more knowledge databases that contain whatever information is relevant for the
given problem. Some parts of the database may be permanent, while others may temporary
and only exist during the solution of the current problem. The information in the databases
may be structured in any appropriate manner.
o A control strategy that determines the order in which the rules are applied to the database,
and provides a way of resolving any conflicts that can arise when several rules match at
once.
o A rule applier which is the computational system that implements the control strategy and
applies the rules.
6.3 Four classes of production systems:-
1. A monotonic production system
2. A non monotonic production system
3. A partially commutative production system
4. A commutative production system.
6.4 Advantages of production systems:-
1. Production systems provide an excellent tool for structuring AI programs.
2. Production Systems are highly modular because the individual rules can be added,
removed or modified independently.
3. The production rules are expressed in a natural form, so the statements contained in the
knowledge base should the a recording of an expert thinking out loud.
6.5 Disadvantages of Production Systems:-
1. One important disadvantage is the fact that it may be very difficult analyse the flow of
control within a production system because the individual rules don’t call each other.
2. Production systems describe the operations that can be performed in a search for a solution
to the problem. They can be classified as follows.
6.6 Program
#include<iostream.h>
#include<conio.h>
int main()
{
char answer;
clrscr();
cout<<"Answer the following question to determine whether JOHN should get scholarship or
not?"<<endl;
CSE/1604722
Output
Fig.6.1
PRACTICAL NO.7
AIM: - Write a program to implement heuristic search procedure.
Program
#include <iostream>
using namespace std;
int main()
{
string a,b,c,d,e;
int t,u,v,w,z,p,q,r;
cout<< "Enter the root node"<< endl;
cin>> a;
cout<<" Enter the value of root node"<< endl;
cin>>t;
cout<< "Enter child 1"<< endl;
cin>>b;
cout<< "Enter value from root to child 1"<<
endl; cin>>u;
cout<< "Enter value from child1 to terminal"<<
endl; cin>> p;
cout<< "Enter child 2"<< endl;
cin>>c;
cout<< "Enter value of child 2"<< endl;
cin>>v;
cout<< "Enter value from child2 to terminal"<<
endl; cin>> q;
cout<< "Enter child 3"<< endl;
cin>>d;
cout<< "Enter value of child 3"<< endl;
cin>>w;
cout<< "Enter value from child3 to terminal"<<
endl; cin>> r;
cout<< "Enter terminal node"<< endl;
cin>> e;
if((u+p)<(v+q)&& (u+p)<(w+r))
{
cout<< "Heuristic path is from a to b to e"<<
endl; cout<< "Total value is"<< t+u+p;
}
else if((v+q)<(u+p)&&(v+p)<(w+r))
{
cout<< "Heuristic path is from a to c to e"<<
endl; cout<< "Total value is"<< t+v+p;
}
else if((w+r)<(u+p)&& (w+r)<(v+q))
{
cout<< "Heuristic path is from a to d to e"<<
endl; cout<< "Total value is"<< t+w+r<< endl;
}
return 0;
}
OUTPUT:
Fig.7.1
PRACTICAL NO.8
AIM: - Write a program to implement expert system.
Program
#include <iostream>
using namespace std;
void measels(char,char,char,char,char);
void flu(char,char,char,char,char,char,char,char);
void cold(char,char,char,char,char);
void chickenpox(char,char,char,char);
int main()
{
char name[50];
char a,b,c,d,e,f,g,h,i,j,k;
cout << "Please enter your name.. " << endl;
cin>> name;
cout << "Do you have fever? (y/n)"<< endl;
cin>>a;
cout << "Do you have rashes? (y/n)"<< endl;
cin>>b;
cout << "Do you have headache? (y/n)"<< endl;
cin>>c;
cout << "Do you have running nose? (y/n)"<<
endl; cin>>d;
cout << "Do you have conjunctivities? (y/n)"<<
endl; cin>>e;
cout << "Do you have cough? (y/n)"<< endl;
cin>>f;
cout << "Do you have ache? (y/n)"<< endl;
cin>>g;
cout << "Do you have chills? (y/n)"<< endl;
cin>>h;
cout << "Do you have swollen glands? (y/n)"<<
endl; cin>>i;
cout << "Do you have snezzing? (y/n)"<< endl;
cin>>j;
cout << "Do you have sore throat? (y/n)"<< endl;
cin>>k;
measels(a,f,e,d,b);
flu(a,c,g,e,h,k,f,d);
cold(c,j,k,d,h);
chickenpox(a,h,g,b);
return 0;
} void measels(char q,char w,char r,char t,char y)
{
if(q=='y'&&w=='y'&& r=='y' && t=='y' && y==
'y') cout<< "You may have measels."<< endl;
else
cout<< "";
}
void flu(char q,char w,char r,char t,char y,char p,char l,char x)
{
if(q=='y'&&w=='y'&& r=='y' && t=='y' && y== 'y'&& p=='y' && l=='y' &&
x=='y') cout<< "You may have flu."<< endl;
else
cout<< "";
}
OUTPUT:
Fig.8.1
PRACTICAL NO.9
AIM: - WAP to implement search problem of 3 x 3 puzzle.
Program
#include <iostream>
#include <iomanip>
#include <array>
using namespace std;
void printarray(int num[3][3])
{
for(int i = 0;i < 3; i++)
{
for(int j = 0; j< 3; j++)
{
cout << num[i][j] << " ";
}
cout << "\n";
}
}
{
swapValues(array, i, j, i+1, j);
swapValues(array, i, j, i+2, j);
}
else if(i==1&&j==1)
{
swapValues(array, i+1, j, i, j);
swapValues(array, i-1, j, i, j);
}
else if(i==0&&j==2)
{
swapValues(array, i, j, i+1, j);
}
else
swapValues(array, i, j, i-1, j);
swapValues(array, i, j, i+1, j);
}
else
swapValues(array, i, j, i-1, j);
swapValues(array, i, j, i+2, j);
//int coord1d = j * 3 + i;
}
class Puzzle
{
public:
Puzzle();
void swapValues(int num[3][3], int i1, int j1, int i2, int
j2); //void moveleft(int[3][3], int start1, int start2);
void moveup(int (&array)[3][3], int i, int j);
void moveright(int (&array)[3][3], int i, int j);
void moveleft(int (&array)[3][3], int i, int j);
void movedown(int (&array)[3][3], int i, int j);
void printarray(int[3][3]);
};
int main()
{
int state1[3][3] = {{2, 8, 3}, {1, 6, 4}, {7, 0, 5}};
int state2[3][3] = {{2, 8, 1}, {4, 6, 3}, {0, 7, 5}};
int gstate[3][3] = {{1, 2, 3}, {8, 0, 4}, {7, 6, 5}};
cout << "this is state 1" << endl;
printarray(state1);
cout << "\n\n";
cout << "now this is state 2" << endl;
printarray(state2);
cout << "\n\n";
cout << "now this is the goal state" << endl;;
printarray(gstate);
int start1, start2;
cout << endl << endl << "please enter your starting point in the states listed above going up or
down" << endl;
cin >> start1;
cout << "now enter the point going left to right" <<
endl; cin >> start2;
//moveleft(state1, start1, start2);
cout << "this is moving coordinate (1, 1) upwards" <<
endl; moveup(state1, start1, start2);
printarray(state1);
cout << endl;
cout << "this is moving coordinate (1, 1) to the left" <<
endl; moveleft(state1, start1, start2);
printarray(state1);
cout << endl;
cout << "this is moving coordinate (1, 1) downwards" <<
endl; movedown(state1, start1, start2);
printarray(state1);
cout << endl;
cout << "this is moving coordinate (1, 1) to the right" << endl;
moveright(state1, start1, start2);
printarray(state1);
cout << endl;
cin.get();
cin.get();
return 0;
}
BTCS- 704 Artificial Intelligence Page 22
CSE/1604722
OUTPUT:
Fig.9.1
PRACTICAL NO.10
AIM: - Program to implement a* algorithm.
Program
#include <iostream>
#include <iomanip>
#include <queue>
#include <string>
#include <math.h>
#include <ctime>
using namespace std;
const int n=60; // horizontal size of the map
const int m=60; // vertical size size of the map
static int map[n][m];
static int closed_nodes_map[n][m]; // map of closed (tried-out) nodes
static int open_nodes_map[n][m]; // map of open (not-yet-tried)
nodes static int dir_map[n][m]; // map of directions
const int dir=8; // number of possible directions to go at any
position // if dir==4
//static int dx[dir]={1, 0, -1, 0};
//static int dy[dir]={0, 1, 0, -1};
// if dir==8
static int dx[dir]={1, 1, 0, -1, -1, -1, 0, 1};
static int dy[dir]={0, 1, 1, 1, 0, -1, -1, -1};
class node
{
3.current
position int xPos;
int yPos;
4.total distance already travelled to reach the node
int level;
5. priority=level+remaining distance estimate
int priority; // smaller: higher priority
public:
node(int xp, int yp, int d, int p)
{xPos=xp; yPos=yp; level=d; priority=p;}
// Euclidian Distance
d=static_cast<int>(sqrt(xd*xd+yd*yd));
// Manhattan distance
//d=abs(xd)+abs(yd);
// Chebyshev distance
//d=max(abs(xd), abs(yd));
return(d);
}
};
// A-star algorithm.
// The route returned is a string of direction digits.
string pathFind( const int & xStart, const int & yStart,
const int & xFinish, const int & yFinish )
{
static priority_queue<node> pq[2]; // list of open (not-yet-tried) nodes
static int pqi; // pq index
static node* n0;
static node* m0;
static int i, j, x, y, xdx, ydy;
static char c;
pqi=0;
// A* search
while(!pq[pqi].empty())
{
// get the current node w/ the highest priority
// from the list of open nodes
n0=new node( pq[pqi].top().getxPos(), pq[pqi].top().getyPos(),
BTCS- 704 Artificial Intelligence Page 25
CSE/1604722
pq[pqi].top().getLevel(), pq[pqi].top().getPriority());
x=n0->getxPos(); y=n0->getyPos();
// garbage collection
delete n0;
// empty the leftover nodes
while(!pq[pqi].empty()) pq[pqi].pop();
return path;
}
int main()
{
srand(time(NULL));
OUTPUT:
Fig.10.1