DataEmulationHelper.cs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Runtime.InteropServices;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace XdCxRhDW.DataEmulation
  8. {
  9. public static class DataEmulationHelper
  10. {
  11. private const string dll = @"AddIns\SignalEmulation.dll";
  12. #region cpp dll Interop
  13. [DllImport(dll, EntryPoint = "genSignalsWithDtDf", CallingConvention = CallingConvention.Cdecl)]
  14. private extern static void GenSignalsWithDtDfCore(string file1, string file2, long fsHz, int sigLenMs, double dt, double df, int snr2, int snr1);
  15. //生成噪声,文件,采样率,时长ms,最大幅度
  16. [DllImport(dll, EntryPoint = "genNoizes", CallingConvention = CallingConvention.Cdecl)]
  17. private extern static void GenNoizes(string file1, long fsHz, int tlenms, int Am);
  18. #endregion
  19. /// <summary>
  20. /// 生成一组常规信号文件
  21. /// </summary>
  22. /// <param name="file1">输出文件1</param>
  23. /// <param name="file2">输出文件2</param>
  24. /// <param name="fsHz">采样率Hz</param>
  25. /// <param name="sigTimeLenMs">信号时长(毫秒)</param>
  26. /// <param name="dt">时差秒</param>
  27. /// <param name="df">频差Hz</param>
  28. /// <param name="snr1">文件1信噪比</param>
  29. /// <param name="snr2">文件2信噪比</param>
  30. public static void GenSignalsFile(string file1, string file2, long fsHz, int sigTimeLenMs, double dt, double df, int snr1, int snr2)
  31. {
  32. GenSignalsWithDtDfCore(file1, file2, fsHz, sigTimeLenMs, dt, df, snr2, snr1);
  33. }
  34. /// <summary>
  35. /// 生成单个噪声文件
  36. /// </summary>
  37. /// <param name="file1"></param>
  38. /// <param name="fsHz"></param>
  39. /// <param name="timeLenMs"></param>
  40. /// <param name="am"></param>
  41. public static void GenNoizesFile(string file1, long fsHz, int timeLenMs, int am)
  42. {
  43. GenNoizes(file1, fsHz, timeLenMs, am);
  44. }
  45. }
  46. }