Understanding Artificial Intelligence Techniques

A
r
t
i
f
i
c
i
a
l
 
I
n
t
e
l
l
i
g
e
n
c
e
T
e
c
h
n
i
q
u
e
 
One of the results to come out of the first three decades of AI research is that
intelligence requires knowledge.
 What disadvantages does knowledge possess ?
 
      1) It has a great amount of volume.
 
      2) It is hard to characterize and identify correctly.
 
      3) It is endlessly changing.
 
      4) Knowledge is different from data, because it is organized in a way that
agrees to the ways it will be used.
 
AI Technique
 
AI technique is a method that exploits knowledge that should be represented in
such a way that:
 
      1) The knowledge captures generalization. 
What this means is grouping
situations that share important properties rather than representing each
situation seperatly. The advantage that knowledge has would be that
unreasonable amounts of memory and updating will no longer be required.
Anything without this property is called 'data' rather than knowledge.
      2) It should be represented in such a way that it can be understood by the
people who must prepare it. 
For many programs the size of the data can be
acheived automatically by (taking readings from a number of instruments), but
in many AI areas, most of the knowledge a program has must basically be
provided by people in terms that they understand it.
 
AI Technique
 
3) It could easily be adjusted to correct errors and to demonstrate changes in
the world.
4) It could be used in different situations even though it may not entirely be
complete.
 
AI Technique
 
AI Technique
 
Intelligence requires Knowledge
 
Knowledge possesses less desirable properties such as:
-Voluminous
Hard to characterize accurately
Constantly changing
Differs from data that can be used
 
AI technique is a method that exploits knowledge that should be
represented in such a way that:
Knowledge captures generalization
It can be understood by people who must provide it
It can be easily modified to correct errors.
It can be used in variety of situations
 
It is possible to solve AI problems without using
techniques but those solutions may not be good.
 
It is possible to apply AI techniques to the solution of
non-AI problems.
 
Try to characterize AI techniques as problem
independent.
 
AI Technique
 
Three programs are presented to play tic tac toe:
 
the program in this series increase in
 
Their complexity
Use of generalization
Clarity of their knowledge
Extensibility of their approach
 
AI Technique
 
Let’s look at one problem and a series of approaches for solving the same
 
 
 
 X
 
 o
 
 o
 
 X
 
 X
 
 o
 
 
X
 
win
Introductory Problem: Tic-Tac-Toe-1
Tic-tac-toe, is a pencil-and-paper game for two players, O and X, who take
turns marking the spaces in a 3×3 grid.
The player who succeeds in placing three respective marks in a horizontal,
vertical or diagonal row wins the game.
 
Program 1:
 
Data Structures:
Board: 9 element vector representing the board, with 1-9 for each
square. An element contains the value 0 if it is blank, 1 if it is filled by
X, or 2 if it is filled with a O
0 = blank,           1 =X,                   2 = O
 
 
 
 
 
 
Movetable: A large vector of 19,683 elements (
3
9
), each element  is 9-
element vector
.(
3
9
 = 19,683 ways to arrange (blank, X, O) in 9
spaces)
 
Algorithm:
 
1.
 
View the vector as a ternary number. Convert it to a
 
decimal number.
 
2.
 
Use the computed number as an index into
 
Move-Table and access the vector stored there.
 
3.
 
Set the new board to that vector.
 
 
Introductory Problem: Tic-Tac-Toe-1
 
Introductory Problem: Tic-Tac-Toe-1
1             2          3          4          5            6           7         8            9
 
000 000 000
 
000 010 000
 
.
.
.
 
Introductory Problem: Tic-Tac-Toe-1
 
Introductory Problem: Tic-Tac-Toe-1
 
M
o
v
e
t
a
b
l
e
 
-
-
 
Introductory Problem: Tic-Tac-Toe-1
 
0
 
 
 
 
 
 
 
1
 
 
 
-
-
 
 
 
 
 
19682
 
Comments:
This program is very efficient in time. Theoritically it can play
optimal game
 
1.
 
A lot of space to store the Move-Table that specifies correct
move to make from each board position
 
