2016-12-11 8 views
0

Я хочу использовать функцию ввода файлов LTSpice для имитации схемы с использованием бита реального мира. Мне нужны данные за время по сравнению с версией с амплитудой, но не знаю, какой программный пакет может это сделать для меня. Audacity может конвертировать MP3 в WAV, но из того, что я вижу, не может сделать это без текстового файла без заголовка.Как изменить WAV на txt файл времени и амплитуды?

Так что .WAV файл в текстовый файл из двух столбцов времени/амплитуды.

Любые идеи для свободного способа сделать это?

+0

Вы читаете этот ответ, используя программное обеспечение, способное выполнить эту задачу. Измените свой вопрос, чтобы предоставить образцы ввода и ожидаемого результата, и вы получите ответ. – enhzflep

ответ

0

Вот краткая реализация с использованием javascript.

Я оставлю его как упражнение для преобразования строки результата в Blob, которую можно легко загрузить, так же как я оставлю выбор канала, результаты стерео и возможность выбрать небольшую часть звуковой дорожки для обработки.

<!doctype html> 
<html> 
<head> 
<script> 
"use strict"; 
function byId(id){return document.getElementById(id)} 

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////// 
window.addEventListener('load', onDocLoaded, false); 

var audioCtx; 

function onDocLoaded(evt) 
{ 
    audioCtx = new AudioContext(); 
    byId('fileInput').addEventListener('change', onFileInputChangedGeneric, false); 
} 

function onFileInputChangedGeneric(evt) 
{ 
    // load file if chosen 
    if (this.files.length != 0) 
    { 
     var fileObj = this.files[0]; 
     loadAndTabulateAudioFile(fileObj, byId('output')); 
    } 
    // clear output otherwise 
    else 
     byId('output').textContent = ''; 
} 

// processes channel 0 only 
// 
// creates a string that represents a 2 column table, where each row contains the time and amplitude of a sample 
// columns are tab seperated 
function loadAndTabulateAudioFile(fileObj, tgtElement) 
{ 
    var a = new FileReader(); 
    a.onload = loadedCallback; 
    a.readAsArrayBuffer(fileObj); 
    function loadedCallback(evt) 
    { 
     audioCtx.decodeAudioData(evt.target.result, onDataDecoded); 
    } 
    function onDataDecoded(buffer) 
    { 
     //console.log(buffer); 
     var leftChannel = buffer.getChannelData(0); 

     //var rightChannel = buffer.getChannelData(1); 
     console.log("# samples: " + buffer.length); 
     console.log(buffer); 

     var result = ''; 
     var i, n = buffer.length, invSampleRate = 1.0/buffer.sampleRate; 
     for (i=0; i<n; i++) 
     { 
      var curResult = (invSampleRate*i).toFixed(8) + "\t" + leftChannel[i] + "\n"; 
      result += curResult; 
     } 
     tgtElement.textContent = result; 
    } 
} 

</script> 
<style> 
</style> 
</head> 
<body> 
    <label>Select audio file: <input type='file' id='fileInput'/></label> 
    <hr> 
    <pre id='output'></pre> 
</body> 
</html> 

 Смежные вопросы

  • Нет связанных вопросов^_^