赞
踩
本文将介绍一个可以通过语音指令来控制坦克大战游戏的程序,用户只需要添加几个疾病区然后控制坦克进行向上、向下、向左、向右、开火、停止等操作。同时还支持指令微调、提高指令的准确率。
本项目开发换为:
conda install pytorch torchvision torchaudio pytorch-cuda=12.1 -c pytorch -c nvidia
pip install -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple
运行main.py
程序即可启动游戏,可以调整的参数有:sec_time
为录制时间,单位秒;last_len
为上一部分的数据长度,单位秒;。
增加指令,需要在instruct.txt
添加指令,然后再main.py
添加你指令的处理函数。
日志输出:
支持指令:['向上', '向下', '向左', '向右', '停止', '开火']
请发出指令...
触发指令:【向上】
触发指令:【开火】
触发指令:【开火】
游戏页面:
微调指令模型的代码在finetune
目录下,微调前切换到finetune
目录,具体的训练过程看下面操作。
运行record_data.py
代码,启动录音程序,默认录制2秒钟,建议录制完成之后,再录制1秒钟的音频,注意录制1秒钟时间非常短,按下回车之后要立马开始说话。其实自定义数据可以参考生成的dataset
目录。
输出日志:
请输入指令内容:向上
请输入录入次数:10
第1次录音,按回车开始说话:
开始录音......
录音已结束!
第2次录音,按回车开始说话:
运行generate_data_list.py
代码,生成训练数据列表。
执行下面命令训练模型,如果是Windows,需要把参数并接为一行,并删除\
。
funasr-train \
++model=../models/paraformer-zh \
++train_data_set_list=dataset/train.jsonl \
++valid_data_set_list=dataset/validation.jsonl \
++dataset_conf.batch_type="token" \
++dataset_conf.batch_size=10000 \
++train_conf.max_epoch=5 \
++train_conf.log_interval=1
++train_conf.keep_nbest_models=5 \
++train_conf.avg_nbest_model=3 \
++output_dir="./outputs"
运行merge_model.py
代码,将训练好的模型合并成一个模型../models/paraformer-zh-finetune
。
游戏的开发参考了TankWar。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。