SignalEmulation.cs 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. using DevExpress.XtraEditors;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Drawing;
  7. using System.IO;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using System.Windows.Forms;
  12. using DW5S.KxcApi;
  13. namespace DW5S.DataEmulation
  14. {
  15. public partial class SignalEmulation : DevExpress.XtraEditors.XtraForm
  16. {
  17. public SignalEmulation()
  18. {
  19. InitializeComponent();
  20. }
  21. private void btnOpenDir_Click(object sender, EventArgs e)
  22. {
  23. System.Diagnostics.Process.Start("explorer.exe", ".\\信号仿真\\");
  24. }
  25. private async void btnBuilder_ClickAsync(object sender, EventArgs e)
  26. {
  27. if (!long.TryParse(txtFsHz.Text, out long fsHz))
  28. {
  29. XtraMessageBox.Show("采样率非数字!");
  30. return;
  31. }
  32. if (!double.TryParse(txtDto1.Text, out double dt1))
  33. {
  34. XtraMessageBox.Show("时差1非数字!");
  35. return;
  36. }
  37. int.TryParse(txtSigLen.Text, out int brustCount);
  38. if (!double.TryParse(txtDfo1.Text, out double df1))
  39. {
  40. XtraMessageBox.Show("频差1非数字!");
  41. return;
  42. }
  43. if (!double.TryParse(txtDto2.Text, out double dt2))
  44. {
  45. XtraMessageBox.Show("时差2非数字!");
  46. return;
  47. }
  48. if (!double.TryParse(txtDfo2.Text, out double df2))
  49. {
  50. XtraMessageBox.Show("频差2非数字!");
  51. return;
  52. }
  53. if (fsHz <= 0 || fsHz > 100000000)
  54. {
  55. XtraMessageBox.Show("采样率范围(0,100000000]!");
  56. return;
  57. }
  58. if (brustCount <= 0 || brustCount > 500)
  59. {
  60. XtraMessageBox.Show("突发个数范围(0,500]");
  61. return;
  62. }
  63. btnBuild.Enabled = false;
  64. dt1 = dt1 / 1e6;
  65. dt2 = dt2 / 1e6;
  66. await Task.Run(() =>
  67. {
  68. Directory.CreateDirectory("信号仿真");
  69. var t1 = DateTime.Now;
  70. var f1 = $"信号仿真\\{t1:yyyyMMddHHmmss}_D{260}_FS{fsHz}_ch1.dat";
  71. var f2 = $"信号仿真\\{t1:yyyyMMddHHmmss}_D{260}_FS{fsHz}_ch2.dat";
  72. var f3 = $"信号仿真\\{t1:yyyyMMddHHmmss}_D{260}_FS{fsHz}_ch3.dat";
  73. DataEmulationHelper.GenBrustFiles(f1, f2, f3, fsHz, brustCount, dt1, df1, dt2, df2);
  74. });
  75. btnBuild.Enabled = true;
  76. }
  77. }
  78. }