Python을 사용한 AI – 휴리스틱 검색
휴리스틱 검색은 인공 지능에서 핵심적인 역할을합니다. 이 장에서는 이에 대해 자세히 배웁니다.
인공 지능의 휴리스틱 검색 개념
휴리스틱은 우리를 가능한 해결책으로 이끄는 경험 법칙입니다. 인공 지능의 대부분의 문제는 기하 급수적이며 가능한 많은 해결책이 있습니다. 어떤 솔루션이 올바른지 정확히 알지 못하며 모든 솔루션을 확인하는 데 비용이 많이 듭니다.
따라서 휴리스틱을 사용하면 솔루션 검색 범위가 좁아지고 잘못된 옵션이 제거됩니다. 휴리스틱을 사용하여 검색 공간에서 검색을 유도하는 방법을 휴리스틱 검색이라고합니다. 휴리스틱 기술은 사용할 때 검색을 향상시킬 수 있기 때문에 매우 유용합니다.
정보가없는 검색과 정보가없는 검색의 차이점
제어 전략 또는 검색 기술에는 정보가없는 것과 정보가있는 두 가지 유형이 있습니다. 여기에 주어진대로 자세히 설명되어 있습니다.
정보가없는 검색
블라인드 검색 또는 블라인드 제어 전략이라고도합니다. 문제 정의에 대한 정보 만 있고 상태에 대한 다른 추가 정보가 없기 때문에 이름이 지정되었습니다. 이러한 종류의 검색 기술은 솔루션을 얻기 위해 전체 상태 공간을 검색합니다. BFS (Breadth First Search) 및 DFS (Depth First Search)는 정보가없는 검색의 예입니다.
정보에 입각 한 검색
휴리스틱 검색 또는 휴리스틱 제어 전략이라고도합니다. 주에 대한 추가 정보가 있기 때문에 이름이 붙여졌습니다. 이 추가 정보는 탐색 및 확장 할 하위 노드 간의 선호도를 계산하는 데 유용합니다. 각 노드와 관련된 휴리스틱 기능이 있습니다. BFS (Best First Search), A *, 평균 및 분석은 정보에 입각 한 검색의 예입니다.
제약 만족 문제 (CSP)
제약은 제한 또는 제한을 의미합니다. AI에서 제약 만족 문제는 일부 제약 조건에서 해결해야하는 문제입니다. 이러한 문제를 해결하면서 제약을 위반하지 않는 데 초점을 두어야합니다. 마지막으로 최종 솔루션에 도달하면 CSP는 제한 사항을 준수해야합니다.
제약 만족으로 해결되는 현실 세계 문제
이전 섹션에서는 제약 만족 문제 생성에 대해 설명했습니다. 이제 이것을 실제 문제에도 적용 해 보겠습니다. 제약 만족으로 해결 된 실제 문제의 몇 가지 예는 다음과 같습니다.
대수 관계 풀기
제약 만족 문제의 도움으로 우리는 대수 관계를 풀 수 있습니다. 이 예에서는 간단한 대수 관계를 풀려고합니다.a*2 = b. 값을 반환합니다.a 과 b 우리가 정의 할 범위 내에서.
이 Python 프로그램을 완료하면 제약 조건 만족으로 문제를 해결하는 기본 사항을 이해할 수 있습니다.
프로그램을 작성하기 전에 python-constraint라는 Python 패키지를 설치해야합니다. 다음 명령을 사용하여 설치할 수 있습니다.
pip install python-constraint
다음 단계는 제약 조건 만족을 사용하여 대수 관계를 해결하기위한 Python 프로그램을 보여줍니다.
가져 오기 constraint 다음 명령을 사용하여 패키지-
from constraint import *
이제 다음과 같은 모듈의 개체를 만듭니다. problem() 아래와 같이-
problem = Problem()
이제 변수를 정의하십시오. 여기에 두 개의 변수 a와 b가 있고 10을 범위로 정의하고 있습니다. 즉, 처음 10 개의 숫자 내에서 해를 구했습니다.
problem.addVariable('a', range(10))
problem.addVariable('b', range(10))
다음으로이 문제에 적용 할 특정 제약 조건을 정의하십시오. 여기에서 제약 조건을 사용하고 있음을 관찰하십시오.a*2 = b.
problem.addConstraint(lambda a, b: a * 2 == b)
이제 다음 개체를 만듭니다. getSolution() 다음 명령을 사용하는 모듈-
solutions = problem.getSolutions()
마지막으로 다음 명령을 사용하여 출력을 인쇄하십시오.
print (solutions)
위 프로그램의 출력을 다음과 같이 관찰 할 수 있습니다.
[{'a': 4, 'b': 8}, {'a': 3, 'b': 6}, {'a': 2, 'b': 4}, {'a': 1, 'b': 2}, {'a': 0, 'b': 0}]
매직 스퀘어
매직 스퀘어는 각 행과 각 열의 숫자와 대각선의 숫자가 모두 '마법 상수'라고하는 동일한 숫자가되는 정사각형 그리드에서 고유 한 숫자 (일반적으로 정수)의 배열입니다. .
다음은 매직 스퀘어를 생성하기위한 간단한 Python 코드의 단계적 실행입니다.
이름이 지정된 함수 정의 magic_square, 아래와 같이-
def magic_square(matrix_ms):
iSize = len(matrix_ms[0])
sum_list = []
다음 코드는 사각형의 수직 코드를 보여줍니다-
for col in range(iSize):
sum_list.append(sum(row[col] for row in matrix_ms))
다음 코드는 수평 제곱에 대한 코드를 보여줍니다-
sum_list.extend([sum (lines) for lines in matrix_ms])
다음 코드는 사각형의 수평 코드를 보여줍니다-
dlResult = 0
for i in range(0,iSize):
dlResult +=matrix_ms[i][i]
sum_list.append(dlResult)
drResult = 0
for i in range(iSize-1,-1,-1):
drResult +=matrix_ms[i][i]
sum_list.append(drResult)
if len(set(sum_list))>1:
return False
return True
이제 행렬의 값을 제공하고 출력을 확인하십시오.
print(magic_square([[1,2,3], [4,5,6], [7,8,9]]))
출력이 False 합계가 같은 숫자가 아니기 때문에.
print(magic_square([[3,9,2], [3,5,7], [9,1,6]]))
출력이 True 합계가 같은 숫자이므로 15 여기.