Skip to main content

🚰🔌 OCR มิเตอร์ไฟฟ้าและมิเตอร์น้ำ

1 ICต่อคำขอ
v2.0 Active POST /v3/store/smart-city/power-meter-and-water-meter

Water Meter OCR เป็นบริการ AI ของ iApp ที่ทำการอ่านและแปลงข้อมูลตัวเลขบนมิเตอร์น้ำและมิเตอร์ไฟฟ้าโดยอัตโนมัติ บริการนี้สามารถตรวจจับและดึงข้อมูลตัวเลขจากหน้าปัดมิเตอร์ทั้งแบบกลมและแบบสี่เหลี่ยมได้

ทดลองใช้ Demo!

Example Images (Click to try)

Example 1

เริ่มต้นใช้งาน

  1. สิ่งที่ต้องมี

    • API key จาก iApp Technology
    • รูปภาพมิเตอร์น้ำ/ไฟฟ้าที่ชัดเจน
    • การเชื่อมต่ออินเทอร์เน็ต
  2. เริ่มต้นใช้งานอย่างรวดเร็ว

    • การจดจำค่ามิเตอร์ที่รวดเร็ว
    • รองรับมิเตอร์หลายประเภท
    • อินเทอร์เฟซ REST API ที่ใช้งานง่าย
  3. คุณสมบัติหลัก

    • การตรวจจับค่ามิเตอร์อัตโนมัติ
    • การจดจำตัวเลขที่มีความแม่นยำสูง
    • ระยะเวลาตอบสนองที่รวดเร็ว
    • การผสานรวมที่ง่ายดาย
  4. ความปลอดภัยและการปฏิบัติตามข้อกำหนด

    • เป็นไปตามข้อกำหนด GDPR และ PDPA
    • ไม่มีการเก็บข้อมูลหลังการประมวลผล
วิธีรับ API Key?

กรุณาไปที่หน้า การจัดการ API Key เพื่อดู API key ที่มีอยู่ของคุณ หรือขอ API key ใหม่

API Endpoints

EndpointMethodคำอธิบายค่าบริการ
/v3/store/smart-city/power-meter-and-water-meter
Legacy: /meter-number-ocr
POSTดึงค่าจากมิเตอร์ไฟฟ้า/น้ำ1 IC ต่อคำขอ
/v3/store/smart-city/power-meter-and-water-meter/file
Legacy: /meter-number-ocr/file
POSTดึงค่าจากไฟล์รูปภาพมิเตอร์1 IC ต่อคำขอ
/v3/store/smart-city/power-meter-and-water-meter/base64
Legacy: /meter-number-ocr/base64
POSTดึงค่าจากรูปภาพมิเตอร์ base641 IC ต่อคำขอ

ตัวอย่าง

การประยุกต์ใช้จริงกับมิเตอร์ไฟฟ้าและมิเตอร์น้ำ

1. มิเตอร์น้ำแบบหน้าปัดกลม

ตัวอย่างที่ 1 ตัวอย่างที่ 1 มิเตอร์ไฟฟ้าและมิเตอร์น้ำ

ตัวอย่างที่ 2 ตัวอย่างที่ 2 มิเตอร์ไฟฟ้าและมิเตอร์น้ำ

2. มิเตอร์น้ำแบบหน้าปัดสี่เหลี่ยม

ตัวอย่างที่ 3 มิเตอ�ร์ไฟฟ้าและมิเตอร์น้ำ

Request

curl --location --request POST 'https://api.iapp.co.th/meter-number-ocr/file' \
--header 'apikey: ----Your API Key----' \
--form 'file=@"/Users/id_1016_value_367_003.jpg"'

Response

{
"infer_time": 0.16,
"label": "024963",
"message": "success",
"status": 200
}

คุณสมบัติและความสามารถ

คุณสมบัติหลัก

  • การตรวจจับหน้าปัดมิเตอร์อัตโนมัติ (แบบกลมและสี่เหลี่ยม)
  • การจดจำตัวเลขที่มีความแม่นยำสูง
  • เวลาประมวลผลที่รวดเร็ว
  • รองรับรูปแบบไฟล์รูปภาพหลายรูปแบบ

