當前位置: 首頁>>代碼示例>>Python>>正文


Python Math.semitone_to_frequency方法代碼示例

本文整理匯總了Python中Math.semitone_to_frequency方法的典型用法代碼示例。如果您正苦於以下問題:Python Math.semitone_to_frequency方法的具體用法?Python Math.semitone_to_frequency怎麽用?Python Math.semitone_to_frequency使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Math的用法示例。


在下文中一共展示了Math.semitone_to_frequency方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: analyze_overtones

# 需要導入模塊: import Math [as 別名]
# 或者: from Math import semitone_to_frequency [as 別名]
	def analyze_overtones(self,semitone,overtones=None):
		""" calculates power and peak center for each overtone and yields tuples (overtone, frequency, power, peak_center, difference_in_semitones) """
		frequency = Math.semitone_to_frequency(semitone)
		peak_radius = self.get_peak_radius()

		overtone=0

		while overtones==None or overtone<overtones:
			f = frequency*(overtone+1)
			s = Math.frequency_to_semitone(f)

			lower_frequency = f - peak_radius*1.65
			upper_frequency = f + peak_radius*1.65

			lower_frequency = min(lower_frequency, Math.semitone_to_frequency(s-0.5))
			upper_frequency = max(upper_frequency, Math.semitone_to_frequency(s+0.5))

			power = self.get_power_in_frequency_range(lower_frequency,upper_frequency)
			peak_center = self.get_powerfreq_spline().integral(lower_frequency,upper_frequency) / power

			difference_in_semitones = Math.frequency_to_semitone(peak_center) - s

			yield overtone, f, power, peak_center, difference_in_semitones

			overtone += 1
開發者ID:Leberwurscht,項目名稱:Python-Guitar-Transcription-Aid,代碼行數:27,代碼來源:VisualizerControl.py

示例2: overtones_to_equalizer

# 需要導入模塊: import Math [as 別名]
# 或者: from Math import semitone_to_frequency [as 別名]
    def overtones_to_equalizer(self, control, semitone, overtones=10):
        if not self.project:
            return

        x = self.project.pipeline.eq.frequencies
        y = self.project.pipeline.eq.props.transmission

        fundamental_frequency = Math.semitone_to_frequency(semitone)

        for overtone in xrange(overtones + 1):
            frequency = fundamental_frequency * (overtone + 1)
            semitone = Math.frequency_to_semitone(frequency)

            lower = Math.semitone_to_frequency(semitone - 0.5)
            upper = Math.semitone_to_frequency(semitone + 0.5)

            if lower > x[-1]:
                break

            for i in xrange(len(x)):
                if x[i] > upper:
                    break

                if lower <= x[i]:
                    y[i] = 1.0

        self.project.pipeline.eq.props.transmission = y
開發者ID:Leberwurscht,項目名稱:Python-Guitar-Transcription-Aid,代碼行數:29,代碼來源:transcribe.py

示例3: analyze_semitone

# 需要導入模塊: import Math [as 別名]
# 或者: from Math import semitone_to_frequency [as 別名]
    def analyze_semitone(self, control, semitone):
        if not self.project:
            return
        if not control.has_data:
            return

        text = ""

        for overtone, frequency, power, peak_center, difference_in_semitones in control.analyze_overtones(semitone, 10):
            s = Math.frequency_to_semitone(frequency)
            position = control.start + control.duration / 2.0
            lower = Math.semitone_to_frequency(s - 0.5)
            upper = Math.semitone_to_frequency(s + 0.5)
            onset_min, onset_max = self.project.appsinkpipeline.find_onset(lower, upper, position, limit=5)
            text += "%d. overtone: %f Hz (semitone %f; near %s)\n" % (overtone, frequency, s, Math.note_name(s))
            text += "\tPower: %f (%f dB)\n" % (power, Math.power_to_magnitude(power))
            text += "\tPosition: %f Hz (off by %f semitones)\n" % (peak_center, difference_in_semitones)
            text += "\tOnset: between %fs and %fs\n" % (onset_min, onset_max)
            text += "\n"

        w = gtk.Window()
        w.set_size_request(500, 400)
        w.set_title("Info on %s (%f)" % (Math.note_name(semitone), semitone))

        sw = gtk.ScrolledWindow()
        w.add(sw)

        tv = gtk.TextView()
        tv.get_buffer().set_text(text)
        tv.set_editable(False)
        sw.add(tv)

        w.show_all()
