Added 9 Columns
PopulateCalculated Removed Open Insight API IFX Directory yml ec fix v2_52_0-Tests editorconfig net8.0 mesfs.infineon.com Infineon.EAF.Runtime 2.49.3 pool name Kanban
This commit is contained in:
@ -75,6 +75,15 @@ public class ProcessData : IProcessData
|
||||
public string Wafer { get; set; }
|
||||
public string WaferSize { get; set; }
|
||||
public string Zone { get; set; }
|
||||
//
|
||||
public string Nine10mmEdgeMean { get; set; }
|
||||
public string Nine4mmEdgeMean { get; set; }
|
||||
public string NineCriticalPointsAverage { get; set; }
|
||||
public string NineCriticalPointsPhaseAngleAverage { get; set; }
|
||||
public string NineCriticalPointsStdDev { get; set; }
|
||||
public string NineEdgeMeanDelta { get; set; }
|
||||
public string NineMean { get; set; }
|
||||
public string NineResRangePercent { get; set; }
|
||||
|
||||
List<object> Shared.Properties.IProcessData.Details => _Details;
|
||||
|
||||
@ -386,6 +395,141 @@ public class ProcessData : IProcessData
|
||||
UniqueId = string.Format("{0}_{1}_{2}", logistics.JobID, lot, Path.GetFileNameWithoutExtension(logistics.ReportFullPath));
|
||||
}
|
||||
|
||||
private List<Detail> GetDetails()
|
||||
{
|
||||
List<Detail> results = new();
|
||||
Detail detail;
|
||||
string token = GetToken();
|
||||
while (!string.IsNullOrEmpty(token))
|
||||
{
|
||||
detail = new()
|
||||
{ NAvg = token };
|
||||
_ = GetToEOL();
|
||||
detail.Nsl = GetToken();
|
||||
_ = GetToEOL();
|
||||
detail.Vd = GetToken();
|
||||
_ = GetToEOL();
|
||||
detail.FlatZ = GetToken();
|
||||
_ = GetToEOL();
|
||||
detail.RhoAvg = GetToken();
|
||||
_ = GetToEOL();
|
||||
detail.Rhosl = GetToken();
|
||||
_ = GetToEOL();
|
||||
detail.Phase = GetToken();
|
||||
_ = GetToEOL();
|
||||
detail.Grade = GetToken();
|
||||
detail.UniqueId = string.Concat("_Point-", results.Count + 1);
|
||||
results.Add(detail);
|
||||
_ = GetToken();
|
||||
_ = GetToken();
|
||||
_ = GetToken();
|
||||
_ = GetToken();
|
||||
token = GetToken();
|
||||
//if (token.Contains("LincPDF") || token.Contains("MULTIPLE"))
|
||||
if (token.Contains("MULTIPLE"))
|
||||
{
|
||||
//ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
//ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
token = GetToken();
|
||||
}
|
||||
}
|
||||
return results;
|
||||
}
|
||||
|
||||
private static double Variance(List<double> samples)
|
||||
{
|
||||
if (samples.Count <= 1)
|
||||
return double.NaN;
|
||||
double variance = 0;
|
||||
double t = samples[0];
|
||||
for (int i = 1; i < samples.Count; i++)
|
||||
{
|
||||
t += samples[i];
|
||||
double diff = ((i + 1) * samples[i]) - t;
|
||||
variance += diff * diff / ((i + 1.0) * i);
|
||||
}
|
||||
return variance / (samples.Count - 1);
|
||||
}
|
||||
|
||||
private static double StandardDeviation(List<double> samples) =>
|
||||
Math.Sqrt(Variance(samples));
|
||||
|
||||
private void PopulateCalculated(List<Detail> details)
|
||||
{
|
||||
if (details.Count != 9)
|
||||
{
|
||||
NineMean = string.Empty;
|
||||
Nine4mmEdgeMean = string.Empty;
|
||||
Nine10mmEdgeMean = string.Empty;
|
||||
NineEdgeMeanDelta = string.Empty;
|
||||
NineResRangePercent = string.Empty;
|
||||
NineCriticalPointsStdDev = string.Empty;
|
||||
NineCriticalPointsAverage = string.Empty;
|
||||
NineCriticalPointsPhaseAngleAverage = string.Empty;
|
||||
}
|
||||
else
|
||||
{
|
||||
int j;
|
||||
double phase;
|
||||
double rhoAvg;
|
||||
double phaseValue;
|
||||
double rhoAvgValue;
|
||||
List<double> allRhoPoints = new();
|
||||
List<double> edge4mmRhoPoints = new();
|
||||
List<double> edge10mmRhoPoints = new();
|
||||
List<double> criticalRhoPoints = new();
|
||||
List<double> criticalPhasePoints = new();
|
||||
for (int i = 0; i < details.Count; i++)
|
||||
{
|
||||
j = i + 1;
|
||||
if (!double.TryParse(details[i].RhoAvg, out rhoAvg))
|
||||
rhoAvgValue = 0;
|
||||
else
|
||||
rhoAvgValue = rhoAvg;
|
||||
if (!double.TryParse(details[i].Phase, out phase))
|
||||
phaseValue = 0;
|
||||
else
|
||||
phaseValue = phase;
|
||||
allRhoPoints.Add(rhoAvgValue);
|
||||
if (j is 3 or 4 or 7 or 8)
|
||||
edge4mmRhoPoints.Add(rhoAvgValue);
|
||||
else if (j == 1)
|
||||
{
|
||||
criticalRhoPoints.Add(rhoAvgValue);
|
||||
criticalPhasePoints.Add(phaseValue);
|
||||
}
|
||||
else if (j is 2 or 5 or 6 or 9)
|
||||
{
|
||||
criticalRhoPoints.Add(rhoAvgValue);
|
||||
edge10mmRhoPoints.Add(rhoAvgValue);
|
||||
criticalPhasePoints.Add(phaseValue);
|
||||
}
|
||||
else
|
||||
throw new NotSupportedException();
|
||||
}
|
||||
double nineMean = allRhoPoints.Average();
|
||||
double nine4mmEdgeSum = edge4mmRhoPoints.Sum();
|
||||
double nine10mmEdgeSum = edge10mmRhoPoints.Sum();
|
||||
double nine4mmEdgeMean = edge4mmRhoPoints.Average();
|
||||
double nine10mmEdgeMean = edge10mmRhoPoints.Average();
|
||||
double nineCriticalPointsAverage = criticalRhoPoints.Average();
|
||||
double nineCriticalPointsStdDev = StandardDeviation(criticalRhoPoints);
|
||||
double nineCriticalPointsPhaseAngleAverage = criticalPhasePoints.Average();
|
||||
double nineEdgeMeanDelta = (nine4mmEdgeSum - nine10mmEdgeSum) / nine10mmEdgeSum * 100;
|
||||
double nineResRangePercent = (criticalRhoPoints.Max() - criticalRhoPoints.Min()) / nineCriticalPointsAverage * 100;
|
||||
NineMean = nineMean.ToString("0.0000000");
|
||||
Nine4mmEdgeMean = nine4mmEdgeMean.ToString("0.0000000");
|
||||
Nine10mmEdgeMean = nine10mmEdgeMean.ToString("0.0000000");
|
||||
NineEdgeMeanDelta = nineEdgeMeanDelta.ToString("0.0000000");
|
||||
NineResRangePercent = nineResRangePercent.ToString("0.0000000");
|
||||
NineCriticalPointsStdDev = nineCriticalPointsStdDev.ToString("0.0000000");
|
||||
NineCriticalPointsAverage = nineCriticalPointsAverage.ToString("0.0000000");
|
||||
NineCriticalPointsPhaseAngleAverage = nineCriticalPointsPhaseAngleAverage.ToString("0.0000000");
|
||||
}
|
||||
}
|
||||
|
||||
#pragma warning disable IDE0060
|
||||
private void Parse(IFileRead fileRead, Logistics logistics, List<FileInfo> fileInfoCollection, string ghostPCLFileName, string pdfTextStripperFileName)
|
||||
#pragma warning restore IDE0060
|
||||
@ -438,7 +582,7 @@ public class ProcessData : IProcessData
|
||||
headerText = headerText.Replace("line", "");
|
||||
headerText = headerText.Replace("middle", "");
|
||||
headerText = headerText.Replace("side", "");
|
||||
headerText = headerText.Replace("top", ""); // This will change "Stop Voltage" to "S Voltage"
|
||||
headerText = headerText.Replace("top", "");
|
||||
headerText = headerText.Replace("corner", "");
|
||||
headerText = headerText.Replace("bottom", "");
|
||||
headerText = headerText.Replace("ruleunder", "_");
|
||||
@ -451,7 +595,7 @@ public class ProcessData : IProcessData
|
||||
_ = GetBefore("Start Voltage:");
|
||||
StartVoltage = GetBefore("V");
|
||||
ScanPast("Wafer :");
|
||||
Wafer = GetBefore("S Voltage :"); // This is actually "Stop Voltage"
|
||||
Wafer = GetBefore("S Voltage :");
|
||||
StopVoltage = GetBefore("V");
|
||||
Set(logistics, headerText);
|
||||
RampRate = GetBefore("mV/sec");
|
||||
@ -519,42 +663,9 @@ public class ProcessData : IProcessData
|
||||
RsRadialGradient = GetToken();
|
||||
//ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
string token = GetToken();
|
||||
while (!string.IsNullOrEmpty(token))
|
||||
{
|
||||
Detail hgProbeDetail = new()
|
||||
{ NAvg = token };
|
||||
_ = GetToEOL();
|
||||
hgProbeDetail.Nsl = GetToken();
|
||||
_ = GetToEOL();
|
||||
hgProbeDetail.Vd = GetToken();
|
||||
_ = GetToEOL();
|
||||
hgProbeDetail.FlatZ = GetToken();
|
||||
_ = GetToEOL();
|
||||
hgProbeDetail.RhoAvg = GetToken();
|
||||
_ = GetToEOL();
|
||||
hgProbeDetail.Rhosl = GetToken();
|
||||
_ = GetToEOL();
|
||||
hgProbeDetail.Phase = GetToken();
|
||||
_ = GetToEOL();
|
||||
hgProbeDetail.Grade = GetToken();
|
||||
hgProbeDetail.UniqueId = string.Concat("_Point-", _Details.Count + 1);
|
||||
_Details.Add(hgProbeDetail);
|
||||
_ = GetToken();
|
||||
_ = GetToken();
|
||||
_ = GetToken();
|
||||
_ = GetToken();
|
||||
token = GetToken();
|
||||
//if (token.Contains("LincPDF") || token.Contains("MULTIPLE"))
|
||||
if (token.Contains("MULTIPLE"))
|
||||
{
|
||||
//ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
//ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
ScanPast("Flat Z: Grade : % Flat Z: Grade : % Flat Z: Grade : %");
|
||||
token = GetToken();
|
||||
}
|
||||
}
|
||||
List<Detail> details = GetDetails();
|
||||
PopulateCalculated(details);
|
||||
_Details.AddRange(details);
|
||||
}
|
||||
foreach (Detail detail in _Details.Cast<Detail>())
|
||||
{
|
||||
|
Reference in New Issue
Block a user