domingo, 30 de julho de 2023

Gerador de Legendas - 6.0

- A ideia desta versão é gerar o arquivo de legenda no formato .srt a partir de uma interface Web.

- Instale o Flask com o comando:

pip install flask

- Segue o código para criar um aplicativo da web usando Flask:

import os
import subprocess
import vosk
import pysrt
import json
from flask import Flask, render_template, request
from werkzeug.utils import secure_filename
from moviepy.editor import VideoFileClip

app = Flask(__name__)

UPLOAD_FOLDER = 'uploads'
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER

def recognize_speech(file_path, language, text_widget=None, subtitles=None):
# Configurar o caminho do modelo de idioma Vosk de acordo com a escolha do usuário
if language == "en":
model_path = "vosk-model-small-en-us-0.15"
elif language == "pt":
model_path = "vosk-model-pt-fb-v0.1.1-20220516_2113"
elif language == "es":
model_path = "vosk-model-small-es-0.42"
else:
raise ValueError("Idioma não suportado.")

# Verificar se o arquivo de entrada existe
if not os.path.isfile(file_path):
raise FileNotFoundError("O arquivo de vídeo não existe.")

# Configurar a taxa de amostragem para o modelo Vosk
sample_rate = 16000

# Carregar o modelo de idioma Vosk
model = vosk.Model(model_path)

# Inicializar o reconhecedor de fala Vosk
rec = vosk.KaldiRecognizer(model, sample_rate)
rec.SetWords(True)

# Obter a duração do áudio para atualização da barra de progresso
audio_duration = VideoFileClip(file_path).duration

# Comando FFmpeg para extrair o áudio e converter para WAV
ffmpeg_command = f"ffmpeg -y -i {file_path} -vn -acodec pcm_s16le -ar {sample_rate} -ac 1 -f wav -"
ffmpeg_process = subprocess.Popen(ffmpeg_command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)

# Realizar o reconhecimento de fala por blocos de áudio
start_time = 0
block_duration = 9 # Definir a duração do bloco em segundos

while start_time < audio_duration:
# Ler o próximo bloco de áudio do processo ffmpeg
audio_data = ffmpeg_process.stdout.read(sample_rate * block_duration)

# Realizar o reconhecimento de fala no bloco atual
rec.AcceptWaveform(audio_data)

# Extrair o texto reconhecido do resultado
result = json.loads(rec.Result())

if "result" in result:
transcript = " ".join([word["word"] for word in result["result"]])
if transcript.strip(): # Verificar se o texto não está vazio
end_time = min(start_time + block_duration, audio_duration)
subtitles.append(pysrt.SubRipItem(index=len(subtitles) + 1, start=pysrt.SubRipTime(seconds=start_time), end=pysrt.SubRipTime(seconds=end_time), text=transcript))

# Atualizar o texto no widget Text (interface do usuário)
if text_widget is not None:
text_widget.insert(tk.END, f"--> {transcript}\n")
text_widget.see(tk.END) # Rolar o texto para mantê-lo visível
text_widget.update() # Atualizar a interface do usuário

# Atualizar o tempo de início para o próximo bloco
start_time += block_duration

# Fechar o processo ffmpeg
ffmpeg_process.stdout.close()
ffmpeg_process.wait()

return subtitles

@app.route("/", methods=["GET", "POST"])
def index():
if request.method == "POST":
file = request.files["video_file"]
language = request.form["language_choice"]

# Verificar se o arquivo foi enviado corretamente
if file and file.filename.endswith(".mp4"):
# Crie o diretório de uploads se ainda não existir
if not os.path.exists(app.config['UPLOAD_FOLDER']):
os.makedirs(app.config['UPLOAD_FOLDER'])

# Salvar o arquivo de vídeo com um nome exclusivo no diretório "uploads"
file_path = os.path.join(app.config['UPLOAD_FOLDER'], secure_filename(file.filename))
file.save(file_path)

try:
subtitles = pysrt.SubRipFile()
recognize_speech(file_path, language, text_widget=None, subtitles=subtitles)
output_file = os.path.splitext(file_path)[0]

if language == "en":
output_file += "_ing.srt"
elif language == "pt":
output_file += "_por.srt"
elif language == "es":
output_file += "_esp.srt"

with open(output_file, "w", encoding="utf-8") as f:
for subtitle in subtitles:
f.write(str(subtitle))
f.write("\n")

message = f"Processo concluído. Legenda gerada em {output_file}"
except Exception as e:
message = f"Erro durante o reconhecimento: {str(e)}"
else:
message = "Selecione um arquivo de vídeo no formato .mp4."

return render_template("index.html", message=message)

return render_template("index.html")

if __name__ == "__main__":
app.run(debug=True)

- Crie um diretório chamado "templates" no mesmo diretório onde se encontra o aplicativo web com o código acima (arquivo Python com extensão .py)  e crie um arquivo chamado "index.html" dentro desse diretório. O conteúdo do arquivo "index.html" será a interface do aplicativo da web. Você pode escrever o HTML, CSS e JavaScript necessários para criar a interface do usuário de acordo com suas preferências e requisitos.

Exemplo básico do arquivo "index.html":