開發者ID:Leberwurscht,項目名稱:Python-Guitar-Transcription-Aid,代碼行數:35,代碼來源:transcribe.py

示例4: vis_plot_evolution

# 需要導入模塊: import Math [as 別名]
# 或者: from Math import semitone_to_frequency [as 別名]
    def vis_plot_evolution(self, viscontrol, semitone):
        if not self.project:
            return

        playback_marker = self.project.timeline.ruler.get_playback_marker()
        if not playback_marker:
            return

        import scipy.interpolate

        start, duration = playback_marker

        ##########
        dialog = gtk.Dialog(
            title="interval",
            flags=gtk.DIALOG_DESTROY_WITH_PARENT | gtk.DIALOG_MODAL,
            buttons=(gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT, gtk.STOCK_OK, gtk.RESPONSE_ACCEPT),
        )
        entry = gtk.Entry()
        entry.set_text("0.1")
        dialog.vbox.add(entry)
        dialog.show_all()
        dialog.run()
        interval = float(entry.get_text())
        dialog.destroy()
        #############

        # 		interval = 0.1
        delta = interval / 2.0
        steps = 1.0 * duration / delta

        x = []
        y = []
        for step in xrange(int(steps)):
            pos = start + step * delta
            frq, power = self.project.appsinkpipeline.get_spectrum(pos - interval / 2.0, pos + interval / 2.0)
            # 			frq, power = self.project.appsinkpipeline.get_spectrum(pos,pos+interval)

            spline = scipy.interpolate.InterpolatedUnivariateSpline(frq, power, None, [None, None], 1)

            lower = Math.semitone_to_frequency(semitone - 0.5)
            upper = Math.semitone_to_frequency(semitone + 0.5)
            total = spline.integral(lower, upper)

            x.append(pos)
            y.append(total)

        w = Analyze.Analyze()
        w.show_all()
        w.simple_plot(x, y)
開發者ID:Leberwurscht,項目名稱:Python-Guitar-Transcription-Aid,代碼行數:52,代碼來源:transcribe.py

示例5: press_semitone

# 需要導入模塊: import Math [as 別名]
# 或者: from Math import semitone_to_frequency [as 別名]
	def press_semitone(self,semitone,target,event,string,fret):
		if event.button==1:
			self.pipeline.get_by_name("volume").set_property("volume", self.volume.get_value())
			self.pipeline.get_by_name("src").set_property("freq", Math.semitone_to_frequency(semitone.semitone))
			self.pipeline.set_state(gst.STATE_PLAYING)
		elif event.button==3:
			self.open_context_menu(semitone,event,string,fret)
開發者ID:Leberwurscht,項目名稱:Python-Guitar-Transcription-Aid,代碼行數:9,代碼來源:Visualizer.py

示例6: find_onset

# 需要導入模塊: import Math [as 別名]
# 或者: from Math import semitone_to_frequency [as 別名]
    def find_onset(self, viscontrol, semitone):
        if not self.project:
            return

        playback_marker = self.project.timeline.ruler.get_playback_marker()
        if not playback_marker:
            return

        start, duration = playback_marker

        position = start + duration / 2.0

        lower = Math.semitone_to_frequency(semitone - 0.5)
        upper = Math.semitone_to_frequency(semitone + 0.5)

        onset, onset_max = self.project.appsinkpipeline.find_onset(lower, upper, position)

        self.project.timeline.ruler.set_playback_marker(onset, start + duration - onset)
