Skip to content
Snippets Groups Projects
  • Nick Draper's avatar
    ef3ccb58
    Merge pull request #23693 from mantidproject/23488_update_file_headers · ef3ccb58
    Nick Draper authored
    Update copyright headers in all files
    
    Squashed commit of the following:
    
    * First version of a script to manage copyright statements
    
    re #23468
    
    * Neatened up script, added comments
    
    re #23488
    
    * move script to tools directory
    
    re #23488
    
    * small script changes and a couple of manual file changes
    
    re #23488
    
    * Minor chnage to whitespace detection in regex
    
    re #23488
    
    * Add an excluded directory
    
    re #23488
    
    * remove a repeasted copyright statement in a file
    
    re #23488
    
    * Don't comsume the comment end if it is on the same line
    
    re #23488
    
    * fix error in new copright parsing
    
    re #23488
    
    * remove double copyrifght entry
    
    re #23488
    
    * Improve handling of old copyrights at the start of comments
    
    re #23488
    
    * remove empty comments re #23488
    
    * exclude gsoapgenerated directories
    
    re #23488
    
    * Sort out greedy line matching re #23488
    
    * improve empty comment removal
    
    re #23488
    
    * improve false positives
    
    re #23488
    
    * impressive speedup by limiting regex matching length
    
    re #23488
    
    * remove evil invisible non ascii character
    
    Also upadte the copyright at the same time
    
    re #23488
    
    * resolve multiple copyrights in a single file
    
    re #23488
    
    * resolve an issue with new statement detection
    
    re #23488
    
    * another unprintable unicode character
    
    re #23488
    
    * pep updates and cmake the new copyright fit clang format
    
    re #23488
    
    * update already done new format headers
    
    re #23488
    
    * wrong type of bracket
    
    re #23488
    
    * Update class_maker and friends
    
    re #23488
    
    * Update all copyright statements
    
    re #23488
    
    * clang format re #23488
    
    * flake8 warnings re #23488
    
    * Flake8 warnings re #23488
    
    * Exclude .cmake.in and rb.in files
    
    re #23488
    
    * replace missing line re #23488
    
    * exclude .py.in files as they are flasely recognized as C++
    
    re #23488
    
    * another setp.py.in re #23488
    
    * another .py.in correction re #23488
    
    * Hopefully the last of the .py.in files re #23488
    
    * resolve utf-8 encoding of python files and changed ABINS checksum
    
    re #23488
    
    * updates to unit tests that reference line numbers
    
    re #23488
    
    * remaining unit test files and other fixes
    
    re #23488
    ef3ccb58
    History
    Merge pull request #23693 from mantidproject/23488_update_file_headers
    Nick Draper authored
    Update copyright headers in all files
    
    Squashed commit of the following:
    
    * First version of a script to manage copyright statements
    
    re #23468
    
    * Neatened up script, added comments
    
    re #23488
    
    * move script to tools directory
    
    re #23488
    
    * small script changes and a couple of manual file changes
    
    re #23488
    
    * Minor chnage to whitespace detection in regex
    
    re #23488
    
    * Add an excluded directory
    
    re #23488
    
    * remove a repeasted copyright statement in a file
    
    re #23488
    
    * Don't comsume the comment end if it is on the same line
    
    re #23488
    
    * fix error in new copright parsing
    
    re #23488
    
    * remove double copyrifght entry
    
    re #23488
    
    * Improve handling of old copyrights at the start of comments
    
    re #23488
    
    * remove empty comments re #23488
    
    * exclude gsoapgenerated directories
    
    re #23488
    
    * Sort out greedy line matching re #23488
    
    * improve empty comment removal
    
    re #23488
    
    * improve false positives
    
    re #23488
    
    * impressive speedup by limiting regex matching length
    
    re #23488
    
    * remove evil invisible non ascii character
    
    Also upadte the copyright at the same time
    
    re #23488
    
    * resolve multiple copyrights in a single file
    
    re #23488
    
    * resolve an issue with new statement detection
    
    re #23488
    
    * another unprintable unicode character
    
    re #23488
    
    * pep updates and cmake the new copyright fit clang format
    
    re #23488
    
    * update already done new format headers
    
    re #23488
    
    * wrong type of bracket
    
    re #23488
    
    * Update class_maker and friends
    
    re #23488
    
    * Update all copyright statements
    
    re #23488
    
    * clang format re #23488
    
    * flake8 warnings re #23488
    
    * Flake8 warnings re #23488
    
    * Exclude .cmake.in and rb.in files
    
    re #23488
    
    * replace missing line re #23488
    
    * exclude .py.in files as they are flasely recognized as C++
    
    re #23488
    
    * another setp.py.in re #23488
    
    * another .py.in correction re #23488
    
    * Hopefully the last of the .py.in files re #23488
    
    * resolve utf-8 encoding of python files and changed ABINS checksum
    
    re #23488
    
    * updates to unit tests that reference line numbers
    
    re #23488
    
    * remaining unit test files and other fixes
    
    re #23488
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
BoseEinsteinDistributionTest.h 3.14 KiB
// Mantid Repository : https://github.com/mantidproject/mantid
//
// Copyright © 2018 ISIS Rutherford Appleton Laboratory UKRI,
//     NScD Oak Ridge National Laboratory, European Spallation Source
//     & Institut Laue - Langevin
// SPDX - License - Identifier: GPL - 3.0 +
#ifndef MANTID_KERNEL_BOSEEINSTEINDISTRIBUTIONTEST_H_
#define MANTID_KERNEL_BOSEEINSTEINDISTRIBUTIONTEST_H_