html
<!DOCTYPE html> <html> <head> <title>Gerador de Legendas</title> </head> <body> <h1>Gerador de Legendas</h1> <form action="/" method="post" enctype="multipart/form-data"> <label for="video_file">Escolha o arquivo de vídeo:</label> <input type="file" name="video_file" id="video_file" accept=".mp4"><br> <label>Selecione o idioma para reconhecimento:</label><br> <input type="radio" name="language_choice" value="en" checked> Inglês<br> <input type="radio" name="language_choice" value="pt"> Português<br> <input type="radio" name="language_choice" value="es"> Espanhol<br> <input type="submit" value="Iniciar Reconhecimento"> </form> {% if message %} <p>{{ message }}</p> {% endif %} </body> </html>

- Este é um exemplo simples que mostra a página com um formulário para enviar o arquivo de vídeo e selecionar o idioma para o reconhecimento. O resultado do reconhecimento será exibido como uma mensagem na mesma página após o processamento. Note que este é apenas um exemplo básico, e você pode estilizar e aprimorar a interface do usuário conforme necessário.

- Depois de criar o arquivo "index.html" e o diretório "templates", execute o script Python para iniciar o servidor da web:

python3 seu_script.py

- Acesse o aplicativo em um navegador web acessando http://127.0.0.1:5000/ e utilize-o para reconhecer o áudio do arquivo de vídeo selecionado e gerar as legendas.

- O arquivo de vídeo carregado e o arquivo de legenda no formato .srt gerado são salvos no diretório "uploads". O código do aplicativo web garante que o arquivo seja salvo com um nome exclusivo para evitar conflitos se várias pessoas usarem o aplicativo simultaneamente.

 

sábado, 29 de julho de 2023

Ferramenta Para Comprimir Mola de Espingarda de Pressão

- Ideia para comprimir com segurança a mola de espingardas de pressão.

- É possível (e até melhor) usar sem o cano raiado.

- Sem esta ferramenta é praticamente impossível recolocar o gatilho na posição, pois neste modelo de espingarda o pino que fixa o batente da mola de pressão serve de eixo para o gatilho.


Gerador de Legendas - 5.0

- Nesta versão foi acrescentada uma interface gráfica ao script;

- A parte de tradução das foi retirada;

- O reconhecimento da fala suporta 3 idiomas: Inglês, Português e Espanhol.

import os
import subprocess
import vosk
import pysrt
import json
import sys
import tkinter as tk
from tkinter import filedialog
import threading
from moviepy.editor import VideoFileClip

def recognize_speech(file_path, language, text_widget, subtitles):
    # Configurar o caminho do modelo de idioma Vosk de acordo com a escolha do usuário
    if language == "en":
        model_path = "vosk-model-small-en-us-0.15"
    elif language == "pt":
        model_path = "vosk-model-pt-fb-v0.1.1-20220516_2113"
    elif language == "es":
        model_path = "vosk-model-small-es-0.42"
    else:
        raise ValueError("Idioma não suportado.")

    # Verificar se o arquivo de entrada existe
    if not os.path.isfile(file_path):
        raise FileNotFoundError("O arquivo de vídeo não existe.")

    # Configurar a taxa de amostragem para o modelo Vosk
    sample_rate = 16000

    # Carregar o modelo de idioma Vosk
    model = vosk.Model(model_path)

    # Inicializar o reconhecedor de fala Vosk
    rec = vosk.KaldiRecognizer(model, sample_rate)
    rec.SetWords(True)

    # Obter a duração do áudio para atualização da barra de progresso
    audio_duration = VideoFileClip(file_path).duration

    # Comando FFmpeg para extrair o áudio e converter para WAV
    ffmpeg_command = f"ffmpeg -y -i {file_path} -vn -acodec pcm_s16le -ar {sample_rate} -ac 1 -f wav -"
    ffmpeg_process = subprocess.Popen(ffmpeg_command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)

    # Realizar o reconhecimento de fala por blocos de áudio
    start_time = 0
    prev_end_time = 0

    while True:
        # Ler o próximo bloco de áudio do processo ffmpeg
        audio_data = ffmpeg_process.stdout.read(sample_rate * 9)
        if len(audio_data) == 0:
            break

        # Realizar o reconhecimento de fala no bloco atual
        rec.AcceptWaveform(audio_data)

        # Extrair o texto reconhecido do resultado
        result = json.loads(rec.Result())

        if "result" in result:
            transcript = " ".join([word["word"] for word in result["result"]])
            if transcript.strip():  # Verificar se o texto não está vazio
                block_duration = result["result"][-1]["end"] - prev_end_time
                progress_percentage = (start_time + block_duration) / audio_duration * 100
                subtitles.append(pysrt.SubRipItem(index=len(subtitles) + 1, start=pysrt.SubRipTime(seconds=start_time), end=pysrt.SubRipTime(seconds=start_time + block_duration), text=transcript))
                
                # Atualizar o texto no widget Text
                text_widget.insert(tk.END, f"--> {transcript}\n")
                text_widget.see(tk.END)  # Rolar o texto para mantê-lo visível

                # Atualizar o tempo de início para o próximo bloco
                start_time += block_duration
                prev_end_time = result["result"][-1]["end"]

    # Fechar o processo ffmpeg
    ffmpeg_process.stdout.close()
    ffmpeg_process.wait()

    return subtitles

