챗봇은 어떻게 대답할까? 룰 기반과 AI 챗봇의 차이

3 분 소요

고객센터에 들어가면 무엇을 도와드릴까요라는 채팅창이 먼저 뜹니다. 어떤 챗봇은 정해진 버튼만 누르게 하고, 어떤 챗봇은 사람처럼 자유롭게 대화를 주고받습니다. 같은 챗봇처럼 보여도 안에서 대답을 만들어 내는 방식이 사뭇 다릅니다.

이번 글에서는 챗봇이 어떻게 대답을 만들어 내는지, 룰 기반 챗봇과 AI 챗봇이 어떻게 다른지를 코드 없이 풀어 보겠습니다.

챗봇은 크게 두 종류입니다 #

챗봇은 대답을 만드는 방식에 따라 크게 둘로 나뉩니다. 하나는 미리 정해 둔 규칙을 따라 답하는 룰 기반 챗봇이고, 다른 하나는 AI가 문장을 이해하고 답을 지어내는 AI 챗봇입니다.

겉모습은 비슷한 채팅창이라 구분이 잘 안 되지만, 둘은 잘하는 일과 못하는 일이 분명히 다릅니다. 그 차이를 알면 어떤 챗봇이 어디에 어울리는지 가늠할 수 있습니다.

룰 기반 챗봇은 정해진 길을 따라갑니다 #

룰 기반 챗봇은 사람이 미리 짜 둔 시나리오를 따라 움직입니다. 배송 문의를 누르면 배송 안내를, 환불을 누르면 환불 절차를 보여 주는 식입니다. 특정 단어가 들어오면 정해진 답을 내놓도록 규칙을 걸어 두기도 합니다.

이 방식은 예측 가능하고 안정적입니다. 정해진 답만 내놓으니 엉뚱한 소리를 할 일이 없습니다. 대신 미리 짜 둔 길을 벗어난 질문에는 약합니다. 사용자가 예상 밖으로 물으면 이해하지 못했어요를 되풀이하며 막히는 챗봇이 대개 이 방식입니다.

AI 챗봇은 문장을 이해하고 만들어 냅니다 #

AI 챗봇은 앞서 다룬 LLM을 바탕에 둡니다. 정해진 버튼이 아니라 사용자가 자유롭게 쓴 문장을 이해하고, 그에 맞는 답을 즉석에서 문장으로 지어냅니다. 똑같은 질문을 다르게 표현해도 알아듣고, 미리 짜 두지 않은 질문에도 대응합니다.

다만 약점도 분명합니다. AI는 그럴듯하지만 사실과 다른 답을 자신 있게 내놓기도 합니다. 흔히 환각이라고 부르는 현상입니다. 그래서 정확성이 중요한 안내를 AI 챗봇에만 맡기는 것은 위험할 수 있습니다.

실무에서는 둘을 섞습니다 #

그래서 실제 서비스는 두 방식을 함께 씁니다. 배송 조회나 영업시간처럼 자주 묻고 답이 정해진 질문은 룰 기반으로 빠르고 정확하게 처리하고, 자유롭고 복잡한 질문은 AI에 맡기는 식입니다.

여기에 한 가지 장치를 더하기도 합니다. AI가 아무 말이나 지어내지 않도록, 회사의 공식 자료나 도움말 문서를 함께 참고하게 하는 것입니다. AI가 그 자료 안에서 근거를 찾아 답하게 하면, 환각을 줄이면서도 자연스러운 대화를 얻을 수 있습니다.

좋은 챗봇은 한계를 압니다 #

잘 만든 챗봇은 자기가 못 푸는 질문을 붙들고 있지 않습니다. 해결이 어려우면 깔끔하게 사람 상담원에게 넘깁니다. 챗봇의 목표는 모든 것을 혼자 답하는 것이 아니라, 쉬운 것은 빠르게 처리하고 어려운 것은 알맞은 사람에게 연결하는 것입니다.

다룰 범위를 분명히 정하는 것도 중요합니다. 무엇이든 답하려다 환각으로 잘못된 정보를 주느니, 다루는 범위를 좁히고 그 안에서 정확하게 답하는 것이 신뢰를 지키는 길입니다.

왜 비개발자가 알면 일이 편해지는가 #

  • 도입을 판단합니다. 정형 질문이 많은지 자유로운 질문이 많은지에 따라 룰 기반과 AI 중 무엇이 맞는지 가늠할 수 있습니다.
  • 시나리오를 설계합니다. 룰 기반 챗봇이 정해진 길을 따른다는 점을 알면, 자주 묻는 질문을 정리해 막힘없는 흐름을 짤 수 있습니다.
  • 한계를 설명합니다. AI 챗봇이 환각을 낼 수 있다는 점을 알면, 어디까지 맡기고 어디서 사람에게 넘길지 기준을 세울 수 있습니다.

마무리 #

오늘은 챗봇이 룰 기반과 AI 기반으로 나뉘고, 실무에서는 둘을 섞어 쓰며, 좋은 챗봇은 자기 한계를 알고 사람에게 넘길 줄 안다는 점을 살펴봤습니다. 정해진 길을 정확히 가는 룰 기반과, 자유롭게 이해하되 가끔 틀리는 AI의 차이를 아는 것이 핵심입니다.

AI 챗봇의 바탕인 AI와 LLM의 큰 그림이 궁금하다면 AI,머신러닝,LLM 큰 그림을, LLM이 어떻게 문장을 만들어 내는지 더 알고 싶다면 LLM은 어떻게 다음 단어를 예측하는가를 함께 읽어 보시길 권합니다.

X