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%20from%20pyspark.sql%20import%20functions%20as%20F%0A%20%20%20%20import%20samidare_lib.analysis%20as%20analysis%0A%20%20%20%20import%20catm_lib.util.catmviewer%20as%20cat%0A%20%20%20%20import%20samidare_lib.core%20as%20core%0A%20%20%20%20import%20samidare_lib.util%20as%20util%0A%20%20%20%20import%20marimo_lib.util%20as%20molib%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%20%E3%83%92%E3%83%83%E3%83%88%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E8%A7%A3%E6%9E%90%E3%83%87%E3%83%A2%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%20marimo%20as%20mo%0A%20%20%20%20import%20pandas%20as%20pd%0A%20%20%20%20from%20plotly.subplots%20import%20make_subplots%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%23%20%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E3%83%93%E3%83%AB%E3%83%89%0A%0A%20%20%20%20%E3%81%93%E3%81%AE%E3%83%8E%E3%83%BC%E3%83%88%E3%81%A7%E3%81%AF%E3%83%92%E3%83%83%E3%83%88%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%81%AE%E6%8F%8F%E7%94%BB%E6%96%B9%E6%B3%95%E3%82%92%E7%B4%B9%E4%BB%8B%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%93%E3%81%AE%E3%83%8E%E3%83%BC%E3%83%88%E3%81%A7%E3%81%AF%E4%B8%BB%E3%81%AB%60src%2Fsamidare_lib.analysis%2Fhit_pattern.py%60%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%A6%E8%A7%A3%E6%9E%90%E3%82%92%E8%A1%8C%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%E5%BF%85%E8%A6%81%E3%81%AA%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%81%AF%E6%B3%A2%E5%BD%A2%E6%8A%BD%E5%87%BA%E8%A7%A3%E6%9E%90%E6%B8%88%E3%81%BF%E3%81%AE%60parquet%60%E3%81%A8%E3%83%9E%E3%83%83%E3%83%97%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%60csv%60%E3%81%A7%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%BE%E3%81%9A%E3%81%AF%E3%81%9D%E3%82%8C%E3%82%89%E3%81%AE%E3%83%91%E3%82%B9%E3%82%92%E5%AE%A3%E8%A8%80%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%60%60%60python%0A%20%20%20%20map_path%20%3D%20'prm%2Fcat%2Fminitpc.map'%0A%20%20%20%20input%20%3D%20'output%2Fminitpc_demo_pulse.parquet'%0A%20%20%20%20%60%60%60%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%20map_path%20%3D%20'prm%2Fcat%2Fminitpc.map'%0A%20%20%20%20input%20%3D%20'output%2Fminitpc_demo_pulse.parquet'%0A%20%20%20%20return%20input%2C%20map_path%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%E6%AC%A1%E3%81%AB%E4%BB%A5%E4%B8%8B%E3%81%AE%E9%96%A2%E6%95%B0%E3%81%A7%E3%83%9E%E3%83%83%E3%83%97%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%81%AE%E6%83%85%E5%A0%B1%E3%82%92%E6%B3%A2%E5%BD%A2%E8%A7%A3%E6%9E%90%E6%B8%88%E3%81%BF%E3%81%AE%E3%83%87%E3%83%BC%E3%82%BF%E3%81%AB%E5%9F%8B%E3%82%81%E8%BE%BC%E3%81%BF%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E5%BC%95%E6%95%B0%E3%81%AE%60debug%60%E3%82%92%60True%60%E3%81%AB%E3%81%99%E3%82%8B%E3%81%A8%E3%81%9D%E3%82%8C%E3%81%9E%E3%82%8C%E3%81%AE%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%81%AE%E3%83%87%E3%83%BC%E3%82%BF%E3%81%AE%E4%B8%80%E4%BE%8B%E3%82%92%E8%A1%A8%E7%A4%BA%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%AE%E9%96%A2%E6%95%B0%E3%81%A7%E3%81%AF%E5%85%83%E3%81%AE%60parquet%60%E3%81%AB%E5%AF%BE%E3%81%97%E3%81%A6%60samidare_id%60%2C%20%60tpc_id%60%2C%20%60dev_id%60%2C%20%60pad_id%60%E3%82%92%E8%BF%BD%E5%8A%A0%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%93%E3%82%8C%E3%82%89%E5%88%97%E3%81%AE%E6%84%8F%E5%91%B3%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E3%81%AF%E5%88%A5%E3%81%AE%E3%83%8E%E3%83%BC%E3%83%88%E3%83%96%E3%83%83%E3%82%AF%60mapfile_check.py%60%E3%82%92%E5%8F%82%E7%85%A7%E3%81%8F%E3%81%A0%E3%81%95%E3%81%84%E3%80%82%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(input%2C%20map_path)%3A%0A%20%20%20%20df%20%3D%20analysis.hit_pattern.asign_map(input%2C%20map_path%2C%20debug%3DTrue)%0A%20%20%20%20return%20(df%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%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%82%93%E3%81%A0%E3%82%89TPC%E3%81%AE%E3%83%87%E3%83%90%E3%82%A4%E3%82%B9%E7%95%AA%E5%8F%B7%E3%81%94%E3%81%A8%E3%81%AB%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E6%8A%BD%E5%87%BA%E3%81%97%E3%80%81%E3%81%9D%E3%82%8C%E3%81%9E%E3%82%8C%E3%81%A7%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E7%95%AA%E5%8F%B7%E3%82%92%E4%BB%98%E4%B8%8E%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%93%E3%81%AE%E5%9B%9E%E7%94%9F%E3%82%B3%E3%83%BC%E3%83%89%E3%81%A7%E3%81%AF%E7%9B%B4%E5%89%8D%E3%83%87%E3%83%BC%E3%82%BF%E3%81%A8%E3%81%AE%E6%99%82%E9%96%93%E5%B7%AE%E3%82%92%E8%A6%8B%E3%81%AA%E3%81%8C%E3%82%89%E3%80%81%60threshold%60%E3%81%AB%E3%81%A6%E6%8C%87%E5%AE%9A%E3%81%97%E3%81%9F%E5%80%A4%E3%82%92%E8%B6%85%E3%81%88%E3%82%8B%E3%81%BE%E3%81%A7%E3%81%AE%E3%83%87%E3%83%BC%E3%82%BF%E3%82%921%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E3%81%A8%E5%AE%9A%E7%BE%A9%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E7%9B%B4%E4%B8%8B%E3%81%AE%E3%82%BB%E3%83%AB%E3%81%8C%60dev_id%60%E3%81%8C1%E3%81%AETPC%E3%81%AE%E3%83%87%E3%83%BC%E3%82%BF%E3%81%A7%E3%81%AE%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E4%BB%98%E4%B8%8E%E7%B5%90%E6%9E%9C%E3%80%81%E3%81%9D%E3%81%AE%E4%B8%8B%E3%81%8C2%E3%81%AETPC%E3%81%AE%E3%83%87%E3%83%BC%E3%82%BF%E3%81%A7%E3%81%AE%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E4%BB%98%E4%B8%8E%E7%B5%90%E6%9E%9C%E3%81%A7%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_(df)%3A%0A%20%20%20%20_pol1%20%3D%200.0075948252197827%0A%20%20%20%20_pol0%20%3D%200.2907597292526938%0A%0A%20%20%20%20df_tpc1%20%3D%20df.filter(F.col(%22dev_id%22)%3D%3D1)%0A%0A%20%20%20%20df_evt1%20%3D%20core.event_builder.build_events(%0A%20%20%20%20%20%20%20%20df_tpc1%2C%0A%20%20%20%20%20%20%20%20time_col%3D'timestamp_ns'%2C%0A%20%20%20%20%20%20%20%20id_col%3D'event_id'%2C%0A%20%20%20%20%20%20%20%20threshold%3D1.5e6%2C%0A%20%20%20%20%20%20%20%20device_name%3D'mini1'%0A%20%20%20%20)%0A%0A%20%20%20%20df_evt1%20%3D%20analysis.hit_pattern.calculate_energy_depoist(%0A%20%20%20%20%20%20%20%20df_evt1%2C%0A%20%20%20%20%20%20%20%20device_name%3D'mini1'%2C%0A%20%20%20%20%20%20%20%20pol0%3D_pol0%2C%0A%20%20%20%20%20%20%20%20pol1%3D_pol1%0A%20%20%20%20)%0A%20%20%20%20return%20(df_evt1%2C)%0A%0A%0A%40app.cell%0Adef%20_(df)%3A%0A%20%20%20%20_pol1%20%3D%200.00651260438912663%0A%20%20%20%20_pol0%20%3D%200.24932806669203858%0A%0A%20%20%20%20df_tpc2%20%3D%20df.filter(F.col(%22dev_id%22)%3D%3D2)%0A%0A%20%20%20%20df_evt2%20%3D%20core.event_builder.build_events(%0A%20%20%20%20%20%20%20%20df_tpc2%2C%0A%20%20%20%20%20%20%20%20time_col%3D'timestamp_ns'%2C%0A%20%20%20%20%20%20%20%20id_col%3D'event_id'%2C%0A%20%20%20%20%20%20%20%20threshold%3D1.5e6%2C%0A%20%20%20%20%20%20%20%20device_name%3D'mini2'%0A%20%20%20%20)%0A%0A%20%20%20%20df_evt2%20%3D%20analysis.hit_pattern.calculate_energy_depoist(%0A%20%20%20%20%20%20%20%20df_evt2%2C%0A%20%20%20%20%20%20%20%20device_name%3D'mini2'%2C%0A%20%20%20%20%20%20%20%20pol0%3D_pol0%2C%0A%20%20%20%20%20%20%20%20pol1%3D_pol1%0A%20%20%20%20)%0A%20%20%20%20return%20(df_evt2%2C)%0A%0A%0A%40app.cell%0Adef%20_(df_evt1)%3A%0A%20%20%20%20util.parquetinfo.md_dump_parquet(df_evt1%2C%20n%3D10)%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%E3%81%9D%E3%82%8C%E3%81%9E%E3%82%8C%E3%81%AB%E5%88%A5%E3%80%85%E3%81%AB%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E7%95%AA%E5%8F%B7%E3%82%92%E4%BB%98%E4%B8%8E%E3%81%97%E3%81%9F%E5%BE%8C%E3%81%AB%E3%80%81%E3%81%9D%E3%82%8C%E3%81%9E%E3%82%8C%E3%81%AE%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E3%81%BE%E3%81%A8%E3%82%81%E3%81%A6%E5%86%8D%E5%BA%A6%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E4%BB%98%E4%B8%8E%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%96%B0%E3%81%97%E3%81%84%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E7%95%AA%E5%8F%B7%E3%81%AF%60merged_event_id%60%E3%81%AB%E6%A0%BC%E7%B4%8D%E3%81%95%E3%82%8C%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_(df_evt1%2C%20df_evt2)%3A%0A%20%20%20%20df_re%20%3D%20analysis.hit_pattern.add_merged_events_by_time_window(%0A%20%20%20%20%20%20%20%20ref_parquet%3Ddf_evt1%2C%0A%20%20%20%20%20%20%20%20add_parquet%3Ddf_evt2%2C%0A%20%20%20%20%20%20%20%20ref_dev_name%3D'mini1'%2C%0A%20%20%20%20%20%20%20%20add_dev_name%3D'mini2'%2C%0A%20%20%20%20%20%20%20%20window_ns%3D3e6%2C%0A%20%20%20%20)%0A%0A%0A%20%20%20%20util.parquetinfo.md_dump_parquet(df_re.orderBy(%22merged_ts%22)%2C%20n%3D50)%0A%20%20%20%20return%20(df_re%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%E7%90%86%E6%83%B3%E7%9A%84%E3%81%AB%E3%81%AF%60merged_event_id%60%E3%81%AFMini1%2C%20Mini2%E3%81%9D%E3%82%8C%E3%81%9E%E3%82%8C%E3%81%A7%E9%87%8D%E8%A4%87%E3%81%8C%E3%81%82%E3%81%A3%E3%81%A6%E6%AC%B2%E3%81%97%E3%81%8F%E3%81%AA%E3%81%84%E3%81%A7%E3%81%99%E3%81%8C%E3%80%81%E3%82%A2%E3%82%AF%E3%82%B7%E3%83%87%E3%83%B3%E3%82%BF%E3%83%AB%E3%82%B3%E3%82%A4%E3%83%B3%E3%82%B7%E3%83%87%E3%83%B3%E3%82%B9%E3%81%AA%E3%81%A9%E3%81%A7%E3%80%81%E6%99%82%E9%96%93%E7%9A%84%E3%81%AB%E8%BF%91%E3%81%84%E9%A0%98%E5%9F%9F%E3%81%AB%E8%A4%87%E6%95%B0%E3%81%AE%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E3%81%8C%E5%85%A5%E3%82%8A%E8%BE%BC%E3%82%80%E5%8F%AF%E8%83%BD%E6%80%A7%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%AE%E3%81%9F%E3%82%81%E3%80%81%E5%86%8D%E5%BA%A6%E4%BB%A5%E4%B8%8B%E3%81%A7%E3%80%81%E5%90%8C%E3%81%98%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E7%95%AA%E5%8F%B7%E5%90%8C%E5%A3%AB%E3%81%AE%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%94%E3%83%B3%E3%82%B0%E3%81%97%E3%81%A6%E3%80%81%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E9%85%8D%E5%88%97%E3%81%AB%E5%A4%89%E6%8F%9B%E3%81%97%E3%81%BE%E3%81%99%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(df_re)%3A%0A%20%20%20%20df_evt1_m%20%3D%20analysis.hit_pattern.build_events(df_re%2C'mini1')%0A%20%20%20%20df_evt2_m%20%3D%20analysis.hit_pattern.build_events(df_re%2C'mini2')%0A%0A%0A%20%20%20%20util.parquetinfo.md_dump_parquet(df_evt1_m%2C%20n%3D10)%0A%20%20%20%20return%20df_evt1_m%2C%20df_evt2_m%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%9D%E3%81%AE%E5%BE%8C%E3%80%81%60merged_event_id%60%E3%82%92%E3%83%AA%E3%83%95%E3%82%A1%E3%83%AC%E3%83%B3%E3%82%B9%E3%81%A8%E3%81%97%E3%81%A6%E3%83%87%E3%83%BC%E3%82%BF%E3%81%AE%E7%B5%90%E5%90%88%E3%82%92%E8%A1%8C%E3%81%84%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_(df_evt1_m%2C%20df_evt2_m)%3A%0A%20%20%20%20df_joined_evt%20%3D%20df_evt1_m.join(df_evt2_m%2C%20on%3D%22merged_event_id%22%2C%20how%3D%22left%22)%0A%0A%20%20%20%20util.parquetinfo.md_dump_parquet(df_joined_evt%2C%20n%3D10)%0A%20%20%20%20return%20(df_joined_evt%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%87%E3%83%BC%E3%82%BF%E7%A2%BA%E8%AA%8D%0A%0A%0A%20%20%20%20%E4%BB%A5%E4%B8%8B%E3%81%A7%E3%81%AF%E3%82%A2%E3%83%AB%E3%83%95%E3%82%A1%E7%B7%9A%E3%81%8C%E4%B8%A1%E6%96%B9%E3%81%AETPC%E3%81%AB%E5%88%B0%E9%81%94%E3%81%97%E3%81%9F%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E3%82%92%E9%81%B8%E6%8A%9E%E3%81%97%E3%81%A6%E3%80%81%E3%83%87%E3%83%BC%E3%82%BF%E3%81%AE%E5%9B%B3%E7%A4%BA%E3%82%92%E8%A1%8C%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%BE%E3%81%9A%E3%81%AF%E3%80%81%E3%81%9D%E3%82%8C%E3%81%9E%E3%82%8C%E3%81%AETPC%E3%81%AB%E3%81%A6%E8%90%BD%E3%81%A8%E3%81%97%E3%81%A6%E3%82%A8%E3%83%8D%E3%83%AB%E3%82%AE%E3%83%BC%E6%90%8D%E5%A4%B1%E3%82%92%E5%9B%B3%E7%A4%BA%E3%81%97%E3%81%A6%E3%81%BF%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%60spark%60%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%9F%E8%A7%A3%E6%9E%90%E3%81%A7%E4%BD%BF%E3%81%88%E3%82%8B%E9%96%A2%E6%95%B0%E3%81%AA%E3%81%A9%E3%81%AF%E7%9C%81%E7%95%A5%E3%81%97%E3%81%BE%E3%81%99%E3%81%8C%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%E3%81%A7%E3%81%AF%E3%80%81%E3%81%93%E3%82%8C%E3%81%BE%E3%81%A7%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%E3%81%A7%E8%A7%A3%E6%9E%90%E3%81%97%E3%81%9F%E3%83%87%E3%83%BC%E3%82%BF%E3%81%8B%E3%82%89%E3%80%81%E3%83%81%E3%83%83%E3%83%97%E7%95%AA%E5%8F%B7%E3%80%81%E3%83%81%E3%83%A3%E3%83%B3%E3%83%8D%E3%83%AB%E7%95%AA%E5%8F%B7%E3%80%81%E5%90%84TPC%E3%81%A7%E3%81%AE%E5%A4%9A%E9%87%8D%E5%BA%A6%E3%80%81%E5%90%84%E3%80%85%E3%81%AE%E3%83%91%E3%83%83%E3%83%89%E3%81%A7%E3%81%AE%E3%82%A8%E3%83%8D%E3%83%AB%E3%82%AE%E3%83%BC%E3%81%AE%E5%92%8C%E3%81%AA%E3%81%A9%E3%82%92%E6%8A%BD%E5%87%BA%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%BE%E3%81%9F%E6%8A%BD%E5%87%BA%E3%81%AE%E9%9A%9B%E3%81%AF%E4%B8%8B%E6%B5%81%E5%81%B4%E3%81%AETPC%E3%81%AE%E5%A4%9A%E9%87%8D%E5%BA%A6%E3%81%8C8%E4%BB%A5%E4%B8%8A%E3%81%A7%E3%81%82%E3%82%8B%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E3%81%AB%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E3%83%95%E3%82%A3%E3%83%AB%E3%82%BF%E3%83%BC%E3%81%97%E3%81%A6%E3%81%84%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_(df_joined_evt)%3A%0A%20%20%20%20_df%20%3D%20(%20df_joined_evt%0A%20%20%20%20%20%20%20%20.filter(F.col(%22event_id_mini2%22).isNotNull())%0A%20%20%20%20%20%20%20%20.filter(F.size(%22de_mini1%22)%20%3D%3D%201)%0A%20%20%20%20%20%20%20%20.filter(F.size(%22de_mini2%22)%20%3D%3D%201)%0A%20%20%20%20%20%20%20%20.select(%0A%20%20%20%20%20%20%20%20%20%20%20%20%22de_mini1%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22de_mini2%22%2C%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%22charge_mini1%22%2C%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%22charge_mini2%22%2C%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%22chip_mini1%22%2C%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%22chip_mini2%22%2C%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%22channel_mini1%22%2C%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%22channel_mini2%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22charge_mini1%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22charge_mini2%22%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.withColumn(%22de1%22%2C%20F.explode(%22de_mini1%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22de2%22%2C%20F.explode(%22de_mini2%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22_1%22%2C%20F.explode(%22charge_mini1%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22_2%22%2C%20F.explode(%22charge_mini2%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22n1%22%2C%20F.size(%22_1%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22n2%22%2C%20F.size(%22_2%22))%20%20%20%0A%20%20%20%20%20%20%20%20.withColumn(%22chip1%22%2C%20F.explode(%22chip_mini1%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22chip2%22%2C%20F.explode(%22chip_mini2%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22channel1%22%2C%20F.explode(%22channel_mini1%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22channel2%22%2C%20F.explode(%22channel_mini2%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22q1%22%2C%20F.explode(%22charge_mini1%22))%0A%20%20%20%20%20%20%20%20.withColumn(%22q2%22%2C%20F.explode(%22charge_mini2%22))%20%0A%20%20%20%20)%0A%0A%20%20%20%20df_hit%20%3D%20(%20_df%0A%20%20%20%20%20%20%20%20.select(%22de1%22%2C%22de2%22%2C%22n1%22%2C%20%22n2%22%2C%20%22chip1%22%2C%20%22chip2%22%2C%20%22channel1%22%2C%20%22channel2%22%2C%20%22q1%22%2C%20%22q2%22)%0A%20%20%20%20%20%20%20%20.filter(F.col(%22n2%22)%20%3E%208)%0A%20%20%20%20)%0A%20%20%20%20return%20(df_hit%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%9D%E3%81%97%E3%81%A6%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%E3%81%A7%E6%8F%8F%E7%94%BB%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%8F%8F%E7%94%BB%E3%81%AB%E3%81%AF%60Plotly%60%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%A6%E3%81%84%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%60marimo%60%E3%81%AE%E3%83%8E%E3%83%BC%E3%83%88%E3%83%96%E3%83%83%E3%82%AF%E3%81%A7%E4%BD%BF%E3%81%84%E3%82%84%E3%81%99%E3%81%84%E3%82%88%E3%81%86%E3%81%AB%E5%8A%A0%E5%B7%A5%E3%81%97%E3%81%9F%E3%83%A9%E3%82%A4%E3%83%96%E3%83%A9%E3%83%AA%20(%5Bmatimo-lib%5D(https%3A%2F%2Fgithub.com%2FFumiHubCNS%2Fmarimo-lib))%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%81%84%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_(df_hit)%3A%0A%20%20%20%20%23%23%23%20%E2%91%A0%20-%3E%20Pandas%20-%3E%20numpy%20array%0A%20%20%20%20_df%20%3D%20%20df_hit.toPandas()%0A%0A%20%20%20%20_c1%20%3D%20_df%20%5B%22de1%22%5D.to_numpy()%0A%20%20%20%20_c2%20%3D%20_df%20%5B%22de2%22%5D.to_numpy()%0A%0A%0A%20%20%20%20%23%23%23%20%E2%91%A1%20Plot%20data%20with%20Plotly%0A%20%20%20%20_fig%20%3D%20molib.plot.get_subplots_object(%0A%20%20%20%20%20%20%20%20rows%20%3D%201%2C%0A%20%20%20%20%20%20%20%20cols%20%3D%202%2C%0A%20%20%20%20%20%20%20%20subplot_titles%20%3D%5B%0A%20%20%20%20%20%20%20%20%20%20%20%20%22Total%20dE%20in%20Mini%20TPC%201%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22Total%20dE%20inMini%20TPC%202%22%0A%20%20%20%20%20%20%20%20%5D%0A%20%20%20%20)%0A%0A%20%20%20%20molib.plot.add_sub_plot(%0A%20%20%20%20%20%20%20%20_fig%2C1%2C1%2C%0A%20%20%20%20%20%20%20%20data%3D%5B_c1%20%5D%2C%0A%20%20%20%20%20%20%20%20axes_title%3D%5B'Energy%20Deposit%20%5BkeV%5D'%2C'Counts'%5D%2C%0A%20%20%20%20%20%20%20%20func%3Dmolib.plot.go_Histogram%2C%0A%20%20%20%20%20%20%20%20xrange%3D%5B0%2C300%2C%203%5D%0A%0A%20%20%20%20)%0A%0A%20%20%20%20molib.plot.add_sub_plot(%0A%20%20%20%20%20%20%20%20_fig%2C1%2C2%2C%0A%20%20%20%20%20%20%20%20data%3D%5B_c2%5D%2C%0A%20%20%20%20%20%20%20%20axes_title%3D%5B'Energy%20Deposit%20%5BkeV%5D'%2C'Counts'%5D%2C%0A%20%20%20%20%20%20%20%20func%3Dmolib.plot.go_Histogram%2C%0A%20%20%20%20%20%20%20%20xrange%3D%5B0%2C300%2C%203%5D%0A%20%20%20%20)%0A%0A%20%20%20%20_fig.update_layout(height%3D400%2C%20width%3D1000%2C%20showlegend%3DTrue%2C%20title_text%3D%22Alpha%20Particle%20Data%22)%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%E6%9C%80%E5%BE%8C%E3%81%AB%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%97%E3%81%A6%E3%81%BF%E3%81%BE%E3%81%99%E3%80%82%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%92%E3%83%83%E3%83%88%E3%83%91%E3%83%BC%E3%82%BF%E3%83%B3%E3%81%AE%E8%A7%A3%E6%9E%90%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%89%8B%E9%A0%86%E3%81%AF%E4%BB%A5%E4%B8%8B%E3%81%AE%E9%80%9A%E3%82%8A%0A%0A%20%20%20%201.%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%81%BE%E3%81%99%E3%80%82%0A%20%20%20%202.%20TPC%E3%81%AE%E6%A7%8B%E9%80%A0%E3%82%84%E9%85%8D%E7%BD%AE%E3%82%92%E8%A8%AD%E5%AE%9A%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%0A%20%20%20%203.%20%60chip%60%2C%20%60channel%60%E3%81%8B%E3%82%89SAMIDARE%E5%86%85%E3%81%A7%E3%83%A6%E3%83%8B%E3%83%BC%E3%82%AF%E3%81%AAID%E3%82%92%E4%BB%98%E4%B8%8E%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%0A%20%20%20%204.%20%E3%83%92%E3%83%83%E3%83%88%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E6%8F%8F%E7%94%BB%E7%94%A8%E3%81%AE%E3%83%AA%E3%82%B9%E3%83%88%E3%82%92%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E6%AF%8E%E3%81%AB%E8%A8%88%E7%AE%97%E3%81%97%E3%80%81%E9%85%8D%E5%88%97%E3%81%AB%E6%A0%BC%E7%B4%8D%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_(df_hit%2C%20map_path)%3A%0A%20%20%20%20%23%23%23%20%E2%91%A0%20%20%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%81%BF%EF%BC%88%E3%81%82%E3%82%89%E3%81%9F%E3%81%AA%E5%88%97%E3%81%AE%E4%BB%98%E4%B8%8E%E3%81%8A%E3%82%82%E8%A1%8C%E3%81%AA%E3%81%A3%E3%81%A6%E3%81%84%E3%82%8B%EF%BC%89%0A%20%20%20%20mapdf%20%3D%20analysis.hit_pattern.load_map(map_path%2Cfile_type%3D'pandas')%0A%0A%20%20%20%20%23%23%23%20%E2%91%A1%20%E8%AA%AD%E3%81%BF%E5%87%BA%E3%81%97%E9%9B%BB%E6%A5%B5%E3%81%AE%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%81%A8%E3%82%B8%E3%82%AA%E3%83%A1%E3%83%88%E3%83%AA%E3%82%92%E8%A8%AD%E5%AE%9A%0A%20%20%20%20offset%20%3D%20-3.031088913245535%0A%20%20%20%20pad1%20%3D%20util.padinfo.get_tpc_info(offset%2B45)%0A%20%20%20%20pad2%20%3D%20util.padinfo.get_tpc_info(offset%2B136.5%2CFalse)%0A%20%20%20%20tpcs%20%3D%20util.padinfo.marge_padinfos(pad1%2Cpad2)%0A%0A%20%20%20%20%23%23%23%20%E2%91%A2%20samidare_id%20%3D%2032%20*%20chip%20%2B%20channel%E3%81%A8%E3%81%84%E3%81%86%E5%80%A4%E3%82%92%E4%BB%98%E4%B8%8E%0A%20%20%20%20_df%20%3D%20(%20df_hit%20%0A%20%20%20%20%20%20%20%20.withColumn(%0A%20%20%20%20%20%20%20%20%20%20%20%20%22samidare_id1%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20F.expr(%22transform(arrays_zip(chip1%2C%20channel1)%2C%20x%20-%3E%20x.chip1%20*%2032%20%2B%20x.channel1)%22)%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.withColumn(%0A%20%20%20%20%20%20%20%20%20%20%20%20%22samidare_id2%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20F.expr(%22transform(arrays_zip(chip2%2C%20channel2)%2C%20x%20-%3E%20x.chip2%20*%2032%20%2B%20x.channel2)%22)%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20)%0A%0A%20%20%20%20%23%23%23%20%E2%91%A3%20%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88by%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E3%81%AB%E3%83%92%E3%83%83%E3%83%88%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%82%92%E8%A8%88%E7%AE%97%0A%20%20%20%20hits_data%20%3D%20%5B%5D%0A%0A%20%20%20%20for%20_ev%20in%20_df.toLocalIterator()%3A%0A%20%20%20%20%20%20%20%20_sid%20%3D%20_ev%5B'samidare_id1'%5D%20%2B%20_ev%5B'samidare_id2'%5D%0A%20%20%20%20%20%20%20%20_q%20%3D%20_ev%5B'q1'%5D%20%2B%20_ev%5B'q2'%5D%0A%0A%20%20%20%20%20%20%20%20_gid%20%3D%20%5B%5D%0A%0A%20%20%20%20%20%20%20%20for%20_id%20in%20_sid%3A%0A%20%20%20%20%20%20%20%20%20%20%20%20_gid.append(util.mapfile.get_any_from_mapdf_using_ref(mapdf%2C%20refLabel%3D'samidareID'%2C%20refID%3D_id%2C%20label%3D'gid'))%0A%0A%20%20%20%20%20%20%20%20%23%20tpcid_arr%20%3D%20_gid%0A%20%20%20%20%20%20%20%20%23%20de_arr%20%20%20%20%3D%20_q%20%0A%0A%20%20%20%20%20%20%20%20%23%20reflist%20%3D%20de_arr%0A%20%20%20%20%20%20%20%20_q_lst%20%3D%20%5B0%5D%20*%20len(tpcs.ids)%0A%0A%20%20%20%20%20%20%20%20for%20_i%20in%20range(len(_gid))%3A%0A%20%20%20%20%20%20%20%20%20%20%20%20_q_lst%5B_gid%5B_i%5D%5D%20%3D%20_q%5B_i%5D%0A%0A%0A%20%20%20%20%20%20%20%20_edges%2C%20_colors%20%3D%20cat.get_color_bins(_q_lst%2C%20n_bins%3D20%2C%20cmap_name%3D%22ocean_r%22%2C%20fmt%3D%22hex%22)%0A%20%20%20%20%20%20%20%20_color_array%20%3D%20cat.get_color_array(_q_lst%2C%20_edges%2C%20_colors)%0A%0A%0A%20%20%20%20%20%20%20%20hits_data.append(_color_array)%20%20%20%20%0A%20%20%20%20return%20hits_data%2C%20tpcs%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%E4%BB%A5%E4%B8%8B%E3%81%AE%E4%BA%8C%E3%81%A4%E3%81%AE%E3%82%BB%E3%83%AB%E3%81%A7%E3%83%92%E3%83%83%E3%83%88%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%81%AE%E6%8F%8F%E7%94%BB%E3%82%92%E8%A1%8C%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E7%9B%B4%E4%B8%8B%E3%81%AE%E3%82%BB%E3%83%AB%E3%81%AF%E3%82%A4%E3%83%B3%E3%82%BF%E3%83%A9%E3%82%AF%E3%83%86%E3%82%A3%E3%83%96%E3%81%AA%E3%82%B9%E3%83%A9%E3%82%A4%E3%83%80%E3%83%BC%E3%82%92%E4%BD%9C%E3%81%A3%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%0A%0A%20%20%20%20%E3%81%9D%E3%81%AE%E4%B8%8B%E3%81%AE%E3%82%BB%E3%83%AB%E3%81%8C%E5%AE%9F%E9%9A%9B%E3%81%AB%E6%8F%8F%E7%94%BB%E3%82%92%E8%A1%8C%E3%81%AA%E3%81%A3%E3%81%A6%E3%81%84%E3%82%8B%E9%96%A2%E6%95%B0%E3%81%A7%E3%80%81%E3%82%B9%E3%83%A9%E3%82%A4%E3%83%80%E3%83%BC%E3%81%AE%E4%BD%8D%E7%BD%AE%E3%81%A7%E6%8F%8F%E7%94%BB%E3%81%99%E3%82%8B%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E7%95%AA%E5%8F%B7%E3%82%92%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_(hits_data%2C%20mo)%3A%0A%20%20%20%20idx%20%3D%20mo.ui.slider(start%3D0%2C%20stop%3Dlen(hits_data)-1%2C%20step%3D1%2C%20value%3D0%2C%20label%3D%22event%20index%22)%0A%20%20%20%20idx%0A%20%20%20%20return%20(idx%2C)%0A%0A%0A%40app.cell%0Adef%20_(hits_data%2C%20idx%2C%20tpcs)%3A%0A%20%20%20%20tpcs.show_pads(%0A%20%20%20%20%20%20%20%20plot_type%3D'map'%2C%0A%20%20%20%20%20%20%20%20plane%3D'zx'%2C%0A%20%20%20%20%20%20%20%20color_map%3Dhits_data%5Bidx.value%5D%2C%20%0A%20%20%20%20%20%20%20%20check_id%20%3D%20True%2C%0A%20%20%20%20%20%20%20%20check_size%20%3D%207%2C%0A%20%20%20%20%20%20%20%20check_data%20%3D%20tpcs.ids%2C%0A%20%20%20%20%20%20%20%20canvassize%20%3D%20%5B12%2C7%5D%2C%0A%20%20%20%20%20%20%20%20return_flag%3DTrue%0A%20%20%20%20)%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
bc4a746f7c7407e16351ee7ed88f85f1