-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #133 from VirtualPhotonics/feature/122-add-ability…
…-to-use-layered-concentric-infinite-cylinders-with-refractive-index-mismatch Feature/122 add ability to use layered concentric infinite cylinders with refractive index mismatch
- Loading branch information
Showing
17 changed files
with
1,541 additions
and
700 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
207 changes: 207 additions & 0 deletions
207
...DataStructuresValidation/TissueInputs/SingleInfiniteCylinderTissueInputValidationTests.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,207 @@ | ||
using System.Collections.Generic; | ||
using NUnit.Framework; | ||
using Vts.Common; | ||
using Vts.MonteCarlo; | ||
using Vts.MonteCarlo.Detectors; | ||
using Vts.MonteCarlo.Sources; | ||
using Vts.MonteCarlo.Tissues; | ||
|
||
namespace Vts.Test.MonteCarlo.DataStructuresValidation.TissueInputs | ||
{ | ||
[TestFixture] | ||
public class SingleInfiniteCylinderTissueInputValidationTests | ||
{ | ||
/// <summary> | ||
/// Test to check that underlying MultiLayerTissue is good | ||
/// </summary> | ||
[Test] | ||
public void validate_underlying_multilayer_tissue_definition() | ||
{ | ||
var input = new SimulationInput( | ||
10, | ||
"", | ||
new SimulationOptions(), | ||
new DirectionalPointSourceInput(), | ||
new SingleInfiniteCylinderTissueInput( | ||
new InfiniteCylinderTissueRegion( | ||
new Position(0, 0, 10), | ||
2.0, | ||
new OpticalProperties()), | ||
// define layer tissues that are incorrect | ||
new ITissueRegion[] | ||
{ | ||
new LayerTissueRegion( | ||
new DoubleRange(double.NegativeInfinity, 0.0), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)), | ||
new LayerTissueRegion( | ||
new DoubleRange(0.0, 20.0), | ||
new OpticalProperties(0.01, 1.0, 0.8, 1.4)), | ||
new LayerTissueRegion( | ||
new DoubleRange(100.0, double.PositiveInfinity), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)) | ||
} | ||
), | ||
new List<IDetectorInput>() | ||
{ | ||
new FluenceOfXAndYAndZDetectorInput() | ||
} | ||
); | ||
var result = SimulationInputValidation.ValidateInput(input); | ||
Assert.IsFalse(result.IsValid); | ||
} | ||
|
||
/// <summary> | ||
/// Test to check that infinite cylinders have non-zero axis definitions. | ||
/// </summary> | ||
[Test] | ||
public void validate_infinite_cylinder_has_nonzero_radii() | ||
{ | ||
var input = new SimulationInput( | ||
10, | ||
"", | ||
new SimulationOptions(), | ||
new DirectionalPointSourceInput(), | ||
new SingleInfiniteCylinderTissueInput( | ||
// set one infinite cylinder radius to 0.0 | ||
new InfiniteCylinderTissueRegion( | ||
new Position(0, 0, 1), | ||
0.0, // radius=0 | ||
new OpticalProperties()), | ||
new ITissueRegion[] | ||
{ | ||
new LayerTissueRegion( | ||
new DoubleRange(double.NegativeInfinity, 0.0), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)), | ||
new LayerTissueRegion( | ||
new DoubleRange(0.0, 20.0), | ||
new OpticalProperties(0.01, 1.0, 0.8, 1.4)), | ||
new LayerTissueRegion( | ||
new DoubleRange(20.0, double.PositiveInfinity), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)) | ||
} | ||
), | ||
new List<IDetectorInput>() | ||
{ | ||
new FluenceOfXAndYAndZDetectorInput() | ||
} | ||
); | ||
var result = SimulationInputValidation.ValidateInput(input); | ||
Assert.IsFalse(result.IsValid); | ||
} | ||
|
||
/// <summary> | ||
/// Test to check that at least one tissue layer is defined | ||
/// </summary> | ||
[Test] | ||
public void validate_at_least_one_tissue_layer_defined() | ||
{ | ||
var input = new SimulationInput( | ||
10, | ||
"", | ||
new SimulationOptions(), | ||
new DirectionalPointSourceInput(), | ||
new SingleInfiniteCylinderTissueInput( | ||
new InfiniteCylinderTissueRegion( | ||
new Position(0, 0, 1), | ||
2.0, | ||
new OpticalProperties()), | ||
new ITissueRegion[] | ||
{ | ||
new LayerTissueRegion( | ||
new DoubleRange(double.NegativeInfinity, 0.0), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)), | ||
new LayerTissueRegion( | ||
new DoubleRange(0.0, double.PositiveInfinity), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)) | ||
} | ||
), | ||
new List<IDetectorInput>() | ||
{ | ||
new FluenceOfXAndYAndZDetectorInput() | ||
} | ||
); | ||
var result = SimulationInputValidation.ValidateInput(input); | ||
Assert.IsFalse(result.IsValid); | ||
} | ||
|
||
/// <summary> | ||
/// Test to check that infinite cylinder is entirely contained within tissue layer | ||
/// </summary> | ||
[Test] | ||
public void validate_infinite_cylinders_are_within_tissue_layer() | ||
{ | ||
var input = new SimulationInput( | ||
10, | ||
"", | ||
new SimulationOptions(), | ||
new DirectionalPointSourceInput(), | ||
new SingleInfiniteCylinderTissueInput( | ||
// set infinite cylinder radius to go beyond layer | ||
new InfiniteCylinderTissueRegion( | ||
new Position(0, 0, 1), | ||
15.0, | ||
new OpticalProperties()), | ||
new ITissueRegion[] | ||
{ | ||
new LayerTissueRegion( | ||
new DoubleRange(double.NegativeInfinity, 0.0), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)), | ||
new LayerTissueRegion( | ||
new DoubleRange(0.0, 20.0), | ||
new OpticalProperties(0.01, 1.0, 0.8, 1.4)), | ||
new LayerTissueRegion( | ||
new DoubleRange(20.0, double.PositiveInfinity), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)) | ||
} | ||
), | ||
new List<IDetectorInput>() | ||
{ | ||
new FluenceOfXAndYAndZDetectorInput() | ||
} | ||
); | ||
var result = SimulationInputValidation.ValidateInput(input); | ||
Assert.IsFalse(result.IsValid); | ||
} | ||
|
||
/// <summary> | ||
/// Test to check two layer tissue with one layer enclosing concentric infinite cylinders works | ||
/// </summary> | ||
[Test] | ||
public void validate_infinite_cylinder_within_one_layer_of_multilayer_works() | ||
{ | ||
var input = new SimulationInput( | ||
10, | ||
"", | ||
new SimulationOptions(), | ||
new DirectionalPointSourceInput(), | ||
new SingleInfiniteCylinderTissueInput( | ||
new InfiniteCylinderTissueRegion( | ||
new Position(0, 0, 5), | ||
2.0, | ||
new OpticalProperties(1.0, 1.0, 0.8, 1.4)), | ||
new ITissueRegion[] | ||
{ | ||
new LayerTissueRegion( | ||
new DoubleRange(double.NegativeInfinity, 0.0), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)), | ||
new LayerTissueRegion( | ||
new DoubleRange(0.0, 10.0), | ||
new OpticalProperties(0.01, 1.0, 0.8, 1.4)), | ||
new LayerTissueRegion( | ||
new DoubleRange(10.0, 20.0), | ||
new OpticalProperties(0.1, 1.5, 0.8, 1.3)), | ||
new LayerTissueRegion( | ||
new DoubleRange(20.0, double.PositiveInfinity), | ||
new OpticalProperties(0.0, 1e-10, 1.0, 1.0)) | ||
} | ||
), | ||
new List<IDetectorInput>() | ||
{ | ||
new FluenceOfXAndYAndZDetectorInput() | ||
} | ||
); | ||
var result = SimulationInputValidation.ValidateInput(input); | ||
Assert.IsTrue(result.IsValid); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.