Skip to content

Commit

Permalink
Now returns match offset into track in seconds
Browse files Browse the repository at this point in the history
  • Loading branch information
worldveil committed Nov 21, 2014
1 parent 5741964 commit 684902f
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 9 deletions.
11 changes: 3 additions & 8 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -107,19 +107,14 @@ There are two ways to recognize audio using Dejavu. You can use Dejavu interacti
```python
>>> from dejavu.recognize import MicrophoneRecognizer
>>> print djv.recognize(MicrophoneRecognizer, seconds=10) # Defaults to 10 seconds.
{
'song_id': 16,
'song_name': 'Love Somebody - Maroon 5',
'confidence': 21,
'offset' : 867
}
{'song_id': 1, 'song_name': 'Taylor Swift - Shake It Off', 'confidence': 3948, 'offset_seconds': 30.00018, 'match_time': 0.7159781455993652, 'offset': 646L}
```

Or by reading files via scripting functions:

```python
>>> from dejavu.recognize import FileRecognizer
>>> song = djv.recognize(FileRecognizer, "va_us_top_40/wav/07 - Mirrors - Justin Timberlake.wav")
>>> song = djv.recognize(FileRecognizer, "va_us_top_40/wav/Mirrors - Justin Timberlake.wav")
```

Note that the `offset` field of the returned song object tells you about the position in which the song was matched. See [here](https://github.com/worldveil/dejavu/issues/43) for a description of how.
Expand Down Expand Up @@ -169,7 +164,7 @@ python run_tests.py \
./mp3
```

The testing scripts are as of now are a bit rough, and could certainly use some love and attention if you're interested in submitting a PR!
The testing scripts are as of now are a bit rough, and could certainly use some love and attention if you're interested in submitting a PR! For example, underscores in audio filenames currently [breaks](https://github.com/worldveil/dejavu/issues/63) the test scripts.

## How does it work?

Expand Down
7 changes: 6 additions & 1 deletion dejavu/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ class Dejavu(object):
CONFIDENCE = 'confidence'
MATCH_TIME = 'match_time'
OFFSET = 'offset'
OFFSET_SECS = 'offset_seconds'

def __init__(self, config):
super(Dejavu, self).__init__()
Expand Down Expand Up @@ -148,11 +149,15 @@ def align_matches(self, matches):
return None

# return match info
nseconds = round(float(largest) / fingerprint.DEFAULT_FS * \
fingerprint.DEFAULT_WINDOW_SIZE * \
fingerprint.DEFAULT_OVERLAP_RATIO, 5)
song = {
Dejavu.SONG_ID : song_id,
Dejavu.SONG_NAME : songname,
Dejavu.CONFIDENCE : largest_count,
Dejavu.OFFSET : largest }
Dejavu.OFFSET : largest,
Dejavu.OFFSET_SECS : nseconds }

return song

Expand Down

0 comments on commit 684902f

Please sign in to comment.