class SpeechRecognitionApp(tk.Tk):
    def __init__(self):
        super().__init__()
        self.title("Gerador de Legendas")
        self.geometry("500x500")

        self.file_path = tk.StringVar()
        self.language_choice = tk.StringVar(value="en")

        tk.Label(self, text="Escolha o arquivo de vídeo:").pack(pady=10)
        tk.Button(self, text="Procurar", command=self.browse_file).pack(pady=5)

        tk.Label(self, text="Selecione o idioma para reconhecimento:").pack(pady=10)
        tk.Radiobutton(self, text="Inglês", variable=self.language_choice, value="en").pack(anchor=tk.W)
        tk.Radiobutton(self, text="Português", variable=self.language_choice, value="pt").pack(anchor=tk.W)
        tk.Radiobutton(self, text="Espanhol", variable=self.language_choice, value="es").pack(anchor=tk.W)

        self.display_text = tk.Text(self, wrap="word", width=60, height=10)
        self.display_text.pack(pady=10)

        self.start_recognition_button = tk.Button(self, text="Iniciar Reconhecimento", command=self.start_recognition_process)
        self.start_recognition_button.pack(pady=10)

    def browse_file(self):
        self.file_path.set(filedialog.askopenfilename(filetypes=[("Arquivos de Vídeo", "*.mp4")]))
        file_path = self.file_path.get()
        self.display_text.delete(1.0, tk.END)
        self.display_text.insert(tk.END, f"Arquivo de vídeo: {file_path}")

    def start_recognition_process(self):
        file_path = self.file_path.get()
        language = self.language_choice.get()
        if not file_path:
            self.display_text.delete(1.0, tk.END)
            self.display_text.insert(tk.END, "Selecione um arquivo de vídeo.")
            return

        if not os.path.isfile(file_path):
            self.display_text.delete(1.0, tk.END)
            self.display_text.insert(tk.END, "O arquivo de vídeo não existe.")
            return

        # Limpar o texto reconhecido anterior
        self.display_text.delete(1.0, tk.END)

        # Desabilitar o botão de início para evitar múltiplas execuções
        self.start_recognition_button.config(state=tk.DISABLED)

        # Iniciar o processo de reconhecimento em uma thread separada
        threading.Thread(target=self.perform_recognition, args=(file_path, language)).start()

    def save_subtitles(self, output_file, subtitles):
        # Cria um arquivo .srt com as legendas geradas
        with open(output_file, "w", encoding="utf-8") as f:
            for subtitle in subtitles:
                f.write(str(subtitle))
                f.write('\n')

        self.display_text.delete(1.0, tk.END)
        self.display_text.insert(tk.END, f"Processo concluído. Legenda gerada em {output_file}")

    def perform_recognition(self, file_path, language):
        try:
            subtitles = pysrt.SubRipFile()
            self.display_text.insert(tk.END, "Iniciando o reconhecimento...\n")
            self.update_idletasks()

            blocks = recognize_speech(file_path, language, self.display_text, subtitles)

            # Obter o caminho do arquivo de saída .srt
            output_file = os.path.splitext(file_path)[0]
            if language == "en":
                output_file += "_ing.srt"
            elif language == "pt":
                output_file += "_por.srt"
            elif language == "es":
                output_file += "_esp.srt"

            # Salvar as legendas em formato .srt
            self.save_subtitles(output_file, subtitles)

        except Exception as e:
            self.display_text.insert(tk.END, f"Erro durante o reconhecimento: {str(e)}\n")
            self.update_idletasks()

        finally:
            # Habilitar o botão de início após o término do reconhecimento
            self.start_recognition_button.config(state=tk.NORMAL)

if __name__ == "__main__":
    app = SpeechRecognitionApp()
    app.mainloop()
 

segunda-feira, 24 de julho de 2023

Gerador de Legendas - 4.0

- Nesta versão o arquivo de entrada é recebido como parâmetro do script .py e o arquivo de saída será a legenda traduzida e terá o mesmo nome do arquivo de entrada com a extensão .srt .

import os
import subprocess
import vosk
import pysrt
import json
import sys

if len(sys.argv) != 2:
    print("Uso: python3 nome_do_script.py arquivo_de_entrada.mp4")
    sys.exit(1)

# Caminho do arquivo de vídeo (arquivo de entrada)
video_file = sys.argv[1]

# Verificar se o arquivo de entrada existe
if not os.path.isfile(video_file):
    print("O arquivo de entrada não existe.")
    sys.exit(1)

# Caminho do arquivo de saída (legendas em pt-BR)
output_file = os.path.splitext(video_file)[0] + ".srt"

# Comando FFmpeg para extrair o áudio e converter para WAV
ffmpeg_command = f"ffmpeg -y -i {video_file} -vn -acodec pcm_s16le -ar 16000 -ac 1 -f wav -"
ffmpeg_process = subprocess.Popen(ffmpeg_command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)

# Carregar o modelo de idioma Vosk
model_path = "vosk-model-small-en-us-0.15"
model = vosk.Model(model_path)
sample_rate = 16000

# Inicializar o reconhecedor de fala Vosk
rec = vosk.KaldiRecognizer(model, sample_rate)
rec.SetWords(True)

# Realizar o reconhecimento de fala por blocos de áudio
subtitles = pysrt.SubRipFile()
start_time = 0
prev_end_time = 0

