From 0b108f56b2d0c35d01ee361dc593119ac52a14e1 Mon Sep 17 00:00:00 2001
From: lx <ex_lixiang17@cosl.com.cn>
Date: 星期五, 05 九月 2025 16:39:13 +0800
Subject: [PATCH] update

---
 ErrorAnalysis.Service/COMergeCalcService.cs |  123 ++++++++++++++++++++++++++++++++++++++++
 1 files changed, 121 insertions(+), 2 deletions(-)

diff --git a/ErrorAnalysis.Service/COMergeCalcService.cs b/ErrorAnalysis.Service/COMergeCalcService.cs
index 3f1df05..42bd463 100644
--- a/ErrorAnalysis.Service/COMergeCalcService.cs
+++ b/ErrorAnalysis.Service/COMergeCalcService.cs
@@ -1,4 +1,5 @@
 锘縰sing ErrorAnalysis.Repository;
+using ErrorAnalysis.Repository.Entity;
 using Microsoft.VisualBasic;
 using System;
 using System.Collections.Generic;
@@ -107,7 +108,7 @@
         }
 
         /// <summary>
-        /// 鑾峰彇杩滄帰澶碈鎴朞鍊�
+        /// 鑾峰彇杩滄帰澶碈鎴朞鍊硷紙搴熷純锛�
         /// </summary>
         /// <param name="connectionString">鏁版嵁搴撹繛鎺ュ瓧绗︿覆</param>
         /// <param name="modelId">绠℃煴ID</param>
@@ -143,7 +144,7 @@
         }
 
         /// <summary>
-        /// 鑾峰彇杩戞帰澶碈鎴朞鍊�
+        /// 鑾峰彇杩戞帰澶碈鎴朞鍊硷紙搴熷純锛�
         /// </summary>
         /// <param name="connectionString">鏁版嵁搴撹繛鎺ュ瓧绗︿覆</param>
         /// <param name="modelId">绠℃煴ID</param>
@@ -178,6 +179,124 @@
             return result;
         }
 