2.
 
A lot of work to specify all the entries in the
 
Move-Table.
 
3.
It is unlikely that all the required Move-Table entries can be
determined and entered without errors
 
4.   The method is specific to this game and cannot be extended.
 
Introductory Problem: Tic-Tac-Toe-1
 
Data Structures:
 
Board : Nine element vector representation. There will be nine integer
variables Board[1] – Board[9]. Each variable can store only a 2 indicating a
blank, 3 indicating an X, and 5 indicating an O.
.
2 = blank,
           
3 =X,
                   
5 = O
 
Turn: An integer indicating which move of the game is to be played
                    1 indicate the first move.
                     9 indicate the last move.
 
X and O: Constants representing X and O which represents the player
 
Introductory Problem: Tic-Tac-Toe-2
 
 
1) make2: tries to make two in a row. It first tries to play in the
 center then tries non-corner squares.
2) Posswin(p):
 
        if player p cannot win in the next move
   
Return 0
 
                    else
 
       
 
          Returns the number of square that
   
constitutes a winning move
 
            (posswin checks each row, column, and diagonal)
    * If (product == 18) X can win ((3 * 3 * 2) = 18)
     * If (product == 50) O can win ((5 * 5 * 2) = 50)
 
3)Go(n): 
Go(n) makes a move in square n
           This procedure set Board[n] to 3 if Turn is odd, or 5 if Turn is even. Also
 
increments Turn by 1.
 
 
F
u
n
c
t
i
o
n
s
:
 
Introductory Problem: Tic-Tac-Toe-2
 
Turn = 1                  Go(1) – upper left corner of board
Turn = 2                  If Board[5] = 2 Then Go(5) else Go (1)
Turn = 3                  If Board[9] = 2 Then Go(9) else Go(3)
Turn = 4                  If PossWin(X) != 0 Then Go(PossWin(X)) [block opponents move]
                                      else Go(make2)
Turn = 5                  If PossWin(X) != 0 Then Go(PossWin(X)) [win]
                                      else if   PossWin(O) != 0 Then Go(PossWin(0)[ block win ]
                                      else if  Board[7] = 2 Then Go(7) else Go(3)
Turn = 6                  if PossWin(]O) != 0 Then Go(PossWin(O))
                                      else if   PossWin(X) != 0 Then Go(PossWin(X))
                                      else   Go(make2).
