44 Commits

Author SHA1 Message Date
21in7
1d0522dc33 feat: standardize parameters for mine_resource action in AIPlanner to improve error handling and compatibility with LM Studio responses 2026-03-27 20:23:22 +09:00
21in7
d9801ee457 feat: implement action aliasing and parameter normalization in AIPlanner to enhance compatibility with LM Studio responses 2026-03-27 20:19:53 +09:00
21in7
66f3a327e8 feat: add action validation and sanitization in AIPlanner to ensure only allowed actions are processed 2026-03-27 20:14:52 +09:00
21in7
8e743d12e7 feat: enhance AIPlanner with compact system prompt and improved JSON parsing for input-only mode responses 2026-03-27 20:10:44 +09:00
21in7
d054f9aee1 feat: implement automatic payload candidate retry mechanism in AIPlanner for improved LM Studio compatibility 2026-03-27 20:07:32 +09:00
21in7
2cf072d38c feat: enhance AIPlanner payload structure for LM Studio compatibility by including 'input' field and improve response content extraction methods 2026-03-27 20:04:18 +09:00
21in7
4b104f2146 chore: update OLLAMA_HOST and API endpoint in AIPlanner, and add .cursor to .gitignore 2026-03-27 19:58:18 +09:00
kswdev0
c93785a809 chore: increase timeout for API requests in AIPlanner to 600 seconds and add local settings for Claude permissions 2026-03-27 14:46:28 +09:00
kswdev0
1b2688d1e1 refactor: update AIPlanner response format to JSON and simplify structure 2026-03-27 11:03:02 +09:00
kswdev0
dabce8b6fb refactor: replace Ollama client with HTTPX for API requests in AIPlanner 2026-03-27 10:59:43 +09:00
kswdev0
3fccbb20eb refactor: remove assistant message placeholder from AIPlanner user message format 2026-03-27 10:55:48 +09:00
kswdev0
f6947d7345 feat: modify user message format and enhance AIPlanner options with increased context size 2026-03-27 10:51:43 +09:00
kswdev0
a4ade0d5c0 fix: update default Ollama model to qwen3.5:9b 2026-03-27 09:39:38 +09:00
kswdev0
fe1f0c1193 feat: add think parameter to AIPlanner options for enhanced configuration 2026-03-27 09:38:44 +09:00
kswdev0
7014b47231 feat: enhance AIPlanner with loading spinner during Ollama requests and update print statements for clarity 2026-03-27 09:26:38 +09:00
kswdev0
82fa73342f fix: update default Ollama model to qwen3.5:9b-nothink 2026-03-27 09:14:13 +09:00
21in7
2d20e729f9 fix: change default model to qwen3.5:9b 2026-03-27 00:07:48 +09:00
21in7
2212dda22f feat: replace GLM API with local Ollama structured output, remove ~400 lines of JSON repair code 2026-03-27 00:00:19 +09:00
kswdev0
084c17418a fix: AIPlanner에서 finish_reason 처리 및 휴리스틱 폴백 로직 개선
- 응답의 finish_reason이 'length'이고 비JSON 텍스트가 포함된 경우, 즉시 상태 기반 휴리스틱 폴백으로 전환하는 로직 추가
- AIPlanner 클래스에 _last_glm_finish_reason 속성을 추가하여 이전 finish_reason을 추적
- README.md에 변경 사항 반영
2026-03-26 13:08:38 +09:00
kswdev0
9d3c7176d3 fix: AIPlanner JSON-only repair 및 빈 actions 처리 개선
- JSON-only repair를 한 번 적용했음에도 비JSON 텍스트가 계속 오는 경우, 즉시 상태 기반 휴리스틱 폴백으로 전환하는 로직 추가
- LLM이 빈 actions를 반환할 경우에도 즉시 휴리스틱 플랜으로 대체하여 진행을 유지하도록 개선
- README.md에 변경 사항 반영
2026-03-26 13:00:02 +09:00
kswdev0
64cd08297b fix: AIPlanner JSON-only repair 프롬프트 및 max_tokens 조정
- JSON-only repair 프롬프트의 내용을 간소화하여 명확한 요구사항을 전달하도록 수정
- 재시도 시 max_tokens를 250으로 줄이고, temperature를 0.0으로 설정하여 JSON 포맷 준수율을 높임
- README.md에 변경 사항 반영
2026-03-26 12:56:56 +09:00
kswdev0
9634362002 fix: AIPlanner에서 GLM 모델 버전 변경 및 JSON 응답 처리 개선
- GLM 모델 버전을 "GLM-4.7"에서 "GLM-4.5-Air"로 변경
- JSON 응답 처리 시, 재시도 시 max_tokens 및 temperature 조정 로직 추가하여 JSON 포맷 준수율 향상
- README.md에 변경 사항 반영
2026-03-26 12:54:59 +09:00
kswdev0
146e6b3982 fix: AIPlanner에서 HTTP 429 오류 처리 및 재시도 로직 개선
- GLM API에서 HTTP 429 (Rate limit) 오류 발생 시, 'Retry-After' 헤더를 확인하여 적절한 대기 시간을 설정하도록 로직 추가
- 재시도 시 기본 백오프 대신 'Retry-After' 값이 있을 경우 이를 우선 적용하여 대기 시간 조정
- README.md에 변경 사항 반영
2026-03-26 12:51:40 +09:00
kswdev0
c30fb426a8 fix: AIPlanner JSON 출력 요구사항 및 max_tokens 조정
- JSON 출력 요구사항을 명확히 하여 응답의 첫 비공백 문자가 반드시 `{` 이어야 함을 추가
- 재시도 시 max_tokens를 줄여 JSON 잘림 문제를 완화하는 로직 추가
- README.md에 변경 사항 반영
2026-03-26 11:58:08 +09:00
kswdev0
6e5f781529 feat: AIPlanner에서 건설 전 이동 보장 로직 추가
- `_ensure_move_before_build_actions` 메서드를 추가하여, LLM이 "move" 후 "place_entity"/"insert_to_entity"/"set_recipe" 순서를 놓치는 경우를 방지
- 최근 이동 좌표와 비교하여 필요 시 자동으로 이동 액션을 삽입하는 로직 구현
- 관련 단위 테스트 추가 및 README.md에 변경 사항 반영
2026-03-26 11:56:33 +09:00
kswdev0
e0ca8f7b52 feat: GLM 디버그 정보 출력 개선
- `_glm_debug_enabled()`가 활성화된 경우, JSON 응답에서 `finish_reason`을 출력하도록 로직 추가하여 디버깅 정보 강화
- 디버그 출력에 대한 가독성을 높여 문제 해결 시 유용한 정보 제공
2026-03-26 11:52:31 +09:00
kswdev0
3e90090b5e feat: AIPlanner JSON 파싱 실패 시 재시도 로직 개선
- JSON 파싱 실패 감지 시, 다음 재시도에 `JSON-only repair` 프롬프트를 추가하여 모델이 스키마를 준수하도록 유도하는 로직을 구현
- README.md에 JSON 파싱 실패 처리 및 재시도 로직에 대한 설명 추가
2026-03-26 11:48:44 +09:00
kswdev0
ace5d63480 feat: AIPlanner JSON 파싱 로직 개선 및 다중 JSON 객체 처리 추가
- `_parse_json()` 메서드에서 응답 내 여러 JSON 객체 중 `actions`를 포함한 계획 객체를 우선 선택하도록 로직 개선
- JSON 파싱 실패 시 잘림 복구 로직을 추가하여 안정성 향상
- 관련 단위 테스트 추가 및 README.md에 변경 사항 반영
2026-03-26 11:36:45 +09:00
kswdev0
db08db62a3 feat: GLM 디버그 정보 출력 추가
- `_glm_debug_enabled()`가 활성화된 경우, content와 reasoning의 길이 및 JSON 유사성 여부를 포함한 디버그 정보를 출력하도록 로직 추가
- 디버깅을 위한 content 및 reasoning의 미리보기 문자열도 포함하여 문제 해결 시 유용한 정보 제공
2026-03-26 11:20:12 +09:00
kswdev0
7353226603 feat: AIPlanner의 GLM 응답 처리 로직 개선
- content가 비어있거나 JSON 형태가 아닐 경우 reasoning_content를 우선 사용하도록 로직 개선
- JSON 유사성을 판단하는 헬퍼 함수 추가 및 기존 동작 유지
- 관련 단위 테스트 추가 및 README.md에 변경 사항 반영
2026-03-26 11:17:34 +09:00
kswdev0
a2648f9095 feat: GLM 응답에서 assistant 텍스트 추출 로직 개선 및 관련 경고 메시지 추가
- GLM 응답의 content가 비어있을 경우 reasoning_content를 대신 사용하도록 로직 개선
- 새로운 메서드 _extract_glm_assistant_text 추가하여 assistant 텍스트 추출을 명확히 함
- 관련 단위 테스트 추가 및 README.md에 변경 사항 반영
2026-03-26 11:11:24 +09:00
kswdev0
b014df06b8 feat: GLM 응답 content 비어있을 때 경고 메시지 추가 및 JSON 파싱 실패 처리 개선
- GLM 응답의 content가 비어있을 경우 경고 메시지를 출력하도록 로직 추가
- JSON 파싱 시 raw가 비어있을 경우 ValueError를 발생시켜 오류 처리를 강화
- 관련 문서 및 README.md에 변경 사항 반영
2026-03-26 11:04:38 +09:00
kswdev0
0a46e16e5b feat: JSON 배열 처리 및 오류 메시지 개선
- `_parse_json()` 메서드에서 최상위 JSON 배열을 허용하고, 이를 `actions` 리스트로 래핑하여 정상적인 파이프라인으로 이어지도록 개선
- JSON 파싱 실패 시 원인 파악을 돕기 위해 오류 메시지에 첫 비공백 문자를 포함
- 새로운 단위 테스트를 추가하여 JSON 객체 및 배열 파서의 회귀 방지
- README.md 및 문서에 변경 사항 반영
2026-03-26 10:57:25 +09:00
kswdev0
3d118fe649 feat: mining_state 설정 최적화 및 GLM 예외 처리 개선
- `mine_resource` 함수에서 채굴 상태를 매 루프마다 반복 설정하던 로직을 제거하여, 우클릭 유지와 유사한 동작으로 최적화
- GLM API 호출 실패 시 예외 처리 로직을 개선하여, 다양한 오류 원인을 로그로 출력하고 상태 요약 기반의 폴백 로직 추가
- 새로운 연결 검사 스크립트 추가 및 README.md에 GLM API 연결 문제 디버깅 섹션 추가
- 관련 문서 및 주의사항 업데이트
2026-03-26 09:49:47 +09:00
21in7
25eaa7f6cd feat: 추가된 메모리 기능으로 광맥 및 마지막 행동 저장
- 에이전트가 발견한 광맥 좌표를 `ore_patch_memory.json`에 저장하여 재시작 시 활용 가능
- 마지막 실행한 행동과 결과를 `agent_last_action_memory.json`에 저장하여 다음 상태 요약에서 참고 가능
- `state_reader.py`에서 메모리 로드 및 상태 요약에 포함
- `ai_planner.py`에서 시스템 프롬프트에 기억된 광맥 및 마지막 행동 관련 가이드 추가
- `README.md`에 새로운 메모리 기능 설명 추가
2026-03-25 23:34:25 +09:00
21in7
8c90e80582 feat: 인벤토리 캐시 및 JSON 인코더 추가
- 인벤토리 캐시 기능을 추가하여, RCON으로 인벤토리를 읽지 못할 경우 이전에 성공적으로 읽은 데이터를 활용
- Lua에서 JSON 인코딩을 위한 간단한 함수 추가, 일부 Factorio 버전에서 `game.table_to_json`이 없을 경우 대체
- `README.md`에 인벤토리 캐시 및 JSON 인코더 사용에 대한 설명 추가
- `scan_resources()`와 `mine_resource`의 반경을 확장하여 자원 탐색 실패를 줄임
2026-03-25 23:03:08 +09:00
21in7
37127f7f4f feat: explore 메서드에 wanted_ores 매개변수 추가 및 로직 개선
- explore 메서드에 wanted_ores 매개변수를 추가하여 특정 자원을 찾을 수 있도록 개선
- 원하는 자원이 발견될 때까지 계속 이동하며, 다른 자원이 발견되더라도 즉시 멈추지 않도록 로직 수정
- 시스템 프롬프트 및 README.md에 변경 사항 반영
2026-03-25 21:51:37 +09:00
21in7
7abdf8713a fix: mine_resource 채굴 로직 개선 및 JSON 파싱 안정성 향상
- 광석 위치로 이동 후 실제 자원 존재 여부를 재확인하여 실패한 타일을 제외하는 로직 추가
- JSON 파싱 시 중괄호 및 대괄호 균형을 추적하고, 잘린 응답 복구 로직을 개선하여 안정성 향상
- README.md에 변경 사항 및 기능 설명 추가
2026-03-25 21:37:15 +09:00
root
7953047212 fix: GLM 모델명 수정 2026-03-25 20:33:16 +09:00
63e9add1dd feat: explore 액션을 시스템 프롬프트에 추가
- explore를 최우선 탐색 액션으로 안내
- move는 "좌표를 알 때만" 사용하도록 변경
- fallback 행동도 move→explore로 변경
- 방향별 순서 안내 (east→north→south→west)
2026-03-25 20:27:27 +09:00
37c71e85c5 fix: SyntaxError - f-string 안의 리터럴 중괄호 수정
f"...'{' 없음..." → "...'{' 없음..." + raw[:300]
f-string 안에서 { 리터럴은 구문 오류를 발생시킴
2026-03-25 15:18:11 +09:00
6f220bc3f5 fix: JSON 파싱 강화 + 3회 재시도 + 잘린 응답 복구
- max_tokens 1500→2000 (잘림 방지)
- 중첩 괄호 카운팅 기반 JSON 추출
- _repair_truncated_json() 잘린 응답 복구
- 3회 실패 시 기본 탐색 행동 반환 (크래시 방지)
- 시스템 프롬프트 강화 (순수 JSON 강조)
2026-03-25 15:11:00 +09:00
75195ece3e 순수 플레이 전환: AI 프롬프트에 이동거리/재료/건설거리 제약 반영 2026-03-25 12:48:11 +09:00
7f7034bba2 Add ai_planner.py - AI 행동 계획 모듈 2026-03-25 10:24:02 +09:00