실생활 핵심정보 추출(2부): 오픈소스 LLM 성능 개선
1부에 이어 이 가이드에서는 송장 정보 추출을 위해 오픈 소스 LLM(대형 언어 모델)인 Qwen2 2B 및 LLaMA 3.1을 사용하여 데이터 개인정보 보호 문제 및 하드웨어 제한(12GB VRAM을 갖춘 RTX 3060)을 극복하는 데 중점을 둡니다.
Qwen2 2B와 LLaMA 3.1이 필요한 이유는 무엇인가요?
이 모델을 선택한 이유는 리소스 제약 때문이었습니다. Qwen2-VL-2B-Instruct는 효율적인 크기로 인해 더 큰 7B 모델보다 선호되었습니다. Ollama를 통해 액세스되는 LLaMA 3.1(8B)은 최적화된 장기 컨텍스트 이해를 위해 선택되었습니다. Ollama의 Qwen2(이미지 지원 부족) 및 LLaVA(다국어 기능 부족)와 같은 다른 모델은 부적합한 것으로 간주되었습니다.
이 2가지 모델 전략은 Qwen2의 일반 핵심 정보 추출 기능과 LLaMA 3.1의 뛰어난 긴 컨텍스트 처리 및 JSON 출력 일관성(특히 다국어 문서의 경우)을 활용합니다. Qwen2는 처음에 원시 정보를 추출한 다음 LLaMA 3.1에서 이를 정제하여 표준화된 JSON 형식으로 구성합니다. PaddleOCR은 Part 1과 마찬가지로 Qwen2의 비전 기능을 향상시킵니다.
일본 송장 예시
일본 청구서를 테스트 사례로 사용했습니다. 초기 OCR 프로세스(언어 감지 및 PaddleOCR 통합)에서 다음과 같은 인식된 텍스트가 생성되었습니다.
<code>Recognized Text: {'ori_text': '根岸 東急ストア TEL 045-752-6131 領収証 [TOP2C!UbO J3カード」 クレヅッ 卜でのお支払なら 200円で3ボイン卜 お得なカード! 是非こ入会下さい。 2013年09月02日(月) レジNO. 0102 NOO07さ と う 001131 スダフエウ卜チーネ 23 単198 1396 003271 オインイ年 ユウ10 4238 000805 ソマ一ク スモー一クサーモン 1298 003276 タカナン ナマクリーム35 1298 001093 ヌテラ スフレクト 1398 000335 バナサ 138 000112 アボト 2つ 単158 1316 A000191 タマネキ 429 合計 2,111 (内消費税等 100 現金 10001 お預り合計 110 001 お釣り 7 890', 'ori_language': 'ja', 'text': 'Negishi Tokyu Store TEL 045-752-6131 Receipt [TOP2C!UbO J3 Card] If you pay with a credit card, you can get 3 points for 200 yen.A great value card!Please join us. Monday, September 2, 2013 Cashier No. 0102 NOO07 Satou 001131 Sudafue Bucine 23 Single 198 1396 003271 Oinyen Yu 10 4238 000805 Soma Iku Smo Iku Salmon 1298 003276 Takanan Nama Cream 35 1 298 001093 Nutella Sprect 1398 000335 Banasa 138 000112 Aboto 2 AA 158 1316 A000191 Eggplant 429 Total 2,111 (including consumption tax, etc. 100 Cash 10001 Total deposited 110 001 Change 7 890', 'language': 'en',}</code>
이를 ChatGPT 기준과 비교하여 초기 테스트에서 ChatGPT의 우수한 성능을 입증했습니다.
Qwen2 2B 결과(독립형)
Qwen2를 단독으로 사용해보니 한계가 드러났습니다. JSON 출력은 여러 분야에서 불완전하고 부정확했으며, 이는 일관된 JSON 형식 및 긴 컨텍스트 처리에 대한 어려움을 강조했습니다.
Qwen2와 LLaMA 3.1 접근 방식 결합
Qwen2의 출력을 개선하기 위해 LLaMA 3.1을 사후 프로세서로 사용하여 개선되었지만 여전히 불완전한 결과를 얻었습니다. 일부 핵심 항목은 정확하게 추출되었으나, 세부 항목 정보는 여전히 문제가 있었습니다.
향후 개선 사항: Qwen2VL 미세 조정
다음 부분에서는 이 전문 작업의 정확성과 처리 속도를 크게 향상시키는 것을 목표로 영수증 데이터 데이터 세트를 사용하여 Qwen2VL 모델을 미세 조정하는 방법을 자세히 설명합니다.
결론
이 실험은 실제 핵심 정보 추출을 위한 오픈 소스 LLM의 잠재력과 한계를 보여줍니다. 결합된 접근 방식은 단일 모델을 사용하는 것보다 향상된 기능을 제공하지만 최적의 성능을 달성하려면 특히 모델 미세 조정을 통한 추가 개선이 필요합니다. 데이터 개인 정보 보호 및 효율적인 리소스 활용에 중점을 두는 것이 이 오픈 소스 접근 방식의 주요 장점입니다.
위 내용은 핵심 정보 추출에 대한 실용적인 접근 방식(2부)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