while True:
    # Ler o próximo bloco de áudio do processo ffmpeg
    audio_data = ffmpeg_process.stdout.read(sample_rate * 2 * 10)
    if len(audio_data) == 0:
        break

    # Realizar o reconhecimento de fala no bloco atual
    rec.AcceptWaveform(audio_data)

    # Extrair o texto reconhecido do resultado
    result = json.loads(rec.Result())

    if "result" in result:
        transcript = " ".join([word["word"] for word in result["result"]])

        if transcript.strip():  # Verificar se o texto não está vazio
            #print(f"{start_time:.2f}s - {transcript}")

            # Traduzir o texto para o português usando o translate-shell
            translation_command = ["trans", "-b", "-no-ansi", "-no-warn", "-no-auto", "-no-bidi", "-s", "en", "-t", "pt-br"]
            translation_process = subprocess.Popen(translation_command, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)
            translation, _ = translation_process.communicate(input=transcript.strip().encode())
            translation = translation.decode().strip()
            print(f"{start_time:.2f}s - {translation}")

            # Adicionar legenda traduzida ao arquivo de legendas
            block_duration = result["result"][-1]["end"] - prev_end_time
            start_timestamp = pysrt.SubRipTime(seconds=start_time)
            end_timestamp = pysrt.SubRipTime(seconds=start_time + block_duration)
            subtitles.append(pysrt.SubRipItem(index=len(subtitles) + 1, start=start_timestamp, end=end_timestamp, text=translation))

            # Atualizar o tempo de início para o próximo bloco
            start_time += block_duration
            prev_end_time = result["result"][-1]["end"]

# Fechar o processo ffmpeg
ffmpeg_process.stdout.close()
ffmpeg_process.wait()

# Salvar legendas em pt-BR
subtitles.save(output_file, encoding="utf-8")

print("Processo concluído. Legenda em pt-BR gerada em", output_file)


Gerador de Legendas - 3.0

- Nesta versão o tamanho do bloco a ser lido não é mais fixo, depende das pausas existente no áudio. Parece ter gerado melhores legendas.

import os
import subprocess
import vosk
import pysrt
import json

# Caminho do arquivo de vídeo
video_file = "movie.mp4"

# Caminho do arquivo de saída (legendas em pt-BR)
output_file = "traducaoptbrblocovariavel.srt"

# Comando FFmpeg para extrair o áudio e converter para WAV
ffmpeg_command = f"ffmpeg -y -i {video_file} -vn -acodec pcm_s16le -ar 16000 -ac 1 -f wav -"
ffmpeg_process = subprocess.Popen(ffmpeg_command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)

# Carregar o modelo de idioma Vosk
model_path = "vosk-model-small-en-us-0.15"
model = vosk.Model(model_path)
sample_rate = 16000

# Inicializar o reconhecedor de fala Vosk
rec = vosk.KaldiRecognizer(model, sample_rate)
rec.SetWords(True)

# Realizar o reconhecimento de fala por blocos de áudio
subtitles = pysrt.SubRipFile()
start_time = 0
prev_end_time = 0

while True:
    # Ler o próximo bloco de áudio do processo ffmpeg
    audio_data = ffmpeg_process.stdout.read(sample_rate * 2 * 10)
    if len(audio_data) == 0:
        break

    # Realizar o reconhecimento de fala no bloco atual
    rec.AcceptWaveform(audio_data)

    # Extrair o texto reconhecido do resultado
    result = json.loads(rec.Result())

    if "result" in result:
        transcript = " ".join([word["word"] for word in result["result"]])

        if transcript.strip():  # Verificar se o texto não está vazio
            print(f"{start_time:.2f}s - {transcript}")

            # Traduzir o texto para o português usando o translate-shell
            translation_command = ["trans", "-b", "-no-ansi", "-no-warn", "-no-auto", "-no-bidi", "-s", "en", "-t", "pt-br"]
            translation_process = subprocess.Popen(translation_command, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)
            translation, _ = translation_process.communicate(input=transcript.strip().encode())
            translation = translation.decode().strip()
            print(f"{start_time:.2f}s - {translation}")

            # Adicionar legenda traduzida ao arquivo de legendas
            block_duration = result["result"][-1]["end"] - prev_end_time
            start_timestamp = pysrt.SubRipTime(seconds=start_time)
            end_timestamp = pysrt.SubRipTime(seconds=start_time + block_duration)
            subtitles.append(pysrt.SubRipItem(index=len(subtitles) + 1, start=start_timestamp, end=end_timestamp, text=translation))

            # Atualizar o tempo de início para o próximo bloco
            start_time += block_duration
            prev_end_time = result["result"][-1]["end"]

# Fechar o processo ffmpeg
ffmpeg_process.stdout.close()
ffmpeg_process.wait()

# Salvar legendas em pt-BR
subtitles.save(output_file, encoding="utf-8")

print("Processo concluído. Legenda em pt-BR gerada em", output_file)

 

Gerador de Legendas - 2.0

- Pequena alteração no código para otimização do tempo de resposta. O comando FFmpeg é executado como um subprocesso PIPE, isto evita o carregamento do código do programa para a memória a cada execução em um bloco de áudio. 

import os
import subprocess
import vosk
import pysrt
import json

# Caminho do arquivo de vídeo
video_file = "movie.mp4"

# Caminho do arquivo de saída (legendas em pt-BR)
output_file = "legendatraduzidaveloz.srt"

