| | |
| | | using System.Linq; |
| | | using System.Text; |
| | | using System.Threading.Tasks; |
| | | using static System.Runtime.InteropServices.JavaScript.JSType; |
| | | |
| | | namespace ErrorAnalysis.Service |
| | | { |
| | | public class COMergeCalcService |
| | | { |
| | | //Ncoef=1e8*2.54*2.54*2*6*11*2*77*0.2/0.6*speed; |
| | | //Fcoef=1e8*2.54*2.54*4*6*2*11*77*0.2/0.6*speed; |
| | | |
| | | const double _gg = (9.0 - 0.0) / 255.0;//0.03529 |
| | | const double _offset = 0.0; |
| | | |
| | |
| | | const int _oWinStartIndex = (int)(4.88 / _gg + _offset); // org |
| | | const int _oWinEndIndex = (int)(6.36 / _gg + _offset); // width = 6.36-4.88=1.48 |
| | | |
| | | public static double GetFarMergeCResult(string connectionString, string modelId, int porosity) |
| | | private static double GetInterplolateResult(RepositoryBase repos, string modelId, double porosity, double sw, double speed) |
| | | { |
| | | |
| | | } |
| | | |
| | | public static double GetFarMergeCResult(string connectionString, string modelId, double porosity, double sw, double speed) |
| | | { |
| | | if (porosity > 40) |
| | | throw new InvalidDataException("Porosity value out of range!"); |
| | | |
| | | var repository = new COFarResultRepository(connectionString); |
| | | var cResult = repository.GetCOFarResult(modelId, porosity, 0); |
| | | if (cResult == null) |
| | | throw new InvalidDataException("COFarResult not found"); |
| | | var cArr = cResult.InelasticSpec?.Split(',').Select(v => Convert.ToDouble(v)).ToArray(); |
| | | if (cArr == null) |
| | | throw new InvalidDataException("COFarResult InelasticSpec is null"); |
| | | double result = 0; |
| | | if (porosity % 5 == 0) |
| | | { |
| | | var cResult = repository.GetCOFarResult(modelId, (int)porosity, 0); |
| | | if (cResult == null) |
| | | throw new InvalidDataException("COFarResult not found"); |
| | | var cArr = cResult.InelasticSpec?.Split(',').Select(v => Convert.ToDouble(v)).ToArray(); |
| | | if (cArr == null) |
| | | throw new InvalidDataException("COFarResult InelasticSpec is null"); |
| | | |
| | | var length = _cWinEndIndex - _cWinStartIndex + 1; |
| | | var result = cArr.Skip(_cWinStartIndex).Take(length).Sum(); |
| | | var length = _cWinEndIndex - _cWinStartIndex + 1; |
| | | var originC = cArr.Skip(_cWinStartIndex).Take(length).Sum(); |
| | | var coef = originC * 1e8 * 2.54 * 2.54 * 4 * 6 * 2 * 11 * 77 * 0.2 / 0.6 * speed*depth*0.07; |
| | | if (sw > 0) |
| | | result = Utility.Interpolate(sw, 100, 0, 0, coef); |
| | | |
| | | } |
| | | else |
| | | { |
| | | double ceilingResult = 0; |
| | | var ceilingPorosity = Math.Ceiling(porosity / 5) * 5; |
| | | var ceilingCResult = repository.GetCOFarResult(modelId, (int)ceilingPorosity, 0); |
| | | if (ceilingCResult == null) |
| | | throw new InvalidDataException("COFarResult not found"); |
| | | var ceilingCArr = ceilingCResult.InelasticSpec?.Split(',').Select(v => Convert.ToDouble(v)).ToArray(); |
| | | if (ceilingCArr == null) |
| | | throw new InvalidDataException("COFarResult InelasticSpec is null"); |
| | | |
| | | var ceilingLength = _cWinEndIndex - _cWinStartIndex + 1; |
| | | var ceilingOriginC = ceilingCArr.Skip(_cWinStartIndex).Take(ceilingLength).Sum(); |
| | | var ceilingCoef = ceilingOriginC * 1e8 * 2.54 * 2.54 * 4 * 6 * 2 * 11 * 77 * 0.2 / 0.6 * speed; |
| | | if (sw > 0) |
| | | ceilingResult = Utility.Interpolate(sw, 100, 0, 0, ceilingCoef); |
| | | |
| | | double floorResult = 0; |
| | | var floorPorosity = Math.Floor(porosity / 5) * 5; |
| | | var floorCResult = repository.GetCOFarResult(modelId, (int)floorPorosity, 0); |
| | | if (floorCResult == null) |
| | | throw new InvalidDataException("COFarResult not found"); |
| | | var floorCArr = floorCResult.InelasticSpec?.Split(',').Select(v => Convert.ToDouble(v)).ToArray(); |
| | | if (floorCArr == null) |
| | | throw new InvalidDataException("COFarResult InelasticSpec is null"); |
| | | |
| | | var floorLength = _cWinEndIndex - _cWinStartIndex + 1; |
| | | var floorOriginC = floorCArr.Skip(_cWinStartIndex).Take(floorLength).Sum(); |
| | | var floorCoef = floorOriginC * 1e8 * 2.54 * 2.54 * 4 * 6 * 2 * 11 * 77 * 0.2 / 0.6 * speed; |
| | | if (sw > 0) |
| | | floorResult = Utility.Interpolate(sw, 100, 0, 0, floorCoef); |
| | | |
| | | result = Utility.Interpolate(porosity, floorPorosity, floorResult, ceilingPorosity, ceilingResult); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | public static double GetFarMergeOResult(string connectionString, string modelId, int porosity) |
| | | public static double GetFarMergeOResult(string connectionString, string modelId, double porosity, double sw, double speed) |
| | | { |
| | | var repository = new COFarResultRepository(connectionString); |
| | | var cResult = repository.GetCOFarResult(modelId, porosity, 100); |
| | |
| | | return result; |
| | | } |
| | | |
| | | public static double GetNearMergeCResult(string connectionString, string modelId, int porosity) |
| | | public static double GetNearMergeCResult(string connectionString, string modelId, double porosity, double sw, double speed) |
| | | { |
| | | var repository = new CONearResultRepository(connectionString); |
| | | var cResult = repository.GetCONearResult(modelId, porosity, 0); |
| | |
| | | return result; |
| | | } |
| | | |
| | | public static double GetNearMergeOResult(string connectionString, string modelId, int porosity) |
| | | public static double GetNearMergeOResult(string connectionString, string modelId, double porosity, double sw, double speed) |
| | | { |
| | | var repository = new CONearResultRepository(connectionString); |
| | | var cResult = repository.GetCONearResult(modelId, porosity, 100); |