File size: 2,728 Bytes
8aa16bd 4c9ec3d 2edc5ce 8aa16bd eda7fd3 8aa16bd 4153dc5 997e0dd 4153dc5 e59711a 4153dc5 097f1bc |
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 |
---
base_model:
- microsoft/table-transformer-detection
library_name: transformers
---
# Model Card for Model ID
This repository contains a fine-tuned version of the Table Transformer model, specifically adapted for detecting tables in IFRS (International Financial Reporting Standards) PDFs. The model is based on the Table Transformer architecture, which is designed to extract tables from unstructured documents such as PDFs and images.
## Model Details
**Base Model:** microsoft/table-transformer-detection
**Library:** transformers
**Training Data:** The model was trained on a dataset consisting of 2359 IFRS scans, with a focus on detecting tables without borders.
**Classes**: The model is trained to detect two classes: 0 - table (regular tables) and 1 - table_rotated (rotated tables).
## Example Image
![model image](./GPN_IFRS_RUS_12m2021_77.png)
# Usage
```python
from transformers import DetrForObjectDetection, DetrImageProcessor
from PIL import Image
import torch
# Load the image processor and model
# DetrImageProcessor is used to preprocess the images before feeding them to the model
image_processor = DetrImageProcessor()
# Load the pre-trained TableTransformer model for object detection
# This model is specifically trained for detecting tables in IFRS documents
model = TableTransformerForObjectDetection.from_pretrained(
"apkonsta/table-transformer-detection-ifrs",
)
# Prepare the image
# Open the image file and convert it to RGB format
image = Image.open("path/to/your/ifrs_pdf_page.png").convert("RGB")
# Table detection threshold
# Set a threshold for detecting tables; only detections with a confidence score above this threshold will be considered
TD_th = 0.5
# Preprocess the image using the image processor
# The image is encoded into a format that the model can understand
encoding = image_processor(image, return_tensors="pt")
# Perform inference without computing gradients (saves memory and computations)
with torch.no_grad():
outputs = model(**encoding)
# Get the probabilities for each detected object
# The softmax function is applied to the logits to get probabilities
probas = outputs.logits.softmax(-1)[0, :, :-1]
# Keep only the detections with a confidence score above the threshold
keep = probas.max(-1).values > TD_th
# Get the target sizes for post-processing
# The target sizes are the dimensions of the original image
target_sizes = torch.tensor(image.size[::-1]).unsqueeze(0)
# Post-process the model outputs to get the final bounding boxes
# The bounding boxes are scaled back to the original image size
postprocessed_outputs = image_processor.post_process(outputs, target_sizes)
bboxes_scaled = postprocessed_outputs[0]["boxes"][keep]
```
|