# Comando FFmpeg para extrair o áudio e converter para WAV
ffmpeg_command = f"ffmpeg -y -i {video_file} -vn -acodec pcm_s16le -ar 16000 -ac 1 -f wav -"
ffmpeg_process = subprocess.Popen(ffmpeg_command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)

# Carregar o modelo de idioma Vosk
model_path = "vosk-model-small-en-us-0.15"
model = vosk.Model(model_path)
sample_rate = 16000

# Inicializar o reconhecedor de fala Vosk
rec = vosk.KaldiRecognizer(model, sample_rate)
rec.SetWords(True)

# Configurações do bloco de áudio
block_size = 9  # Duração em segundos de cada bloco de áudio

# Realizar o reconhecimento de fala por blocos de áudio
subtitles = pysrt.SubRipFile()
start_time = 0

while True:
    # Ler o próximo bloco de áudio do processo ffmpeg
    audio_data = ffmpeg_process.stdout.read(sample_rate * 2 * block_size)
    if len(audio_data) == 0:
        break

    # Realizar o reconhecimento de fala no bloco atual
    rec.AcceptWaveform(audio_data)
    result = rec.Result()

    # Extrair o texto reconhecido do resultado
    if result:
        transcript = json.loads(result)["text"]

        if transcript.strip():  # Verificar se o texto não está vazio
            print(f"{start_time:.2f}s - {transcript}")

            # Traduzir o texto para o português usando o translate-shell
            translation_command = ["trans", "-b", "-no-ansi", "-no-warn", "-no-auto", "-no-bidi", "-s", "en", "-t", "pt-br"]
            translation_process = subprocess.Popen(translation_command, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)
            translation, _ = translation_process.communicate(input=transcript.strip().encode())
            translation = translation.decode().strip()
            print(f"{start_time:.2f}s - {translation}")

            # Adicionar legenda traduzida ao arquivo de legendas
            start_timestamp = pysrt.SubRipTime(seconds=start_time)
            end_timestamp = pysrt.SubRipTime(seconds=start_time + block_size)
            subtitles.append(pysrt.SubRipItem(index=len(subtitles) + 1, start=start_timestamp, end=end_timestamp, text=translation))

    # Atualizar o tempo de início para o próximo bloco
    start_time += block_size

# Fechar o processo ffmpeg
ffmpeg_process.stdout.close()
ffmpeg_process.wait()

# Salvar legendas em pt-BR
subtitles.save(output_file, encoding="utf-8")

print("Processo concluído. Legenda em pt-BR gerada em", output_file)

quinta-feira, 13 de julho de 2023

Gerador de Legendas

# Script em linguagem Python gerador de legendas em português a partir de vídeos em inglês

import os
import subprocess
import vosk
import pysrt
import json

# Caminho do arquivo de vídeo
video_file = "movie.mp4"

# Caminho do arquivo de saída (legendas em pt-BR)
output_file = "traducaoptbr.srt"

# Comando FFmpeg para extrair o áudio e converter para WAV
ffmpeg_command = f"ffmpeg -y -i {video_file} -vn -acodec pcm_s16le -ar 16000 -ac 1 audio.wav > /dev/null 2>&1"
subprocess.call(ffmpeg_command, shell=True)

# Carregar o modelo de idioma Vosk
model_path = "vosk-model-small-en-us-0.15"
model = vosk.Model(model_path)
sample_rate = 16000

# Inicializar o reconhecedor de fala Vosk
rec = vosk.KaldiRecognizer(model, sample_rate)
rec.SetWords(True)

# Configurações do bloco de áudio
block_size = 10  # Duração em segundos de cada bloco de áudio

# Realizar o reconhecimento de fala por blocos de áudio
subtitles = pysrt.SubRipFile()
total_duration = os.path.getsize("audio.wav") / (sample_rate * 2)  # Tamanho do arquivo em bytes / taxa de amostragem / bytes por amostra (2 bytes)
start_time = 0

while start_time < total_duration:
    end_time = min(start_time + block_size, total_duration)

    # Carregar o bloco de áudio atual
    audio_file = "audio.wav"
    ffmpeg_command = f"ffmpeg -y -ss {start_time} -i {audio_file} -t {block_size} audio_block.wav > /dev/null 2>&1"
    subprocess.call(ffmpeg_command, shell=True)

    # Realizar o reconhecimento de fala no bloco atual
    with open("audio_block.wav", "rb") as f:
        audio_data = f.read()
        rec.AcceptWaveform(audio_data)
        result = rec.Result()

    # Extrair o texto reconhecido do resultado
    if result:
        result_json = json.loads(result)
        transcript = result_json["text"]

        if transcript.strip():  # Verificar se o texto não está vazio
            print(f"{start_time:}s - {transcript}")
            # Traduzir o texto para o português usando o translate-shell
            input_file = "transcript.txt"
            output_file = "translation.txt"
            with open(input_file, "w") as f:
                f.write(transcript.strip())
            command = f"trans -b -no-ansi -no-warn -no-auto -no-bidi -s en -t pt-br -i {input_file} > {output_file}"
            subprocess.call(command, shell=True)
            with open(output_file, "r") as f:
                translation = f.read().strip()
                print(f"{start_time:}s - {translation}")
            # Adicionar legenda traduzida ao arquivo de legendas
            start_timestamp = pysrt.SubRipTime(seconds=start_time)
            end_timestamp = pysrt.SubRipTime(seconds=end_time)
            subtitles.append(pysrt.SubRipItem(index=len(subtitles) + 1, start=start_timestamp, end=end_timestamp, text=translation))

    # Atualizar o tempo de início para o próximo bloco
    start_time = end_time