ข้อมูลที่รองรับ

  • หมายเลขค่ามิเตอร์
  • การตรวจจับประเภทหน้าปัดมิเตอร์

เอกสารอ้างอิง API

Endpoint

POST https://api.iapp.co.th/meter-number-ocr/file

Headers

ชื่อประเภทคำอธิบาย
apikeystringAPI key ของคุณ

Request Body

ชื่อประเภทคำอธิบาย
fileimageรูปภาพมิเตอร์ที่ชัดเจน

ตัวอย่างโค้ด

Python

import requests

url = "https://api.iapp.co.th/meter-number-ocr/file"

payload = {}
files=[
('file',('{YOUR UPLOADED FILE NAME}',open('{YOUR UPLOADED FILE PATH}','rb'),'image/png'))
]
headers = {
'apikey': '{YOUR_API_KEY}'
}

response = requests.request("POST", url, headers=headers, data=payload, files=files)

print(response.text)

JavaScript

const axios = require('axios');
const FormData = require('form-data');
const fs = require('fs');
let data = new FormData();
data.append('file', fs.createReadStream('{YOUR UPLOADED FILE PATH}'));

let config = {
method: 'post',
maxBodyLength: Infinity,
url: 'https://api.iapp.co.th/meter-number-ocr/file',
headers: {
'apikey': '{YOUR_API_KEY}',
...data.getHeaders()
},
data : data
};

axios.request(config)
.then((response) => {
console.log(JSON.stringify(response.data));
})
.catch((error) => {
console.log(error);
});

PHP

<?php

$curl = curl_init();