thedifferencebet weenaforloopandawhileloopinpythonisthataforloopisusured wherleationsisknortiStiskNowninAdvance, whileLeOpisUssed whileLoopisUssedStoBeCheckedThoBeCheckedTherfeTefeateThinumberofiTeRations.1) forloopsareIdealFerenceCecenceS

Python에서는 반복의 수가 알려진 경우에 루프가 적합한 반면, 반복 횟수가 알려지지 않고 더 많은 제어가 필요한 경우 루프는 적합합니다. 1) 루프의 경우 간결하고 피해자 코드가있는 목록, 문자열 등과 같은 시퀀스에 적합합니다. 2) 조건에 따라 루프를 제어하거나 사용자 입력을 기다릴 때 루프가 더 적절하지만 무한 루프를 피하기 위해주의를 기울여야합니다. 3) 성능 측면에서 For 루프는 약간 빠르지 만 차이는 일반적으로 크지 않습니다. 올바른 루프 유형을 선택하면 코드의 효율성과 가독성이 향상 될 수 있습니다.

파이썬에서 목록은 5 가지 방법을 통해 병합 될 수 있습니다. 1) 단순하고 직관적 인 연산자를 사용하여 작은 목록에 적합합니다. 2) Extend () 메소드를 사용하여 자주 업데이트 해야하는 목록에 적합한 원본 목록을 직접 수정하십시오. 3) 목록 분석 공식, 요소에 대한 간결하고 운영; 4) 효율적인 메모리에 IterTools.chain () 함수를 사용하여 대형 데이터 세트에 적합합니다. 5) * 연산자 및 Zip () 함수를 사용하여 요소를 짝을 이루어야하는 장면에 적합합니다. 각 방법에는 특정 용도 및 장점 및 단점이 있으며 선택할 때 프로젝트 요구 사항 및 성능을 고려해야합니다.

Forloopsareusedwhendumberofiterationsisknown, whileloopsareusediltilaconditionismet.1) forloopsareIdealfecquenceslikelists, idingsyntax likes'forfruitinfruits : print (fruit) '

Toconcatenatealistoflistsinpython, usextend, listcomprehensions, itertools.chain, orrecursiveFunctions.1) extendMethodistRaightForwardButverbose.2) ListComprehensionsArecisancisancisancisancisanceciancectionforlargerdatasets.3) itertools.chainismory-lefforforlargedas

Tomergelistsinpython, youcanusethe operator, extendmethod, listcomprehension, oritertools.chain, 각각은 각각의 지위를 불러 일으킨다

Python 3에서는 다양한 방법을 통해 두 개의 목록을 연결할 수 있습니다. 1) 작은 목록에 적합하지만 큰 목록에는 비효율적입니다. 2) 메모리 효율이 높지만 원래 목록을 수정하는 큰 목록에 적합한 확장 방법을 사용합니다. 3) 원래 목록을 수정하지 않고 여러 목록을 병합하는 데 적합한 * 운영자 사용; 4) 메모리 효율이 높은 대형 데이터 세트에 적합한 itertools.chain을 사용하십시오.

join () 메소드를 사용하는 것은 Python의 목록에서 문자열을 연결하는 가장 효율적인 방법입니다. 1) join () 메소드를 사용하여 효율적이고 읽기 쉽습니다. 2)주기는 큰 목록에 비효율적으로 운영자를 사용합니다. 3) List Comprehension과 Join ()의 조합은 변환이 필요한 시나리오에 적합합니다. 4) READE () 방법은 다른 유형의 감소에 적합하지만 문자열 연결에 비효율적입니다. 완전한 문장은 끝납니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)