X-Git-Url: http://git.euphorik.ch/?p=master-thesis.git;a=blobdiff_plain;f=Parasitemia%2FParasitemia%2FConfig.fs;h=aa8f0e5edeecbf09d2752edc4f73e3981dad010b;hp=a1b06e2b588adc35079d5f0809001d43d75fd68d;hb=044b0ae69df3ac565432545b2fa934589016f9bd;hpb=6d99ab0dadc57e91cd846844b620fc90b52a2f96 diff --git a/Parasitemia/Parasitemia/Config.fs b/Parasitemia/Parasitemia/Config.fs index a1b06e2..aa8f0e5 100644 --- a/Parasitemia/Parasitemia/Config.fs +++ b/Parasitemia/Parasitemia/Config.fs @@ -2,6 +2,8 @@ open System +open Const + type Debug = | DebugOff | DebugOn of string // Output directory. @@ -9,39 +11,44 @@ type Debug = type Parameters = { scale: float - minRbcRadius: float - maxRbcRadius: float + initialAreaOpen: int + + minRbcRadius: float32 + maxRbcRadius: float32 preFilterSigma: float // Ellipse. factorNbPick: float - factorWindowSize: float // factor of 'maxRBCSize'. // Parasites detection. darkStainLevel: float + maxDarkStainRatio: float - stainArea: float // Factor of a RBC area. 0.5 means the half of RBC area. - stainLevel: float // [0, 1] - - infectionArea: float // Factor of a RBC area. 0.5 means the half of RBC area. - infectionLevel: float // [0, 1] - parasitePixelsRequired: int + stainArea: float32 // Factor of a RBC area. 0.5 means the half of RBC area. + stainLevel: float // > 1 + maxStainRatio: float // [0, 1] - maxDarkStainRatio: float + infectionArea: float32 // Factor of a RBC area. 0.5 means the half of RBC area. + infectionLevel: float // > 1 - minimumCellArea: float // Factor of RBC area. + standardDeviationMaxRatio: float // The standard deviation of the pixel values of a cell can't be greater than standardDeviationMaxRatio * global standard deviation + minimumCellArea: float32 // Factor of the nominal RBC area. } type Config (param: Parameters) = member this.Parameters = param member val Debug = DebugOff with get, set - member val RBCRadius = 30. with get, set + member val RBCRadius = 30.f with get, set member this.RBCMinRadius = this.RBCRadius + param.minRbcRadius * this.RBCRadius member this.RBCMaxRadius = this.RBCRadius + param.maxRbcRadius * this.RBCRadius - member this.RBCMinArea = param.minimumCellArea * Math.PI * this.RBCRadius ** 2.0 + member this.RBCArea = PI * this.RBCRadius ** 2.f + member this.RBCMinArea = param.minimumCellArea * this.RBCArea + + member this.InfectionArea = param.infectionArea * this.RBCArea + member this.StainArea = param.stainArea * this.RBCArea - member this.InfectionArea = param.infectionArea * Math.PI * this.RBCRadius ** 2.0 - member this.StainArea = param.stainArea * Math.PI * this.RBCRadius ** 2.0 + member this.Copy () = + this.MemberwiseClone() :?> Config