File size: 3,249 Bytes
ccf71be
a73a1f6
02fde7e
638f1e4
02fde7e
 
 
456def3
ccf71be
7b5dbb4
ccf71be
 
 
 
a73a1f6
02fde7e
 
 
 
ed8db1b
 
 
 
 
 
02fde7e
 
ed8db1b
 
 
 
 
 
a73a1f6
ed8db1b
 
 
 
 
 
 
 
 
 
a73a1f6
ed8db1b
 
 
 
 
02fde7e
 
 
 
ed8db1b
 
02fde7e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
456def3
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
75
76
---
title: LogMetric
datasets:
- None
tags:
- evaluate
- metric
description: 'TODO: add a description here'
sdk: gradio
sdk_version: 3.19.1
app_file: app.py
pinned: false
---

# Metric Card for LogMetric

***Module Card Instructions:*** *Fill out the following subsections. Feel free to take a look at existing metric cards if you'd like examples.*

## Metric Description
This metric is used for evaluating how good a generated log(file) is, given a reference. 

The metric measures two different aspects

1. It evaluates if the predicted log has the correct amount of timestamps, if timestamps are monotonically increasing and if the timestamps are consistent in their format.
2. For measuring the similarity in content (without timestamps), this metric uses sacrebleu.

## How to Use
The metric can be just by simply giving the predicted log and the reference log as string.

Example with timestamps that are of correct amount, consistent, monotonically increasing (-> timestamp score of 1.0):
```
>>> predictions = ["2024-01-12 11:23 hello, nice to meet you \n 2024-01-12 11:24 So we see each other again"]
>>> references = ["2024-02-14 This is a hello to you \n 2024-02-15 Another hello"]
logmetric = evaluate.load("svenwey/logmetric")
>>> results = logmetric.compute(predictions=predictions, 
...                             references=references)
>>> print(results["timestamp_score"])
1.0
```

Example with timestamp missing from prediction:
```
>>> predictions = ["hello, nice to meet you"]
>>> references = ["2024-02-14 This is a hello to you"]
logmetric = evaluate.load("svenwey/logmetric")
>>> results = logmetric.compute(predictions=predictions, 
...                             references=references)
>>> print(results["timestamp_score"])
0.0
```


### Inputs
*List all input arguments in the format below*
- **predictions** *(string list): The logs, as predicted/generated by the ML model. **Important: Every logfile is only one string, even if it contains multiple lines!***
- **references** *(string list): The reference logs (ground truth)*
### Output Values

*Explain what this metric outputs and provide an example of what the metric output looks like. Modules should return a dictionary with one or multiple key-value pairs, e.g. {"bleu" : 6.02}*

*State the range of possible values that the metric's output can take, as well as what in that range is considered good. For example: "This metric can take on any value between 0 and 100, inclusive. Higher scores are better."*

#### Values from Popular Papers
*Give examples, preferrably with links to leaderboards or publications, to papers that have reported this metric, along with the values they have reported.*

### Examples
*Give code examples of the metric being used. Try to include examples that clear up any potential ambiguity left from the metric description above. If possible, provide a range of examples that show both typical and atypical results, as well as examples where a variety of input parameters are passed.*

## Limitations and Bias
*Note any known limitations or biases that the metric has, with links and references if possible.*

## Citation
*Cite the source where this metric was introduced.*

## Further References
*Add any useful further references.*