asigalov61
commited on
Upload TMIDIX.py
Browse files
TMIDIX.py
CHANGED
@@ -471,19 +471,6 @@ def grep(score=None, channels=None):
|
|
471 |
itrack += 1
|
472 |
return new_score
|
473 |
|
474 |
-
def play_score(score=None):
|
475 |
-
r'''Converts the "score" to midi, and feeds it into 'aplaymidi -'
|
476 |
-
'''
|
477 |
-
if score == None:
|
478 |
-
return
|
479 |
-
import subprocess
|
480 |
-
pipe = subprocess.Popen(['aplaymidi','-'], stdin=subprocess.PIPE)
|
481 |
-
if score_type(score) == 'opus':
|
482 |
-
pipe.stdin.write(opus2midi(score))
|
483 |
-
else:
|
484 |
-
pipe.stdin.write(score2midi(score))
|
485 |
-
pipe.stdin.close()
|
486 |
-
|
487 |
def score2stats(opus_or_score=None):
|
488 |
r'''Returns a dict of some basic stats about the score, like
|
489 |
bank_select (list of tuples (msb,lsb)),
|
@@ -2059,7 +2046,7 @@ def Optimus_MIDI_TXT_Processor(MIDI_file,
|
|
2059 |
|
2060 |
#print('Loading MIDI file...')
|
2061 |
midi_file = open(MIDI_file, 'rb')
|
2062 |
-
if debug: print('Processing File:',
|
2063 |
|
2064 |
try:
|
2065 |
opus = midi2opus(midi_file.read())
|
@@ -5166,8 +5153,9 @@ def advanced_check_and_fix_chords_in_chordified_score(chordified_score,
|
|
5166 |
pitches_index=4,
|
5167 |
patches_index=6,
|
5168 |
use_filtered_chords=False,
|
5169 |
-
use_full_chords=
|
5170 |
remove_duplicate_pitches=True,
|
|
|
5171 |
fix_bad_pitches=False,
|
5172 |
skip_drums=False
|
5173 |
):
|
@@ -5221,22 +5209,64 @@ def advanced_check_and_fix_chords_in_chordified_score(chordified_score,
|
|
5221 |
tones_counts = Counter([p % 12 for p in pitches_chord]).most_common()
|
5222 |
|
5223 |
if tones_counts[0][1] > 1:
|
5224 |
-
|
|
|
5225 |
|
5226 |
elif tones_counts[1][1] > 1:
|
5227 |
-
|
|
|
5228 |
|
5229 |
else:
|
5230 |
-
|
|
|
5231 |
|
5232 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
5233 |
tones_chord_combs = [list(comb) for i in range(len(tones_chord)-1, 0, -1) for comb in combinations(tones_chord, i)]
|
5234 |
|
5235 |
for co in tones_chord_combs:
|
5236 |
if co in CHORDS:
|
5237 |
-
tones_chord = co
|
5238 |
break
|
5239 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
5240 |
if len(tones_chord) == 1:
|
5241 |
tones_chord = [pitches_chord[0] % 12]
|
5242 |
|
@@ -5636,7 +5666,7 @@ def basic_enhanced_delta_score_notes_tokenizer(enhanced_delta_score_notes,
|
|
5636 |
final_score_tokens_ints_seq = flatten(score_tokens_ints_seq)
|
5637 |
|
5638 |
if max_seq_len > -1:
|
5639 |
-
final_score_tokens_ints_seq =
|
5640 |
|
5641 |
if seq_pad_value > -1:
|
5642 |
final_score_tokens_ints_seq += [seq_pad_value] * (max_seq_len - len(final_score_tokens_ints_seq))
|
@@ -8154,7 +8184,7 @@ def compress_patches_in_escore_notes(escore_notes,
|
|
8154 |
n_patches = num_patches
|
8155 |
|
8156 |
if group_patches:
|
8157 |
-
patches_set = sorted(set([e[6] for e in
|
8158 |
trg_patch_list = []
|
8159 |
seen = []
|
8160 |
for p in patches_set:
|
@@ -8165,7 +8195,7 @@ def compress_patches_in_escore_notes(escore_notes,
|
|
8165 |
trg_patch_list = sorted(trg_patch_list)
|
8166 |
|
8167 |
else:
|
8168 |
-
trg_patch_list = sorted(set([e[6] for e in
|
8169 |
|
8170 |
if 128 in trg_patch_list and n_patches > 1:
|
8171 |
trg_patch_list = trg_patch_list[:n_patches-1] + [128]
|
@@ -8834,33 +8864,188 @@ ALL_CHORDS_FULL = [[0], [0, 3], [0, 3, 5], [0, 3, 5, 8], [0, 3, 5, 9], [0, 3, 5,
|
|
8834 |
|
8835 |
def escore_notes_to_parsons_code(escore_notes,
|
8836 |
times_index=1,
|
8837 |
-
pitches_index=4
|
|
|
8838 |
):
|
8839 |
|
8840 |
-
parsons = ""
|
|
|
8841 |
|
8842 |
prev = ['note', -1, -1, -1, -1, -1, -1]
|
8843 |
|
8844 |
for e in escore_notes:
|
8845 |
if e[times_index] != prev[times_index]:
|
8846 |
|
8847 |
-
if
|
8848 |
-
parsons += "*"
|
8849 |
-
|
8850 |
-
elif e[pitches_index] > prev[pitches_index]:
|
8851 |
parsons += "U"
|
|
|
8852 |
|
8853 |
elif e[pitches_index] < prev[pitches_index]:
|
8854 |
parsons += "D"
|
|
|
8855 |
|
8856 |
elif e[pitches_index] == prev[pitches_index]:
|
8857 |
parsons += "R"
|
|
|
8858 |
|
8859 |
prev = e
|
8860 |
|
8861 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
8862 |
|
8863 |
###################################################################################
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
8864 |
#
|
8865 |
# This is the end of the TMIDI X Python module
|
8866 |
#
|
|
|
471 |
itrack += 1
|
472 |
return new_score
|
473 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
474 |
def score2stats(opus_or_score=None):
|
475 |
r'''Returns a dict of some basic stats about the score, like
|
476 |
bank_select (list of tuples (msb,lsb)),
|
|
|
2046 |
|
2047 |
#print('Loading MIDI file...')
|
2048 |
midi_file = open(MIDI_file, 'rb')
|
2049 |
+
if debug: print('Processing File:', MIDI_file)
|
2050 |
|
2051 |
try:
|
2052 |
opus = midi2opus(midi_file.read())
|
|
|
5153 |
pitches_index=4,
|
5154 |
patches_index=6,
|
5155 |
use_filtered_chords=False,
|
5156 |
+
use_full_chords=False,
|
5157 |
remove_duplicate_pitches=True,
|
5158 |
+
fix_bad_tones_chords=False,
|
5159 |
fix_bad_pitches=False,
|
5160 |
skip_drums=False
|
5161 |
):
|
|
|
5209 |
tones_counts = Counter([p % 12 for p in pitches_chord]).most_common()
|
5210 |
|
5211 |
if tones_counts[0][1] > 1:
|
5212 |
+
good_tone = tones_counts[0][0]
|
5213 |
+
bad_tone = tones_counts[1][0]
|
5214 |
|
5215 |
elif tones_counts[1][1] > 1:
|
5216 |
+
good_tone = tones_counts[1][0]
|
5217 |
+
bad_tone = tones_counts[0][0]
|
5218 |
|
5219 |
else:
|
5220 |
+
good_tone = pitches_chord[0] % 12
|
5221 |
+
bad_tone = [t for t in tones_chord if t != good_tone][0]
|
5222 |
|
5223 |
+
tones_chord = [good_tone]
|
5224 |
+
|
5225 |
+
if fix_bad_tones_chords:
|
5226 |
+
|
5227 |
+
if good_tone > bad_tone:
|
5228 |
+
|
5229 |
+
if sorted([good_tone, (12+(bad_tone+1)) % 12]) in CHORDS:
|
5230 |
+
tones_chord = sorted([good_tone, (12+(bad_tone-1)) % 12])
|
5231 |
+
|
5232 |
+
elif sorted([good_tone, (12+(bad_tone-1)) % 12]) in CHORDS:
|
5233 |
+
tones_chord = sorted([good_tone, (12+(bad_tone+1)) % 12])
|
5234 |
+
|
5235 |
+
else:
|
5236 |
+
|
5237 |
+
if sorted([good_tone, (12+(bad_tone-1)) % 12]) in CHORDS:
|
5238 |
+
tones_chord = sorted([good_tone, (12+(bad_tone-1)) % 12])
|
5239 |
+
|
5240 |
+
elif sorted([good_tone, (12+(bad_tone+1)) % 12]) in CHORDS:
|
5241 |
+
tones_chord = sorted([good_tone, (12+(bad_tone+1)) % 12])
|
5242 |
+
|
5243 |
+
if len(tones_chord) > 2:
|
5244 |
tones_chord_combs = [list(comb) for i in range(len(tones_chord)-1, 0, -1) for comb in combinations(tones_chord, i)]
|
5245 |
|
5246 |
for co in tones_chord_combs:
|
5247 |
if co in CHORDS:
|
|
|
5248 |
break
|
5249 |
|
5250 |
+
if fix_bad_tones_chords:
|
5251 |
+
|
5252 |
+
dt_chord = list(set(co) ^ set(tones_chord))
|
5253 |
+
|
5254 |
+
for t in dt_chord:
|
5255 |
+
tones_chord.append((12+(t+1)) % 12)
|
5256 |
+
tones_chord.append((12+(t-1)) % 12)
|
5257 |
+
|
5258 |
+
ex_tones_chord = sorted(set(tones_chord))
|
5259 |
+
|
5260 |
+
tones_chord_combs = [list(comb) for i in range(4, 0, -2) for comb in combinations(ex_tones_chord, i) if all(t in list(comb) for t in co)]
|
5261 |
+
|
5262 |
+
for eco in tones_chord_combs:
|
5263 |
+
if eco in CHORDS:
|
5264 |
+
tones_chord = eco
|
5265 |
+
break
|
5266 |
+
|
5267 |
+
else:
|
5268 |
+
tones_chord = co
|
5269 |
+
|
5270 |
if len(tones_chord) == 1:
|
5271 |
tones_chord = [pitches_chord[0] % 12]
|
5272 |
|
|
|
5666 |
final_score_tokens_ints_seq = flatten(score_tokens_ints_seq)
|
5667 |
|
5668 |
if max_seq_len > -1:
|
5669 |
+
final_score_tokens_ints_seq = final_score_tokens_ints_seq[:max_seq_len]
|
5670 |
|
5671 |
if seq_pad_value > -1:
|
5672 |
final_score_tokens_ints_seq += [seq_pad_value] * (max_seq_len - len(final_score_tokens_ints_seq))
|
|
|
8184 |
n_patches = num_patches
|
8185 |
|
8186 |
if group_patches:
|
8187 |
+
patches_set = sorted(set([e[6] for e in escore_notes]))
|
8188 |
trg_patch_list = []
|
8189 |
seen = []
|
8190 |
for p in patches_set:
|
|
|
8195 |
trg_patch_list = sorted(trg_patch_list)
|
8196 |
|
8197 |
else:
|
8198 |
+
trg_patch_list = sorted(set([e[6] for e in escore_notes]))
|
8199 |
|
8200 |
if 128 in trg_patch_list and n_patches > 1:
|
8201 |
trg_patch_list = trg_patch_list[:n_patches-1] + [128]
|
|
|
8864 |
|
8865 |
def escore_notes_to_parsons_code(escore_notes,
|
8866 |
times_index=1,
|
8867 |
+
pitches_index=4,
|
8868 |
+
return_as_list=False
|
8869 |
):
|
8870 |
|
8871 |
+
parsons = "*"
|
8872 |
+
parsons_list = []
|
8873 |
|
8874 |
prev = ['note', -1, -1, -1, -1, -1, -1]
|
8875 |
|
8876 |
for e in escore_notes:
|
8877 |
if e[times_index] != prev[times_index]:
|
8878 |
|
8879 |
+
if e[pitches_index] > prev[pitches_index]:
|
|
|
|
|
|
|
8880 |
parsons += "U"
|
8881 |
+
parsons_list.append(1)
|
8882 |
|
8883 |
elif e[pitches_index] < prev[pitches_index]:
|
8884 |
parsons += "D"
|
8885 |
+
parsons_list.append(-1)
|
8886 |
|
8887 |
elif e[pitches_index] == prev[pitches_index]:
|
8888 |
parsons += "R"
|
8889 |
+
parsons_list.append(0)
|
8890 |
|
8891 |
prev = e
|
8892 |
|
8893 |
+
if return_as_list:
|
8894 |
+
return parsons_list
|
8895 |
+
|
8896 |
+
else:
|
8897 |
+
return parsons
|
8898 |
+
|
8899 |
+
###################################################################################
|
8900 |
+
|
8901 |
+
def all_consequtive(list_of_values):
|
8902 |
+
return all(b > a for a, b in zip(list_of_values[:-1], list_of_values[1:]))
|
8903 |
+
|
8904 |
+
###################################################################################
|
8905 |
+
|
8906 |
+
def escore_notes_patches(escore_notes, patches_index=6):
|
8907 |
+
return sorted(set([e[patches_index] for e in escore_notes]))
|
8908 |
+
|
8909 |
+
###################################################################################
|
8910 |
+
|
8911 |
+
def build_suffix_array(lst):
|
8912 |
+
|
8913 |
+
n = len(lst)
|
8914 |
+
|
8915 |
+
suffixes = [(lst[i:], i) for i in range(n)]
|
8916 |
+
suffixes.sort()
|
8917 |
+
suffix_array = [suffix[1] for suffix in suffixes]
|
8918 |
+
|
8919 |
+
return suffix_array
|
8920 |
+
|
8921 |
+
###################################################################################
|
8922 |
+
|
8923 |
+
def build_lcp_array(lst, suffix_array):
|
8924 |
+
|
8925 |
+
n = len(lst)
|
8926 |
+
rank = [0] * n
|
8927 |
+
lcp = [0] * n
|
8928 |
+
|
8929 |
+
for i, suffix in enumerate(suffix_array):
|
8930 |
+
rank[suffix] = i
|
8931 |
+
|
8932 |
+
h = 0
|
8933 |
+
|
8934 |
+
for i in range(n):
|
8935 |
+
if rank[i] > 0:
|
8936 |
+
|
8937 |
+
j = suffix_array[rank[i] - 1]
|
8938 |
+
|
8939 |
+
while i + h < n and j + h < n and lst[i + h] == lst[j + h]:
|
8940 |
+
h += 1
|
8941 |
+
|
8942 |
+
lcp[rank[i]] = h
|
8943 |
+
|
8944 |
+
if h > 0:
|
8945 |
+
h -= 1
|
8946 |
+
|
8947 |
+
return lcp
|
8948 |
|
8949 |
###################################################################################
|
8950 |
+
|
8951 |
+
def find_lrno_pattern_fast(lst):
|
8952 |
+
n = len(lst)
|
8953 |
+
if n == 0:
|
8954 |
+
return []
|
8955 |
+
|
8956 |
+
suffix_array = build_suffix_array(lst)
|
8957 |
+
lcp_array = build_lcp_array(lst, suffix_array)
|
8958 |
+
|
8959 |
+
max_len = 0
|
8960 |
+
start_index = 0
|
8961 |
+
|
8962 |
+
for i in range(1, n):
|
8963 |
+
if lcp_array[i] > max_len:
|
8964 |
+
if suffix_array[i] + lcp_array[i] <= suffix_array[i - 1] or suffix_array[i - 1] + lcp_array[i - 1] <= suffix_array[i]:
|
8965 |
+
max_len = lcp_array[i]
|
8966 |
+
start_index = suffix_array[i]
|
8967 |
+
|
8968 |
+
return lst[start_index:start_index + max_len]
|
8969 |
+
|
8970 |
+
###################################################################################
|
8971 |
+
|
8972 |
+
def find_chunk_indexes(original_list, chunk, ignore_index=-1):
|
8973 |
+
|
8974 |
+
chunk_length = len(chunk)
|
8975 |
+
|
8976 |
+
for i in range(len(original_list) - chunk_length + 1):
|
8977 |
+
|
8978 |
+
chunk_index = 0
|
8979 |
+
start_index = ignore_index
|
8980 |
+
|
8981 |
+
for j in range(i, len(original_list)):
|
8982 |
+
if original_list[j] == chunk[chunk_index]:
|
8983 |
+
|
8984 |
+
if start_index == ignore_index:
|
8985 |
+
start_index = j
|
8986 |
+
|
8987 |
+
chunk_index += 1
|
8988 |
+
|
8989 |
+
if chunk_index == chunk_length:
|
8990 |
+
return [start_index, j]
|
8991 |
+
|
8992 |
+
elif original_list[j] != ignore_index:
|
8993 |
+
break
|
8994 |
+
|
8995 |
+
return None
|
8996 |
+
|
8997 |
+
###################################################################################
|
8998 |
+
|
8999 |
+
def escore_notes_lrno_pattern_fast(escore_notes,
|
9000 |
+
channels_index=3,
|
9001 |
+
pitches_index=4,
|
9002 |
+
zero_start_time=True
|
9003 |
+
):
|
9004 |
+
|
9005 |
+
cscore = chordify_score([1000, escore_notes])
|
9006 |
+
|
9007 |
+
score_chords = []
|
9008 |
+
|
9009 |
+
for c in cscore:
|
9010 |
+
|
9011 |
+
tchord = sorted(set([e[pitches_index] % 12 for e in c if e[channels_index] != 9]))
|
9012 |
+
|
9013 |
+
chord_tok = -1
|
9014 |
+
|
9015 |
+
if tchord:
|
9016 |
+
|
9017 |
+
if tchord not in ALL_CHORDS_FULL:
|
9018 |
+
tchord = check_and_fix_tones_chord(tchord)
|
9019 |
+
|
9020 |
+
chord_tok = ALL_CHORDS_FULL.index(tchord)
|
9021 |
+
|
9022 |
+
score_chords.append(chord_tok)
|
9023 |
+
|
9024 |
+
schords = [c for c in score_chords if c != -1]
|
9025 |
+
|
9026 |
+
lrno = find_lrno_pattern_fast(schords)
|
9027 |
+
|
9028 |
+
if lrno:
|
9029 |
+
|
9030 |
+
sidx, eidx = find_chunk_indexes(score_chords, lrno)
|
9031 |
+
|
9032 |
+
escore_notes_lrno_pattern = flatten(cscore[sidx:eidx+1])
|
9033 |
+
|
9034 |
+
if escore_notes_lrno_pattern is not None:
|
9035 |
+
|
9036 |
+
if zero_start_time:
|
9037 |
+
return recalculate_score_timings(escore_notes_lrno_pattern)
|
9038 |
+
|
9039 |
+
else:
|
9040 |
+
return escore_notes_lrno_pattern
|
9041 |
+
|
9042 |
+
else:
|
9043 |
+
return None
|
9044 |
+
|
9045 |
+
else:
|
9046 |
+
return None
|
9047 |
+
|
9048 |
+
###################################################################################
|
9049 |
#
|
9050 |
# This is the end of the TMIDI X Python module
|
9051 |
#
|