import%20marimo%0A%0A__generated_with%20%3D%20%220.20.4%22%0Aapp%20%3D%20marimo.App(width%3D%22medium%22%2C%20auto_download%3D%5B%22html%22%5D)%0A%0Awith%20app.setup%3A%0A%20%20%20%20import%20pandas%20as%20pd%0A%20%20%20%20import%20catm_lib.util.catmviewer%20as%20catview%0A%20%20%20%20import%20samidare_lib.util%20as%20util%0A%0A%0A%40app.cell%0Adef%20_()%3A%0A%20%20%20%20import%20marimo%20as%20mo%0A%0A%20%20%20%20return%20(mo%2C)%0A%0A%0A%40app.cell(hide_code%3DTrue)%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(r%22%22%22%0A%20%20%20%20%23%20Map%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%26%E3%82%B8%E3%82%AA%E3%83%A1%E3%83%88%E3%83%AA%E7%A2%BA%E8%AA%8D%E7%94%A8%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%E3%82%B3%E3%83%BC%E3%83%89%0A%0A%20%20%20%20%E5%AE%9F%E6%A9%9F%E3%81%A7%E5%8F%96%E5%BE%97%E3%81%97%E3%81%9F%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E8%A7%A3%E6%9E%90%E3%81%99%E3%82%8B%E9%9A%9B%E3%81%AB%E3%80%81%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E3%83%87%E3%82%A3%E3%82%B9%E3%83%97%E3%83%AC%E3%82%A4%E3%82%92%E8%A1%A8%E7%A4%BA%E3%81%95%E3%81%9B%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AE%E3%82%AF%E3%83%A9%E3%82%B9%E3%81%AE%E4%BD%BF%E3%81%84%E6%96%B9%E3%82%92%E6%9B%B8%E3%81%84%E3%81%A6%E3%81%8A%E3%81%8D%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%23%23%20%E8%AA%AD%E3%81%BF%E5%87%BA%E3%81%97%E9%9B%BB%E6%A5%B5%E3%81%AE%E6%8F%8F%E7%94%BB%E7%94%A8%E3%81%AE%E3%82%B8%E3%82%AA%E3%83%A1%E3%83%88%E3%83%AA%E3%82%92%E4%BD%9C%E6%88%90%E3%81%99%E3%82%8B%E3%80%82%0A%0A%20%20%20%20%60samidare-lib%60%E3%81%A7%E3%81%AF%5Bcatm-lib%5D(https%3A%2F%2Fgithub.com%2FFumiHubCNS%2Fcatm-lib)%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%E7%BE%A4%E3%81%8C%E4%BD%BF%E3%81%88%E3%82%8B%E3%82%88%E3%81%86%E3%81%AB%E3%81%AA%E3%81%A3%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%60src%2Futil%2Fpadinfo.py%60%E3%81%AB%E3%80%81%60catm-lib%60%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%A6%E8%AA%AD%E3%81%BF%E5%87%BA%E3%81%97%E9%9B%BB%E6%A5%B5%E3%81%AE%E4%BD%8D%E7%BD%AE%E6%83%85%E5%A0%B1%E3%82%92%E6%A0%BC%E7%B4%8D%E3%81%97%E3%81%A6%E3%81%84%E3%82%8B%E3%82%AF%E3%83%A9%E3%82%B9%E3%82%92%E7%94%9F%E6%88%90%E3%81%A7%E3%81%8D%E3%82%8B%E9%96%A2%E6%95%B0%E3%81%8C%E7%94%A8%E6%84%8F%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E4%BE%8B%E3%81%88%E3%81%B0%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%82%88%E3%81%86%E3%81%AB%E3%81%97%E3%81%A6%E9%85%8D%E7%BD%AE%E3%82%92%E7%94%9F%E6%88%90%E3%80%81%E8%A1%A8%E7%A4%BA%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%99%E3%80%82%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_()%3A%0A%20%20%20%20offset%20%3D%20-3.031088913245535%0A%20%20%20%20pad1%20%3D%20util.padinfo.get_tpc_info(offset-5)%0A%20%20%20%20pad2%20%3D%20util.padinfo.get_tpc_info(offset%2B5%2CFalse)%0A%20%20%20%20tpcs%20%3D%20util.padinfo.marge_padinfos(pad1%2Cpad2)%0A%0A%20%20%20%20tpcs.show_pads(return_flag%3DTrue)%0A%20%20%20%20return%20(tpcs%2C)%0A%0A%0A%40app.cell(hide_code%3DTrue)%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(r%22%22%22%0A%20%20%20%20%23%23%20%E3%83%9E%E3%83%83%E3%83%97%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%82%92%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%81%BF%E3%80%81%0A%0A%20%20%20%20%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%E3%81%A7%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%82%92%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%81%BF%E3%80%81%E3%83%87%E3%83%BC%E3%82%BF%E3%81%AE%E5%89%8D%E5%87%A6%E7%90%86%E3%82%92%E8%A1%8C%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E6%9B%B8%E3%81%8F%E5%88%97%E5%90%8D%E3%81%AE%E6%84%8F%E5%91%B3%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E3%81%AF%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%81%A8%E3%81%8A%E3%82%8A%E3%81%A7%E3%81%99%E3%80%82%0A%0A%20%20%20%20%7C%20%E5%88%97%E5%90%8D%20%20%20%20%20%20%20%20%7C%20%E8%AA%AC%E6%98%8E%20%7C%0A%20%20%20%20%7C%20%3A--------%3A%20%7C%20%3A---%3A%20%7C%0A%20%20%20%20%7C%20sampaNo%20%20%20%20%7C%20SAMIDARE%E5%86%85%E3%81%AESAMPA%E3%83%81%E3%83%83%E3%83%97%E3%81%AE%E7%95%AA%E5%8F%B7%E3%80%80%7C%0A%20%20%20%20%7C%20sampaID%20%20%20%20%7C%20%E5%90%84SAMPA%E3%83%81%E3%83%83%E3%83%97%E3%81%AEchannel%E7%95%AA%E5%8F%B7%20%7C%0A%20%20%20%20%7C%20samidareID%20%7C%20SAMIDARE%E3%81%AE%E3%83%81%E3%83%A3%E3%83%B3%E3%83%8D%E3%83%AB%E7%95%AA%E5%8F%B7%20(sampaNo%20*%2032%20%2B%20sampaID%20)%7C%0A%20%20%20%20%7C%20tpcID%20%20%20%20%20%20%7C%20%E3%82%B8%E3%82%AA%E3%83%A1%E3%83%88%E3%83%AA%E3%82%AF%E3%83%A9%E3%82%B9%E3%81%AB%E8%BF%BD%E5%8A%A0%E3%81%97%E3%81%9F%E8%AA%AD%E3%81%BF%E5%87%BA%E3%81%97%E3%83%91%E3%83%83%E3%83%88%E7%BE%A4(tpc)%E3%81%AE%E8%AD%98%E5%88%A5%E7%95%AA%E5%8F%B7%20%7C%0A%20%20%20%20%7C%20padID%20%20%20%20%20%20%7C%20%E5%90%84%E3%83%91%E3%83%83%E3%83%89%E3%81%AEID%20%7C%0A%20%20%20%20%7C%20gid%20%20%20%20%20%20%20%20%7C%20%E3%82%B8%E3%82%AA%E3%83%A1%E3%83%88%E3%83%AA%E3%82%AF%E3%83%A9%E3%82%B9%E3%81%A7%E3%81%AE%E3%82%B0%E3%83%AD%E3%83%BC%E3%83%90%E3%83%ABID%20(%20(tpcID(i)-1)%20*%20max(padID(i))%20%2B%20padID(i)%20%7C%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_()%3A%0A%20%20%20%20tpc_map%20%3D%20'prm%2Fcat%2Fminitpc.map'%0A%0A%20%20%20%20mapdf%20%3D%20pd.read_csv(tpc_map)%0A%20%20%20%20mapdf%5B'padID'%5D%20%3D%20pd.to_numeric(mapdf%5B'padID'%5D%2C%20errors%3D'coerce')%0A%20%20%20%20mapdf%5B'gid'%5D%20%3D%20pd.to_numeric(mapdf%5B'gid'%5D%2C%20errors%3D'coerce')%0A%0A%20%20%20%20mapdf%5B'tpcID'%5D%20%3D%20mapdf%5B'tpcID'%5D.astype(int)%0A%20%20%20%20mapdf%5B'padID'%5D%20%3D%20mapdf%5B'padID'%5D.fillna(-1).astype(int)%0A%20%20%20%20mapdf%5B'gid'%5D%20%3D%20mapdf%5B'gid'%5D.fillna(-1).astype(int)%0A%20%20%20%20mapdf%5B'sampaNo'%5D%20%3D%20mapdf%5B'sampaNo'%5D.astype(int)%0A%20%20%20%20mapdf%5B'sampaID'%5D%20%3D%20mapdf%5B'sampaID'%5D.astype(int)%0A%20%20%20%20mapdf%5B'samidareID'%5D%20%3D%20mapdf%5B'samidareID'%5D.astype(int)%0A%0A%20%20%20%20mapdf%20%3D%20mapdf.reset_index(drop%3DTrue)%0A%0A%20%20%20%20mapdf.head(10)%0A%20%20%20%20return%20(mapdf%2C)%0A%0A%0A%40app.cell(hide_code%3DTrue)%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(r%22%22%22%0A%20%20%20%20%60tpcs.show_pads()%60%E3%81%A7%E3%81%AF%E6%9B%B8%E3%81%8F%E3%83%91%E3%83%83%E3%83%89%E3%81%AB%E8%89%B2%E3%82%92%E3%81%A4%E3%81%91%E3%81%9F%E3%82%8A%E3%80%81%E6%95%B0%E5%80%A4%E3%82%92%E8%A1%A8%E7%A4%BA%E3%81%97%E3%81%9F%E3%82%8A%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%9F%E3%81%A0%E3%81%97%E3%80%81%E3%81%9D%E3%81%AE%E9%9A%9B%E3%81%AB%E3%81%AF%E3%80%81gid%E3%81%AE%E6%98%87%E9%A0%86%E3%81%AB%E5%80%A4%E3%82%92%E6%A0%BC%E7%B4%8D%E3%81%97%E3%81%9F%E3%83%AA%E3%82%B9%E3%83%88%E3%82%92%E6%B8%A1%E3%81%99%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%9D%E3%81%93%E3%81%A7%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%E3%81%A7%E5%AF%BE%E5%BF%9C%E3%83%AA%E3%82%B9%E3%83%88%E3%82%92%E4%BD%9C%E6%88%90%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(mapdf%2C%20mo)%3A%0A%20%20%20%20tpc_chip%20%3D%20%5B%5D%0A%20%20%20%20tpc_channel%20%3D%20%5B%5D%0A%20%20%20%20tpc_dev%20%3D%5B%5D%0A%20%20%20%20rows%20%3D%20%5B%5D%0A%0A%20%20%20%20for%20_i%20in%20range(120)%3A%0A%20%20%20%20%20%20%20%20_chip%20%3D%20util.mapfile.get_any_from_mapdf_using_ref(mapdf%2C%20refLabel%3D'gid'%2C%20refID%3D_i%2C%20label%3D'sampaNo')%0A%20%20%20%20%20%20%20%20_channel%20%3D%20util.mapfile.get_any_from_mapdf_using_ref(mapdf%2C%20refLabel%3D'gid'%2C%20refID%3D_i%2C%20label%3D'sampaID')%0A%20%20%20%20%20%20%20%20_id%20%3D%20util.mapfile.get_any_from_mapdf_using_ref(mapdf%2C%20refLabel%3D'gid'%2C%20refID%3D_i%2C%20label%3D'samidareID')%0A%20%20%20%20%20%20%20%20_dev%20%3D%20util.mapfile.get_any_from_mapdf_using_ref(mapdf%2C%20refLabel%3D'gid'%2C%20refID%3D_i%2C%20label%3D'tpcID')%0A%20%20%20%20%20%20%20%20tpc_chip.append(_chip)%0A%20%20%20%20%20%20%20%20tpc_channel.append(_channel)%0A%20%20%20%20%20%20%20%20tpc_dev.append(_dev)%0A%0A%20%20%20%20%20%20%20%20rows.append(%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%22tpc_id%22%3A%20_i%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22samidare_id%22%3A%20_id%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22sampa_chip%22%3A%20_chip%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22sampa_channel%22%3A%20_channel%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22dev_id%22%3A%20_dev%0A%20%20%20%20%20%20%20%20%7D)%0A%0A%20%20%20%20_df%20%3D%20pd.DataFrame(rows)%0A%20%20%20%20mo.ui.table(_df)%0A%20%20%20%20return%20tpc_channel%2C%20tpc_chip%2C%20tpc_dev%0A%0A%0A%40app.cell%0Adef%20_(tpc_channel%2C%20tpc_chip%2C%20tpc_dev%2C%20tpcs)%3A%0A%20%20%20%20textdict%20%3D%20%7B%20%22tpcid%22%20%3A%20tpcs.ids%20%2C%20%22chipid%22%20%3A%20tpc_chip%20%2C%20%22sampach%22%20%3A%20tpc_channel%2C%20%22dev%22%3A%20tpc_dev%7D%0A%20%20%20%20return%20(textdict%2C)%0A%0A%0A%40app.cell(hide_code%3DTrue)%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(r%22%22%22%0A%20%20%20%20%E3%81%82%E3%81%A8%E3%81%AF%E4%BD%9C%E3%81%A3%E3%81%9F%E3%83%AA%E3%82%B9%E3%83%88%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%80%81%60catview.get_color_array%60%2C%20%60get_color_list%60%E3%82%92%E5%AE%9F%E8%A1%8C%E3%81%97%E3%81%AE%E3%81%A1%E3%81%AB%E6%88%BB%E3%82%8A%E5%80%A4%E3%82%92%E6%B8%A1%E3%81%9B%E3%81%B0%E6%8F%8F%E7%94%BB%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%93%E3%81%93%E3%81%A7%E3%81%AF%E5%BC%95%E6%95%B0%E3%81%A8%E3%81%97%E3%81%A6%E4%BB%A5%E4%B8%8B%E3%81%AE%E5%80%A4%E3%82%92%E5%85%A5%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81%E5%AF%BE%E5%BF%9C%E9%96%A2%E4%BF%82%E3%81%AF%E4%B8%8B%E8%A8%98%E3%81%AE%E8%A1%A8%E3%81%AE%E9%80%9A%E3%82%8A%E3%80%82%0A%0A%0A%20%20%20%20%7C%20%E5%BC%95%E6%95%B0%E5%90%8D%20%20%20%20%20%20%7C%20%E5%80%A4%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7C%20%E8%AA%AC%E6%98%8E%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7C%0A%20%20%20%20%7C%20%3A--------%3A%20%7C%20%3A---------------%3A%20%7C%20%3A--------------%3A%20%7C%0A%20%20%20%20%7C%20check_id%20%20%20%7C%20True%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7C%20%E6%95%B0%E5%80%A4%E3%81%AE%E8%A1%A8%E7%A4%BA%E3%82%AA%E3%83%97%E3%82%B7%E3%83%A7%E3%83%B3%20%7C%0A%20%20%20%20%7C%20check_size%20%7C%2013%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7C%20%E6%95%B0%E5%80%A4%E3%81%AE%E6%96%87%E5%AD%97%E3%82%B5%E3%82%A4%E3%82%BA%20%20%20%20%7C%0A%20%20%20%20%7C%20plot_type%20%20%7C%20'map'%20%20%20%20%20%20%20%20%20%20%20%20%20%7C%20%E6%8F%8F%E7%94%BB%E3%81%AE%E3%82%B9%E3%82%BF%E3%82%A4%E3%83%AB%20%20%20%20%20%20%7C%0A%20%20%20%20%7C%20color_map%20%20%7C%20color_array%20%20%20%20%20%20%20%7C%20%E8%89%B2%E5%88%86%E5%B8%83%E3%81%AE%E5%80%A4%E3%83%AA%E3%82%B9%E3%83%88%20%20%20%20%7C%0A%20%20%20%20%7C%20check_data%20%7C%20textdict%5B%22tpcid%22%5D%20%7C%20%E6%95%B0%E5%80%A4%E3%83%AA%E3%82%B9%E3%83%88%20%20%20%20%20%20%20%20%20%7C%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(textdict%2C%20tpcs)%3A%0A%20%20%20%20cehck_list%20%3D%20textdict%5B%22tpcid%22%5D%0A%0A%20%20%20%20color_array%20%3D%20catview.get_color_array(%0A%20%20%20%20%20%20%20%20cehck_list%2C%0A%20%20%20%20%20%20%20%20*catview.get_color_list(%0A%20%20%20%20%20%20%20%20%20%20%20%20cehck_list%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20cmap_name%3D%22rainbow%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20fmt%3D%22hex%22%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20)%0A%0A%20%20%20%20tpcs.show_pads(%0A%20%20%20%20%20%20%20%20check_id%3DTrue%2C%20%0A%20%20%20%20%20%20%20%20check_size%3D13%2C%20%0A%20%20%20%20%20%20%20%20canvassize%3D%5B12%2C4%5D%2C%0A%20%20%20%20%20%20%20%20plot_type%3D'map'%2C%0A%20%20%20%20%20%20%20%20color_map%3Dcolor_array%2C%20%0A%20%20%20%20%20%20%20%20check_data%3Dtextdict%5B%22tpcid%22%5D%2C%20%0A%20%20%20%20%20%20%20%20return_flag%3DTrue%0A%20%20%20%20)%0A%20%20%20%20return%0A%0A%0A%40app.cell(hide_code%3DTrue)%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(r%22%22%22%0A%20%20%20%20%23%23%20%E3%81%9D%E3%81%AE%E4%BB%96%0A%0A%20%20%20%20%E8%AA%AD%E3%81%BF%E5%87%BA%E3%81%97%E9%9B%BB%E6%A5%B5%E3%81%AE%E4%BD%9C%E3%82%8A%E6%96%B9%E3%81%AE%E8%A9%B3%E7%B4%B0%E3%81%AF%5Bhoge%5D(demo)%E3%81%AB%E4%BB%BB%E3%81%9B%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81%E9%A0%91%E5%BC%B5%E3%82%8B%E3%81%A8%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%82%88%E3%81%86%E3%81%AA%E3%83%87%E3%83%A2%E3%81%8C%E4%BD%9C%E3%82%8C%E3%82%8B%E3%82%88%E3%81%86%E3%81%AB%E3%81%AA%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_()%3A%0A%20%20%20%20import%20catm_lib%20as%20catlib%0A%0A%20%20%20%20catlib.readoutpad.catm.check_pad_view()%0A%20%20%20%20return%0A%0A%0Aif%20__name__%20%3D%3D%20%22__main__%22%3A%0A%20%20%20%20app.run()%0A
89b0a890f40df887d2732b5af148de37