| | |
| | | namespace HStation.WinFrmUI |
| | | using HStation.WinFrmUI.PhartRelation; |
| | | |
| | | namespace HStation.WinFrmUI |
| | | { |
| | | public class AssetsMatchingHelper |
| | | { |
| | |
| | | } |
| | | |
| | | //泵匹配 |
| | | public static async Task<bool> MatchingPumps(PumpMatchingViewModel viewModel, List<Vmo.PumpMainVmo> pumpMainVmos) |
| | | public static async Task<bool> MatchingPumps(PumpMatchingViewModel InputModel, List<Vmo.PumpMainVmo> pumpMainVmos) |
| | | { |
| | | Vmo.PumpMainVmo vmo = null; |
| | | int startCount = 0; |
| | | // 尝试绝对匹配 |
| | | var absoluteMatch = pumpMainVmos.Where(item => |
| | | (viewModel.RatedN == null || viewModel.RatedN == item.RatedSpeed) && |
| | | (viewModel.RatedQ == null || viewModel.RatedQ == item.RatedFlow) && |
| | | (viewModel.RatedH == null || viewModel.RatedH == item.RatedHead) && |
| | | (viewModel.RatedP == item.RatedPower)).ToList(); |
| | | (InputModel.RatedN == null || InputModel.RatedN == item.RatedSpeed) && |
| | | (InputModel.RatedQ == null || InputModel.RatedQ == item.RatedFlow) && |
| | | (InputModel.RatedH == null || InputModel.RatedH == item.RatedHead) && |
| | | (InputModel.RatedP == item.RatedPower)).ToList(); |
| | | if (absoluteMatch != null && absoluteMatch.Count != 0) |
| | | { |
| | | foreach (var item in absoluteMatch) |
| | | { |
| | | int commonCount = CountCommonCharacters(viewModel.ModelType, item.Name); |
| | | int commonCount = GetIntersect(InputModel.ModelType, item.Name); |
| | | if (commonCount > startCount) |
| | | { |
| | | vmo = item; |
| | |
| | | { |
| | | // 尝试区间匹配 |
| | | var rangeMatch = pumpMainVmos.Where(item => |
| | | (viewModel.RatedN.HasValue ? Math.Abs(viewModel.RatedN.Value - item.RatedSpeed) <= _speedTolerance : true) && |
| | | (viewModel.RatedQ.HasValue ? Math.Abs(viewModel.RatedQ.Value - item.RatedFlow) <= _flowTolerance : true) && |
| | | (viewModel.RatedH.HasValue ? Math.Abs(viewModel.RatedH.Value - item.RatedHead) <= _headTolerance : true) && |
| | | (Math.Abs(viewModel.RatedP - item.RatedPower) <= _powerTolerance)).ToList(); |
| | | (InputModel.RatedN.HasValue ? Math.Abs(InputModel.RatedN.Value - item.RatedSpeed) <= _speedTolerance : true) && |
| | | (InputModel.RatedQ.HasValue ? Math.Abs(InputModel.RatedQ.Value - item.RatedFlow) <= _flowTolerance : true) && |
| | | (InputModel.RatedH.HasValue ? Math.Abs(InputModel.RatedH.Value - item.RatedHead) <= _headTolerance : true) && |
| | | (Math.Abs(InputModel.RatedP - item.RatedPower) <= _powerTolerance)).ToList(); |
| | | if (rangeMatch != null && rangeMatch.Count != 0) |
| | | { |
| | | foreach (var item in rangeMatch) |
| | | { |
| | | int commonCount = CountCommonCharacters(viewModel.ModelType, item.Name); |
| | | int commonCount = GetIntersect(InputModel.ModelType, item.Name); |
| | | if (commonCount > startCount) |
| | | { |
| | | vmo = item; |
| | |
| | | { |
| | | foreach (var item in pumpMainVmos) |
| | | { |
| | | int commonCount = CountCommonCharacters(viewModel.ModelType, item.Name); |
| | | int commonCount = GetIntersect(InputModel.ModelType, item.Name); |
| | | if (commonCount > startCount) |
| | | { |
| | | vmo = item; |
| | |
| | | } |
| | | if (vmo != null) |
| | | { |
| | | viewModel.MatchingRatedH = vmo.RatedHead; |
| | | viewModel.MatchingRatedN = vmo.RatedSpeed; |
| | | viewModel.MatchingRatedQ = vmo.RatedFlow; |
| | | viewModel.MatchingRatedP = vmo.RatedPower; |
| | | viewModel.MatchingDbId = vmo.ID.ToString(); |
| | | InputModel.MatchingRatedH = vmo.RatedHead; |
| | | InputModel.MatchingRatedN = vmo.RatedSpeed; |
| | | InputModel.MatchingRatedQ = vmo.RatedFlow; |
| | | InputModel.MatchingRatedP = vmo.RatedPower; |
| | | InputModel.MatchingDbId = vmo.ID.ToString(); |
| | | InputModel.MatchingModelType = vmo.Name; |
| | | var list = await new BLL.XhsPumpMainPhartMappingExtensions().GetByPumpMainID(vmo.ID); |
| | | if (list != null && list.Count > 0) |
| | | { |
| | | viewModel.MatchingCurveDbId = list.First().ID.ToString(); |
| | | InputModel.MatchingCurveDbId = list.First().ID.ToString(); |
| | | var graph_qh = list.First().Diagram.GraphList.Find(x => x.GraphType == HStation.PhartRelation.eGraphType.PumpQH); |
| | | var graph_qe = list.First().Diagram.GraphList.Find(x => x.GraphType == HStation.PhartRelation.eGraphType.PumpQE); |
| | | var graph_qp = list.First().Diagram.GraphList.Find(x => x.GraphType == HStation.PhartRelation.eGraphType.PumpQP); |
| | | if (graph_qh != null) |
| | | { |
| | | var points_qh = PhartPerformCurveHelper.GetFeatPointList(graph_qh.GraphType, graph_qh.GeometryInfo, 100, null); |
| | | InputModel.MatchingCurveQH = new List<CurvePointMatchingViewModel>(); |
| | | foreach (var item in points_qh) |
| | | { |
| | | InputModel.MatchingCurveQH.Add(new CurvePointMatchingViewModel(item.X, item.Y)); |
| | | } |
| | | } |
| | | if (graph_qe != null) |
| | | { |
| | | var points_qe = PhartPerformCurveHelper.GetFeatPointList(graph_qe.GraphType, graph_qe.GeometryInfo, 100, null); |
| | | InputModel.MatchingCurveQE = new List<CurvePointMatchingViewModel>(); |
| | | foreach (var item in points_qe) |
| | | { |
| | | InputModel.MatchingCurveQE.Add(new CurvePointMatchingViewModel(item.X, item.Y)); |
| | | } |
| | | } |
| | | if (graph_qp != null) |
| | | { |
| | | var points_qp = PhartPerformCurveHelper.GetFeatPointList(graph_qp.GraphType, graph_qp.GeometryInfo, 100, null); |
| | | InputModel.MatchingCurveQP = new List<CurvePointMatchingViewModel>(); |
| | | foreach (var item in points_qp) |
| | | { |
| | | InputModel.MatchingCurveQP.Add(new CurvePointMatchingViewModel(item.X, item.Y)); |
| | | } |
| | | } |
| | | } |
| | | return true; |
| | | } |
| | |
| | | { |
| | | foreach (var range in absoluteMatch) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, range.Name); |
| | | int commonCount = GetIntersect(input.ModelType, range.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = range; |
| | |
| | | //区间匹配 |
| | | var rangeMatch = adaptingManageVmos.Where(item => |
| | | { |
| | | if (item.Caliber != null && input.Diameter != null) |
| | | if (item.Caliber.HasValue) |
| | | { |
| | | return Math.Abs(Convert.ToInt64(item.Caliber - input.Diameter)) <= _caliberTolerance; |
| | | } |
| | |
| | | } |
| | | else |
| | | { |
| | | int commonCount = CountCommonCharacters(input.Material, range.Material); |
| | | int commonCount = GetIntersect(input.Material, range.Material); |
| | | if (commonCount > firstCount) |
| | | { |
| | | materialList.Add(range); |
| | |
| | | firstCount = 0; |
| | | foreach (var material in materialList) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, material.Name); |
| | | int commonCount = GetIntersect(input.ModelType, material.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = material; |
| | |
| | | { |
| | | foreach (var item in adaptingManageVmos) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, item.Name); |
| | | int commonCount = GetIntersect(input.ModelType, item.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = item; |
| | |
| | | if (vmo != null) |
| | | { |
| | | input.MatchingMinorLoss = vmo.Coefficient; |
| | | input.MatchingDbId = vmo.ID.ToString(); |
| | | input.MatchingDiameter = vmo.Caliber; |
| | | input.MatchingMaterial = vmo.Material; |
| | | input.MatchingModelType = vmo.Name; |
| | | // input.MatchingValveSetting = |
| | | input.MatchingValveType = vmo.Type.ToString(); |
| | | return true; |
| | | } |
| | | return false; |
| | |
| | | { |
| | | foreach (var range in absoluteMatch) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, range.Name); |
| | | int commonCount = GetIntersect(input.ModelType, range.Name); |
| | | if (commonCount > StartCount) |
| | | { |
| | | vmo = range; |
| | |
| | | foreach (var range in rangeMatch) |
| | | { |
| | | //以材料为条件开始匹配 |
| | | int commonCount = CountCommonCharacters(input.Material, range.Material); |
| | | int commonCount = GetIntersect(input.Material, range.Material); |
| | | if (commonCount > StartCount) |
| | | { |
| | | vmo = range; |
| | |
| | | { |
| | | foreach (var item in pipeLineManageVmos) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, item.Name); |
| | | int commonCount = GetIntersect(input.ModelType, item.Name); |
| | | if (commonCount > StartCount) |
| | | { |
| | | vmo = item; |
| | |
| | | switch (input.eAlgorithmType) |
| | | { |
| | | case HStation.Assets.eAlgorithmType.Hazen: |
| | | input.MatchingMinorLoss = vmo.Hazen; |
| | | input.MatchingRoughness = vmo.Hazen; |
| | | break; |
| | | |
| | | case HStation.Assets.eAlgorithmType.Manning: |
| | | input.MatchingMinorLoss = vmo.Manning; |
| | | input.MatchingRoughness = vmo.Manning; |
| | | break; |
| | | |
| | | case HStation.Assets.eAlgorithmType.Darcy: |
| | | input.MatchingMinorLoss = vmo.Darcy; |
| | | input.MatchingRoughness = vmo.Darcy; |
| | | break; |
| | | |
| | | default: |
| | | input.MatchingMinorLoss = vmo.Hazen; |
| | | input.MatchingRoughness = vmo.Hazen; |
| | | break; |
| | | } |
| | | input.MatchingDbId = vmo.ID.ToString(); |
| | | input.MatchingMaterial = vmo.Material; |
| | | input.MatchingModelType = vmo.Name; |
| | | input.MatchingMinorLoss = vmo.Coefficient; |
| | | return true; |
| | | } |
| | | return false; |
| | |
| | | { |
| | | foreach (var range in absoluteMatch) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, range.Name); |
| | | int commonCount = GetIntersect(input.ModelType, range.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = range; |
| | |
| | | } |
| | | else |
| | | { |
| | | int commonCount = CountCommonCharacters(input.Material, range.Material); |
| | | int commonCount = GetIntersect(input.Material, range.Material); |
| | | if (commonCount > firstCount) |
| | | { |
| | | materialList.Add(range); |
| | |
| | | firstCount = 0; |
| | | foreach (var material in materialList) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, material.Name); |
| | | int commonCount = GetIntersect(input.ModelType, material.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = material; |
| | |
| | | { |
| | | foreach (var item in adaptingManageVmos) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, item.Name); |
| | | int commonCount = GetIntersect(input.ModelType, item.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = item; |
| | |
| | | if (vmo != null) |
| | | { |
| | | input.MatchingMinorLoss = vmo.Coefficient; |
| | | input.MatchingDbId = vmo.ID.ToString(); |
| | | input.MatchingMaterial = vmo.Material; |
| | | input.MatchingModelType = vmo.Name; |
| | | return true; |
| | | } |
| | | return false; |
| | |
| | | { |
| | | foreach (var range in absoluteMatch) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, range.Name); |
| | | int commonCount = GetIntersect(input.ModelType, range.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = range; |
| | |
| | | } |
| | | else |
| | | { |
| | | int commonCount = CountCommonCharacters(input.Material, range.Material); |
| | | int commonCount = GetIntersect(input.Material, range.Material); |
| | | if (commonCount > firstCount) |
| | | { |
| | | materialList.Add(range); |
| | |
| | | firstCount = 0; |
| | | foreach (var material in materialList) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, material.Name); |
| | | int commonCount = GetIntersect(input.ModelType, material.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = material; |
| | |
| | | { |
| | | foreach (var item in adaptingManageVmos) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, item.Name); |
| | | int commonCount = GetIntersect(input.ModelType, item.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = item; |
| | |
| | | if (vmo != null) |
| | | { |
| | | input.MatchingMinorLoss = vmo.Coefficient; |
| | | input.MatchingDbId = vmo.ID.ToString(); |
| | | input.MatchingMaterial = vmo.Material; |
| | | input.MatchingModelType = vmo.Name; |
| | | return true; |
| | | } |
| | | return false; |
| | |
| | | { |
| | | foreach (var range in absoluteMatch) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, range.Name); |
| | | int commonCount = GetIntersect(input.ModelType, range.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = range; |
| | |
| | | } |
| | | else |
| | | { |
| | | int commonCount = CountCommonCharacters(input.Material, range.Material); |
| | | int commonCount = GetIntersect(input.Material, range.Material); |
| | | if (commonCount > firstCount) |
| | | { |
| | | materialList.Add(range); |
| | |
| | | firstCount = 0; |
| | | foreach (var material in materialList) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, material.Name); |
| | | int commonCount = GetIntersect(input.ModelType, material.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = material; |
| | |
| | | { |
| | | foreach (var item in adaptingManageVmos) |
| | | { |
| | | int commonCount = CountCommonCharacters(input.ModelType, item.Name); |
| | | int commonCount = GetIntersect(input.ModelType, item.Name); |
| | | if (commonCount > firstCount) |
| | | { |
| | | vmo = item; |
| | |
| | | if (vmo != null) |
| | | { |
| | | input.MatchingMinorLoss = vmo.Coefficient; |
| | | input.MatchingDbId = vmo.ID.ToString(); |
| | | input.MatchingMaterial = vmo.Material; |
| | | input.MatchingModelType = vmo.Name; |
| | | return true; |
| | | } |
| | | return false; |
| | | } |
| | | |
| | | /* |
| | | //返回两个字符串之间相同的字符个数 |
| | | private static int CountCommonCharacters(string baseString, string compareString) |
| | | private static int GetIntersect(string baseString, string compareString) |
| | | { |
| | | // 将字符串转换为字符集合 |
| | | if (baseString == string.Empty || baseString == null || compareString == string.Empty || compareString == null) |
| | |
| | | // 计算两个集合的交集 |
| | | int commonCount = baseChars.Intersect(comparisonChars).Count(); |
| | | return commonCount; |
| | | } |
| | | }*/ |
| | | |
| | | /// <summary> |
| | | /// 获取两个字符串的所有交集 |
| | |
| | | /// <param name="str1"></param> |
| | | /// <param name="str2"></param> |
| | | /// <returns></returns> |
| | | public static string GetIntersect(string str1, string str2) |
| | | public static int GetIntersect(string str1, string str2) |
| | | { |
| | | if (str1 == null || str2 == null) return null; |
| | | if (str1 == null || str2 == null) return 0; |
| | | |
| | | return string.Join("", str1.Intersect(str2)); |
| | | return string.Join("", str1.Intersect(str2)).Count(); |
| | | } |
| | | } |
| | | } |