File size: 9,218 Bytes
eca1724
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
dcf61aa
 
 
 
 
 
 
925031e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
153d406
925031e
 
 
 
 
 
254206f
c07c4e1
 
 
 
254206f
925031e
c07c4e1
 
 
 
 
 
254206f
925031e
c07c4e1
 
254206f
925031e
c07c4e1
 
 
 
 
 
 
 
254206f
925031e
c07c4e1
 
 
925031e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
cc9efa0
925031e
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
---
license: mit
datasets:
- sujet-ai/Sujet-Finance-QA-Vision-100k
language:
- en
metrics:
- accuracy
pipeline_tag: image-to-text
tags:
- finance
- vlm
- florence
- docvqa
- visual question answering
---

# Introducing Lutece-Vision-Base 🚀

## A Specialized Vision-Language Model (VLM) designed for financial document analysis and question answering

<img src="Announcement.jpg" width="400" height="200">

## Model Description

Lutece-Vision-Base, named after the ancient name of Paris, is a specialized Vision-Language Model (VLM) designed for financial document analysis and question answering. This model is a fine-tuned version of the Microsoft Florence-2-base-ft, specifically tailored to interpret and answer questions about financial documents, reports, and images.

## Model Details

- **Base Model**: microsoft/Florence-2-base-ft
- **Fine-tuning Dataset**: [sujet-ai/Sujet-Finance-QA-Vision-100k](https://huggingface.co/datasets/sujet-ai/Sujet-Finance-QA-Vision-100k)
- **Training Data**: 100,629 Q&A pairs (spanning 9,212 images)
- **Validation Data**: 589 Q&A pairs (one pair per image from a total of 6,421 entries in the validation set)
- **Language**: English
- **License**: MIT

## Training Specifications

- **Number of Epochs**: 7
- **Learning Rate**: 1e-6
- **Optimizer**: AdamW
- **Architecture**: Encoder parameters were frozen during fine-tuning
- **Hardware**: One NVIDIA A100 GPU
- **Training Duration**: Approximately 38 hours

## Performance and Evaluation

We evaluated the model's performance using two approaches:

1. GPT-4o as an LLM judge
2. Cosine similarity measurement

### GPT-4o Evaluation

This method compares the answers generated by both the vanilla Florence model and our fine-tuned Lutece-Vision-Base model.

**Evaluation Process**:
1. For each (image, question) pair in the validation set, we generate answers using both models.
2. GPT-4o acts as an impartial judge, evaluating the correctness of both answers without prior knowledge of the ground truth.
3. The evaluation considers factors such as numerical accuracy, spelling and minor wording differences, completeness of the answer, and relevance of information.

**Evaluation Criteria**:
- Numerical Accuracy: Exact matches required for numbers, dates, and quantities.
- Spelling and Minor Wording: Minor differences are acceptable if the core information is correct.
- Completeness: Answers must fully address the question.
- Relevance: Additional information is acceptable unless it contradicts the correct part of the answer.

**GPT-4o Judge Prompt**:

```
Analyze the image and the question, then evaluate the answers provided by the Vanilla Model and the Finetuned Model.

Question: {question}
Vanilla Model Answer: {vanilla_answer}
Finetuned Model Answer: {finetuned_answer}

Your task is to determine if each answer is correct or incorrect based on the image and question.
Consider the following guidelines:

1. Numerical Accuracy: 
   - For questions involving numbers (e.g., prices, dates, quantities), the answer must be exactly correct.
   - Example: If the correct price is $10.50, an answer of $10.49 or $10.51 is incorrect.
   - Example: If the correct date is June 15, 2023, an answer of June 14, 2023 or June 16, 2023 is incorrect.

2. Spelling and Minor Wording:
   - Minor spelling mistakes or slight wording differences should not be counted as incorrect if the core information is right.
   - Example: If the correct name is "John Smith", answers like "Jon Smith" or "John Smyth" should be considered correct.
   - Example: "The CEO of the company" instead of "The company's CEO" is acceptable.

3. Completeness:
   - The answer must fully address the question to be considered correct.
   - Partially correct answers or answers that miss key parts of the question should be marked as incorrect.

4. Irrelevant Information:
   - Additional irrelevant information does not make an otherwise correct answer incorrect.
   - However, if the irrelevant information contradicts the correct part of the answer, mark it as incorrect.

Respond using the following JSON format:
{
    "vanilla_correct": <boolean>,
    "finetuned_correct": <boolean>,
    "explanation": "Your explanation here"
}

Where:
- "vanilla_correct" is true if the Vanilla Model's answer is correct, false otherwise.
- "finetuned_correct" is true if the Finetuned Model's answer is correct, false otherwise.
- "explanation" briefly explains your evaluation for both answers, referencing the guidelines above.

Your response should contain ONLY the JSON output, and no text before or after to avoid output parsing errors.
```

### Cosine Similarity Measurement

In addition to the GPT-4o evaluation, we also measured the cosine similarity between the answers given by the models and what was labeled as ground truth by GPT-4o. This provides a quantitative measure of how close the model outputs are to the expected answers in the embedding space.

**Process**:
1. We used the BAAI/bge-base-en-v1.5 embedding model ([https://huggingface.co/BAAI/bge-base-en-v1.5](https://huggingface.co/BAAI/bge-base-en-v1.5)) to convert the answers into vector representations.
2. Cosine similarity was calculated between the embeddings of the model-generated answers and the ground truth answers.
3. This similarity score provides an additional metric for evaluating the models' performance, capturing semantic similarity beyond exact word matching.

**Performance Comparison**:

![image/png](https://cdn-uploads.huggingface.co/production/uploads/642d5e6f84bf892b8faa54cc/8AQUQ2RD9Pmp8KerX4_1Q.png)

For a detailed overview of the metrics logged during the training, please refer to our [Weights & Biases report](https://wandb.ai/fine-tune-llm/FinetuneVLM/reports/Finetuning-Lutece-Vision-Base--Vmlldzo4NjI4NzAy?accessToken=fnbibl4i4cx8ljzbfb6f81yitqe580hipliw5e7a4arueha1cjl3zqsownfikkaw).

## Usage

Here's a quick start guide to using Lutece-Vision-Base:

```python
from PIL import Image
from transformers import AutoProcessor, AutoModelForCausalLM, AutoConfig
import torch 

# Load and configure the model
device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
config = AutoConfig.from_pretrained("microsoft/Florence-2-base-ft", trust_remote_code=True)
config.vision_config.model_type = "davit"
model = AutoModelForCausalLM.from_pretrained("sujet-ai/Lutece-Vision-Base", config=config, trust_remote_code=True).to(device).eval()
processor = AutoProcessor.from_pretrained("sujet-ai/Lutece-Vision-Base", config=config, trust_remote_code=True)
task = "<FinanceQA>"

# Load input image and define the question
image = Image.open('test.png').convert('RGB')
prompt = "How much decrease in prepaid expenses was reported?"

# Process input and generate answer
inputs = processor(text=prompt, images=image, return_tensors="pt").to(device)
generated_ids = model.generate(
    input_ids=inputs["input_ids"],
    pixel_values=inputs["pixel_values"],
    max_new_tokens=1024,
    do_sample=False,
    num_beams=3,
)

# Decode and parse the answer
generated_text = processor.batch_decode(generated_ids, skip_special_tokens=False)[0]
parsed_answer = processor.post_process_generation(generated_text, task=task, image_size=(image.width, image.height))
print(parsed_answer[task])
```

## Demo and Further Resources

- **Interactive Demo**: Try out Lutece-Vision-Base using our [Hugging Face Space](https://huggingface.co/spaces/sujet-ai/Lutece-Vision-Base-DEMO). Please note that this demo runs on CPU, so inference might be slower than on GPU.

- **Fine-tuning Tutorial**: If you're interested in fine-tuning Florence 2 for your own tasks, we recommend this excellent [tutorial on Hugging Face](https://huggingface.co/blog/finetune-florence2).

## Limitations and Disclaimer

While Lutece-Vision-Base has been trained on a diverse set of financial documents, it may not cover all possible financial scenarios or document types. The model can make mistakes, especially in complex or ambiguous situations. Users should verify critical information and not rely solely on the model's output for making important financial decisions.

**Disclaimer**: Sujet AI provides Lutece-Vision-Base as-is, without any warranties, expressed or implied. We are not responsible for any consequences resulting from the use of this model. Users should exercise their own judgment and verify information when using the model for financial analysis or decision-making purposes.

The model may reflect biases present in its training data and should be used with this understanding. Continuous evaluation and updating of the model with diverse and representative data are recommended for maintaining its relevance and accuracy.

## Citation and Contact

If you use Lutece-Vision-Base in your research or applications, please cite it as:

```
@software{Lutece-Vision-Base,
  author = {Sujet AI, Allaa Boutaleb, Hamed Rahimi},
  title = {Lutece-Vision-Base: A Fine-tuned VLM for Financial Document Analysis},
  year = {2024},
  url = {https://huggingface.co/sujet-ai/Lutece-Vision-Base}
}
```

For questions, feedback, or collaborations, please reach out to us on [LinkedIn](https://www.linkedin.com/company/sujet-ai/) or visit our website [https://sujet.ai](https://sujet.ai).