11.12课上练习视频字幕识别

一、安装tesseract-ocr

 

教程详见:Tesseract OCR V5.0安装教程(Windows) - 简书 (jianshu.com)

安装时注意添加环境变量和语言包两点

二、视频字母识别

先导入所需要的包,注意视频、文件地址最好都在Python文件夹下

在字母识别时注意语言包的地址不要出错

import pytesseract
import cv2
import numpy as np
from scipy import stats
import os
import matplotlib.pyplot as plt
os.chdir(r'C:\Users\lenovo\AppData\Local\Programs\Python\Python37\Lib\site-packages')

if __name__ == '__main__':
    path = r"C:\Users\lenovo\AppData\Local\Programs\Python\Python37\Lib\site-packages\20210701.mp4"
    print(path)
    cap = cv2.VideoCapture(path)
    frame_count = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))  #帧数
    print(frame_count)
    i=0
    while i<frame_count:
        cap.set(cv2.CAP_PROP_POS_FRAMES, i)
        _, frame = cap.read(i)
        if i==48:
            cv2.imwrite('20210701.jpg',frame)
        shape = frame.shape
        print(shape)
        #cv2.imshow("Frame-1", frame[580:630, 10:1270])
#         plt.imshow(frame)
#         plt.axis("off")
#         plt.show()
        img=frame[630:680, 50:1270]
        plt.imshow(img)
        plt.axis("off")
        plt.show()
        img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)  # 灰度图
        #cv2.imshow("Frame-2:Gray", img)            #显示灰度图
        _, img= cv2.threshold(img, 220, 255, cv2.THRESH_BINARY)  # 图像,阈值,映射的最大值,使用什么算法一般为cv2.thresh_binary
        #cv2.imshow("Frame-3:Binary", img)            #显示灰度图

#从这里开始进行字母识别
        tessdata_dir_config = '--tessdata-dir "C:\\Program Files\\Tesseract-OCR\\tessdata"  --psm 7 -c preserve_interword_spaces=1'
        word = pytesseract.image_to_string(img,
                                           lang='chi_sim',
                                           #config=' --psm 7 -c preserve_interword_spaces=1')
                                           config=tessdata_dir_config)
        print(word)
        i=i+24*2

        if cv2.waitKey(10) & 0xff == ord("q"):
            break

    cap.release()
    cv2.destroyAllWindows()

三、最后结果显示

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在机器学习和深度学习中,"loss过高"通常是指训练过程中模型的损失函数(如交叉熵、均方误差等)的值远高于理想的或预期的范围。对于分类任务来说,比如准确率是100%,loss应该接近于0。当loss达到11.12%,这意味着模型在当前的学习过程中表现不佳,可能存在的原因包括: 1. **模型过拟合**:模型在训练数据上过度学习,导致在新数据上泛化能力差,表现为训练集loss低,验证或测试集loss高。 2. **学习率不合适**:如果学习率设置过大或更新步度过快,可能导致优化器无法找到有效的局部最优解。 3. **数据分布不均衡**:某些类别在训练集中过于稀疏,可能导致模型难以正确处理这些类别,从而提高整体loss。 4. **网络结构或参数初始化不当**:模型的复杂度过高或权重参数未进行正确的初始化,也可能造成初始loss偏高。 5. **优化器问题**:选择的优化算法(如SGD、Adam等)可能不适合当前任务或模型,或者存在梯度爆炸或消失的问题。 要解决这个问题,你可以尝试以下措施: 1. **调整超参数**:如学习率、批量大小、正则化参数等。 2. **数据增强**:增加训练数据的多样性,帮助模型更好地泛化。 3. **改变模型结构**:简化模型,或者尝试更复杂的架构。 4. **使用早停策略**:监控验证集loss,在loss开始上升时停止训练,防止过拟合。 5. **使用其他优化器**:尝试不同的优化算法,如RMSprop或Adagrad。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值