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


Python System.solve方法代碼示例

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


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

示例1: main

# 需要導入模塊: from system import System [as 別名]
# 或者: from system.System import solve [as 別名]
def main(inp):
    """
    Main interface
    """
    if inp is None:
        # generate basis of system
        graph = nx.gnp_random_graph(10, 0.6)
        dim = len(graph.nodes())
        assert nx.is_connected(graph), 'Graph not connected'

        orig_A = nx.to_numpy_matrix(graph)
        orig_B = np.random.uniform(10, 20, size=dim)

        nz = np.nonzero(orig_A)
        orig_A[nz] = np.random.uniform(2, 5, size=len(nz[0]))

        print('Original A:\n', orig_A)
        print('Original B:', orig_B)

        omega = 3
        OMEGA_list = [2.9,3.05,3.1,3.2]#np.arange(3.7, 4.3, 0.05)

        # generate solutions
        data = []
        for OMEGA in tqdm(OMEGA_list):
            runs = []
            for i in trange(dim):
                mask = np.ones(dim, dtype=bool)
                mask[i] = 0
                Bvec = orig_B.copy()
                Bvec[mask] = 0

                syst = System(orig_A, Bvec, omega, OMEGA)
                sols, ts = syst.solve(0.01, 100)

                pdiffs = Reconstructor.extract_phase_differences(sols, ts, syst.Phi)
                #print(pdiffs)
                #System.plot_solution(syst.Phi(ts), sols, ts)

                if pdiffs is not None:
                    runs.append(pdiffs)

            if len(runs) > 0:
                data.append(((OMEGA, omega), runs))

        # cache results
        fname = '{}_{}'.format(datetime.now().strftime('%Y%m%d%H%M%S'), dim)
        np.save('cache/{}'.format(fname), {
            'data': data,
            'ts': ts,
            'orig_A': orig_A,
            'orig_B': orig_B
        })
    else:
        data, ts = inp.item()['data'], inp.item()['ts']
        orig_A, orig_B = inp.item()['orig_A'], inp.item()['orig_B']
        dim = orig_A.shape[0]

        print('Original A:\n', orig_A)
        print('Original B:', orig_B)

    # reconstruct parameters
    recon = Reconstructor(ts, data, dim)
    rec_A, rec_B = recon.reconstruct()

    print('Reconstructed A:\n', rec_A)
    print('Reconstructed B:', rec_B)

    # plot result
    bundle = DictWrapper({
        'orig_A': orig_A,
        'orig_B': orig_B,
        'rec_A': rec_A,
        'rec_B': rec_B
    })
    show_reconstruction_overview(bundle, verbose=dim < 20)
開發者ID:kpj,項目名稱:OsciPy,代碼行數:78,代碼來源:main.py


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