Turn = 7                  If PossWin(X) != 0 Then Go(PossWin(X))
                                      else if   PossWin(O) != 0 Then Go(PossWin(O),
                                      else go  anywhere there is a blank spot.
Turn = 8                  If PossWin(O) != 0 Then Go(PossWin(O))
                                      else if   PossWin(X) != 0 Then Go(PossWin(X)),
                                      else  go anywhere  there is a blank spot
Turn = 9                   Same as Turn 7
 
T
T
h
h
e
e
 
 
a
a
l
l
g
g
o
o
r
r
i
i
t
t
h
h
m
m
 
 
h
h
a
a
s
s
 
 
a
a
 
 
b
b
u
u
i
i
l
l
t
t
 
 
i
i
n
n
 
 
s
s
t
t
r
r
a
a
t
t
e
e
g
g
y
y
 
 
f
f
o
o
r
r
 
 
e
e
a
a
c
c
h
h
 
 
m
m
o
o
v
v
e
e
 
 
i
i
t
t
 
 
m
m
a
a
y
y
m
m
a
a
k
k
e
e
.
.
 
 
I
I
t
t
 
 
m
m
a
a
k
k
e
e
s
s
 
 
t
t
h
h
e
e
 
 
o
o
d
d
d
d
 
 
n
n
u
u
m
m
b
b
e
e
r
r
e
e
d
d
 
 
m
m
o
o
v
v
e
e
s
s
 
 
i
i
f
f
 
 
i
i
t
t
 
 
i
i
s
s
 
 
p
p
l
l
a
a
y
y
i
i
n
n
g
g
 
 
X
X
,
,
 
 
t
t
h
h
e
e
e
e
v
v
e
e
n
n
 
 
n
n
u
u
m
m
b
b
e
e
r
r
e
e
d
d
 
 
m
m
o
o
v
v
e
e
s
s
 
 
i
i
f
f
 
 
i
i
t
t
 
 
i
i
s
s
 
 
p
p
l
l
a
a
y
y
i
i
n
n
g
g
 
 
0
0
 
Comments:
 
1.
 
Not efficient in time, as it has to check several
 
conditions before making each move.
 
2.
 
Easier to understand the program’s strategy.
 
3.  
It depends on programmer's skill
 
4.  
Cannot generalize any program’s knowledge to a different
domain
 
 
 
Introductory Problem: Tic-Tac-Toe-2
 
15
 
 (
8 
+
 5
)
 
Introductory Problem: Tic-Tac-Toe-2’
 
15
 
15
 
15
 
Data Structures
 
 BOARD
 
Nine element vector representation.
   BOARD VECTOR HAS BEEN CHANGED TO
   SO EVERY ROW, COLUMN, DIAGONAL ADD UP TO 15
    2 = blank,           3 =X,                   5 = O
 
TURN
AN INTEGER INDICATING WHICH MOVE IS TO BE PLAYED. 1 IS THE
FIRST MOVE, 9 IS THE LAST.
 
X and O: Constants representing X and O which represents the player
 
Introductory Problem: Tic-Tac-Toe-2’
 
 
 
Posswin(p):
to check for win — keep track of
 
      player’s “squares”. If difference of 15 and sum of two squares
 
      is ≤ 0 or > 9 two squares
                   are not collinear. Otherwise, if square equal to difference is
 
      blank, move there.
                                                   or
                  (S = sum of two paired owned by a player
 
             D = 15 – S
 
             if 0 < D < 10 and Board [D] is empty then return D (the player
 
             can win possible win check:))
 
 
 
 
Introductory Problem: Tic-Tac-Toe-2’
 
Comments:
 
CHOICE OF REPRESENTATION HAS MAJOR IMPACT ON PROBLEM-
SOLVING.
 
ROW-SCAN IS EASIER, NUMBER-COUNTING is EFFICIENT FOR A
COMPUTER
 
C
O
M
P
U
T
E
R
 
L
O
O
K
S
 
A
T
 
T
H
E
 
B
O
A
R
D
 
O
N
E
 
S
Q
U
A
R
E
 
A
T
 
A
 
T
I
M
E
.
 
 
 
Introductory Problem: Tic-Tac-Toe-2’
 
D
a
t
a
 
S
t
r
u
c
t
u
r
e
s
:
1
)
 
B
o
a
r
d
 
p
o
s
i
t
i
o
n
:
 
A
 
S
T
R
U
C
T
U
R
E
 
c
o
n
t
a
i
n
i
n
g
o
- a nine element vector representing the board
o
- A list of board positions that could result from the next move.
o
- a number representing/estimating the likelihood of winning for each move
 
A
l
g
o
r
i
t
h
m
:
T
o
 
d
e
c
i
d
e
 
o
n
 
n
e
x
t
 
m
o
v
e
1) Look at list of subsequent board positions
2) decide which one is best(as described below), make the move and assign
the rating of that best move to the current position.
D
e
c
i
d
i
n
g
 
w
h
i
c
h
 
m
o
v
e
 
i
s
 
b
e
s
t
:
For each move
1) See if it is a win, if yes give it highest rating
2) If not a win:
o
Consider all moves opponent could make next
o
See which of them is worst for us (recursive call)
Assume the opponent will make this move (What is worst for us is best for
opponent) 
Assign the rating of that move to the current node.
3.The best node is then the one with the highest rating.
 
Introductory Problem: Tic-Tac-Toe-3
 
q
A
I
 
T
E
C
H
N
I
Q
U
E
S
q
K
n
o
w
l
e
d
g
e
 
R
e
p
r
e
s
e
n
t
a
t
i
o
n
:
 
r
e
p
r
e
s
e
n
t
 
t
h
e
c
o
m
p
u
t
e
r
s
 
