fix audiostream buffer

This commit is contained in:
lihengzhong 2024-01-09 10:01:50 +08:00
parent 6a7af5d006
commit 46b0f5abab
2 changed files with 663 additions and 655 deletions

View File

@ -406,6 +406,8 @@ class ASR:
idx += self.chunk idx += self.chunk
if streamlen>0: if streamlen>0:
self.queue.put(stream[idx:]) self.queue.put(stream[idx:])
self.input_stream.seek(0)
self.input_stream.truncate()
def get_audio_out(self): def get_audio_out(self):
return self.output_queue.get() return self.output_queue.get()

View File

@ -5,6 +5,7 @@ import numpy as np
#from .utils import * #from .utils import *
import subprocess import subprocess
import os import os
import time
from asrreal import ASR from asrreal import ASR
from rtmp_streaming import StreamerConfig, Streamer from rtmp_streaming import StreamerConfig, Streamer
@ -129,8 +130,8 @@ class NeRFReal:
def test_step(self): def test_step(self):
starter, ender = torch.cuda.Event(enable_timing=True), torch.cuda.Event(enable_timing=True) #starter, ender = torch.cuda.Event(enable_timing=True), torch.cuda.Event(enable_timing=True)
starter.record() #starter.record()
if self.playing: if self.playing:
try: try:
@ -161,9 +162,9 @@ class NeRFReal:
auds = None auds = None
outputs = self.trainer.test_gui(self.cam.pose, self.cam.intrinsics, self.W, self.H, auds, self.eye_area, self.ind_index, self.bg_color, self.spp, self.downscale) outputs = self.trainer.test_gui(self.cam.pose, self.cam.intrinsics, self.W, self.H, auds, self.eye_area, self.ind_index, self.bg_color, self.spp, self.downscale)
ender.record() #ender.record()
torch.cuda.synchronize() #torch.cuda.synchronize()
t = starter.elapsed_time(ender) #t = starter.elapsed_time(ender)
def render(self): def render(self):
if self.opt.asr: if self.opt.asr:
@ -171,8 +172,13 @@ class NeRFReal:
while True: #todo while True: #todo
# update texture every frame # update texture every frame
# audio stream thread... # audio stream thread...
t = time.time()
if self.opt.asr and self.playing: if self.opt.asr and self.playing:
# run 2 ASR steps (audio is at 50FPS, video is at 25FPS) # run 2 ASR steps (audio is at 50FPS, video is at 25FPS)
for _ in range(2): for _ in range(2):
self.asr.run_step() self.asr.run_step()
self.test_step() self.test_step()
delay = 0.04 - (time.time() - t) #40ms
if delay > 0:
time.sleep(delay)