# Salvar legendas em pt-BR
subtitles.save(output_file, encoding="utf-8")

print("Processo concluído. Legenda em pt-BR gerada em", output_file)
   
   1. Dependências:
        ffmpeg: É uma ferramenta de linha de comando para manipulação de arquivos de áudio e vídeo.
        vosk: É uma biblioteca de reconhecimento de fala offline.
        translate-shell: É uma interface de linha de comando para os serviços de tradução online.
        pysrt: É uma biblioteca para criar, modificar e extrair informações de arquivos de legendas em formato SubRip.
        json: É um módulo nativo do Python para trabalhar com dados JSON.
        os: É um módulo que fornece várias funções relacionadas ao sistema operacional.
        subprocess: É um módulo usado para executar comandos do sistema operacional a partir do Python.
        
   2. Instalação das dependências:
        ffmpeg: Você pode instalar o ffmpeg seguindo as instruções disponíveis em https://ffmpeg.org/download.html.
        vosk: Para instalar a biblioteca vosk, você pode usar o gerenciador de pacotes pip com o seguinte comando: pip install vosk.
        pysrt: Para instalar a biblioteca pysrt, você pode usar o pip com o seguinte comando: pip install pysrt.
        Certifique-se de que todas as dependências estejam corretamente instaladas.
        Certifique-se que os caminhos dos arquivos de entrada e saída estejam definidos corretamente no script.
        A biblioteca Vosk pode ser encontrada no GitHub, no seguinte repositório: https://github.com/alphacep/vosk-api
        Para usar a biblioteca Vosk, siga estas etapas:
        Clone o repositório Vosk-API em seu ambiente:
             no bash digite: git clone https://github.com/alphacep/vosk-api.git
             Navegue até o diretório vosk-api/python: cd vosk-api/python
             Instale as dependências necessárias: pip install -r requirements.txt
             Instale a biblioteca Vosk: python setup.py install
             Baixe os modelos de idioma do Vosk que estão no repositório Vosk-API ou em https://alphacephei.com/vosk/models
        
   3. Arquivos de entrada e saída:
        Arquivo de vídeo: O caminho do arquivo de vídeo deve ser definido na variável video_file.
        Arquivo de áudio gerado: O script gera um arquivo chamado "audio.wav" que contém o áudio extraído do arquivo de vídeo. O caminho e o nome deste arquivo são definidos na variável audio_file.
        Arquivo de saída: O script gera também um arquivo cujo nome é definido na variável output_file. Este arquivo contém as legendas traduzidas do inglês para o português (pt-BR).

   4. Funcionamento do script:
        O script usa o ffmpeg para extrair o áudio do arquivo de vídeo movie.mp4 e convertê-lo para o formato WAV. O FFmpeg é executado com o seguinte comando: ffmpeg -y -i {video_file} -vn -acodec pcm_s16le -ar 16000 -ac 1 {audio_file} > /dev/null 2>&1.
        Em seguida, o script carrega o modelo de idioma do Vosk para realizar o reconhecimento de fala no áudio.
        O módulo os é usado para obter informações sobre o arquivo de áudio gerado audio.wav, como o tamanho do arquivo em bytes.
        O reconhecimento de fala é feito em blocos de áudio definidos pela variável block_size.
        Cada bloco de áudio é processado e o texto reconhecido é traduzido para o português usando o translate-shell.
        A tradução utiliza o serviço do Google Translate através do Translate-Shell.
        As legendas traduzidas são adicionadas a um arquivo de legendas em formato SubRip (.srt) usando a biblioteca pysrt.
        Por fim, o arquivo de legendas traducaoptbr.srt é salvo no caminho definido pela variável output_file.

sábado, 8 de julho de 2023

Pedestal Para Celular

 - Suporte para manter o celular fixo durante uma filmagem.



terça-feira, 4 de julho de 2023

Cabos de Faca

- Um cabo feito com plástico derretido numa sanduicheira e "acabamento" com o soprador térmico;

- o outro feito com um cabo de resistência elétrica.


 

-

sexta-feira, 23 de junho de 2023

quinta-feira, 22 de junho de 2023

Cantoneira Alternativa

- Feita com perfil em U;

- Uso de dobras para fixar as laterais internas;

- Se necessário as dobras podem ocupar a parte interna do perfil.

 
















terça-feira, 20 de junho de 2023

Domo Alternativo Simplificado

- Ideia de domo para usar uma tira contínua qualquer com espaços regulares. Neste protótipo foi usado uma mangueira com intervalos de 10 cm;

- Alguns nós estão desconectados pois os parafusos usados são curtos;

- Os centros dos pentágonos estão vazios e os hexágonos não foram completamente formados;

- Foram usadas 5 tiras de 7 espaços, 5 tiras de 6 espaços e 1 tira de 15 espaços. 










sexta-feira, 16 de junho de 2023

DomoPet 3.0

- Ideia de estrutura feita 100% em PET;

