Implemnt sound capture in the simulator
diff --git a/verilog/sim/waveheader.cpp b/verilog/sim/waveheader.cpp
new file mode 100644
index 0000000..1e44700
--- /dev/null
+++ b/verilog/sim/waveheader.cpp
@@ -0,0 +1,53 @@
+#include <stdint.h>
+#include "waveheader.h"
+
+void waveheader(uint8_t *header, uint32_t sampleRate, uint32_t bitsPerSample, uint32_t samples) {
+    uint32_t audioDataLen = samples * (bitsPerSample / 8u) * 2u;
+    uint32_t fileSize = audioDataLen + 44u;
+    uint32_t totalDataLen = fileSize - 8u;
+    uint32_t byteRate = sampleRate * (bitsPerSample / 8u) * 2u;
+    header[0] = 'R';
+    header[1] = 'I';
+    header[2] = 'F';
+    header[3] = 'F';
+    header[4] = (totalDataLen & 0xff); /* file-size (equals file-size - 8) */
+    header[5] = ((totalDataLen >> 8U) & 0xff);
+    header[6] = ((totalDataLen >> 16U) & 0xff);
+    header[7] = ((totalDataLen >> 24U) & 0xff);
+    header[8] = 'W'; /* Mark it as type "WAVE" */
+    header[9] = 'A';
+    header[10] = 'V';
+    header[11] = 'E';
+    header[12] = 'f'; /* Mark the format section 'fmt ' chunk */
+    header[13] = 'm';
+    header[14] = 't';
+    header[15] = ' ';
+    header[16] = 16; /* 4 bytes: size of 'fmt ' chunk, Length of format data.  Always 16 */
+    header[17] = 0;
+    header[18] = 0;
+    header[19] = 0;
+    header[20] = 1; /* format = 1 ,Wave type PCM */
+    header[21] = 0;
+    header[22] = 2; /* channels */
+    header[23] = 0;
+    header[24] = (sampleRate & 0xff);
+    header[25] = ((sampleRate >> 8U) & 0xff);
+    header[26] = ((sampleRate >> 16U) & 0xff);
+    header[27] = ((sampleRate >> 24U) & 0xff);
+    header[28] = (byteRate & 0xff);
+    header[29] = ((byteRate >> 8U) & 0xff);
+    header[30] = ((byteRate >> 16U) & 0xff);
+    header[31] = ((byteRate >> 24U) & 0xff);
+    header[32] = (2 * bitsPerSample / 8); /* block align */
+    header[33] = 0;
+    header[34] = bitsPerSample; /* bits per sample */
+    header[35] = 0;
+    header[36] = 'd'; /*"data" marker */
+    header[37] = 'a';
+    header[38] = 't';
+    header[39] = 'a';
+    header[40] = (audioDataLen & 0xff); /* data-size (equals file-size - 44).*/
+    header[41] = ((audioDataLen >> 8) & 0xff);
+    header[42] = ((audioDataLen >> 16) & 0xff);
+    header[43] = ((audioDataLen >> 24) & 0xff);
+}
\ No newline at end of file