EtcMath.h 1.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. /*
  2. * Copyright 2015 The Etc2Comp Authors.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #pragma once
  17. #include <math.h>
  18. namespace Etc
  19. {
  20. // ----------------------------------------------------------------------------------------------------
  21. // return true if vertical line
  22. bool Regression(float a_afX[], float a_afY[], unsigned int a_Points,
  23. float *a_fSlope, float *a_fOffset);
  24. inline float ConvertMSEToPSNR(float a_fMSE)
  25. {
  26. if (a_fMSE == 0.0f)
  27. {
  28. return INFINITY;
  29. }
  30. return 10.0f * log10f(1.0f / a_fMSE);
  31. }
  32. }