+        public static List<double[]> GetFarSpectrum(string modelId, double porosity, double sw)
+        {
+            var result = new List<double[]>();
+            if (porosity > 40)
+                throw new InvalidDataException("Porosity value out of range!");
+
+            double[] oilLineSpec;
+            double[] waterLineSpec;
+
+            if (porosity % 5 == 0)
+            {
+                oilLineSpec = RepositoryInstance.Instance.COFarResultRepository.GetCOFarResult(modelId, (int)porosity, 0).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+                waterLineSpec = RepositoryInstance.Instance.COFarResultRepository.GetCOFarResult(modelId, (int)porosity, 100).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+            }
+            else
+            {
+                var ceilingPorosity = Math.Ceiling(porosity / 5) * 5;
+                double[] ceilingOilLineSpec = RepositoryInstance.Instance.COFarResultRepository.GetCOFarResult(modelId, (int)ceilingPorosity, 0).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+                double[] ceilingWaterLineSpec = RepositoryInstance.Instance.COFarResultRepository.GetCOFarResult(modelId, (int)ceilingPorosity, 100).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+
+                var floorPorosity = Math.Floor(porosity / 5) * 5;
+                double[] floorOilLineSpec = RepositoryInstance.Instance.COFarResultRepository.GetCOFarResult(modelId, (int)floorPorosity, 0).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+                double[] floorWaterLineSpec = RepositoryInstance.Instance.COFarResultRepository.GetCOFarResult(modelId, (int)floorPorosity, 100).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+
+                oilLineSpec = ceilingOilLineSpec;
+                waterLineSpec = ceilingWaterLineSpec;
+
+                for (int i = 0; i < ceilingOilLineSpec.Length; i++)
+                {
+                    oilLineSpec[i] = Utility.Interpolate(porosity, floorPorosity, floorOilLineSpec[i], ceilingPorosity, ceilingOilLineSpec[i]);
+                    waterLineSpec[i] = Utility.Interpolate(porosity, floorPorosity, floorWaterLineSpec[i], ceilingPorosity, ceilingWaterLineSpec[i]);
+                }
+            }
+            if (sw == 0)
+            {
+                for (int i = 0; i < oilLineSpec.Length; i++)
+                {
+                    result.Add([i, oilLineSpec[i]]);
+                }
+            }
+            else if (sw == 100)
+            {
+                for (int i = 0; i < waterLineSpec.Length; i++)
+                {
+                    result.Add([i, waterLineSpec[i]]);
+                }
+            }
+            else if (sw > 0 && sw < 100)
+            {
+                for (int i = 0; i < waterLineSpec.Length; i++)
+                {
+                    var val = Utility.Interpolate(sw, 0, oilLineSpec[i], 100, waterLineSpec[i]);
+                    result.Add([i, val]);
+                }
+            }
+
+            return result;
+        }
+
+        public static List<double[]> GetNearSpectrum(string modelId, double porosity, double sw)
+        {
+            var result = new List<double[]>();
+            if (porosity > 40)
+                throw new InvalidDataException("Porosity value out of range!");
+
+            double[] oilLineSpec;
+            double[] waterLineSpec;
+
+            if (porosity % 5 == 0)
+            {
+                oilLineSpec = RepositoryInstance.Instance.CONearResultRepository.GetCONearResult(modelId, (int)porosity, 0).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+                waterLineSpec = RepositoryInstance.Instance.CONearResultRepository.GetCONearResult(modelId, (int)porosity, 100).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+            }
+            else
+            {
+                var ceilingPorosity = Math.Ceiling(porosity / 5) * 5;
+                double[] ceilingOilLineSpec = RepositoryInstance.Instance.CONearResultRepository.GetCONearResult(modelId, (int)ceilingPorosity, 0).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+                double[] ceilingWaterLineSpec = RepositoryInstance.Instance.CONearResultRepository.GetCONearResult(modelId, (int)ceilingPorosity, 100).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+
+                var floorPorosity = Math.Floor(porosity / 5) * 5;
+                double[] floorOilLineSpec = RepositoryInstance.Instance.CONearResultRepository.GetCONearResult(modelId, (int)floorPorosity, 0).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+                double[] floorWaterLineSpec = RepositoryInstance.Instance.CONearResultRepository.GetCONearResult(modelId, (int)floorPorosity, 100).CInelasticSpec.Split(',').Select(v => Convert.ToDouble(v)).ToArray();
+
+                oilLineSpec = ceilingOilLineSpec;
+                waterLineSpec = ceilingWaterLineSpec;
+
+                for (int i = 0; i < ceilingOilLineSpec.Length; i++)
+                {
+                    oilLineSpec[i] = Utility.Interpolate(porosity, floorPorosity, floorOilLineSpec[i], ceilingPorosity, ceilingOilLineSpec[i]);
+                    waterLineSpec[i] = Utility.Interpolate(porosity, floorPorosity, floorWaterLineSpec[i], ceilingPorosity, ceilingWaterLineSpec[i]);
+                }
+            }
+            if (sw == 0)
+            {
+                for (int i = 0; i < oilLineSpec.Length; i++)
+                {
+                    result.Add([i, oilLineSpec[i]]);
+                }
+            }
+            else if (sw == 100)
+            {
+                for (int i = 0; i < waterLineSpec.Length; i++)
+                {
+                    result.Add([i, waterLineSpec[i]]);
+                }
+            }
+            else if (sw > 0 && sw < 100)
+            {
+                for (int i = 0; i < waterLineSpec.Length; i++)
+                {
+                    var val = Utility.Interpolate(sw, 0, oilLineSpec[i], 100, waterLineSpec[i]);
+                    result.Add([i, val]);
+                }
+            }
+
+            return result;
+        }
+
         public static (double, double) GetFarCROR(string modelId, double porosity, double sw)
         {
             var cWinLength = _cWinEndIndex - _cWinStartIndex + 1;

--
Gitblit v1.9.3