k
n
o
w
l
e
d
g
e
 
o
f
 
t
h
e
 
w
o
r
l
d
 
b
y
 
s
o
m
e
 
k
i
n
d
o
f
 
d
a
t
a
 
s
t
r
u
c
t
u
r
e
s
 
i
n
 
t
h
e
 
m
a
c
h
i
n
e
s
 
m
e
m
o
r
y
q
S
e
a
r
c
h
:
 
a
 
p
r
o
b
l
e
m
-
s
o
l
v
i
n
g
 
t
e
c
h
n
i
q
u
e
 
t
h
a
t
s
y
s
t
e
m
a
t
i
c
a
l
l
y
 
e
x
p
l
o
r
e
s
 
a
 
s
p
a
c
e
 
o
f
 
p
r
o
b
l
e
m
s
t
a
t
e
s
q
A
b
s
t
r
a
c
t
i
o
n
:
 
p
r
o
v
i
d
e
s
 
w
a
y
 
o
f
 
s
e
p
a
r
a
t
i
n
g
i
m
p
o
r
t
a
n
t
 
f
e
a
t
u
r
e
s
 
f
r
o
m
 
u
n
i
m
p
o
r
t
a
n
t
 
o
n
e
s
CRITERIA FOR SUCCESS
CRITERIA FOR SUCCESS
 
H
o
w
 
w
i
l
l
 
w
e
 
k
n
o
w
 
i
f
 
w
e
 
h
a
v
e
 
s
u
c
c
e
e
d
e
d
?
 
H
o
w
 
w
i
l
l
 
w
e
 
k
n
o
w
 
i
f
 
w
e
 
h
a
v
e
 
c
r
e
a
t
e
d
 
a
 
m
a
c
h
i
n
e
 
 
t
h
a
t
 
i
s
 
i
n
t
e
l
l
i
g
e
n
t
 
we can measure our progress of program
we can measure our progress of program
 
Criteria for Success
Criteria for Success
 
    * Turing test
    * Turing test
 
If the interrogator cannot distinguish the machine from the human, then the
machine may be assumed to be intelligent.
 
We need two people and the
machine.
The interrogator
 He cannot see and speak
to either
 does not know which is
actually machine
May communicate with
them solely by textual
device
 
Turing test
Turing test
 
CRITERIA FOR SUCCESS
CRITERIA FOR SUCCESS
 
It is possible to measure  the achievement  of a program.
    example chess program.
 
DENDRAL is a program that analyzes organic compounds to
determine their structure.
 
It is possible to compare the time taken by a program to complete a
task to the required by a human.
 
we want the programs that fails when people do.
 
 
 
CRITERIA FOR SUCCESS
CRITERIA FOR SUCCESS
Slide Note
Embed
Share

Artificial Intelligence (AI) techniques leverage knowledge representation to achieve generalization, ease of adaptation, and problem-solving capabilities. Knowledge, although voluminous and dynamic, is crucial for developing effective AI solutions. By capturing important properties and enabling adjustments, AI techniques can be applied to various scenarios, enhancing the clarity and extensibility of problem-solving approaches. Explore the evolution of AI techniques through examples such as playing tic-tac-toe, illustrating the progression in complexity, generalization, knowledge clarity, and approach flexibility.


Uploaded on Aug 14, 2024 | 0 Views


Download Presentation

Please find below an Image/Link to download the presentation.

The content on the website is provided AS IS for your information and personal use only. It may not be sold, licensed, or shared on other websites without obtaining consent from the author. Download presentation by click this link. If you encounter any issues during the download, it is possible that the publisher has removed the file from their server.

E N D

