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


Python Filter.optimal_filter方法代碼示例

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


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

示例1: tesana

# 需要導入模塊: import Filter [as 別名]
# 或者: from Filter import optimal_filter [as 別名]

#.........這裏部分代碼省略.........

    if p.size > 0 and n.size > 0:
        # Generate template
        tmpl, sn = Filter.generate_template(p, n, lpfc=lpfc, hpfc=hpfc, nulldc=nulldc, max_shift=max_shift)

        if savedat:
            np.savetxt('%s-template.dat' % session, np.vstack((t, tmpl)).T,
                header='Time (s), Template (A.U.)', delimiter='\t')
            np.savetxt('%s-sn.dat' % session, np.vstack((np.arange(len(sn))*df, sn/np.sqrt(df))).T,
                header='Frequency (Hz), S/N (/srHz)', delimiter='\t')
    
        if plotting:
            # Plot template
            figure()
            plot(t, tmpl)
            xlabel('Time$\quad$(s)')
            ylabel('Template$\quad$(A.U.)')
            tight_layout()
            savefig('%s-template.pdf' % session)
        
            # Plot SNR
            figure()
            plot(np.arange(len(sn))*df, sn/np.sqrt(df))
            loglog()
            xlabel('Frequency$\quad$(Hz)')
            ylabel('S/N$\quad$(/$\sqrt{\mathrm{Hz}}$)')
            tight_layout()
            savefig('%s-sn.pdf' % session)
    
        # Calculate baseline resolution
        print "Resolving power: %.2f (%.2f eV @ 5.9 keV)" % (np.sqrt((sn**2).sum()*2), Analysis.baseline(sn))
    
        # Perform optimal filtering
        pha_p = Filter.optimal_filter(p, tmpl, max_shift=max_shift)
        pha_n = Filter.optimal_filter(n, tmpl, max_shift=0)
    
        # Offset correction
        (a, b), coef = Analysis.fit_offset(pha_p, offset, sigma=sigma, method=ocmethod, flip=flip)
    
        if coef > thre:
            oc_pha_p = Analysis.offset_correction(pha_p, offset, b)
            oc_pha_n = Analysis.offset_correction(pha_n, offset, b)
            print "Offset correction with: PHA = %f * (1 + %f * Offset)" % (a, b)
    
            if plotting:
                figure()
                ka = Analysis.ka(np.vstack((pha_p, offset)).T, sigma=sigma)
                plot(ka.T[1], ka.T[0], '.', c='k')
                x_min, x_max = xlim()
                ofs = np.linspace(x_min, x_max)
                label = '$\mathrm{PHA}=%.2f\\times(1+%.2f\\times\mathrm{Offset})$' % (a, b)
                plot(ofs, a*(1+b*ofs), 'r-', label=label)
                xlabel('Offset$\quad$(V)')
                ylabel('PHA$\quad$(V)')
                legend(frameon=False)
                tight_layout()
                savefig('%s-offset.pdf' % session)
        else:
            oc_pha_p = pha_p
            oc_pha_n = pha_n
            print "Skipped offset correction: correlation coefficient (%f) is too small" % coef

        # Check line database
        if "%sKa" % atom not in Constants.LE.keys() or "%sKb" % atom not in Constants.LE.keys():
            raise ValueError('Unsupported atom: %s' % atom)
開發者ID:robios,項目名稱:PyTES,代碼行數:69,代碼來源:Util.py


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