1. 비헤이비어 트리 소개
비헤이비어 트리는 게임 AI같은 거를 빠르고 쉽게, 그리고 가독성도 좋고 재활용성도 좋게 만드는데 특화되어있다.
FSM, HFSM이 상태가 많아지면 유지보수, 가독성 등을 잃게 되는 단점을 보완했다고 볼 수 있다.
(FSM과 BT의 차이를 대략적으로 보여줌)
비헤이비어 트리는 HFSM과 마찬가지로 계층적인 특성을 띄고 있는데, (HFSM이랑 약간 유사한데, BT가 더 조직화 됐다고 보면됨.)
다만 HFSM처럼 각 상태에서 조건을 체크하고, 직접 상태를 이전시키는 것이 아닌, 각 노드는 True, False, (Running) 값을 조건에 따라서 결과값을 반환 하지만, 전이 자체는 다른 노드가 처리한다.
FSM의 경우에는 A에서 B로 전이를 하려면, 해당 상태 내부에서 SetState를 해야했지만, BT의 경우에는 부모노드 혹은 조상노드 중 하나가 알아서 전이를 해준다. 그로인해, 각 노드는 역할을 부여받은 독립적인 처리만 담당하면 되고, 그를 엮어 주는 녀석을 따로 있게 된다. 또한 각 노드들은 우선순위를 받게 되는데, 이는 자식노드의 순서를 통해 이루어지게 된다. 즉, 먼저 처리하거나 확인했으면 하는 것들을 더 손쉽게 설정할 수 있다.
예를들면, A하고 B하게 짰는데, 갑자기 B하고 A하게 수정해야 된다면 그냥 자식노드의 순서만 바꿔주면 된다.
하나의 큰 행동 (테스트, EX_ 공격) 같은 것들이 서브트리로 이루어지기 때문에, 해당 행동을 찾기 쉽고, 다른 AI에 복붙하기 쉽다. 이러한 구조적인 특징 덕분에 비헤이비어 트리는 이름 그대로, 트리로 이루어 지게 된다. (FSM, HFSM은 그래프임)
가독성
트리 구조이기 때문에, 위에서 아래로 쭉 읽어 오면서 볼 수 있다. 즉, 비헤이비어 트리는 흐름이 한눈에 보인다. 또한 전이를 담당하는 노드가 따로 있기 때문에, AI의 행동이 뭔가 이상할때, 빠르게 체크해 볼 수 있다. 덧붙여, 특정 행동이 뭔가 이상하게 작동한다면, 그 행동만 콕 집어서 T, F 조건이 이상한지, 행동이 이상한지 확인해 볼 수 있다. 하나의 큰 행동이 이상한거 같을때 (ex_공격이 좀 이상한데?) 손쉽게 관련 큰 행동를 찾아낼 수 있다. 또한 어떤 조건이 우선순위가 높은지 한눈에 확인하고, 그 순서가 잘못 됐는지 쉽게 판단할 수 있다.
유지보수
추가
(비슷한 행동을 추가 할때)
FSM의 경우에는 일부분 똑같이 작동하되, 그외 부분이 좀 다르면은, 일단 공통되는 부분을 복사하고, 다르게 작동하는 행동 관련 전이조건을 설정하고 다르게 작동하는 상태조건에서도 복사한 부분에 연관되는 부분을 수정하는 등.. 손이 많이간다. 비헤이비어 트리의 경우에는 그냥 전이조건 노드 하나 때와서 적절한 조건 노드의 자식으로 추가하면 된다.
(완전 다른 행동을 추가 할때)
만약 공격 패턴 중에 점프를 하나 추가하고 싶다면, 공격 행동의 자식으로 있는 공격 행동 노드들 사이에 점프 행동을 형제 노드로 집어넣어주면 끝난다. (공격 패턴 중 행동을 하나 제외하는 것도 마찬가지다.)
삭제
그냥 노드를 삭제하면 된다. (만약 FSM이었다면, 그 노드와 연관된 모든 노드를 수정해야 됐을 것이다.) 그냥 잎 노드를 삭제해야 하는 경우라면, 어차피 다른 자식노드로 알아서 전이조건 담당 노드가 바꿔 줄꺼니까 신경안써도 된다. 그리고 각 노드는 독립적이기 때문에, 삭제했다고 다음노드가 뻑가거나 할 가능성은 적다.
전이를 담당하는 노드가 삭제 된다는 것은, 특정 큰 행동이 삭제된다고 볼 수 있다. 예를 들면, 공격이라는 전이를 담당하는 노드가 있고, 자식 노드로는 에임조준, 총 발사, 재장전으로 이루어져 있다면, 공격노드를 삭제하는 것은, 그냥 공격을 삭제한다는 것이므로, 이 경우에도 대부분 그냥 지우면 된다.
수정
만약 특정 행동의 조건이 맘에 안들면, 그 조건을 담당하는 노드를 열어보고 수정하면 끝이다. 만약, 전이가 되는 작동원리가 맘에 안들면, 전이를 담당하는 노드만 수정하면 된다. 만약 A, B, C순서가 아닌 B, A, C 순서로 실행되고 싶다면, 자식노드의 순서만 바꿔주면 된다.
2. 비헤이비어 트리 설명
UE4에서 사용되는 이벤트 기반의 비헤이비어 트리와는 다른, 표준 비헤이비어 트리에 대한 설명이다.
비헤이비어 트리의 특징
1. 계층적인 구조, 트리다.
2. 각 노드는 Success (True), Failure (False), Running 를 반환한다.
3. Composite, Leaf, Decorator 중 하나로 노드 타입이 설정된다.
4. Leaf노드에서 행동(Action)을 처리한다. (항상은 아니고 보통 그렇게 함.)
5. BlackBoard는 BT에 필요한 데이터를 관리한다.
비헤이비어 트리 사진
이런식으로 이루어진다고 보면 된다.
사진 출처 : http://dolphin.ivyro.net/file/algorithm/ai/tutorial02.html
반환 타입
모든 노드가 공통적으로 가져야 하는 성질이다.
아래 값중 하나를 탐색때 마다 하나 반환해야 함.
Success (True) | 성공했을 때 반환 |
Failure (False) | 실패했을 때 반환 |
Running | 진행중이므로, 다음 탐색에서 Success, Failure, Running 중 하나 반환 |
Composite
전이를 담당 하는 노드, 자식노드들을 순차(왼쪽에서 오른쪽으로) or 랜덤으로 실행하면서 T, F 여부를 판단한다.
즉, 분기의 루트를 정의하고, 그 분기가 어떻게 실행되는지에 대한 기본 규칙을 정의한다. (ex_ 탐색 주기 등등..)
Sequence | Failure가 나오는 즉시 Failure 반환 모든 자식 노드가 Success면 Success 반환 |
Selector | Success가 나오는 즉시 Success반환 모든 자식 노드가 Failure면 Failure반환 |
Parallel | 모든 자식 노드를 병렬로 실행 |
Decorator
하나의 자식을 가지며, 자식 노드의 결과를 변형하거나, 반복시키는 역할이다.
Condition | 조건에 따라서 자식을 실행하거나 실패를 반환한다. |
Inverter | 자식의 결과를 반대로 출력 ex_) 자식이 Success면 Failure 반환 |
Loop | 일정 시간 또는 횟수 동안 자식을 반복실행 |
Blackboard
비헤이비어 트리의 데이터를 담당한다.
비헤이비어 트리에 필요한 데이터를 관리해준다.
EX_) 캐릭터가 이동해야 하는 위치, 추적중인 객체의 마지막 위치 등..
보다 더 자세한 예시들
FSM
FSM 구조에서 상태가 계속해서 늘어나면 나중에는 이런 구조가 된다.
HFSM (Hierachical Finite State Machines)
BT (Behavior Tree)
'CS > 자료구조 & 알고리즘' 카테고리의 다른 글
[C#] .NET의 연결 리스트 : LinkedList<T> (0) | 2023.08.29 |
---|---|
[C#] 힙 (Heap) (0) | 2023.08.29 |
C++ 프림(Prim) 알고리즘으로 MST 찾기 (0) | 2023.08.12 |
[C++] STL 연관 컨테이너(associative container), set, multiset (0) | 2023.08.11 |
[C++] STL 연관 컨테이너(associative container), map, multimap (0) | 2023.08.11 |