Sanjayraju30 commited on
Commit
d4534d1
·
verified ·
1 Parent(s): 46c7b06

Update ocr_engine.py

Browse files
Files changed (1) hide show
  1. ocr_engine.py +14 -9
ocr_engine.py CHANGED
@@ -1,22 +1,27 @@
1
  from transformers import TrOCRProcessor, VisionEncoderDecoderModel
2
  from PIL import Image
3
 
4
- # Load model + processor once
5
  processor = TrOCRProcessor.from_pretrained("microsoft/trocr-base-stage1")
6
  model = VisionEncoderDecoderModel.from_pretrained("microsoft/trocr-base-stage1")
7
 
8
  def extract_weight(image: Image.Image) -> str:
9
- # Convert image to RGB just in case
10
  image = image.convert("RGB")
11
-
12
- # Preprocess + generate prediction
13
  pixel_values = processor(images=image, return_tensors="pt").pixel_values
14
  generated_ids = model.generate(pixel_values)
 
15
 
16
- # Decode output
17
- text = processor.batch_decode(generated_ids, skip_special_tokens=True)[0]
18
 
19
- # Keep only numbers + decimal
20
- weight = ''.join(filter(lambda x: x in '0123456789.', text))
 
 
 
 
21
 
22
- return weight.strip() if weight else "No valid weight detected"
 
 
 
 
1
  from transformers import TrOCRProcessor, VisionEncoderDecoderModel
2
  from PIL import Image
3
 
4
+ # Load model + processor
5
  processor = TrOCRProcessor.from_pretrained("microsoft/trocr-base-stage1")
6
  model = VisionEncoderDecoderModel.from_pretrained("microsoft/trocr-base-stage1")
7
 
8
  def extract_weight(image: Image.Image) -> str:
 
9
  image = image.convert("RGB")
 
 
10
  pixel_values = processor(images=image, return_tensors="pt").pixel_values
11
  generated_ids = model.generate(pixel_values)
12
+ full_text = processor.batch_decode(generated_ids, skip_special_tokens=True)[0]
13
 
14
+ # Extract digits
15
+ weight = ''.join(filter(lambda x: x in '0123456789.', full_text))
16
 
17
+ # Check for unit in original OCR text
18
+ unit = "grams" # default
19
+ if "kg" in full_text.lower():
20
+ unit = "kg"
21
+ elif "g" in full_text.lower():
22
+ unit = "grams"
23
 
24
+ if weight:
25
+ return f"{weight} {unit}"
26
+ else:
27
+ return "No valid weight detected"