summaryrefslogtreecommitdiffstats
path: root/Examples/WhisperDesktop/Utils/logger.cpp
blob: 712835b308b64da7b9ae1e7da7e16a14b8edd6ec (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#include "stdafx.h"
#include "logger.h"
#include "miscUtils.h"

namespace
{
	using namespace Whisper;

	// Terminal color map. 10 colors grouped in ranges [0.0, 0.1, ..., 0.9]
	// Lowest is red, middle is yellow, highest is green.
	static const std::array<const char*, 10> k_colors =
	{
		"\033[38;5;196m", "\033[38;5;202m", "\033[38;5;208m", "\033[38;5;214m", "\033[38;5;220m",
		"\033[38;5;226m", "\033[38;5;190m", "\033[38;5;154m", "\033[38;5;118m", "\033[38;5;82m",
	};

	static int colorIndex( const sToken& tok )
	{
		const float p = tok.probability;
		const float p3 = p * p * p;
		int col = (int)( p3 * float( k_colors.size() ) );
		col = std::max( 0, std::min( (int)k_colors.size() - 1, col ) );
		return col;
	}
}

void printTime( CStringA& rdi, Whisper::sTimeSpan time, bool comma )
{
	Whisper::sTimeSpanFields fields = time;
	const uint32_t hours = fields.days * 24 + fields.hours;
	const char separator = comma ? ',' : '.';
	rdi.AppendFormat( "%02d:%02d:%02d%c%03d",
		(int)hours,
		(int)fields.minutes,
		(int)fields.seconds,
		separator,
		fields.ticks / 10'000 );
}

HRESULT logNewSegments( const iTranscribeResult* results, size_t newSegments, bool printSpecial )
{
	sTranscribeLength length;
	CHECK( results->getSize( length ) );

	const size_t len = length.countSegments;
	size_t i = len - newSegments;

	const sSegment* const segments = results->getSegments();
	const sToken* const tokens = results->getTokens();

	CStringA str;
	for( ; i < len; i++ )
	{
		const sSegment& seg = segments[ i ];
		str = "[";
		printTime( str, seg.time.begin );
		str += " --> ";
		printTime( str, seg.time.end );
		str += "]  ";

		for( uint32_t j = 0; j < seg.countTokens; j++ )
		{
			const sToken& tok = tokens[ seg.firstToken + j ];
			if( !printSpecial && ( tok.flags & eTokenFlags::Special ) )
				continue;
			str += k_colors[ colorIndex( tok ) ];
			str += tok.text;
			str += "\033[0m";
		}
		logInfo( u8"%s", cstr( str ) );
	}

	return S_OK;
}