Wideband autonomous SDR analysis engine forked from sdr-visual-suite
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

19 рядки
579B

  1. package classifier
  2. // Classify builds features and applies the rule-based classifier.
  3. func Classify(input SignalInput, spectrum []float64, sampleRate int, fftSize int, iq []complex64) *Classification {
  4. if len(spectrum) == 0 || input.FirstBin < 0 || input.LastBin < 0 {
  5. return nil
  6. }
  7. feat := ExtractFeatures(input, spectrum, sampleRate, fftSize)
  8. if len(iq) > 0 {
  9. envVar, zc, instStd, crest := ExtractTemporalFeatures(iq)
  10. feat.EnvVariance = envVar
  11. feat.ZeroCross = zc
  12. feat.InstFreqStd = instStd
  13. feat.CrestFactor = crest
  14. }
  15. cls := RuleClassify(feat)
  16. return &cls
  17. }