質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

2202閲覧

Pythonを用いたwavelet変換の色を見やすくする方法について

hirohiro1999

総合スコア5

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/11/01 08:31

・わからないこと
Pythonを用いたwavelet変換をしているのですが、出力されるグラフの配色がわかりにくくて困っています。
イメージ説明

上の図のようになってしまいます。
この配色をわかりやすく変える方法を知っている方がいらっしゃいましたら教えていただきたいです。

・参考にしたサイト
リンク内容

・使用しているコード

Python

1import pywt 2# from swan import pycwt 3import numpy as np 4import matplotlib.pyplot as plt 5import wave 6#import struct 7from scipy import fromstring, int16 8from typing import List, Tuple 9import math 10def get_ticks_label_set(all_labels:List, num:int)-> Tuple[List, List]: 11 length = len(all_labels) 12 step = length//(num-1) 13 pick_positions = np.arange(0, length, step) 14 pick_labels = all_labels[::step] 15 return pick_positions, pick_labels 16#from pylab import * 17#from scipy import signal 18wavfile = 'C:\Users\hiro2\Desktop\sound\1_cut4.wav' 19wr = wave.open(wavfile, "rb") 20ch = wr.getnchannels() 21width = wr.getsampwidth() 22fr = wr.getframerate() 23fn = wr.getnframes() 24print("オーディオチャンネル数(モノラル: 1 ステレオ:2 ) : ", ch) 25print("オーディオフレーム数 : ", fn) 26print("サンプリングレート : ",fr) 27print("サンプルサイズ(バイト数) : ", width) 28origin = wr.readframes(fn) 29wr.close() 30# ステレオ前提 > monoral 31y2 = np.frombuffer(origin, dtype="int16") /32768.0 32y=y2[::2] 33x = np.linspace(0,fn/fr, fn, endpoint=False) 34plt.plot(x, y) 35plt.show() 36print("y2",len(y2)) 37print("origin",len(origin)) 38print("x",len(x)) 39print("y",len(y)) 40print(type(y2[0])) 41#縦軸 スケール 横軸 周波数軸(FFTした時) 42time = 10 # s (秒) 43# fs = 32000 # ウェーブレット変換のサンプリング周波数 44fs = 10000 # ウェーブレット変換のサンプリング周波数 45dt = 1/fs # サンプリング間隔(時間) 1/dt = Hz 46t = np.arange(0, time, 1/fr) 47sig = y2[:fr*time] #fr は音声そのもののサンプリング周波数 48wavelet_type = 'cmor1.5-1.0' 49wav = pywt.ContinuousWavelet(wavelet_type) 50# precisionによってデータ個数(len)が変わる 51int_psi, x = pywt.integrate_wavelet(wav, precision=8) 52#print(len(int_psi)) 53plt.plot(x, int_psi) 54plt.show() 55nq_f = fs/2.0 # ナイキスト周波数 56print(dt) 57print(fs) 58print(nq_f) 59# 解析したい周波数のリスト(ナイキスト周波数以下) 60# 1 Hz ~ nq_f Hzの間を等間隔にbunkatu分割 分割は柱の数(100分割したかったらbunkatu=101) 61bunkatu = 101 62freqs = np.linspace(1,nq_f,bunkatu) 63print(len(freqs)) 64# サンプリング周波数に対する比率を算出 65freqs_rate = freqs / fs 66# スケール:サンプリング周波数=1:fs(1/dt)としてスケールに換算 67scales = 1 / freqs_rate 68# 逆順に入れ替え 69scales = scales[::-1] 70#print(scales) 71frequencies_rate = pywt.scale2frequency(scale=scales, wavelet=wavelet_type) 72#print(frequencies_rate) 73# スケール:サンプリング周波数=1:fs(1/dt)として換算 74frequencies = frequencies_rate / dt 75#print(frequencies) 76x_positions, x_labels = get_ticks_label_set(t, num=time*2+1) 77#print(x_positions) 78#print(x_labels) 79y_positions, y_labels = get_ticks_label_set(freqs[::-1], num=11) 80#print(y_positions) 81#print(y_labels) 82n = 0 # 切り捨て桁数 83y_labels = [math.floor(d * 10 ** n) / (10 ** n) for d in y_labels] 84#print(y_labels) 85n = 2 # 切り捨て桁数 86x_labels = [math.floor(d * 10 ** n) / (10 ** n) for d in x_labels] 87#print(x_labels) 88cwtmatr, freqs_rate = pywt.cwt(sig, scales=scales, wavelet=wavelet_type) 89#print(cwtmatr.shape) 90plt.imshow(np.abs(cwtmatr), aspect='auto') 91plt.yticks(y_positions, y_labels) 92plt.xticks(x_positions, x_labels) 93plt.xlabel("Time[s]") 94plt.ylabel("Frequency[Hz]") 95plt.show() 96#print(t)

・追記
10秒の動画を解析しただけで相当重いのでノートパソコンで実行する場合はご注意ください

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

jbpb0

2021/11/01 08:59

plt.imshow(np.abs(cwtmatr), aspect='auto') ↓ 変更 plt.imshow(np.abs(cwtmatr), aspect='auto', cmap=plt.cm.jet, interpolation='nearest') plt.colorbar() で、どうでしょうか?
hirohiro1999

2021/11/02 06:53

できました! ありがとうございます!
guest

回答1

0

ベストアンサー

python

1plt.imshow(np.abs(cwtmatr), aspect='auto')

↓ 変更

python

1plt.imshow(np.abs(cwtmatr), aspect='auto', cmap=plt.cm.jet, interpolation='nearest') 2plt.colorbar()

投稿2021/11/02 07:49

jbpb0

総合スコア7653

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問