Spaces:
Running
Running
| import librosa | |
| from scripts.explain import musiclime_multimodal, musiclime_unimodal | |
| def explain_multimodal_runner(sample: str): | |
| # Load test audio and lyrics | |
| audio_path = f"data/external/{sample}.mp3" | |
| lyrics_path = f"data/external/{sample}.txt" | |
| # Load audio | |
| audio_data, sr = librosa.load(audio_path) | |
| # Load lyrics | |
| with open(lyrics_path, "r", encoding="utf-8") as f: | |
| lyrics_text = f.read() | |
| print("Running multimodal MusicLIME explanation...") | |
| result = musiclime_multimodal(audio_data, lyrics_text) | |
| print("\n=== MULTIMODAL EXPLANATION RESULTS ===") | |
| print( | |
| f"Prediction: {result['prediction']['class_name']} ({result['prediction']['confidence']:.3f})" | |
| ) | |
| print(f"Runtime: {result['summary']['runtime_seconds']:.2f}s") | |
| print("\n=== TOP FEATURES (by absolute importance) ===") | |
| for feature in result["explanations"]: | |
| print( | |
| f"Rank {feature['rank']}: {feature['modality']} | Weight: {feature['weight']:.4f} | Importance: {feature['importance']:.4f}" | |
| ) | |
| print(f" Feature: {feature['feature_text'][:80]}...") | |
| print() | |
| def explain_unimodal_runner(sample: str): | |
| # Load test audio | |
| audio_path = f"data/external/{sample}.mp3" | |
| # Load audio | |
| audio_data, sr = librosa.load(audio_path) | |
| print("Running audio-only MusicLIME explanation...") | |
| result = musiclime_unimodal(audio_data, modality="audio") | |
| print("\n=== AUDIO-ONLY EXPLANATION RESULTS ===") | |
| print( | |
| f"Prediction: {result['prediction']['class_name']} ({result['prediction']['confidence']:.3f})" | |
| ) | |
| print(f"Runtime: {result['summary']['runtime_seconds']:.2f}s") | |
| print("\n=== TOP FEATURES (by absolute importance) ===") | |
| for feature in result["explanations"]: | |
| print( | |
| f"Rank {feature['rank']}: {feature['modality']} | Weight: {feature['weight']:.4f} | Importance: {feature['importance']:.4f}" | |
| ) | |
| print(f" Feature: {feature['feature_text'][:80]}...") | |
| print() | |
| if __name__ == "__main__": | |
| sample = "sample" | |
| # Run multimodal explanation | |
| explain_multimodal_runner(sample) | |
| print("\n" + "=" * 60 + "\n") | |
| # Run audio-only explanation | |
| explain_unimodal_runner(sample) | |