public BenchmarkResults Execute() { var onlineSigners = OnlineLoader.EnumerateSigners().ToList(); Parallel.ForEach(onlineSigners, onSigner => { try { Console.WriteLine(onSigner.ID + " started at " + DateTime.Now.ToString("h:mm:ss tt")); Parallel.ForEach(onSigner.Signatures, onSig => OnlinePipeline.Transform(onSig)); } catch (Exception e) { Console.WriteLine(e.ToString()); } } ); var benchmark = FusionPipelines.GetBenchmark(onlineSigners, IsOptimal); return(benchmark.Execute()); }
public FusionBenchmarkResults Execute() { var offlineSigners = OfflineLoader.EnumerateSigners().ToList(); var onlineSigners = OnlineLoader.EnumerateSigners().ToList(); Console.WriteLine(offlineSigners.Count); Console.WriteLine(onlineSigners.Count); Console.WriteLine(offlineSigners[0].Signatures.Count); Console.WriteLine(onlineSigners[0].Signatures.Count); var offOnSigners = new List <Signer>(); var onOffSigners = new List <Signer>(); var fusionPipeline = FinalFusionPipelines.GetFusionPipeline(offlineSigners, true, InputBaseSigInputCntID); foreach (var offSigner in offlineSigners) { try { Console.WriteLine(offSigner.ID + " started at " + DateTime.Now.ToString("h:mm:ss tt")); var onSigner = onlineSigners.Find(signer => signer.ID == offSigner.ID); Parallel.ForEach(offSigner.Signatures, offSig => { try { MarosPipeline.Transform(offSig); var onSig = onSigner.Signatures.Find(sig => sig.ID == offSig.ID); onSig.SetFeature <Image <Rgba32> >(FusionFeatures.Image, offSig.GetFeature(FusionFeatures.Image)); var onToOnPipeline = FinalFusionPipelines.GetHackedOnToOnPipeline(offSig.GetFeature(FusionFeatures.Bounds)); onToOnPipeline.Transform(onSig); OnlinePipeline.Transform(onSig); } catch (Exception e) { Console.WriteLine(e.ToString()); } } ); Parallel.ForEach(offSigner.Signatures, offSig => { try { fusionPipeline.Transform(offSig); OnlinePipeline.Transform(offSig); } catch (Exception e) { Console.WriteLine(e.ToString()); } } ); var offonSigner = FusionPipelines.GetMixedSigner(offSigner, onSigner); var onoffSigner = FusionPipelines.GetMixedSigner(onSigner, offSigner); offOnSigners.Add(offonSigner); onOffSigners.Add(onoffSigner); Console.WriteLine(offSigner.ID + " finished at " + DateTime.Now.ToString("h:mm:ss tt")); } catch (Exception e) { Console.WriteLine(e.ToString()); } } var offoffBenchmark = FusionPipelines.GetBenchmark(offlineSigners, IsOptimal); var offonBenchmark = FusionPipelines.GetBenchmark(offOnSigners, IsOptimal); var onoffBenchamrk = FusionPipelines.GetBenchmark(onOffSigners, IsOptimal); var ononBenchmark = FusionPipelines.GetBenchmark(onlineSigners, IsOptimal); return(new FusionBenchmarkResults { OffOffResults = offoffBenchmark.Execute(), OffOnResults = offonBenchmark.Execute(), OnOffResults = onoffBenchamrk.Execute(), OnOnResults = ononBenchmark.Execute() }); }