fix audiostream buffer
This commit is contained in:
parent
6a7af5d006
commit
46b0f5abab
|
@ -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()
|
||||||
|
|
16
nerfreal.py
16
nerfreal.py
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue