You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

93 lines
2.9 KiB

// SPDX-License-Identifier: AGPL-3.0-only
/**
* Digital Voice Modem - DVMConsole
* AGPLv3 Open Source. Use is subject to license terms.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* @package DVM / DVM Console
* @license AGPLv3 License (https://opensource.org/licenses/AGPL-3.0)
*
* Copyright (C) 2025 Caleb, K4PHP
*
*/
namespace DVMConsole
{
/// <summary>
/// Helper to convert audio between different chunk sizes
/// </summary>
public static class AudioConverter
{
public const int OriginalPcmLength = 1600;
public const int ExpectedPcmLength = 320;
/// <summary>
/// Helper to go from a big chunk size to smaller
/// </summary>
/// <param name="audioData"></param>
/// <returns></returns>
public static List<byte[]> SplitToChunks(byte[] audioData, int OgLength = OriginalPcmLength, int ExepcetedLength = ExpectedPcmLength)
{
List<byte[]> chunks = new List<byte[]>();
if (audioData.Length != OgLength)
{
Console.WriteLine($"Invalid PCM length: {audioData.Length}, expected: {OgLength}");
return chunks;
}
for (int offset = 0; offset < OgLength; offset += ExepcetedLength)
{
byte[] chunk = new byte[ExpectedPcmLength];
Buffer.BlockCopy(audioData, offset, chunk, 0, ExepcetedLength);
chunks.Add(chunk);
}
return chunks;
}
/// <summary>
/// Helper to go from small chunks to a big chunk
/// </summary>
/// <param name="chunks"></param>
/// <returns></returns>
public static byte[] CombineChunks(List<byte[]> chunks, int OgLength = OriginalPcmLength, int ExepcetedLength = ExpectedPcmLength)
{
if (chunks.Count * ExepcetedLength != OgLength)
{
Console.WriteLine($"Invalid number of chunks: {chunks.Count}, expected total length: {OgLength}");
return null;
}
byte[] combined = new byte[OgLength];
int offset = 0;
foreach (var chunk in chunks)
{
Buffer.BlockCopy(chunk, 0, combined, offset, ExepcetedLength);
offset += ExepcetedLength;
}
return combined;
}
/// <summary>
/// From https://github.com/W3AXL/rc2-dvm/blob/main/rc2-dvm/Audio.cs
/// </summary>
/// <param name="pcm16"></param>
/// <returns></returns>
public static float[] PcmToFloat(short[] pcm16)
{
float[] floats = new float[pcm16.Length];
for (int i = 0; i < pcm16.Length; i++)
{
float v = (float)pcm16[i] / (float)short.MaxValue;
if (v > 1) { v = 1; }
if (v < -1) { v = -1; }
floats[i] = v;
}
return floats;
}
}
}

Powered by TurnKey Linux.