curl_setopt_array($curl, array(
CURLOPT_URL => 'https://api.iapp.co.th/meter-number-ocr/file',
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => '',
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 0,
CURLOPT_FOLLOWLOCATION => true,
CURL_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => 'POST',
CURLOPT_POSTFIELDS => array('file'=> new CURLFILE('{YOUR UPLOADED FILE PATH}')),
CURLOPT_HTTPHEADER => array(
'apikey: {YOUR_API_KEY}'
),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;

Swift

let parameters = [
[
"key": "file",
"src": "{YOUR UPLOADED FILE PATH}",
"type": "file"
]] as [[String: Any]]

let boundary = "Boundary-\(UUID().uuidString)"
var body = Data()
var error: Error? = nil
for param in parameters {
if param["disabled"] != nil { continue }
let paramName = param["key"]!
body += Data("--\(boundary)\r\n".utf8)
body += Data("Content-Disposition:form-data; name=\"\(paramName)\"".utf8)
if param["contentType"] != nil {
body += Data("\r\nContent-Type: \(param["contentType"] as! String)".utf8)
}
let paramType = param["type"] as! String
if paramType == "text" {
let paramValue = param["value"] as! String
body += Data("\r\n\r\n\(paramValue)\r\n".utf8)
} else {
let paramSrc = param["src"] as! String
let fileURL = URL(fileURLWithPath: paramSrc)
if let fileContent = try? Data(contentsOf: fileURL) {
body += Data("; filename=\"\(paramSrc)\"\r\n".utf8)
body += Data("Content-Type: \"content-type header\"\r\n".utf8)
body += Data("\r\n".utf8)
body += fileContent
body += Data("\r\n".utf8)
}
}
}
body += Data("--\(boundary)--\r\n".utf8);
let postData = body


var request = URLRequest(url: URL(string: "https://api.iapp.co.th/meter-number-ocr/file")!,timeoutInterval: Double.infinity)
request.addValue("{YOUR_API_KEY}", forHTTPHeaderField: "apikey")
request.addValue("multipart/form-data; boundary=\(boundary)", forHTTPHeaderField: "Content-Type")

request.httpMethod = "POST"
request.httpBody = postData

let task = URLSession.shared.dataTask(with: request) { data, response, error in
guard let data = data else {
print(String(describing: error))
return
}
print(String(data: data, encoding: .utf8)!)
}

task.resume()

Kotlin

val client = OkHttpClient()
val mediaType = "text/plain".toMediaType()
val body = MultipartBody.Builder().setType(MultipartBody.FORM)
.addFormDataPart("file","{YOUR UPLOADED FILE NAME}",
File("{YOUR UPLOADED FILE PATH}").asRequestBody("application/octet-stream".toMediaType()))
.build()
val request = Request.Builder()
.url("https://api.iapp.co.th/meter-number-ocr/file")
.post(body)
.addHeader("apikey", "{YOUR_API_KEY}")
.build()
val response = client.newCall(request).execute()

Java

OkHttpClient client = new OkHttpClient().newBuilder()
.build();
MediaType mediaType = MediaType.parse("text/plain");
RequestBody body = new MultipartBody.Builder().setType(MultipartBody.FORM)
.addFormDataPart("file","{YOUR UPLOADED FILE NAME}",
RequestBody.create(MediaType.parse("application/octet-stream"),
new File("{YOUR UPLOADED FILE PATH}")))
.build();
Request request = new Request.Builder()
.url("https://api.iapp.co.th/meter-number-ocr/file")
.method("POST", body)
.addHeader("apikey", "{YOUR_API_KEY}")
.build();
Response response = client.newCall(request).execute();

Dart

var headers = {
'apikey': '{YOUR_API_KEY}'
};
var request = http.MultipartRequest('POST', Uri.parse('https://api.iapp.co.th/meter-number-ocr/file'));
request.files.add(await http.MultipartFile.fromPath('file', '{YOUR UPLOADED FILE PATH}'));
request.headers.addAll(headers);

http.StreamedResponse response = await request.send();

if (response.statusCode == 200) {
print(await response.stream.bytesToString());
}
else {
print(response.reasonPhrase);
}

ความแม่นยำและประสิทธิภาพ

การประเมินทำขึ้นจากข้อมูลรูปภาพมิเตอร์น้ำทั้งแบบหน้าปัดสี่เหลี่ยมและหน้าปัดกลม (107 ภาพ)

การประเมินโมเดล

โมเดลคำอธิบายความแม่นยำ (%)
Water Meter Detection Modelตรวจจับมิเตอร์น้ำจากรูปภาพที่ป้อนเข้ามา96.22
OCR Modelจดจำตัวเลข76.47
Overall Accuracyความแม่นยำโดยรวมของระบบ73.58

การประเมินตัวอักษร

ตัวเลขจำนวนทั้งหมดจำนวนที่ถูกต้องความแม่นยำ (%)
019718895.43
1858094.12
2585391.38
3696391.3
4656295.38
5575087.72
6514384.31
7524892.31
8484083.33
9595084.75

ความแม่นยำโดยรวมจากการตรวจจับตัวเลขที่ถูกต้อง = 90 %

ประวัติ/บันทึกการเปลี่ยนแปลง

เวอร์ชัน 1.0 - 2021-10-05

เพิ่ม

  • แนะนำ OCR มิเตอร์น้ำของ iApp
  • รองรับมิเตอร์น้ำทุกประเภท

เวอร์ชัน 1.1 - 2021-12-02

แก้ไข

  • การตรวจจับ 2 หลักที่พิกัด x เดียวกัน
  • เพิ่มความแม่นยำจาก 62.26 เป็น 73.58

ตัวอย่างโค้ด

Curl

curl -X POST https://api.iapp.co.th/v3/store/smart-city/meter-reading \
-H "apikey: YOUR_API_KEY" \
-F "file=@/path/to/meter.jpg"

Python

import requests

url = "https://api.iapp.co.th/v3/store/smart-city/meter-reading"
files = {"file": ("("/path/to/meter.jpg", "rb"))}
headers = {"apikey": "YOUR_API_KEY"}

response = requests.post(url, headers=headers, files=files)
print(response.json())

JavaScript

const axios = require("axios");
const FormData = require("form-data");
const fs = require("fs");

let data = new FormData();
data.append("file", fs.createReadStream("/path/to/meter.jpg"));

let config = {
method: "post",
url: "https://api.iapp.co.th/v3/store/smart-city/meter-reading",
headers: {
apikey: "YOUR_API_KEY",
...data.getHeaders(),
},
data: data,
};

axios(config)
.then((response) => console.log(response.data))
.catch((error) => console.log(error));

PHP

<?php
$curl = curl_init();

curl_setopt_array($curl, array(
CURLOPT_URL => 'https://api.iapp.co.th/v3/store/smart-city/meter-reading',
CURLOPT_RETURNTRANSFER => true,
CURLOPT_POST => true,
CURLOPT_POSTFIELDS => array(
'file'=> new CURLFILE('/path/to/meter.jpg')
),
CURLOPT_HTTPHEADER => array(
'apikey: YOUR_API_KEY'
),
));

$response = curl_exec($curl);
curl_close($curl);
echo $response;
?>

Swift

import Foundation

let url = URL(string: "https://api.iapp.co.th/v3/store/smart-city/meter-reading")!
var request = URLRequest(url: url)
request.httpMethod = "POST"
request.addValue("YOUR_API_KEY", forHTTPHeaderField: "apikey")

let boundary = "Boundary-\(UUID().uuidString)"
request.setValue("multipart/form-data; boundary=\(boundary)", forHTTPHeaderField: "Content-Type")

var body = Data()
body.append("--\(boundary)\r\n".data(using: .utf8)!)
body.append("Content-Disposition: form-data; name=\"file\"; filename=\"file.jpg\"\r\n".data(using: .utf8)!)
body.append("Content-Type: image/jpeg\r\n\r\n".data(using: .utf8)!)

if let fileData = try? Data(contentsOf: URL(fileURLWithPath: "/path/to/meter.jpg")) {
body.append(fileData)
}
body.append("\r\n--\(boundary)--\r\n".data(using: .utf8)!)

request.httpBody = body

let task = URLSession.shared.dataTask(with: request) { data, response, error in
if let data = data {
print(String(data: data, encoding: .utf8)!)
}
}
task.resume()

Kotlin

import okhttp3.*
import okhttp3.MediaType.Companion.toMediaTypeOrNull
import okhttp3.RequestBody.Companion.asRequestBody
import java.io.File

val client = OkHttpClient()

val file = File("/path/to/meter.jpg")
val requestBody = MultipartBody.Builder()
.setType(MultipartBody.FORM)
.addFormDataPart("file", file.name, file.asRequestBody("image/jpeg".toMediaTypeOrNull()))
.build()

val request = Request.Builder()
.url("https://api.iapp.co.th/v3/store/smart-city/meter-reading")
.addHeader("apikey", "YOUR_API_KEY")
.post(requestBody)
.build()

client.newCall(request).execute().use { response ->
println(response.body?.string())
}

Java

import okhttp3.*;
import java.io.File;

OkHttpClient client = new OkHttpClient();

File file = new File("/path/to/meter.jpg");

RequestBody requestBody = new MultipartBody.Builder()
.setType(MultipartBody.FORM)
.addFormDataPart("file", file.getName(),
RequestBody.create(MediaType.parse("image/jpeg"), file))
.build();

Request request = new Request.Builder()
.url("https://api.iapp.co.th/v3/store/smart-city/meter-reading")
.addHeader("apikey", "YOUR_API_KEY")
.post(requestBody)
.build();

try (Response response = client.newCall(request).execute()) {
System.out.println(response.body().string());
}

Dart

import 'package:http/http.dart' as http;

var request = http.MultipartRequest(
'POST',
Uri.parse('https://api.iapp.co.th/v3/store/smart-city/meter-reading')
);

request.files.add(await http.MultipartFile.fromPath(
'file',
'/path/to/meter.jpg'
));

request.headers.addAll({
'apikey': 'YOUR_API_KEY'
});

var response = await request.send();
var responseBody = await response.stream.bytesToString();
print(responseBody);

ราคา

ชื่อบริการ AI APIIC ต่อคำขอOn-Premise
Power and Meter OCR1 IC/คำขอติดต่อ