Force Single Image => Sorting
This commit is contained in:
parent
3899cf6b4c
commit
9b8e3bdf55
@ -42,79 +42,83 @@ public class MapLogicSupport : Shared.Models.Methods.IMapLogicSupport
|
|||||||
List<SortingContainer> results = new();
|
List<SortingContainer> results = new();
|
||||||
SortingContainer sortingContainer;
|
SortingContainer sortingContainer;
|
||||||
Sorting[] collection = Shared.Models.Stateless.Methods.ISorting.Sort(sortingCollection);
|
Sorting[] collection = Shared.Models.Stateless.Methods.ISorting.Sort(sortingCollection);
|
||||||
|
double a;
|
||||||
|
double b;
|
||||||
|
double c;
|
||||||
|
double d;
|
||||||
double faceDistancePermyriad;
|
double faceDistancePermyriad;
|
||||||
double sortingDaysDeltaTolerance;
|
double sortingDaysDeltaTolerance;
|
||||||
double faceDistanceMinimumConfidence;
|
double faceDistanceMinimumConfidence;
|
||||||
double faceDistanceAreaPermilleTolerance;
|
double faceDistanceAreaPermilleTolerance;
|
||||||
if (useFiltersCounter is null)
|
if (useFiltersCounter is null)
|
||||||
{
|
{
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance;
|
a = 1f;
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad;
|
b = 1f;
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
c = 1f;
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence;
|
d = 1f;
|
||||||
}
|
}
|
||||||
else if (useFiltersCounter.Value == 1)
|
else if (useFiltersCounter.Value < 5)
|
||||||
{
|
{
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * 1.5;
|
a = 1.25f;
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad;
|
b = 0.8f;
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
c = a;
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence;
|
d = b;
|
||||||
}
|
}
|
||||||
else if (useFiltersCounter.Value == 2)
|
else if (useFiltersCounter.Value < 9)
|
||||||
{
|
{
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance;
|
a = 1.5f;
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad * 1.5;
|
b = 0.667f;
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
c = a;
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence;
|
d = b;
|
||||||
}
|
}
|
||||||
else if (useFiltersCounter.Value == 3)
|
else if (useFiltersCounter.Value < 13)
|
||||||
|
{
|
||||||
|
a = 1.75f;
|
||||||
|
b = 0.571f;
|
||||||
|
c = a;
|
||||||
|
d = b;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
a = 2f;
|
||||||
|
b = 0.5f;
|
||||||
|
c = a;
|
||||||
|
d = b;
|
||||||
|
}
|
||||||
|
if (useFiltersCounter is null)
|
||||||
{
|
{
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance;
|
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance;
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad;
|
faceDistancePermyriad = _FaceDistancePermyriad;
|
||||||
|
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence;
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * .5;
|
|
||||||
}
|
}
|
||||||
else if (useFiltersCounter.Value == 4)
|
else if (useFiltersCounter.Value is 1 or 5 or 9 or 13)
|
||||||
{
|
{
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * 2;
|
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * a;
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad * 1.5;
|
faceDistancePermyriad = _FaceDistancePermyriad * c;
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * d;
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * .5;
|
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance * d;
|
||||||
}
|
}
|
||||||
else if (useFiltersCounter.Value == 5)
|
else if (useFiltersCounter.Value is 2 or 6 or 10 or 14)
|
||||||
{
|
{
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * 1.5;
|
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * c;
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad * 2;
|
faceDistancePermyriad = _FaceDistancePermyriad * a;
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * d;
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * .5;
|
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance * d;
|
||||||
}
|
}
|
||||||
else if (useFiltersCounter.Value == 6)
|
else if (useFiltersCounter.Value is 3 or 7 or 11 or 15)
|
||||||
{
|
{
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * 1.5;
|
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * c;
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad * 1.5;
|
faceDistancePermyriad = _FaceDistancePermyriad * c;
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * b;
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * .25;
|
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance * d;
|
||||||
}
|
}
|
||||||
else if (useFiltersCounter.Value == 7)
|
else if (useFiltersCounter.Value is 4 or 8 or 12 or 16)
|
||||||
{
|
{
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * 2.5;
|
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * c;
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad * 2;
|
faceDistancePermyriad = _FaceDistancePermyriad * c;
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * d;
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * .25;
|
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance * b;
|
||||||
}
|
|
||||||
else if (useFiltersCounter.Value == 8)
|
|
||||||
{
|
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * 2;
|
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad * 2.5;
|
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
|
||||||
faceDistanceMinimumConfidence = _FaceDistanceMinimumConfidence * .25;
|
|
||||||
}
|
|
||||||
else if (useFiltersCounter.Value == 9)
|
|
||||||
{
|
|
||||||
sortingDaysDeltaTolerance = _SortingDaysDeltaTolerance * 2;
|
|
||||||
faceDistancePermyriad = _FaceDistancePermyriad * 2;
|
|
||||||
faceDistanceAreaPermilleTolerance = _FaceDistanceAreaPermilleTolerance;
|
|
||||||
faceDistanceMinimumConfidence = 0;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -297,4 +301,20 @@ public class MapLogicSupport : Shared.Models.Methods.IMapLogicSupport
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Dictionary<int, Dictionary<int, Mapping>> GetIdToNormalizedPixelPercentageToFace(Mapping[] mappingCollection)
|
||||||
|
{
|
||||||
|
Dictionary<int, Dictionary<int, Mapping>> results = new();
|
||||||
|
Dictionary<int, Mapping> keyValuePairs;
|
||||||
|
foreach (Mapping mapping in mappingCollection)
|
||||||
|
{
|
||||||
|
if (!results.ContainsKey(mapping.MappingFromItem.Id))
|
||||||
|
results.Add(mapping.MappingFromItem.Id, new());
|
||||||
|
keyValuePairs = results[mapping.MappingFromItem.Id];
|
||||||
|
if (keyValuePairs.ContainsKey(mapping.MappingFromLocation.NormalizedPixelPercentage))
|
||||||
|
throw new NotSupportedException();
|
||||||
|
keyValuePairs.Add(mapping.MappingFromLocation.NormalizedPixelPercentage, mapping);
|
||||||
|
}
|
||||||
|
return results;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -1,4 +1,5 @@
|
|||||||
using System.Text.Json;
|
using System.Text.Json;
|
||||||
|
using View_by_Distance.Distance.Models.Stateless;
|
||||||
using View_by_Distance.FaceRecognitionDotNet;
|
using View_by_Distance.FaceRecognitionDotNet;
|
||||||
using View_by_Distance.Shared.Models;
|
using View_by_Distance.Shared.Models;
|
||||||
|
|
||||||
@ -10,6 +11,7 @@ public partial class E_Distance
|
|||||||
private readonly List<string> _Moved;
|
private readonly List<string> _Moved;
|
||||||
private readonly List<double?> _Debug;
|
private readonly List<double?> _Debug;
|
||||||
private readonly List<string> _Renamed;
|
private readonly List<string> _Renamed;
|
||||||
|
private readonly Serilog.ILogger? _Log;
|
||||||
private readonly bool _DistanceRenameToMatch;
|
private readonly bool _DistanceRenameToMatch;
|
||||||
private readonly double _FaceDistanceTolerance;
|
private readonly double _FaceDistanceTolerance;
|
||||||
private readonly bool _DistanceMoveUnableToMatch;
|
private readonly bool _DistanceMoveUnableToMatch;
|
||||||
@ -26,6 +28,7 @@ public partial class E_Distance
|
|||||||
_AllMappedFaceFiles = new();
|
_AllMappedFaceFiles = new();
|
||||||
_AllMappedFaceFileNames = new();
|
_AllMappedFaceFileNames = new();
|
||||||
_DuplicateMappedFaceFiles = new();
|
_DuplicateMappedFaceFiles = new();
|
||||||
|
_Log = Serilog.Log.ForContext<E_Distance>();
|
||||||
_DistanceRenameToMatch = distanceRenameToMatch;
|
_DistanceRenameToMatch = distanceRenameToMatch;
|
||||||
_FaceDistanceTolerance = faceDistanceTolerance;
|
_FaceDistanceTolerance = faceDistanceTolerance;
|
||||||
_DistanceMoveUnableToMatch = distanceMoveUnableToMatch;
|
_DistanceMoveUnableToMatch = distanceMoveUnableToMatch;
|
||||||
@ -438,8 +441,14 @@ public partial class E_Distance
|
|||||||
|
|
||||||
public void Clear()
|
public void Clear()
|
||||||
{
|
{
|
||||||
|
if (_Log is null)
|
||||||
|
throw new NullReferenceException(nameof(_Log));
|
||||||
double?[] debug = (from l in _Debug where l is null or not 0 select l).ToArray();
|
double?[] debug = (from l in _Debug where l is null or not 0 select l).ToArray();
|
||||||
|
if (debug.Any())
|
||||||
|
{
|
||||||
string debugMessage = $"{_Debug.Count - debug.Length} - {debug.Min()} - {_Debug.Max()}";
|
string debugMessage = $"{_Debug.Count - debug.Length} - {debug.Min()} - {_Debug.Max()}";
|
||||||
|
_Log.Info(debugMessage);
|
||||||
|
}
|
||||||
if (_Moved.Any() || _Renamed.Any() || _DuplicateMappedFaceFiles.Any())
|
if (_Moved.Any() || _Renamed.Any() || _DuplicateMappedFaceFiles.Any())
|
||||||
throw new NotImplementedException("Restart!");
|
throw new NotImplementedException("Restart!");
|
||||||
_Debug.Clear();
|
_Debug.Clear();
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
|
using System.Diagnostics;
|
||||||
using System.Drawing;
|
using System.Drawing;
|
||||||
using System.Drawing.Imaging;
|
using System.Drawing.Imaging;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Text.Json;
|
using System.Text.Json;
|
||||||
using System.Text.Json.Serialization;
|
using System.Text.Json.Serialization;
|
||||||
|
using View_by_Distance.Face.Models.Stateless;
|
||||||
using View_by_Distance.FaceRecognitionDotNet;
|
using View_by_Distance.FaceRecognitionDotNet;
|
||||||
using View_by_Distance.Metadata.Models;
|
using View_by_Distance.Metadata.Models;
|
||||||
using View_by_Distance.Property.Models;
|
using View_by_Distance.Property.Models;
|
||||||
@ -34,7 +36,6 @@ public class D_Face
|
|||||||
private readonly bool _RetryImagesWithoutAFace;
|
private readonly bool _RetryImagesWithoutAFace;
|
||||||
private readonly Configuration _Configuration;
|
private readonly Configuration _Configuration;
|
||||||
private readonly int _NumberOfTimesToUpsample;
|
private readonly int _NumberOfTimesToUpsample;
|
||||||
private readonly int _FaceDistanceAreaPermilleTolerance;
|
|
||||||
private readonly ImageCodecInfo _ImageCodecInfo;
|
private readonly ImageCodecInfo _ImageCodecInfo;
|
||||||
private readonly ModelParameter _ModelParameter;
|
private readonly ModelParameter _ModelParameter;
|
||||||
private readonly PredictorModel _PredictorModel;
|
private readonly PredictorModel _PredictorModel;
|
||||||
@ -44,6 +45,7 @@ public class D_Face
|
|||||||
private readonly int _FaceDistanceHiddenImageFactor;
|
private readonly int _FaceDistanceHiddenImageFactor;
|
||||||
private readonly EncoderParameters _EncoderParameters;
|
private readonly EncoderParameters _EncoderParameters;
|
||||||
private readonly ImageCodecInfo _HiddenImageCodecInfo;
|
private readonly ImageCodecInfo _HiddenImageCodecInfo;
|
||||||
|
private readonly int _FaceDistanceAreaPermilleTolerance;
|
||||||
private readonly bool _ForceFaceLastWriteTimeToCreationTime;
|
private readonly bool _ForceFaceLastWriteTimeToCreationTime;
|
||||||
private readonly EncoderParameters _HiddenEncoderParameters;
|
private readonly EncoderParameters _HiddenEncoderParameters;
|
||||||
private readonly JsonSerializerOptions _WriteIndentedAndWhenWritingNull;
|
private readonly JsonSerializerOptions _WriteIndentedAndWhenWritingNull;
|
||||||
@ -190,6 +192,8 @@ public class D_Face
|
|||||||
|
|
||||||
private List<Shared.Models.Face> GetFaces(Shared.Models.Property property, MappingFromItem mappingFromItem, int outputResolutionWidth, int outputResolutionHeight, int outputResolutionOrientation)
|
private List<Shared.Models.Face> GetFaces(Shared.Models.Property property, MappingFromItem mappingFromItem, int outputResolutionWidth, int outputResolutionHeight, int outputResolutionOrientation)
|
||||||
{
|
{
|
||||||
|
if (_Log is null)
|
||||||
|
throw new NullReferenceException(nameof(_Log));
|
||||||
List<Shared.Models.Face> results = new();
|
List<Shared.Models.Face> results = new();
|
||||||
FaceRecognitionDotNet.Image? unknownImage;
|
FaceRecognitionDotNet.Image? unknownImage;
|
||||||
if (!mappingFromItem.ResizedFileHolder.Exists)
|
if (!mappingFromItem.ResizedFileHolder.Exists)
|
||||||
@ -199,7 +203,10 @@ public class D_Face
|
|||||||
try
|
try
|
||||||
{ unknownImage = FaceRecognition.LoadImageFile(mappingFromItem.ResizedFileHolder.FullName); }
|
{ unknownImage = FaceRecognition.LoadImageFile(mappingFromItem.ResizedFileHolder.FullName); }
|
||||||
catch (Exception)
|
catch (Exception)
|
||||||
{ unknownImage = null; }
|
{
|
||||||
|
unknownImage = null;
|
||||||
|
_Log.Info(string.Concat(new StackFrame().GetMethod()?.Name, " <", mappingFromItem.ResizedFileHolder.FullName, ">"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (unknownImage is null)
|
if (unknownImage is null)
|
||||||
results.Add(new(property, outputResolutionWidth, outputResolutionHeight, outputResolutionOrientation, mappingFromItem.RelativePath, location: null));
|
results.Add(new(property, outputResolutionWidth, outputResolutionHeight, outputResolutionOrientation, mappingFromItem.RelativePath, location: null));
|
||||||
|
@ -857,7 +857,6 @@ public partial class DlibDotNet
|
|||||||
int normalizedPixelPercentage;
|
int normalizedPixelPercentage;
|
||||||
string deterministicHashCodeKey;
|
string deterministicHashCodeKey;
|
||||||
MappingFromItem mappingFromItem;
|
MappingFromItem mappingFromItem;
|
||||||
MappingFromPerson mappingFromPerson;
|
|
||||||
MappingFromLocation mappingFromLocation;
|
MappingFromLocation mappingFromLocation;
|
||||||
List<Shared.Models.Face> collection = new();
|
List<Shared.Models.Face> collection = new();
|
||||||
foreach (Container container in containers)
|
foreach (Container container in containers)
|
||||||
@ -887,11 +886,10 @@ public partial class DlibDotNet
|
|||||||
if (face.FaceEncoding is null || face.Location is null || face.OutputResolution is null)
|
if (face.FaceEncoding is null || face.Location is null || face.OutputResolution is null)
|
||||||
continue;
|
continue;
|
||||||
areaPermille = Shared.Models.Stateless.Methods.IMapping.GetAreaPermille(face.Location, face.OutputResolution);
|
areaPermille = Shared.Models.Stateless.Methods.IMapping.GetAreaPermille(face.Location, face.OutputResolution);
|
||||||
mappingFromPerson = new(approximateYears: null, by: null, displayDirectoryName: string.Empty, personBirthday: null, segmentB: string.Empty);
|
|
||||||
normalizedPixelPercentage = Shared.Models.Stateless.Methods.ILocation.GetNormalizedPixelPercentage(face.Location, Shared.Models.Stateless.ILocation.Digits, Shared.Models.Stateless.ILocation.Factor, face.OutputResolution);
|
normalizedPixelPercentage = Shared.Models.Stateless.Methods.ILocation.GetNormalizedPixelPercentage(face.Location, Shared.Models.Stateless.ILocation.Digits, Shared.Models.Stateless.ILocation.Factor, face.OutputResolution);
|
||||||
deterministicHashCodeKey = Shared.Models.Stateless.Methods.IMapping.GetDeterministicHashCodeKey(item.Property.Id.Value, face.Location, Shared.Models.Stateless.ILocation.Digits, Shared.Models.Stateless.ILocation.Factor, face.OutputResolution);
|
deterministicHashCodeKey = Shared.Models.Stateless.Methods.IMapping.GetDeterministicHashCodeKey(item.Property.Id.Value, face.Location, Shared.Models.Stateless.ILocation.Digits, Shared.Models.Stateless.ILocation.Factor, face.OutputResolution);
|
||||||
mappingFromLocation = new(areaPermille, face.Location.Confidence, deterministicHashCodeKey, normalizedPixelPercentage);
|
mappingFromLocation = new(areaPermille, face.Location.Confidence, deterministicHashCodeKey, normalizedPixelPercentage);
|
||||||
mapping = new(mappingFromItem, mappingFromLocation, mappingFromPerson);
|
mapping = new(mappingFromItem, mappingFromLocation);
|
||||||
face.SetMapping(mapping);
|
face.SetMapping(mapping);
|
||||||
collection.Add(face);
|
collection.Add(face);
|
||||||
}
|
}
|
||||||
@ -901,22 +899,6 @@ public partial class DlibDotNet
|
|||||||
return results;
|
return results;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static Dictionary<int, Dictionary<int, Mapping>> GetIdToNormalizedPixelPercentageToFace(Mapping[] mappingCollection)
|
|
||||||
{
|
|
||||||
Dictionary<int, Dictionary<int, Mapping>> results = new();
|
|
||||||
Dictionary<int, Mapping> keyValuePairs;
|
|
||||||
foreach (Mapping mapping in mappingCollection)
|
|
||||||
{
|
|
||||||
if (!results.ContainsKey(mapping.MappingFromItem.Id))
|
|
||||||
results.Add(mapping.MappingFromItem.Id, new());
|
|
||||||
keyValuePairs = results[mapping.MappingFromItem.Id];
|
|
||||||
if (keyValuePairs.ContainsKey(mapping.MappingFromLocation.NormalizedPixelPercentage))
|
|
||||||
throw new NotSupportedException();
|
|
||||||
keyValuePairs.Add(mapping.MappingFromLocation.NormalizedPixelPercentage, mapping);
|
|
||||||
}
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void MapLogic(string argZero, long ticks, PersonContainer[] personContainers, Container[] containers, string a2PeopleSingletonDirectory, string dResultsFullGroupDirectory, string d2FacePartsContentDirectory, string eDistanceContentDirectory, string outputResolution)
|
private void MapLogic(string argZero, long ticks, PersonContainer[] personContainers, Container[] containers, string a2PeopleSingletonDirectory, string dResultsFullGroupDirectory, string d2FacePartsContentDirectory, string eDistanceContentDirectory, string outputResolution)
|
||||||
{
|
{
|
||||||
int? useFiltersCounter = null;
|
int? useFiltersCounter = null;
|
||||||
@ -940,7 +922,7 @@ public partial class DlibDotNet
|
|||||||
eDistanceContentDirectory,
|
eDistanceContentDirectory,
|
||||||
mappingCollection,
|
mappingCollection,
|
||||||
mapLogicSupport);
|
mapLogicSupport);
|
||||||
Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping = GetIdToNormalizedPixelPercentageToFace(mappingCollection);
|
Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping = MapLogicSupport.GetIdToNormalizedPixelPercentageToFace(mappingCollection);
|
||||||
mapLogic.CopyManualFiles(dFacesContentDirectory, idToNormalizedPixelPercentageToMapping);
|
mapLogic.CopyManualFiles(dFacesContentDirectory, idToNormalizedPixelPercentageToMapping);
|
||||||
int totalNotMapped = mapLogic.AddToMapping(mappingCollection);
|
int totalNotMapped = mapLogic.AddToMapping(mappingCollection);
|
||||||
if (_Configuration.MappingSaveMapped)
|
if (_Configuration.MappingSaveMapped)
|
||||||
@ -949,7 +931,7 @@ public partial class DlibDotNet
|
|||||||
sortingContainers = mapLogicSupport.SetFaceMappingSortingCollectionThenGetSortingContainers(_AppSettings.MaxDegreeOfParallelism, ticks, mapLogic, distinctFilteredFaces, useFiltersCounter);
|
sortingContainers = mapLogicSupport.SetFaceMappingSortingCollectionThenGetSortingContainers(_AppSettings.MaxDegreeOfParallelism, ticks, mapLogic, distinctFilteredFaces, useFiltersCounter);
|
||||||
if (!sortingContainers.Any())
|
if (!sortingContainers.Any())
|
||||||
{
|
{
|
||||||
for (useFiltersCounter = 1; useFiltersCounter < 11; useFiltersCounter++)
|
for (useFiltersCounter = 1; useFiltersCounter < 17; useFiltersCounter++)
|
||||||
{
|
{
|
||||||
sortingContainers = mapLogicSupport.SetFaceMappingSortingCollectionThenGetSortingContainers(_AppSettings.MaxDegreeOfParallelism, ticks, mapLogic, distinctFilteredFaces, useFiltersCounter);
|
sortingContainers = mapLogicSupport.SetFaceMappingSortingCollectionThenGetSortingContainers(_AppSettings.MaxDegreeOfParallelism, ticks, mapLogic, distinctFilteredFaces, useFiltersCounter);
|
||||||
if (sortingContainers.Any())
|
if (sortingContainers.Any())
|
||||||
@ -958,7 +940,7 @@ public partial class DlibDotNet
|
|||||||
}
|
}
|
||||||
MapLogicSupport.SaveFaceDistances(_Configuration.PropertyConfiguration, sortingContainers);
|
MapLogicSupport.SaveFaceDistances(_Configuration.PropertyConfiguration, sortingContainers);
|
||||||
if (totalNotMapped > 0)
|
if (totalNotMapped > 0)
|
||||||
mapLogic.ForceSingleImageThenSaveSorting(dFacesContentDirectory, d2FacePartsContentDirectory, mappingCollection, idToNormalizedPixelPercentageToMapping, sortingContainers, useFiltersCounter, totalNotMapped);
|
mapLogic.UpdateFromSortingContainersThenSaveContainers(dFacesContentDirectory, d2FacePartsContentDirectory, mappingCollection, idToNormalizedPixelPercentageToMapping, useFiltersCounter, sortingContainers, totalNotMapped);
|
||||||
if (_Configuration.MappingSaveNotMapped)
|
if (_Configuration.MappingSaveNotMapped)
|
||||||
mapLogic.SaveNotMappedTicks();
|
mapLogic.SaveNotMappedTicks();
|
||||||
if (_Configuration.SaveShortcutsForOutputResolutions.Contains(outputResolution))
|
if (_Configuration.SaveShortcutsForOutputResolutions.Contains(outputResolution))
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
using Humanizer;
|
using Humanizer;
|
||||||
using ShellProgressBar;
|
using ShellProgressBar;
|
||||||
using System.Text.Json;
|
using System.Text.Json;
|
||||||
|
using View_by_Distance.Map.Models.Stateless;
|
||||||
using View_by_Distance.Shared.Models;
|
using View_by_Distance.Shared.Models;
|
||||||
using View_by_Distance.Shared.Models.Stateless.Methods;
|
using View_by_Distance.Shared.Models.Stateless.Methods;
|
||||||
using WindowsShortcutFactory;
|
using WindowsShortcutFactory;
|
||||||
@ -112,9 +113,9 @@ public class MapLogic
|
|||||||
int result = 0;
|
int result = 0;
|
||||||
const int zero = 0;
|
const int zero = 0;
|
||||||
string mappingSegmentB;
|
string mappingSegmentB;
|
||||||
|
int by = IMapLogic.Mapping;
|
||||||
PersonBirthday personBirthday;
|
PersonBirthday personBirthday;
|
||||||
PersonContainer[]? collection;
|
PersonContainer[]? collection;
|
||||||
int by = Stateless.IMapLogic.Mapping;
|
|
||||||
List<PersonContainer> personContainers = new();
|
List<PersonContainer> personContainers = new();
|
||||||
Dictionary<int, PersonContainer[]>? keyValuePairs;
|
Dictionary<int, PersonContainer[]>? keyValuePairs;
|
||||||
foreach (Mapping mapping in mappingCollection)
|
foreach (Mapping mapping in mappingCollection)
|
||||||
@ -213,14 +214,193 @@ public class MapLogic
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private SaveContainer? GetMatchSaveContainer(string dFacesContentDirectory, string d2FacePartsContentDirectory, string directory, Mapping mapping)
|
||||||
|
{
|
||||||
|
if (_Configuration is null)
|
||||||
|
throw new NullReferenceException(nameof(_Configuration));
|
||||||
|
SaveContainer? result;
|
||||||
|
string shortcutFile = string.Empty;
|
||||||
|
string? directoryName = Path.GetDirectoryName(mapping.MappingFromItem.RelativePath);
|
||||||
|
string facesDirectory = Path.Combine($"{dFacesContentDirectory}{directoryName}", mapping.MappingFromItem.ImageFileHolder.NameWithoutExtension);
|
||||||
|
FileHolder faceFileHolder = new(Path.Combine(facesDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{_Configuration.FacesFileNameExtension}"));
|
||||||
|
if (directoryName is null || !faceFileHolder.Exists)
|
||||||
|
result = null;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
string facePartsDirectory = Path.Combine($"{d2FacePartsContentDirectory}{directoryName}", mapping.MappingFromItem.ImageFileHolder.NameWithoutExtension);
|
||||||
|
string checkFile = Path.Combine(directory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}");
|
||||||
|
FileHolder hiddenFaceFileHolder = new(Path.Combine(facesDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{_Configuration.FacesHiddenFileNameExtension}"));
|
||||||
|
FileHolder facePartsFileHolder = new(Path.Combine(facePartsDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{_Configuration.FacePartsFileNameExtension}"));
|
||||||
|
result = new(checkFile, directory, faceFileHolder, hiddenFaceFileHolder, facePartsFileHolder, mapping.MappingFromItem.ResizedFileHolder, shortcutFile);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static (string, bool, bool) Get(int? useFiltersCounter, string forceSingleImageHumanized, Mapping mapping)
|
||||||
|
{
|
||||||
|
string by;
|
||||||
|
bool isByMapping;
|
||||||
|
bool isBySorting;
|
||||||
|
if (mapping.By is null)
|
||||||
|
{
|
||||||
|
isByMapping = false;
|
||||||
|
isBySorting = false;
|
||||||
|
by = $"{nameof(IMapLogic.Mapping)}Null";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
isByMapping = mapping.By == IMapLogic.Mapping;
|
||||||
|
isBySorting = mapping.By == IMapLogic.Sorting;
|
||||||
|
if (isBySorting && mapping.MappingFromPerson is null)
|
||||||
|
by = $"{nameof(IMapLogic.Sorting)} Without Person";
|
||||||
|
else if (isBySorting && useFiltersCounter.HasValue)
|
||||||
|
by = $"{nameof(IMapLogic.Sorting)} Modified Filters - {useFiltersCounter.Value}";
|
||||||
|
else
|
||||||
|
{
|
||||||
|
by = mapping.By.Value switch
|
||||||
|
{
|
||||||
|
IMapLogic.Mapping => nameof(IMapLogic.Mapping),
|
||||||
|
IMapLogic.Sorting => nameof(IMapLogic.Sorting),
|
||||||
|
IMapLogic.ForceSingleImage => forceSingleImageHumanized,
|
||||||
|
_ => throw new NotImplementedException()
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new(by, isByMapping, isBySorting);
|
||||||
|
}
|
||||||
|
|
||||||
|
private string GetDirectory(string by, MappingFromItem mappingFromItem, SortingContainer sortingContainer)
|
||||||
|
{
|
||||||
|
if (_Configuration is null)
|
||||||
|
throw new NullReferenceException(nameof(_Configuration));
|
||||||
|
string result;
|
||||||
|
const int zero = 0;
|
||||||
|
string mappingSegmentB;
|
||||||
|
string personKeyFormatted;
|
||||||
|
PersonBirthday personBirthday;
|
||||||
|
PersonContainer personContainer;
|
||||||
|
result = Path.Combine(_EDistanceContentTicksDirectory, by, sortingContainer.Sorting.Id.ToString(), sortingContainer.Sorting.NormalizedPixelPercentage.ToString());
|
||||||
|
for (int i = 0; i < _NotMappedPersonContainers.Count; i++)
|
||||||
|
{
|
||||||
|
personContainer = _NotMappedPersonContainers[i];
|
||||||
|
if (personContainer.Key is null || personContainer.Birthdays is null || !personContainer.Birthdays.Any())
|
||||||
|
continue;
|
||||||
|
personBirthday = personContainer.Birthdays[zero];
|
||||||
|
mappingSegmentB = Stateless.MapLogic.GetMappingSegmentB(_Ticks, personBirthday, personContainer.ApproximateYears, mappingFromItem);
|
||||||
|
personKeyFormatted = IPersonBirthday.GetFormatted(_Configuration.PersonBirthdayFormat, personBirthday);
|
||||||
|
result = Path.Combine(_EDistanceContentTicksDirectory, by, personKeyFormatted, mappingSegmentB);
|
||||||
|
_NotMappedPersonContainers.RemoveAt(i);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<SaveContainer> GetSaveContainers(string dFacesContentDirectory, string d2FacePartsContentDirectory, Mapping[] mappingCollection, Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping, int? useFiltersCounter, bool saveMapped)
|
||||||
|
{
|
||||||
|
if (_Configuration is null)
|
||||||
|
throw new NullReferenceException(nameof(_Configuration));
|
||||||
|
List<SaveContainer> results = new();
|
||||||
|
string by;
|
||||||
|
bool isByMapping;
|
||||||
|
bool isBySorting;
|
||||||
|
string checkFile;
|
||||||
|
string directory;
|
||||||
|
string shortcutFile;
|
||||||
|
string facesDirectory;
|
||||||
|
string? directoryName;
|
||||||
|
string personDirectory;
|
||||||
|
FileHolder faceFileHolder;
|
||||||
|
string facePartsDirectory;
|
||||||
|
string personKeyFormatted;
|
||||||
|
SaveContainer? saveContainer;
|
||||||
|
FileHolder facePartsFileHolder;
|
||||||
|
FileHolder hiddenFaceFileHolder;
|
||||||
|
Dictionary<int, Mapping>? normalizedPixelPercentageToMapping;
|
||||||
|
string forceSingleImageHumanized = nameof(IMapLogic.ForceSingleImage).Humanize(LetterCasing.Title);
|
||||||
|
foreach (Mapping mapping in mappingCollection)
|
||||||
|
{
|
||||||
|
directoryName = Path.GetDirectoryName(mapping.MappingFromItem.RelativePath);
|
||||||
|
if (directoryName is null)
|
||||||
|
throw new NotSupportedException();
|
||||||
|
(by, isByMapping, isBySorting) = Get(useFiltersCounter, forceSingleImageHumanized, mapping);
|
||||||
|
if (isByMapping && !saveMapped)
|
||||||
|
continue;
|
||||||
|
if (mapping.MappingFromPerson is null)
|
||||||
|
{
|
||||||
|
if (mapping.SortingContainer is null)
|
||||||
|
continue;
|
||||||
|
directory = GetDirectory(by, mapping.MappingFromItem, mapping.SortingContainer);
|
||||||
|
personDirectory = Path.Combine(directory, _Configuration.MappingDefaultName);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (string.IsNullOrEmpty(mapping.MappingFromPerson.SegmentB))
|
||||||
|
throw new NotSupportedException();
|
||||||
|
if (string.IsNullOrEmpty(mapping.MappingFromPerson.DisplayDirectoryName))
|
||||||
|
throw new NotSupportedException();
|
||||||
|
personKeyFormatted = IPersonBirthday.GetFormatted(_Configuration.PersonBirthdayFormat, mapping.MappingFromPerson.PersonBirthday);
|
||||||
|
directory = Path.Combine(_EDistanceContentTicksDirectory, by, personKeyFormatted, mapping.MappingFromPerson.SegmentB);
|
||||||
|
if (isByMapping)
|
||||||
|
personDirectory = Path.Combine(directory, mapping.MappingFromPerson.DisplayDirectoryName);
|
||||||
|
else if (mapping.By is not null)
|
||||||
|
personDirectory = Path.Combine(directory, mapping.MappingFromPerson.DisplayDirectoryName, "lnk");
|
||||||
|
else
|
||||||
|
personDirectory = Path.Combine(directory, mapping.MappingFromPerson.DisplayDirectoryName[..1], "lnk");
|
||||||
|
}
|
||||||
|
saveContainer = new(personDirectory);
|
||||||
|
results.Add(saveContainer);
|
||||||
|
facesDirectory = Path.Combine($"{dFacesContentDirectory}{directoryName}", mapping.MappingFromItem.ImageFileHolder.NameWithoutExtension);
|
||||||
|
faceFileHolder = new(Path.Combine(facesDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{_Configuration.FacesFileNameExtension}"));
|
||||||
|
if (!faceFileHolder.Exists)
|
||||||
|
continue;
|
||||||
|
if (isByMapping)
|
||||||
|
{
|
||||||
|
checkFile = Path.Combine(personDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}");
|
||||||
|
saveContainer = new(checkFile, directory, faceFileHolder);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
facePartsDirectory = Path.Combine($"{d2FacePartsContentDirectory}{directoryName}", mapping.MappingFromItem.ImageFileHolder.NameWithoutExtension);
|
||||||
|
checkFile = Path.Combine(directory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}");
|
||||||
|
shortcutFile = Path.Combine(personDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}.lnk");
|
||||||
|
hiddenFaceFileHolder = new(Path.Combine(facesDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{_Configuration.FacesHiddenFileNameExtension}"));
|
||||||
|
facePartsFileHolder = new(Path.Combine(facePartsDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{_Configuration.FacePartsFileNameExtension}"));
|
||||||
|
saveContainer = new(checkFile, directory, faceFileHolder, hiddenFaceFileHolder, facePartsFileHolder, mapping.MappingFromItem.ResizedFileHolder, shortcutFile);
|
||||||
|
}
|
||||||
|
results.Add(saveContainer);
|
||||||
|
if (!isBySorting || mapping.SortingContainer is null)
|
||||||
|
continue;
|
||||||
|
if (!idToNormalizedPixelPercentageToMapping.TryGetValue(mapping.SortingContainer.Sorting.Id, out normalizedPixelPercentageToMapping))
|
||||||
|
continue;
|
||||||
|
if (!normalizedPixelPercentageToMapping.ContainsKey(mapping.SortingContainer.Sorting.NormalizedPixelPercentage))
|
||||||
|
continue;
|
||||||
|
if (isBySorting && mapping.MappingFromPerson is null)
|
||||||
|
{
|
||||||
|
saveContainer = GetMatchSaveContainer(dFacesContentDirectory, d2FacePartsContentDirectory, directory, normalizedPixelPercentageToMapping[mapping.SortingContainer.Sorting.NormalizedPixelPercentage]);
|
||||||
|
if (saveContainer is not null)
|
||||||
|
results.Add(saveContainer);
|
||||||
|
}
|
||||||
|
saveContainer = Stateless.MapLogic.GetDebugSaveContainer(directory, mapping.SortingContainer, normalizedPixelPercentageToMapping[mapping.SortingContainer.Sorting.NormalizedPixelPercentage]);
|
||||||
|
results.Add(saveContainer);
|
||||||
|
}
|
||||||
|
return results;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void UpdateFromSortingContainersThenSaveContainers(string dFacesContentDirectory, string d2FacePartsContentDirectory, Mapping[] mappingCollection, Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping, int? useFiltersCounter, SortingContainer[] sortingContainers, int totalNotMapped)
|
||||||
|
{
|
||||||
|
int updated = UpdateFromSortingContainers(sortingContainers);
|
||||||
|
List<SaveContainer> saveContainers = GetSaveContainers(dFacesContentDirectory, d2FacePartsContentDirectory, mappingCollection, idToNormalizedPixelPercentageToMapping, useFiltersCounter, saveMapped: false);
|
||||||
|
SaveContainers(totalNotMapped, updated, saveContainers);
|
||||||
|
}
|
||||||
|
|
||||||
public void SaveMapped(string dFacesContentDirectory, string d2FacePartsContentDirectory, Mapping[] mappingCollection, Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping, int totalNotMapped)
|
public void SaveMapped(string dFacesContentDirectory, string d2FacePartsContentDirectory, Mapping[] mappingCollection, Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping, int totalNotMapped)
|
||||||
{
|
{
|
||||||
if (_Configuration is null)
|
if (_Configuration is null)
|
||||||
throw new NullReferenceException(nameof(_Configuration));
|
throw new NullReferenceException(nameof(_Configuration));
|
||||||
int? updated = null;
|
int? updated = null;
|
||||||
int? useFiltersCounter = null;
|
int? useFiltersCounter = null;
|
||||||
string mappingDirectory = Path.Combine(_EDistanceContentTicksDirectory, nameof(Stateless.IMapLogic.Mapping));
|
string mappingDirectory = Path.Combine(_EDistanceContentTicksDirectory, nameof(IMapLogic.Mapping));
|
||||||
List<SaveContainer> saveContainers = Stateless.MapLogic.GetSaveContainers(_Configuration, _EDistanceContentTicksDirectory, dFacesContentDirectory, d2FacePartsContentDirectory, mappingCollection, idToNormalizedPixelPercentageToMapping, useFiltersCounter, saveMapped: true);
|
List<SaveContainer> saveContainers = GetSaveContainers(dFacesContentDirectory, d2FacePartsContentDirectory, mappingCollection, idToNormalizedPixelPercentageToMapping, useFiltersCounter, saveMapped: true);
|
||||||
SaveContainers(totalNotMapped, updated, saveContainers);
|
SaveContainers(totalNotMapped, updated, saveContainers);
|
||||||
if (!string.IsNullOrEmpty(_EDistanceContentTicksDirectory) && Directory.Exists(mappingDirectory))
|
if (!string.IsNullOrEmpty(_EDistanceContentTicksDirectory) && Directory.Exists(mappingDirectory))
|
||||||
Stateless.MapLogic.SaveMappingShortcuts(mappingDirectory);
|
Stateless.MapLogic.SaveMappingShortcuts(mappingDirectory);
|
||||||
@ -293,10 +473,14 @@ public class MapLogic
|
|||||||
if (faceDistanceLength.Length == 0)
|
if (faceDistanceLength.Length == 0)
|
||||||
continue;
|
continue;
|
||||||
if (!_IdThenNormalizedPixelPercentageToPersonContainers.TryGetValue(faceDistanceLength.Id, out normalizedPixelPercentageToPersonContainers))
|
if (!_IdThenNormalizedPixelPercentageToPersonContainers.TryGetValue(faceDistanceLength.Id, out normalizedPixelPercentageToPersonContainers))
|
||||||
continue;
|
personKeysRangesCollection = new();
|
||||||
|
else
|
||||||
|
{
|
||||||
if (!normalizedPixelPercentageToPersonContainers.ContainsKey(faceDistanceLength.NormalizedPixelPercentage.Value))
|
if (!normalizedPixelPercentageToPersonContainers.ContainsKey(faceDistanceLength.NormalizedPixelPercentage.Value))
|
||||||
continue;
|
personKeysRangesCollection = new();
|
||||||
|
else
|
||||||
personKeysRangesCollection = GetPersonKeysRangesCollection(normalizedPixelPercentageToPersonContainers[faceDistanceLength.NormalizedPixelPercentage.Value]);
|
personKeysRangesCollection = GetPersonKeysRangesCollection(normalizedPixelPercentageToPersonContainers[faceDistanceLength.NormalizedPixelPercentage.Value]);
|
||||||
|
}
|
||||||
sorting = ISorting.Get(_Configuration.FaceDistancePermyriad, _Configuration.FaceDistanceTolerance, faceDistanceEncoding, faceDistanceLength, personKeysRangesCollection);
|
sorting = ISorting.Get(_Configuration.FaceDistancePermyriad, _Configuration.FaceDistanceTolerance, faceDistanceEncoding, faceDistanceLength, personKeysRangesCollection);
|
||||||
if (sorting.DistancePermyriad == 0)
|
if (sorting.DistancePermyriad == 0)
|
||||||
continue;
|
continue;
|
||||||
@ -311,7 +495,7 @@ public class MapLogic
|
|||||||
return results;
|
return results;
|
||||||
}
|
}
|
||||||
|
|
||||||
private int UpdateFromSortingContainers(SortingContainer[] sortingContainers)
|
public int UpdateFromSortingContainers(SortingContainer[] sortingContainers)
|
||||||
{
|
{
|
||||||
if (_Configuration is null)
|
if (_Configuration is null)
|
||||||
throw new NullReferenceException(nameof(_Configuration));
|
throw new NullReferenceException(nameof(_Configuration));
|
||||||
@ -321,11 +505,13 @@ public class MapLogic
|
|||||||
string mappingSegmentB;
|
string mappingSegmentB;
|
||||||
string personKeyFormatted;
|
string personKeyFormatted;
|
||||||
PersonBirthday personBirthday;
|
PersonBirthday personBirthday;
|
||||||
|
const int by = IMapLogic.Sorting;
|
||||||
PersonContainer[] personContainers;
|
PersonContainer[] personContainers;
|
||||||
const int by = Stateless.IMapLogic.Sorting;
|
List<int> normalizedPixelPercentageCollectionForA;
|
||||||
List<int> normalizedPixelPercentageCollection;
|
List<int> normalizedPixelPercentageCollectionForB;
|
||||||
Dictionary<string, int> checkKeyValuePairs = new();
|
Dictionary<string, int> checkKeyValuePairs = new();
|
||||||
Dictionary<int, List<int>> idToNormalizedPixelPercentageCollection = new();
|
Dictionary<int, List<int>> idToNormalizedPixelPercentageCollectionForA = new();
|
||||||
|
Dictionary<int, List<int>> idToNormalizedPixelPercentageCollectionForB = new();
|
||||||
Dictionary<int, PersonContainer[]>? normalizedPixelPercentageToPersonContainers;
|
Dictionary<int, PersonContainer[]>? normalizedPixelPercentageToPersonContainers;
|
||||||
int totalSeconds = (int)Math.Floor(new TimeSpan(DateTime.Now.Ticks - _Ticks).TotalSeconds);
|
int totalSeconds = (int)Math.Floor(new TimeSpan(DateTime.Now.Ticks - _Ticks).TotalSeconds);
|
||||||
string message = $") {sortingContainers.Length:000} Update From Sorting Container(s) - {totalSeconds} total second(s)";
|
string message = $") {sortingContainers.Length:000} Update From Sorting Container(s) - {totalSeconds} total second(s)";
|
||||||
@ -336,15 +522,34 @@ public class MapLogic
|
|||||||
progressBar.Tick();
|
progressBar.Tick();
|
||||||
if (sortingContainer.Mapping is null)
|
if (sortingContainer.Mapping is null)
|
||||||
throw new NotSupportedException();
|
throw new NotSupportedException();
|
||||||
|
if (!idToNormalizedPixelPercentageCollectionForA.ContainsKey(sortingContainer.Mapping.MappingFromItem.Id))
|
||||||
|
idToNormalizedPixelPercentageCollectionForA.Add(sortingContainer.Mapping.MappingFromItem.Id, new());
|
||||||
|
normalizedPixelPercentageCollectionForA = idToNormalizedPixelPercentageCollectionForA[sortingContainer.Mapping.MappingFromItem.Id];
|
||||||
|
if (!idToNormalizedPixelPercentageCollectionForB.ContainsKey(sortingContainer.Mapping.MappingFromItem.Id))
|
||||||
|
idToNormalizedPixelPercentageCollectionForB.Add(sortingContainer.Mapping.MappingFromItem.Id, new());
|
||||||
|
normalizedPixelPercentageCollectionForB = idToNormalizedPixelPercentageCollectionForB[sortingContainer.Mapping.MappingFromItem.Id];
|
||||||
if (!_IdThenNormalizedPixelPercentageToPersonContainers.TryGetValue(sortingContainer.Sorting.Id, out normalizedPixelPercentageToPersonContainers))
|
if (!_IdThenNormalizedPixelPercentageToPersonContainers.TryGetValue(sortingContainer.Sorting.Id, out normalizedPixelPercentageToPersonContainers))
|
||||||
throw new NotSupportedException();
|
{
|
||||||
if (!normalizedPixelPercentageToPersonContainers.ContainsKey(sortingContainer.Sorting.NormalizedPixelPercentage))
|
personContainers = Array.Empty<PersonContainer>();
|
||||||
throw new NotSupportedException();
|
if (normalizedPixelPercentageCollectionForA.Contains(sortingContainer.Mapping.MappingFromLocation.NormalizedPixelPercentage))
|
||||||
if (!idToNormalizedPixelPercentageCollection.ContainsKey(sortingContainer.Mapping.MappingFromItem.Id))
|
|
||||||
idToNormalizedPixelPercentageCollection.Add(sortingContainer.Mapping.MappingFromItem.Id, new());
|
|
||||||
normalizedPixelPercentageCollection = idToNormalizedPixelPercentageCollection[sortingContainer.Mapping.MappingFromItem.Id];
|
|
||||||
if (normalizedPixelPercentageCollection.Contains(sortingContainer.Mapping.MappingFromLocation.NormalizedPixelPercentage))
|
|
||||||
continue;
|
continue;
|
||||||
|
key = string.Concat(sortingContainer.Mapping.MappingFromItem.Id, '\t', sortingContainer.Mapping.MappingFromLocation.NormalizedPixelPercentage);
|
||||||
|
if (!checkKeyValuePairs.ContainsKey(key))
|
||||||
|
checkKeyValuePairs.Add(key, new());
|
||||||
|
checkKeyValuePairs[key]++;
|
||||||
|
if (checkKeyValuePairs[key] > _Configuration.SortingMaximumPerKey)
|
||||||
|
continue;
|
||||||
|
sortingContainer.Mapping.UpdateMappingFromUnknownPerson(by, sortingContainer);
|
||||||
|
normalizedPixelPercentageCollectionForA.Add(sortingContainer.Mapping.MappingFromLocation.NormalizedPixelPercentage);
|
||||||
|
result += 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (normalizedPixelPercentageCollectionForB.Contains(sortingContainer.Mapping.MappingFromLocation.NormalizedPixelPercentage))
|
||||||
|
continue;
|
||||||
|
if (!normalizedPixelPercentageToPersonContainers.ContainsKey(sortingContainer.Sorting.NormalizedPixelPercentage))
|
||||||
|
personContainers = Array.Empty<PersonContainer>();
|
||||||
|
else
|
||||||
personContainers = normalizedPixelPercentageToPersonContainers[sortingContainer.Sorting.NormalizedPixelPercentage];
|
personContainers = normalizedPixelPercentageToPersonContainers[sortingContainer.Sorting.NormalizedPixelPercentage];
|
||||||
foreach (PersonContainer personContainer in personContainers)
|
foreach (PersonContainer personContainer in personContainers)
|
||||||
{
|
{
|
||||||
@ -359,71 +564,16 @@ public class MapLogic
|
|||||||
checkKeyValuePairs[key]++;
|
checkKeyValuePairs[key]++;
|
||||||
if (checkKeyValuePairs[key] > _Configuration.SortingMaximumPerKey)
|
if (checkKeyValuePairs[key] > _Configuration.SortingMaximumPerKey)
|
||||||
continue;
|
continue;
|
||||||
normalizedPixelPercentageCollection.Add(sortingContainer.Mapping.MappingFromLocation.NormalizedPixelPercentage);
|
sortingContainer.Mapping.UpdateMappingFromPerson(personContainer.ApproximateYears, by, personContainer.DisplayDirectoryName, personBirthday, mappingSegmentB, sortingContainer);
|
||||||
sortingContainer.Mapping.UpdateMappingFromPerson(personContainer.ApproximateYears, by, personContainer.DisplayDirectoryName, personBirthday, mappingSegmentB);
|
normalizedPixelPercentageCollectionForB.Add(sortingContainer.Mapping.MappingFromLocation.NormalizedPixelPercentage);
|
||||||
sortingContainer.Mapping.SetSortingContainer(sortingContainer);
|
|
||||||
result += 1;
|
result += 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void ForceSingleImage(Mapping[] mappingCollection)
|
|
||||||
{
|
|
||||||
if (_Configuration is null)
|
|
||||||
throw new NullReferenceException(nameof(_Configuration));
|
|
||||||
const int zero = 0;
|
|
||||||
string mappingSegmentB;
|
|
||||||
PersonBirthday personBirthday;
|
|
||||||
List<int>? normalizedPixelPercentages;
|
|
||||||
int by = Stateless.IMapLogic.ForceSingleImage;
|
|
||||||
string displayDirectoryName = _Configuration.MappingDefaultName;
|
|
||||||
Mapping[] mappingCollectionOrderedConfidence = (from l in mappingCollection orderby l.MappingFromLocation.Confidence descending select l).ToArray();
|
|
||||||
foreach (Mapping mapping in mappingCollectionOrderedConfidence)
|
|
||||||
{
|
|
||||||
if (mapping.MappingFromPerson.PersonBirthday is not null)
|
|
||||||
continue;
|
|
||||||
if (_SkipCollection.TryGetValue(mapping.MappingFromItem.Id, out normalizedPixelPercentages))
|
|
||||||
{
|
|
||||||
if (normalizedPixelPercentages.Contains(mapping.MappingFromLocation.NormalizedPixelPercentage))
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
foreach (PersonContainer personContainer in _NotMappedPersonContainers)
|
|
||||||
{
|
|
||||||
if (personContainer.Key is null || personContainer.Birthdays is null || !personContainer.Birthdays.Any())
|
|
||||||
continue;
|
|
||||||
personBirthday = personContainer.Birthdays[zero];
|
|
||||||
mappingSegmentB = Stateless.MapLogic.GetMappingSegmentB(_Ticks, personBirthday, personContainer.ApproximateYears, mapping.MappingFromItem);
|
|
||||||
mapping.UpdateMappingFromPerson(personContainer.ApproximateYears, by, personContainer.DisplayDirectoryName, personBirthday, mappingSegmentB);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void ForceSingleImageThenSaveSorting(string dFacesContentDirectory, string d2FacePartsContentDirectory, Mapping[] mappingCollection, Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping, SortingContainer[] sortingContainers, int? useFiltersCounter, int totalNotMapped)
|
|
||||||
{
|
|
||||||
if (_Configuration is null)
|
|
||||||
throw new NullReferenceException(nameof(_Configuration));
|
|
||||||
int updated;
|
|
||||||
List<SaveContainer> saveContainers;
|
|
||||||
if (!sortingContainers.Any())
|
|
||||||
{
|
|
||||||
updated = 0;
|
|
||||||
ForceSingleImage(mappingCollection);
|
|
||||||
saveContainers = Stateless.MapLogic.GetSaveContainers(_Configuration, _EDistanceContentTicksDirectory, dFacesContentDirectory, d2FacePartsContentDirectory, mappingCollection, idToNormalizedPixelPercentageToMapping, useFiltersCounter, saveMapped: false);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
updated = UpdateFromSortingContainers(sortingContainers);
|
|
||||||
if (useFiltersCounter is null && totalNotMapped - updated > 0)
|
|
||||||
ForceSingleImage(mappingCollection);
|
|
||||||
saveContainers = Stateless.MapLogic.GetSaveContainers(_Configuration, _EDistanceContentTicksDirectory, dFacesContentDirectory, d2FacePartsContentDirectory, mappingCollection, idToNormalizedPixelPercentageToMapping, useFiltersCounter, saveMapped: false);
|
|
||||||
}
|
|
||||||
SaveContainers(totalNotMapped, updated, saveContainers);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void CopyManualFiles(string dFacesContentDirectory, Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping)
|
public void CopyManualFiles(string dFacesContentDirectory, Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping)
|
||||||
{
|
{
|
||||||
if (_Configuration is null)
|
if (_Configuration is null)
|
||||||
@ -447,10 +597,10 @@ public class MapLogic
|
|||||||
string? personDisplayDirectory;
|
string? personDisplayDirectory;
|
||||||
int? normalizedPixelPercentage;
|
int? normalizedPixelPercentage;
|
||||||
WindowsShortcut windowsShortcut;
|
WindowsShortcut windowsShortcut;
|
||||||
|
string by = nameof(IMapLogic.ManualCopy);
|
||||||
Dictionary<int, PersonContainer[]>? keyValuePairs;
|
Dictionary<int, PersonContainer[]>? keyValuePairs;
|
||||||
string by = nameof(Stateless.IMapLogic.ManualCopy);
|
|
||||||
Dictionary<int, Mapping>? normalizedPixelPercentageToMapping;
|
Dictionary<int, Mapping>? normalizedPixelPercentageToMapping;
|
||||||
string successfull = $"_ {nameof(Stateless.IMapLogic.ManualCopy).Humanize(LetterCasing.Title)} Successfull";
|
string successfull = $"_ {nameof(IMapLogic.ManualCopy).Humanize(LetterCasing.Title)} Successfull";
|
||||||
foreach (KeyValuePair<long, PersonContainer> keyValuePair in _PersonKeyToPersonContainer)
|
foreach (KeyValuePair<long, PersonContainer> keyValuePair in _PersonKeyToPersonContainer)
|
||||||
{
|
{
|
||||||
if (keyValuePair.Value.Key is null || keyValuePair.Value.Birthdays is null || !keyValuePair.Value.Birthdays.Any())
|
if (keyValuePair.Value.Key is null || keyValuePair.Value.Birthdays is null || !keyValuePair.Value.Birthdays.Any())
|
||||||
@ -529,7 +679,7 @@ public class MapLogic
|
|||||||
SaveContainer saveContainer;
|
SaveContainer saveContainer;
|
||||||
PersonBirthday personBirthday;
|
PersonBirthday personBirthday;
|
||||||
List<SaveContainer> saveContainers = new();
|
List<SaveContainer> saveContainers = new();
|
||||||
const string facePopulatedKey = nameof(Stateless.IMapLogic.Sorting);
|
const string facePopulatedKey = nameof(IMapLogic.Sorting);
|
||||||
foreach (PersonContainer personContainer in _NotMappedPersonContainers)
|
foreach (PersonContainer personContainer in _NotMappedPersonContainers)
|
||||||
{
|
{
|
||||||
if (personContainer.Key is null || personContainer.Birthdays is null || !personContainer.Birthdays.Any())
|
if (personContainer.Key is null || personContainer.Birthdays is null || !personContainer.Birthdays.Any())
|
||||||
|
@ -654,111 +654,18 @@ internal abstract class MapLogic
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static SaveContainer GetSaveContainer(string directory, SortingContainer sortingContainer, Mapping mapping)
|
internal static SaveContainer GetDebugSaveContainer(string directory, SortingContainer sortingContainer, Mapping mapping)
|
||||||
{
|
{
|
||||||
SaveContainer result;
|
SaveContainer result;
|
||||||
string checkFile = string.Empty;
|
string checkFile = string.Empty;
|
||||||
FileHolder? faceFileHolder = null;
|
FileHolder? faceFileHolder = null;
|
||||||
FileHolder? facePartsFileHolder = null;
|
FileHolder? facePartsFileHolder = null;
|
||||||
FileHolder? hiddenFaceFileHolder = null;
|
FileHolder? hiddenFaceFileHolder = null;
|
||||||
string shortcutFile = Path.Combine(directory, $"{sortingContainer.Mapping.MappingFromLocation.DeterministicHashCodeKey}{sortingContainer.Mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}.lnk");
|
string shortcutFile = Path.Combine(directory, $"{sortingContainer.Mapping.MappingFromLocation.DeterministicHashCodeKey}{sortingContainer.Mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}.debug.lnk");
|
||||||
result = new(checkFile, directory, faceFileHolder, hiddenFaceFileHolder, facePartsFileHolder, mapping.MappingFromItem.ResizedFileHolder, shortcutFile);
|
result = new(checkFile, directory, faceFileHolder, hiddenFaceFileHolder, facePartsFileHolder, mapping.MappingFromItem.ResizedFileHolder, shortcutFile);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static List<SaveContainer> GetSaveContainers(Configuration configuration, string eDistanceContentTicksDirectory, string dFacesContentDirectory, string d2FacePartsContentDirectory, Mapping[] mappingCollection, Dictionary<int, Dictionary<int, Mapping>> idToNormalizedPixelPercentageToMapping, int? useFiltersCounter, bool saveMapped)
|
|
||||||
{
|
|
||||||
List<SaveContainer> results = new();
|
|
||||||
string by;
|
|
||||||
string checkFile;
|
|
||||||
bool isByMapping;
|
|
||||||
bool isBySorting;
|
|
||||||
string directory;
|
|
||||||
string shortcutFile;
|
|
||||||
string facesDirectory;
|
|
||||||
string? directoryName;
|
|
||||||
string personDirectory;
|
|
||||||
FileHolder faceFileHolder;
|
|
||||||
string facePartsDirectory;
|
|
||||||
string personKeyFormatted;
|
|
||||||
SaveContainer saveContainer;
|
|
||||||
FileHolder facePartsFileHolder;
|
|
||||||
FileHolder hiddenFaceFileHolder;
|
|
||||||
Dictionary<int, Mapping>? normalizedPixelPercentageToMapping;
|
|
||||||
string forceSingleImageHumanized = nameof(IMapLogic.ForceSingleImage).Humanize(LetterCasing.Title);
|
|
||||||
foreach (Mapping mapping in mappingCollection)
|
|
||||||
{
|
|
||||||
directoryName = Path.GetDirectoryName(mapping.MappingFromItem.RelativePath);
|
|
||||||
if (directoryName is null)
|
|
||||||
throw new NotSupportedException();
|
|
||||||
if (mapping.MappingFromPerson.PersonBirthday is null)
|
|
||||||
continue;
|
|
||||||
if (string.IsNullOrEmpty(mapping.MappingFromPerson.SegmentB))
|
|
||||||
throw new NotSupportedException();
|
|
||||||
if (mapping.MappingFromPerson.By is null)
|
|
||||||
{
|
|
||||||
isByMapping = false;
|
|
||||||
isBySorting = false;
|
|
||||||
by = $"{nameof(IMapLogic.Mapping)}Null";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
isByMapping = mapping.MappingFromPerson.By == IMapLogic.Mapping;
|
|
||||||
isBySorting = mapping.MappingFromPerson.By == IMapLogic.Sorting;
|
|
||||||
if (isByMapping && !saveMapped)
|
|
||||||
continue;
|
|
||||||
if (isBySorting && useFiltersCounter.HasValue)
|
|
||||||
by = $"{nameof(IMapLogic.Sorting)} Modified Filters - {useFiltersCounter.Value}";
|
|
||||||
else
|
|
||||||
{
|
|
||||||
by = mapping.MappingFromPerson.By.Value switch
|
|
||||||
{
|
|
||||||
IMapLogic.Mapping => nameof(IMapLogic.Mapping),
|
|
||||||
IMapLogic.Sorting => nameof(IMapLogic.Sorting),
|
|
||||||
IMapLogic.ForceSingleImage => forceSingleImageHumanized,
|
|
||||||
_ => throw new NotImplementedException()
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
personKeyFormatted = IPersonBirthday.GetFormatted(configuration.PersonBirthdayFormat, mapping.MappingFromPerson.PersonBirthday);
|
|
||||||
directory = Path.Combine(eDistanceContentTicksDirectory, by, personKeyFormatted, mapping.MappingFromPerson.SegmentB);
|
|
||||||
if (isByMapping)
|
|
||||||
personDirectory = Path.Combine(directory, mapping.MappingFromPerson.DisplayDirectoryName);
|
|
||||||
else if (mapping.MappingFromPerson.By is not null)
|
|
||||||
personDirectory = Path.Combine(directory, mapping.MappingFromPerson.DisplayDirectoryName, "lnk");
|
|
||||||
else
|
|
||||||
personDirectory = Path.Combine(directory, mapping.MappingFromPerson.DisplayDirectoryName[..1], "lnk");
|
|
||||||
saveContainer = new(personDirectory);
|
|
||||||
results.Add(saveContainer);
|
|
||||||
facesDirectory = Path.Combine($"{dFacesContentDirectory}{directoryName}", mapping.MappingFromItem.ImageFileHolder.NameWithoutExtension);
|
|
||||||
faceFileHolder = new(Path.Combine(facesDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{configuration.FacesFileNameExtension}"));
|
|
||||||
if (isByMapping)
|
|
||||||
{
|
|
||||||
checkFile = Path.Combine(personDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}");
|
|
||||||
saveContainer = new(checkFile, directory, faceFileHolder);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
facePartsDirectory = Path.Combine($"{d2FacePartsContentDirectory}{directoryName}", mapping.MappingFromItem.ImageFileHolder.NameWithoutExtension);
|
|
||||||
checkFile = Path.Combine(directory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}");
|
|
||||||
shortcutFile = Path.Combine(personDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}.lnk");
|
|
||||||
hiddenFaceFileHolder = new(Path.Combine(facesDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{configuration.FacesHiddenFileNameExtension}"));
|
|
||||||
facePartsFileHolder = new(Path.Combine(facePartsDirectory, $"{mapping.MappingFromLocation.DeterministicHashCodeKey}{mapping.MappingFromItem.ImageFileHolder.ExtensionLowered}{configuration.FacePartsFileNameExtension}"));
|
|
||||||
saveContainer = new(checkFile, directory, faceFileHolder, hiddenFaceFileHolder, facePartsFileHolder, mapping.MappingFromItem.ResizedFileHolder, shortcutFile);
|
|
||||||
}
|
|
||||||
results.Add(saveContainer);
|
|
||||||
if (!isBySorting || mapping.SortingContainer is null)
|
|
||||||
continue;
|
|
||||||
if (!idToNormalizedPixelPercentageToMapping.TryGetValue(mapping.SortingContainer.Sorting.Id, out normalizedPixelPercentageToMapping))
|
|
||||||
continue;
|
|
||||||
if (!normalizedPixelPercentageToMapping.ContainsKey(mapping.SortingContainer.Sorting.NormalizedPixelPercentage))
|
|
||||||
continue;
|
|
||||||
saveContainer = GetSaveContainer(directory, mapping.SortingContainer, normalizedPixelPercentageToMapping[mapping.SortingContainer.Sorting.NormalizedPixelPercentage]);
|
|
||||||
results.Add(saveContainer);
|
|
||||||
}
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static IEnumerable<(string, string)> GetCollection(string[] yearDirectories)
|
private static IEnumerable<(string, string)> GetCollection(string[] yearDirectories)
|
||||||
{
|
{
|
||||||
foreach (string l in yearDirectories)
|
foreach (string l in yearDirectories)
|
||||||
|
@ -20,7 +20,6 @@ public class C_Resize
|
|||||||
protected readonly string _FileNameExtension;
|
protected readonly string _FileNameExtension;
|
||||||
public string FileNameExtension => _FileNameExtension;
|
public string FileNameExtension => _FileNameExtension;
|
||||||
|
|
||||||
private readonly Serilog.ILogger? _Log;
|
|
||||||
private readonly int _TempResolutionWidth;
|
private readonly int _TempResolutionWidth;
|
||||||
private readonly int _TempResolutionHeight;
|
private readonly int _TempResolutionHeight;
|
||||||
private readonly string[] _ValidResolutions;
|
private readonly string[] _ValidResolutions;
|
||||||
@ -48,7 +47,6 @@ public class C_Resize
|
|||||||
_OutputResolutionOrientationIndex = 2;
|
_OutputResolutionOrientationIndex = 2;
|
||||||
_EncoderParameters = encoderParameters;
|
_EncoderParameters = encoderParameters;
|
||||||
_FileNameExtension = filenameExtension;
|
_FileNameExtension = filenameExtension;
|
||||||
_Log = Serilog.Log.ForContext<C_Resize>();
|
|
||||||
AngleBracketCollection = new List<string>();
|
AngleBracketCollection = new List<string>();
|
||||||
_OverrideForResizeImages = overrideForResizeImages;
|
_OverrideForResizeImages = overrideForResizeImages;
|
||||||
_PropertiesChangedForResize = propertiesChangedForResize;
|
_PropertiesChangedForResize = propertiesChangedForResize;
|
||||||
@ -384,8 +382,6 @@ public class C_Resize
|
|||||||
|
|
||||||
private int[] GetCollection(string outputResolution)
|
private int[] GetCollection(string outputResolution)
|
||||||
{
|
{
|
||||||
if (_Log is null)
|
|
||||||
{ }
|
|
||||||
List<int> results = new();
|
List<int> results = new();
|
||||||
string[] segments = outputResolution.Split('x');
|
string[] segments = outputResolution.Split('x');
|
||||||
results.Add(int.Parse(segments[0]));
|
results.Add(int.Parse(segments[0]));
|
||||||
|
@ -61,16 +61,14 @@ public class MappingFromPerson : Properties.IMappingFromPerson
|
|||||||
{
|
{
|
||||||
|
|
||||||
public int? ApproximateYears { init; get; }
|
public int? ApproximateYears { init; get; }
|
||||||
public int? By { init; get; }
|
|
||||||
public string DisplayDirectoryName { init; get; }
|
public string DisplayDirectoryName { init; get; }
|
||||||
public PersonBirthday? PersonBirthday { init; get; }
|
public PersonBirthday PersonBirthday { init; get; }
|
||||||
public string SegmentB { init; get; }
|
public string SegmentB { init; get; }
|
||||||
|
|
||||||
[JsonConstructor]
|
[JsonConstructor]
|
||||||
public MappingFromPerson(int? approximateYears, int? by, string displayDirectoryName, PersonBirthday? personBirthday, string segmentB)
|
public MappingFromPerson(int? approximateYears, string displayDirectoryName, PersonBirthday personBirthday, string segmentB)
|
||||||
{
|
{
|
||||||
ApproximateYears = approximateYears;
|
ApproximateYears = approximateYears;
|
||||||
By = by;
|
|
||||||
DisplayDirectoryName = displayDirectoryName;
|
DisplayDirectoryName = displayDirectoryName;
|
||||||
PersonBirthday = personBirthday;
|
PersonBirthday = personBirthday;
|
||||||
SegmentB = segmentB;
|
SegmentB = segmentB;
|
||||||
@ -87,24 +85,27 @@ public class MappingFromPerson : Properties.IMappingFromPerson
|
|||||||
public class Mapping : Properties.IMapping
|
public class Mapping : Properties.IMapping
|
||||||
{
|
{
|
||||||
|
|
||||||
protected MappingFromPerson _MappingFromPerson;
|
protected int? _By;
|
||||||
|
protected MappingFromPerson? _MappingFromPerson;
|
||||||
protected SortingContainer? _SortingContainer;
|
protected SortingContainer? _SortingContainer;
|
||||||
|
public int? By => _By;
|
||||||
public MappingFromItem MappingFromItem { init; get; }
|
public MappingFromItem MappingFromItem { init; get; }
|
||||||
public MappingFromLocation MappingFromLocation { init; get; }
|
public MappingFromLocation MappingFromLocation { init; get; }
|
||||||
public MappingFromPerson MappingFromPerson => _MappingFromPerson;
|
public MappingFromPerson? MappingFromPerson => _MappingFromPerson;
|
||||||
public SortingContainer? SortingContainer => _SortingContainer;
|
public SortingContainer? SortingContainer => _SortingContainer;
|
||||||
|
|
||||||
[JsonConstructor]
|
[JsonConstructor]
|
||||||
public Mapping(MappingFromItem mappingFromItem, MappingFromLocation mappingFromLocation, MappingFromPerson mappingFromPerson, SortingContainer? sortingContainer)
|
public Mapping(int? by, MappingFromItem mappingFromItem, MappingFromLocation mappingFromLocation, MappingFromPerson? mappingFromPerson, SortingContainer? sortingContainer)
|
||||||
{
|
{
|
||||||
|
_By = by;
|
||||||
MappingFromItem = mappingFromItem;
|
MappingFromItem = mappingFromItem;
|
||||||
MappingFromLocation = mappingFromLocation;
|
MappingFromLocation = mappingFromLocation;
|
||||||
_MappingFromPerson = mappingFromPerson;
|
_MappingFromPerson = mappingFromPerson;
|
||||||
_SortingContainer = sortingContainer;
|
_SortingContainer = sortingContainer;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Mapping(MappingFromItem mappingFromItem, MappingFromLocation mappingFromLocation, MappingFromPerson mappingFromPerson) :
|
public Mapping(MappingFromItem mappingFromItem, MappingFromLocation mappingFromLocation) :
|
||||||
this(mappingFromItem, mappingFromLocation, mappingFromPerson, null)
|
this(null, mappingFromItem, mappingFromLocation, null, null)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
@ -113,8 +114,24 @@ public class Mapping : Properties.IMapping
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void UpdateMappingFromPerson(int? approximateYears, int? by, string displayDirectoryName, PersonBirthday personBirthday, string segmentB) => _MappingFromPerson = new(approximateYears, by, displayDirectoryName, personBirthday, segmentB);
|
public void UpdateMappingFromUnknownPerson(int? by, SortingContainer sortingContainer)
|
||||||
|
{
|
||||||
|
_By = by;
|
||||||
|
_SortingContainer = sortingContainer;
|
||||||
|
}
|
||||||
|
|
||||||
public void SetSortingContainer(SortingContainer sortingContainer) => _SortingContainer = sortingContainer;
|
public void UpdateMappingFromPerson(int? approximateYears, int? by, string displayDirectoryName, PersonBirthday personBirthday, string segmentB)
|
||||||
|
{
|
||||||
|
_By = by;
|
||||||
|
_SortingContainer = null;
|
||||||
|
_MappingFromPerson = new(approximateYears, displayDirectoryName, personBirthday, segmentB);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void UpdateMappingFromPerson(int? approximateYears, int? by, string displayDirectoryName, PersonBirthday personBirthday, string segmentB, SortingContainer sortingContainer)
|
||||||
|
{
|
||||||
|
_By = by;
|
||||||
|
_SortingContainer = sortingContainer;
|
||||||
|
_MappingFromPerson = new(approximateYears, displayDirectoryName, personBirthday, segmentB);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -26,9 +26,8 @@ public interface IMappingFromPerson
|
|||||||
{
|
{
|
||||||
|
|
||||||
public int? ApproximateYears { init; get; }
|
public int? ApproximateYears { init; get; }
|
||||||
public int? By { init; get; }
|
|
||||||
public string DisplayDirectoryName { init; get; }
|
public string DisplayDirectoryName { init; get; }
|
||||||
public PersonBirthday? PersonBirthday { init; get; }
|
public PersonBirthday PersonBirthday { init; get; }
|
||||||
public string SegmentB { init; get; }
|
public string SegmentB { init; get; }
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -36,9 +35,10 @@ public interface IMappingFromPerson
|
|||||||
public interface IMapping
|
public interface IMapping
|
||||||
{
|
{
|
||||||
|
|
||||||
|
public int? By { get; }
|
||||||
public MappingFromItem MappingFromItem { init; get; }
|
public MappingFromItem MappingFromItem { init; get; }
|
||||||
public MappingFromLocation MappingFromLocation { init; get; }
|
public MappingFromLocation MappingFromLocation { init; get; }
|
||||||
public MappingFromPerson MappingFromPerson { get; }
|
public MappingFromPerson? MappingFromPerson { get; }
|
||||||
public SortingContainer? SortingContainer { get; }
|
public SortingContainer? SortingContainer { get; }
|
||||||
|
|
||||||
}
|
}
|
@ -18,6 +18,10 @@ internal abstract class Sorting
|
|||||||
bool older = timeSpan.TotalMilliseconds < 0;
|
bool older = timeSpan.TotalMilliseconds < 0;
|
||||||
int daysDelta = (int)Math.Round(Math.Abs(timeSpan.TotalDays), 0);
|
int daysDelta = (int)Math.Round(Math.Abs(timeSpan.TotalDays), 0);
|
||||||
int distancePermyriad = (int)(faceDistanceLength.Length.Value / faceDistanceTolerance * faceDistancePermyriad);
|
int distancePermyriad = (int)(faceDistanceLength.Length.Value / faceDistanceTolerance * faceDistancePermyriad);
|
||||||
|
if (!personKeysRangesCollection.Any())
|
||||||
|
withinRanges.Add(0);
|
||||||
|
else
|
||||||
|
{
|
||||||
foreach ((long lcl, long minimum, long maximum, long ucl) in personKeysRangesCollection)
|
foreach ((long lcl, long minimum, long maximum, long ucl) in personKeysRangesCollection)
|
||||||
{
|
{
|
||||||
if (ticks > minimum && ticks < maximum)
|
if (ticks > minimum && ticks < maximum)
|
||||||
@ -27,6 +31,7 @@ internal abstract class Sorting
|
|||||||
else
|
else
|
||||||
withinRanges.Add(2);
|
withinRanges.Add(2);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
int withinRange = withinRanges.Max();
|
int withinRange = withinRanges.Max();
|
||||||
result = new(daysDelta, distancePermyriad, faceDistanceLength.Id, faceDistanceLength.NormalizedPixelPercentage.Value, older, withinRange);
|
result = new(daysDelta, distancePermyriad, faceDistanceLength.Id, faceDistanceLength.NormalizedPixelPercentage.Value, older, withinRange);
|
||||||
return result;
|
return result;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user