本文整理汇总了C#中System.Signature.ToTimeSpan方法的典型用法代码示例。如果您正苦于以下问题:C# Signature.ToTimeSpan方法的具体用法?C# Signature.ToTimeSpan怎么用?C# Signature.ToTimeSpan使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Signature
的用法示例。
在下文中一共展示了Signature.ToTimeSpan方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: CompareParallel
/// <summary>
/// Comparing
/// </summary>
async Task<Congruence[]> CompareParallel(Signature mainSign, Signature[] signs)
{
if (mainSigns == null || signs == null || signs.Length == 0) return null;
IEnumerable<Congruence> ret = null;
object retLock = new object();
Log(String.Format("Parallel compare. Delta is Sigma * {0:0.00}", NSigm));
Recognition.Initialize();
Stopwatch sw = new Stopwatch();
sw.Start();
int k = 1, n = signs.Length;
await Task.Factory.StartNew(() =>
{
Parallel.For(0, signs.Length, delegate(int i)
{
if(signs[i].FreqRate != mainSign.FreqRate)
{
Log(String.Format("Error: \"{0}\" is uncomparable with \"{1}\"",
signs[i].ToString(), mainSign.ToString()));
return;
}
else if (signs[i].BaseFileInfo.SampleRate != mainSign.BaseFileInfo.SampleRate)
{
Log("Warning: basic rates is not equal:");
Log(String.Format("{0} [{1} Hz] : {2} [{3} Hz]",
mainSign.ToString(), mainSign.BaseFileInfo.SampleRate,
signs[i].ToString(), signs[i].BaseFileInfo.SampleRate));
}
// Сравнение
Congruence[] cong = mainSign.CompareTo(signs[i], NSigm);
#region Вывод
StringBuilder sb = new StringBuilder();
sb.AppendFormat("[{0}/{1}]:\t{2} {3}", k++, n, signs[i].ToString(), Environment.NewLine);
if (cong == null)
{
sb.Append("\t\t[NULL]");
lock (logLock) Log(sb.ToString());
return;
}
for (int j = 0; j < cong.Length - 1; j++)
{
sb.AppendFormat("\t\t{0:T}; sigms: {1:0.00} {2}",
mainSign.ToTimeSpan(cong[j].Coord), cong[j].SignSigma, Environment.NewLine);
}
sb.AppendFormat("\t\t{0:T}; sigms: {1:0.00}",
mainSign.ToTimeSpan(cong[cong.Length - 1].Coord), cong[cong.Length - 1].SignSigma);
lock (logLock) Log(sb.ToString());
#endregion
lock (retLock)
{
if (ret == null) ret = cong.AsEnumerable();
else ret = ret.Concat(cong);
}
});
});
sw.Stop();
Log("Elapsed: " + sw.Elapsed + Environment.NewLine + "Compare complete.");
return ret == null ? null : ret.ToArray();
}
示例2: ShowSignInfo
/// <summary>
/// Set new sign info on dataSignInfo
/// </summary>
private void ShowSignInfo(Signature sign)
{
dataSignInfo.Rows.Clear();
dataSignInfo.Rows.Add("Файл", sign.ToString());
dataSignInfo.Rows.Add("Сигнатур в секунду", sign.FreqRate);
dataSignInfo.Rows.Add("Частота источника", sign.BaseFileInfo.SampleRate);
dataSignInfo.Rows.Add("Оконная функция", sign.WindowFunction.ToString());
dataSignInfo.Rows.Add("Длительность", sign.ToTimeSpan().ToString());
}