#include "MantidKernel/Math/Distributions/BoseEinsteinDistribution.h"
#include "MantidKernel/PhysicalConstants.h"

#include <cxxtest/TestSuite.h>

class BoseEinsteinDistributionTest : public CxxTest::TestSuite {
public:
  void test_Standard_Distribution_Gives_Correct_Value_Away_From_Edge() {
    using namespace Mantid::Kernel::Math;
    const double energy = 30.0;
    const double temperature = 35.0;

    TS_ASSERT_DELTA(BoseEinsteinDistribution::n(energy, temperature),
                    0.000047886213, 1e-12);
  }

  void test_Standard_Distribution_Throws_When_Energy_Or_Temperature_Is_Zero() {
    using namespace Mantid::Kernel::Math;
    const double energy = 0.0;
    const double temperature = 35.0;

    TS_ASSERT_THROWS(BoseEinsteinDistribution::n(energy, temperature),
                     std::domain_error);
    TS_ASSERT_THROWS(BoseEinsteinDistribution::n(temperature, energy),
                     std::domain_error);
  }

  void
  test_np1Eps_Is_Returns_Energy_When_Temp_Is_Negative_And_Energy_Positive() {
    using namespace Mantid::Kernel::Math;
    const double energy = 200;
    const double temperature = -35.0;

    const double expected = energy;
    TS_ASSERT_DELTA(BoseEinsteinDistribution::np1Eps(energy, temperature),
                    expected, 1e-12);
  }

  void test_np1Eps_Returns_kbT_When_Answer_When_Exponent_Is_Zero() {
    using namespace Mantid::Kernel::Math;
    const double energy = 0.0;
    const double temperature = 35.0;

    const double expected =
        Mantid::PhysicalConstants::BoltzmannConstant * temperature;
    TS_ASSERT_DELTA(BoseEinsteinDistribution::np1Eps(energy, temperature),
                    expected, 1e-12);
  }

  void test_np1Eps_Is_Returns_Zero_When_Temp_Is_Negative_And_Energy_Negative() {
    using namespace Mantid::Kernel::Math;
    const double energy = -200;
    const double temperature = -35.0;

    const double expected = 0.0;
    TS_ASSERT_DELTA(BoseEinsteinDistribution::np1Eps(energy, temperature),
                    expected, 1e-12);
  }

  void test_np1Eps_Is_Well_Behaved_When_Exponent_Is_Larger_Than_Point1() {
    using namespace Mantid::Kernel::Math;
    const double energy = 20;
    const double temperature = 29.0;

    const double expected = 20.006690611537;

    TS_ASSERT_DELTA(BoseEinsteinDistribution::np1Eps(energy, temperature),
                    expected, 1e-12);
  }

  void
  test_np1Eps_Is_Well_Behaved_When_Abs_Exponent_Is_Larger_Than_Point1_But_Large_And_Negative() {
    using namespace Mantid::Kernel::Math;
    const double energy = -20;
    const double temperature = 35.0;

    const double expected = 0.026407635389;
    TS_ASSERT_DELTA(BoseEinsteinDistribution::np1Eps(energy, temperature),
                    expected, 1e-12);
  }
};

#endif /* MANTID_KERNEL_BOSEEINSTEINDISTRIBUTIONTEST_H_ */