Presentation Transcript


  1. Artificial Intelligence Technique

  2. AI Technique One of the results to come out of the first three decades of AI research is that intelligence requires knowledge. What disadvantages does knowledge possess ? 1) It has a great amount of volume. 2) It is hard to characterize and identify correctly. 3) It is endlessly changing. 4) Knowledge is different from data, because it is organized in a way that agrees to the ways it will be used.

  3. AI Technique AI technique is a method that exploits knowledge that should be represented in such a way that: 1) The knowledge captures generalization. What this means is grouping situations that share important properties rather than representing each situation seperatly. The advantage that knowledge has would be that unreasonable amounts of memory and updating will no longer be required. Anything without this property is called 'data' rather than knowledge. 2) It should be represented in such a way that it can be understood by the people who must prepare it. For many programs the size of the data can be acheived automatically by (taking readings from a number of instruments), but in many AI areas, most of the knowledge a program has must basically be provided by people in terms that they understand it.

  4. AI Technique 3) It could easily be adjusted to correct errors and to demonstrate changes in the world. 4) It could be used in different situations even though it may not entirely be complete.

  5. AI Technique It is possible to solve AI problems without using techniques but those solutions may not be good. It is possible to apply AI techniques to the solution of non-AI problems. Try to characterize AI techniques as problem independent.

  6. AI Technique Let s look at one problem and a series of approaches for solving the same Three programs are presented to play tic tac toe: the program in this series increase in Their complexity Use of generalization Clarity of their knowledge Extensibility of their approach

  7. Introductory Problem: Tic-Tac-Toe-1 Tic-tac-toe, is a pencil-and-paper game for two players, O and X, who take turns marking the spaces in a 3 3 grid. The player who succeeds in placing three respective marks in a horizontal, vertical or diagonal row wins the game. X o o X X o X win

  8. Introductory Problem: Tic-Tac-Toe-1 Program 1: Data Structures: Board: 9 element vector representing the board, with 1-9 for each square. An element contains the value 0 if it is blank, 1 if it is filled by X, or 2 if it is filled with a O 0 = blank, 1 =X, 2 = O 1 2 3 4 5 6 7 8 9 Movetable: A large vector of 19,683 elements (39), each element is 9- element vector.(39 = 19,683 ways to arrange (blank, X, O) in 9 spaces) Algorithm: 1. View the vector as a ternary number. Convert it to a decimal number. 2. Use the computed number as an index into Move-Table and access the vector stored there. 3. Set the new board to that vector.

  9. Introductory Problem: Tic-Tac-Toe-1 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9

  10. Introductory Problem: Tic-Tac-Toe-1 000 000 000 000 000 000 000 010 000 000 000 001 . . . . . . 222 222 222

  11. Introductory Problem: Tic-Tac-Toe-1 move table encode look up

  12. Introductory Problem: Tic-Tac-Toe-1 0 Movetable Movetable 0 0 0 0 1 0 0 0 0 1 2 0 0 0 0 1 0 0 0 - - - - 1 0 2 1 2 0 1 2 1 19682

  13. Introductory Problem: Tic-Tac-Toe-1 Comments: This program is very efficient in time. Theoritically it can play optimal game 1. A lot of space to store the Move-Table that specifies correct move to make from each board position 2. A lot of work to specify all the entries in the Move-Table. 3. It is unlikely that all the required Move-Table entries can be determined and entered without errors 4. The method is specific to this game and cannot be extended.

  14. Introductory Problem: Tic-Tac-Toe-2 1 2 3 4 5 6 Data Structures: 7 8 9 Board : Nine element vector representation. There will be nine integer variables Board[1] Board[9]. Each variable can store only a 2 indicating a blank, 3 indicating an X, and 5 indicating an O.. 2 = blank, 3 =X, 5 = O 1 indicate the first move. 9 indicate the last move. Turn: An integer indicating which move of the game is to be played X and O: Constants representing X and O which represents the player

  15. Introductory Problem: Tic-Tac-Toe-2 Functions: 1) make2: tries to make two in a row. It first tries to play in the center then tries non-corner squares. 2) Posswin(p): if player p cannot win in the next move Return 0 else Returns the number of square that constitutes a winning move (posswin checks each row, column, and diagonal) * If (product == 18) X can win ((3 * 3 * 2) = 18) * If (product == 50) O can win ((5 * 5 * 2) = 50) 3)Go(n): Go(n) makes a move in square n This procedure set Board[n] to 3 if Turn is odd, or 5 if Turn is even. Also increments Turn by 1.

  16. The algorithm has a built in strategy for each move it may make. It makes the odd numbered moves if it is playing X, the even numbered moves if it is playing 0 Turn = 1 Go(1) upper left corner of board Turn = 2 If Board[5] = 2 Then Go(5) else Go (1) Turn = 3 If Board[9] = 2 Then Go(9) else Go(3) else Go(make2) Turn = 4 If PossWin(X) != 0 Then Go(PossWin(X)) [block opponents move] else if PossWin(O) != 0 Then Go(PossWin(0)[ block win ] else if Board[7] = 2 Then Go(7) else Go(3) Turn = 5 If PossWin(X) != 0 Then Go(PossWin(X)) [win] else if PossWin(X) != 0 Then Go(PossWin(X)) else Go(make2). Turn = 6 if PossWin(]O) != 0 Then Go(PossWin(O)) else if PossWin(O) != 0 Then Go(PossWin(O), else go anywhere there is a blank spot. Turn = 7 If PossWin(X) != 0 Then Go(PossWin(X)) else if PossWin(X) != 0 Then Go(PossWin(X)), else go anywhere there is a blank spot Turn = 8 If PossWin(O) != 0 Then Go(PossWin(O)) Turn = 9 Same as Turn 7

  17. Introductory Problem: Tic-Tac-Toe-2 Comments: 1. Not efficient in time, as it has to check several conditions before making each move. 2. Easier to understand the program s strategy. 3. It depends on programmer's skill 4. Cannot generalize any program s knowledge to a different domain

  18. Introductory Problem: Tic-Tac-Toe-2 15 8 3 4 15 1 5 9 6 7 2 15 8 1 6 15 (8 + 5) 3 4 5 9 7 2

  19. Introductory Problem: Tic-Tac-Toe-2 Posswin(p):to check for win keep track of player s squares . If difference of 15 and sum of two squares is 0 or > 9 two squares are not collinear. Otherwise, if square equal to difference is blank, move there. or (S = sum of two paired owned by a player D = 15 S if 0 < D < 10 and Board [D] is empty then return D (the player can win possible win check:))

  20. Introductory Problem: Tic-Tac-Toe-2 Comments: CHOICE OF REPRESENTATION HAS MAJOR IMPACT ON PROBLEM- SOLVING. ROW-SCAN IS EASIER, NUMBER-COUNTING is EFFICIENT FOR A COMPUTER COMPUTER LOOKS AT THE BOARD ONE SQUARE AT A TIME.

  21. Introductory Problem: Tic-Tac-Toe-3 Data Structures: Data Structures: 1) Board position: A STRUCTURE containing A STRUCTURE containing o- a nine element vector representing the board o- A list of board positions that could result from the next move. o- a number representing/estimating the likelihood of winning for each move Algorithm: Algorithm: To decide on next move To decide on next move 1) Look at list of subsequent board positions 2) decide which one is best(as described below), make the move and assign the rating of that best move to the current position. Deciding which move is best: Deciding which move is best: For each move 1) See if it is a win, if yes give it highest rating 2) If not a win: oConsider all moves opponent could make next oSee which of them is worst for us (recursive call) Assume the opponent will make this move (What is worst for us is best for opponent) Assign the rating of that move to the current node. 3.The best node is then the one with the highest rating.

  22. AI TECHNIQUES Knowledge Representation: represent the computer s knowledge of the world by some kind of data structures in the machine s memory Search: a problem-solving technique that systematically explores a space of problem states Abstraction: provides way of separating important features from unimportant ones

  23. CRITERIA FOR SUCCESS How will we know if we have succeeded? How will we know if we have created a machine that is intelligent we can measure our progress of program

  24. Criteria for Success * Turing test

  25. CRITERIA FOR SUCCESS Turing test We need two people and the machine. The interrogator He cannot see and speak to either does not know which is actually machine May communicate with them solely by textual device If the interrogator cannot distinguish the machine from the human, then the machine may be assumed to be intelligent.

Related


More Related Content

giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#