- Distância regular de 22 cm entre os nós.





quarta-feira, 14 de junho de 2023

Muletas Alternativas

- Feitas em 2018 para uso caseiro. Cumpriu satisfatoriamente o objetivo. Uma feita com PVC e outra com cano galvanizado.




domingo, 11 de junho de 2023

BlocoPet 2.0

- Feito em 29 Maio 2021;

- Mistura de massa de papel com isopor triturado;

- Bloco 88 cm comprimento x 30 cm altura x 20 cm largura;

- Longo tempo para secar.





















domingo, 4 de junho de 2023

Roda de Esteira Alternativa

- Ideia de uso da Redução Planetária Alternativa como roda de esteira com redução acoplada.


 



sexta-feira, 2 de junho de 2023

Redução Planetária Alternativa

- Ideia de redução planetária com pião e corrente de moto. O pião central teve os dentes limados para liberar o movimento dos outros sobre a corrente interna.

 


quinta-feira, 1 de junho de 2023

Botão de Pressão Alternativo

- Chave tipo push-button normalmente aberta feita a partir de um bico dosador de azeite de oliva.



sábado, 27 de maio de 2023

Grade Articulável Alternativa

- Grade feita com tiras retiradas de placas de forro de PVC;

- uso do PinoPet nos encontros;

- esta grade cumpriu sua finalidade por vários meses e foi desmontada hoje, logo após estas fotos.

 




sexta-feira, 26 de maio de 2023

PetNó 14

- Barras na mesma disposição do PetNó 13;

- Uso de um PinoPet comprido;


 

 

 









- Dobrar as pontas do PinoPet com um alicate de bico fino.









 

 

 

 

 - Formas de aplicação do PinoPet: rebitado, extremidades dobradas e com ArruelaPet;

 

 

 

 

 

 

 

 

 

 

 

 

 - Aplicação do PetNó 14: TreliçaPet hexagonal 100% em PET;













- Detalhe do alicate unindo as barras para facilitar a inserção do PinoPet. Foi mais necessário antes da ideia de usar um PinoPet mais comprido.


quarta-feira, 24 de maio de 2023

PetNó 13

- Ideia de Nó 100% em PET;

- Aplicação do RebitePet 3.2;

- Apenas um rebite une 6 peças.




quarta-feira, 17 de maio de 2023

Pentágono Côncavo Regular 2.0

 

 
- Feito com fita perfurada;
- Aplicação do RebitePet 3.1;
- Irregularidades devidas às diferenças nas distâncias entres os furos da fita;
- Usadas 5 fitas de 4 a 9 unidades de tamanho.

terça-feira, 16 de maio de 2023

Artigo - Uso da Glicerina Como Aditivo no Sistema de Arrefecimento de Motores de Combustão Interna


 

Artigo Científico: Uso da Glicerina como Aditivo no Sistema de Arrefecimento de Motores a Combustão Interna

Resumo: Este artigo tem como objetivo apresentar uma revisão abrangente sobre o uso da glicerina como aditivo no sistema de arrefecimento de motores a combustão interna. O sistema de arrefecimento desempenha um papel crucial na manutenção da temperatura adequada de funcionamento do motor, e o uso de aditivos busca melhorar a eficiência e prolongar a vida útil do sistema. A glicerina, devido às suas propriedades físico-químicas favoráveis, tem sido estudada como uma opção promissora para aprimorar o desempenho do sistema de arrefecimento. Neste artigo, discutiremos as propriedades da glicerina, seu efeito no sistema de arrefecimento, os resultados de pesquisas experimentais e os desafios associados ao seu uso. Espera-se que este artigo forneça uma visão abrangente e atualizada sobre o assunto, contribuindo para futuras pesquisas e desenvolvimentos na área.User

  1. Introdução

O sistema de arrefecimento desempenha um papel fundamental no funcionamento adequado dos motores a combustão interna. Ele é responsável por controlar a temperatura do motor, garantindo que ele opere dentro dos limites ideais. O líquido de arrefecimento, geralmente composto por água e aditivos, é responsável por absorver o calor gerado pelo motor e dissipá-lo através do radiador. Nesse contexto, o uso de aditivos tem sido amplamente explorado como forma de melhorar a eficiência do sistema de arrefecimento. Um aditivo em potencial é a glicerina, devido às suas propriedades físico-químicas favoráveis. Neste artigo, discutiremos o uso da glicerina como aditivo no sistema de arrefecimento de motores a combustão interna de 4 tempos.User

  1. Propriedades da Glicerina

A glicerina, também conhecida como glicerol ou propanotriol, é um composto químico incolor, viscoso e solúvel em água. É um subproduto comum do processo de produção de biodiesel, sendo obtida a partir de fontes vegetais, como óleos e gorduras. A glicerina de origem vegetal tem estrutura química idêntica à glicerina extraída do petróleo, após passar por processos de purificação.

A glicerina possui várias propriedades que a tornam interessante como aditivo no sistema de arrefecimento. Ela tem alta viscosidade e tem o potencial de elevar a densidade quando misturada com a água, o que pode melhorar a transferência de calor e ajudar a manter a estabilidade da mistura de arrefecimento. Além disso, a glicerina apresenta propriedades anticorrosivas, ajudando a proteger os componentes do sistema contra danos causados pela corrosão. Sua miscibilidade com a água permite uma mistura homogênea, facilitando sua aplicação no sistema de arrefecimento.User

  1. Efeito da Glicerina no Sistema de Arrefecimento

