RootSquareMean.m 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. // _____ _
  2. // |_ _| |_ _ _ ___ ___ _ __ __ _
  3. // | | | ' \| '_/ -_) -_) ' \/ _` |_
  4. // |_| |_||_|_| \___\___|_|_|_\__,_(_)
  5. //
  6. // Threema iOS Client
  7. // Copyright (c) 2014-2020 Threema GmbH
  8. //
  9. // This program is free software: you can redistribute it and/or modify
  10. // it under the terms of the GNU Affero General Public License, version 3,
  11. // as published by the Free Software Foundation.
  12. //
  13. // This program is distributed in the hope that it will be useful,
  14. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. // GNU Affero General Public License for more details.
  17. //
  18. // You should have received a copy of the GNU Affero General Public License
  19. // along with this program. If not, see <https://www.gnu.org/licenses/>.
  20. #import "RootSquareMean.h"
  21. @interface RootSquareMean ()
  22. @property Float32 rms;
  23. @property (nonatomic) UInt32 count;
  24. @end
  25. @implementation RootSquareMean
  26. - (instancetype)init
  27. {
  28. self = [super init];
  29. if (self) {
  30. self.rms = 0.0f;
  31. self.count = 0;
  32. }
  33. return self;
  34. }
  35. - (void)addValue:(SInt16)value {
  36. _rms += value * value;
  37. _count ++;
  38. }
  39. - (Float32)getAndReset {
  40. Float32 result = sqrtf(_rms/_count);
  41. _rms = 0.0f;
  42. _count = 0;
  43. return result;
  44. }
  45. - (UInt32)count {
  46. return _count;
  47. }
  48. @end