開發者ID:Leberwurscht,項目名稱:Python-Guitar-Transcription-Aid,代碼行數:20,代碼來源:transcribe.py

示例7: __init__

# 需要導入模塊: import Math [as 別名]
# 或者: from Math import semitone_to_frequency [as 別名]
	def __init__(self, control, tuning=-5, **kwargs):
		FretboardWindowBase.__init__(self, **kwargs)

		self.set_title("Undertones of %s-tuned string (%f - %f Hz)" % (Math.note_name(tuning), tuning, Math.semitone_to_frequency(tuning)))

		root = self.canvas.get_root_item()
		self.visualizer = Undertones(control, self.volume, parent=root, tuning=tuning)

		self.adjust_canvas_size()
開發者ID:Leberwurscht,項目名稱:Python-Guitar-Transcription-Aid,代碼行數:11,代碼來源:Visualizer.py

示例8: analyze_semitone

# 需要導入模塊: import Math [as 別名]
# 或者: from Math import semitone_to_frequency [as 別名]
	def analyze_semitone(self,semitone,overtones=10, undertones=2, undertone_limit=80.):
		""" calculate total power, inharmonicity and independence coefficients """

		analysis = self.analyze_overtones(semitone,overtones)

		# fundamental tone
		overtone, fundamental_frequency, power, peak_center, difference_in_semitones = analysis.next()

		fundamental_power = power
		fundamental_diff_square = power * difference_in_semitones**2.
		fundamental_diff = power * difference_in_semitones

		# overtones
		overtone_power = 0
		overtone_diff_squares = 0
		overtone_diffs = 0

		for overtone, frequency, power, peak_center, difference_in_semitones in analysis:
			overtone_power += power
			overtone_diff_squares += power * difference_in_semitones**2.
			overtone_diffs += power * difference_in_semitones

		total_power = fundamental_power + overtone_power
		diff_squares = fundamental_diff_square + overtone_diff_squares
		diffs = fundamental_diff + overtone_diffs

		center = diffs/total_power
		variance = diff_squares/total_power - center**2.
		standard_deviation = numpy.sqrt(variance)

		# calculate upper_dependence
#		if fundamental_frequency<150.: fp = fundamental_power*15.	# exception for low-pitched tones
#		else: fp = fundamental_power
#		alien_power = max(0, overtone_power - 0.5*fp)
		alien_power = max(0, overtone_power - 0.5*fundamental_power)
		upper_dependence = alien_power / total_power
		print "upperdependence of %d is %f" % (semitone, upper_dependence)

		# calculate lower_dependence
		peak_radius = self.get_peak_radius()

		undertone_power = 0

		for undertone in xrange(2,undertones+2):
			undertone_frequency = fundamental_frequency / undertone
			if undertone_frequency < undertone_limit: break

			s = Math.frequency_to_semitone(undertone_frequency)

			lower_frequency = undertone_frequency - peak_radius*1.65
			upper_frequency = undertone_frequency + peak_radius*1.65

			lower_frequency = min(lower_frequency, Math.semitone_to_frequency(s-0.5))
			upper_frequency = max(upper_frequency, Math.semitone_to_frequency(s+0.5))

			power = self.get_power_in_frequency_range(lower_frequency,upper_frequency)

			power /= undertone**2.

#			if undertone_frequency>150.: power *= 15

			undertone_power += power

		lower_dependence = undertone_power / total_power
		print "lowerdependence of %d is %f (%f/%f)" % (semitone, lower_dependence, undertone_power, total_power)

		return fundamental_power, total_power, center, standard_deviation, upper_dependence, lower_dependence
開發者ID:Leberwurscht,項目名稱:Python-Guitar-Transcription-Aid,代碼行數:69,代碼來源:VisualizerControl.py


注:本文中的Math.semitone_to_frequency方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。