O uso da glicerina como aditivo no sistema de arrefecimento pode trazer diversos benefícios. A alta viscosidade e a maior densidade que a da água da glicerina pode aumentar a eficiência da transferência de calor, permitindo que o líquido de arrefecimento absorva mais calor do motor. Isso contribui para manter a temperatura do motor em níveis adequados, evitando o superaquecimento.

Além disso, a glicerina apresenta propriedades anticorrosivas, que ajudam a proteger os componentes do sistema contra a corrosão. A corrosão é um problema comum em sistemas de arrefecimento, especialmente devido à presença de metais diferentes e à exposição a altas temperaturas. A adição de glicerina pode formar uma camada protetora nas superfícies metálicas, reduzindo o risco de corrosão e prolongando a vida útil do sistema.User

  1. Pesquisas Experimentais sobre o Uso da Glicerina no Sistema de Arrefecimento

Diversos estudos têm sido conduzidos para investigar os efeitos do uso da glicerina como aditivo no sistema de arrefecimento de motores a combustão interna. Essas pesquisas envolvem a análise de diferentes proporções de glicerina na mistura de arrefecimento e a avaliação de parâmetros como temperatura, eficiência de arrefecimento, corrosão e desgaste dos componentes.

Em um estudo realizado por Tipoalgo (2016), foram utilizadas concentrações variadas de glicerina de origem vegetal bidestilada em um veículo Polo Classic ano 97. Observou-se que uma concentração de 66% de glicerina resultou em maior transferência de calor do motor para o radiador, evidenciado pelo maior aquecimento das tubulações. Além disso, verificou-se um efeito detergente da glicerina, que causou limpeza das oxidações preexistentes no sistema de arrefecimento. Foram observados vazamentos no radiador devido à esta ação detergente da glicerina em certas ligas metálicas, especialmente o ferro com sinais preexistentes de oxidações. Apesar disso, a regularidade do arrefecimento do motor foi mantida até o presente, maio de 2023.User

  1. Desafios e Considerações

Embora o uso da glicerina como aditivo no sistema de arrefecimento de motores a combustão interna apresente potenciais benefícios, existem alguns desafios a serem considerados. Um dos principais desafios é a compatibilidade da glicerina com os materiais presentes no sistema de arrefecimento, como mangueiras, juntas, selos e radiadores. O aumento da temperatura nas tubulações exige destas maior resistência neste quesito. Algumas ligas metálicas já oxidadas podem ser mais suscetíveis à corrosão quando em contato com altas concentrações de glicerina, o que pode levar a vazamentos e danos nos componentes.

Além disso, a glicerina possui um ponto de congelamento superior ao de aditivos tradicionais, como o monoetilenoglicol. Isso pode ser uma desvantagem em regiões onde as temperaturas ambiente podem atingir valores muito baixos, pois há o risco de congelamento do líquido de arrefecimento e danos ao sistema.

Outros pontos a serem considerados são a disponibilidade e o custo da glicerina. Embora seja possível obter glicerina de origem vegetal a partir de subprodutos da indústria de biodiesel é importante garantir a qualidade e a pureza do produto para evitar impurezas que possam comprometer o desempenho do sistema de arrefecimento.User

  1. Conclusão

O uso da glicerina como aditivo no sistema de arrefecimento de motores a combustão interna apresenta vantagens e desafios a serem considerados. Por um lado, a glicerina possui propriedades físico-químicas favoráveis, como alta viscosidade e densidade, além de propriedades anticorrosivas, que podem melhorar a eficiência do sistema de arrefecimento. Estudos experimentais mostraram que o uso da glicerina pode resultar em maior transferência de calor do motor para o radiador e contribuir para a limpeza das oxidações preexistentes.

No entanto, desafios relacionados à compatibilidade com materiais desgastados, ponto de congelamento e disponibilidade da glicerina devem ser cuidadosamente considerados. Em regiões com baixas temperaturas, é importante avaliar o risco de congelamento do líquido de arrefecimento.

Diante dos resultados promissores e dos desafios mencionados, futuras pesquisas e desenvolvimentos são necessários para aprimorar o uso da glicerina como aditivo no sistema de arrefecimento de motores a combustão interna. Estudos mais aprofundados são necessários para avaliar a longevidade do sistema, a compatibilidade com diferentes materiais e as condições de operação em diversos cenários.User

Em conclusão, o uso da glicerina como aditivo no sistema de arrefecimento de motores a combustão interna mostrou potenciais benefícios em sete anos de uso, como maior eficiência de transferência de calor e propriedades anticorrosivas. No entanto, é necessário considerar os desafios relacionados à compatibilidade com materiais, ponto de congelamento e disponibilidade da glicerina. Pesquisas experimentais têm fornecido insights valiosos, demonstrando a influência da concentração de glicerina nas propriedades do sistema de arrefecimento. Futuros estudos devem se concentrar na melhoria da compatibilidade e na avaliação de diferentes condições operacionais. Com avanços adicionais, o uso da glicerina como aditivo no sistema de arrefecimento pode se tornar uma alternativa viável e sustentável para melhorar a eficiência e prolongar a vida útil dos motores a combustão interna.