From 7816081c9d3a95d0ba8a6a03793594f056b00975 Mon Sep 17 00:00:00 2001 From: Zhiyi Wu Date: Fri, 29 Dec 2023 21:59:14 +0000 Subject: [PATCH] edit --- joss_paper/Fig1.pdf | Bin 0 -> 19638 bytes joss_paper/Fig2.pdf | Bin 0 -> 15761 bytes joss_paper/paper.md | 25 +++++++++++++++---------- 3 files changed, 15 insertions(+), 10 deletions(-) create mode 100644 joss_paper/Fig1.pdf create mode 100644 joss_paper/Fig2.pdf diff --git a/joss_paper/Fig1.pdf b/joss_paper/Fig1.pdf new file mode 100644 index 0000000000000000000000000000000000000000..e60938a1f92372c0c85b5887cfdbf155bc907b91 GIT binary patch literal 19638 zcmdUXcRZEv|9?ginHd>zl#zsUj&nFi_8!U19vR2V-m)?xdqhS?Hkn0c$d;LGLN+1U zN%Ff7@Av1EeBQkuk8gkdI1ldobzk@MdR?#UbzRqMT-RYz5R+hsaB$%~NZRYZ10X-iSG!Tp9N+l34ag)7+*4Oo8W7l%{JkI7fw#}vN`R!Qi!yV*`z<%fJ zz3&Bk(;ekc>1hQoZ1}dJRztv6khcN798?fywI4}uc|s=^DiGFLkk-U;+PLYN@w=-^ z$fkCEpGHQu@A^E|MFue=hP1ITjmIx9>)=gP@O85?XA?Ev4r`Y847?Js?Wt=pYZk=a zU5~_ua`&|Hq8?KSzRYjtqrO>ftC7W*;Yt@vYn&Me8-ol#99XPKRG*#>{o*5@Oo~}W z(&c8TOkEIawRjEuNRgtqMVyW@m33Dlmo%fVLU_)oHs1eCxic>QwvMy}`frwN*ouLPXdYd9sZAXSW`e9gq zKsEC-Pp>y3;uiPF#GjvOU+Z=EElR9b9KK}dc=dw5Hs4NlRqup*_&Bbl_V~5C*VqCI zXb5VYTf0^ULNO@>-Ap9ET9$IVH7bvl)>ru8dC@UG8j|R5{eo1YnfrbZV=0$e7!Gp>Bge*zn1Vov{zr zH7IyvZckJz%s8)z@6}@B~~j4x2H19F)>0t81mCDpRasEzn+Er=4^QcR>lWK@b|l-(1QwTV<&yn4{9U~HybW7>G>upwv7fm1p~_Z*{eq)mr@+%ok61@IzS%gg zTp-EDe{et1*ac(AlrNP<{%fSmw4EmLYo#}{2oo~Z*0a)r6w_4Kaf=_R!mI)_8AZKy z5+9R?rd$)X0iPKeY2xnQh{M`sbmZ@jy?5LwjDWs#CB9<$P zrOfBrd{XyF+Js)%)A#bmsIhay#&UU@)2if2!^QNq{x@U z(#;ukG`{ybOciV6lZRoTTYdhb6B zA!9Tk?_tQS zw0_hoC|z;zo#58Ybs^Yi8O8J0jdBt@%SFy*CX-prUYEnn%t>_gplMUE3ecSFUraTS zFt}<0jWujDEx7PLHCDzU^dJziM(bVO7$Wu!s|t@VMFIP1cK3}z?Q{xRyXbRONpVZPydoe<#?UqQzPeYqW~6j zr?zSPh#b3^aS7wnE2I;jQG#*>*E3N^zXQ~=$OMLt*@A*ce|H$X2{UbyG!#d}hefa1 zYT|>E*%Rxb!*Kz^B5P|itoSkdPUrdgF*Sdq@ALb5YhJFXA7)mER<#xUrd|<5&Z#4j zf^$Ndaw-x6X4nUN5_C^)=gB>J9nwcDiyzdMVqfgba_KBiR{`0K89`?}sce8a4=?@{ zVHAu~tm@Xg| ziN)*o(eO=?=TmP|+4c@*8u!;yCg4^J%TDlSI>xaL1jTuY`z@Ky%TFX)%5rl;TW%zg zq%6wIOns;k8T90>04swfD?roQd+)KqZ^5nWbx0)|myVwcx9==B2D}`ueClws!p`B7<1- zFIPezwY!Dok`>xtQYPi+y`K`;9a(x7>y@h{gLk*sbiMP8OCpp-k#@77Gv+0p0;x5X z+C#=bJy#;#G&?h{rSCE$g|}`f@CH6@b~-;Xs_gVMk&9RYx8IMx154JU_AdK7@2uEn z=9}+sJy~$gYKhK*A{huYw!FXi$+E@|izAZ^w^hb79p7Ec@lNN%8+7~ta$SQ(Lh6Gl zm;zEwpE~$kD3x|CsJ^7nRM6rKtK7Hs*4Y@0xs0&YW0k|a<$PIfj?6>tGie)iHR^i( z$C#H|lhSkhcbql#!mE-p2Ii#PO!l6ZCWKAn3e_xb9_TmHwPR&*YjwvKt-F@3N2_{? zbIY~cZuS-J(kCa&=Cdkle*Z-D8OP@iWnI35s4;Z4Q#IxG=aHK?uveo#*xj{(a8hZ~ zF|>wVRYki{0U5XeZ4)@~gx1U2Y#9SE1K3?({ z+x?y>>v$CsD5%7dAmhp`Kc9e2B2{%aAO=B2t+n zN`73UZbE6VTS2?mKCZKRJd`|Cy0@iidm&L6s zmDBe}o}=t^!|otIhzh~3VhR|1c=GbLY0N&>Gp)Mx5A7S{Sm%X>)8vArtv@4NWaTqi zvmDq-_b7)7InJ)Jtu$dIKhvnX;*esqINueJ?M$CMks>1_BllYG%hEh&Y@SF_PG3W{ zA!RRyTsP^5qK&e;!ZR*j*0nBC6Qnjyn?D3i6eAw)0qeDqAe?lCxYUWJV+q`NL_;isp zuO|XLpttpQ zQA<7;#1;;R!R!v+kDT`&Z|P18MOIqYZ4_!Xs^VxDE04AdFQbAkwX4QgOd0$EJrvgF4>(5nnzl1Q8&fOMVz}R z33siBCp=Ub1N-iyqz+=Aq|ko3!-!$~Np}2=-5Yft1w1M%(6CZ8c`7fX;%88xr=;iG zI~Q1JTx?W?23*Xr!Xw3QGhb}AuRh4zd5w?M;mdBNnhiVK;)v{HANhdC*f(fa_k)w3 zM0OVsWo7i269!zNT{p;2E}V+14dAmW=$jnuXj)ZeS5g-H%!ht~Q-~pcBU$vp%{@Y^GeeY;q{x33MUJf)DE&YI)8CKTN$jiy840VZk;)qk$$%?{ z;$--~J_bYQH;5Hl>J`Pr=f*?sonI?}Z%!l}v}#O_ER+w8n5=mWRh?1z?t|UnppNkX zma0zndAVMj^kPTTF6Jd-3_^8`H&e#O*pgqxF#EsP@W;pJNVSygeCBvyR6Ta1PJ!8e z@X#yr3Xdq`xifg;1KfO`%#?GO(aI&wRM120_N^FJs6PZsk$OHY|H@2Lk;P8-JX`hK zxLD@dRBDZGs@JgOkZOgA1g5F<5bRX#IHr##>FzkF8Wrh;GjqGw`ue^m-Z}#&i`VO1 zU{19Ngo=|omq&DWxnNrJhLUU93@@t?o8)wgyP9$#9`CI5lHBDb& z!4FHfK7fO6CD?3Y8th4h1VQi1l z!7lOP%p0Ux*W1P$i79U=*B>t4QCy5Z?-yuV{gBUFJ%Yms&(CXM%Igw03l5cM(mgU$ zN4+y150MHL(l~9_{AWb3Vli3?-pBM<)*^=Bwbi~hEr=|#4~O3WvG9!^UpvTZ>Xz^o z<@ucp;YM~$X*a0SC;cqyF-aqE9G>C9yg9&_H|`S9KH##!ngE^gdmu%O^#qGU3e!vo z`=zkJ@EJT|$S{VJuer^ce((G5uy6Zt+nm$JR(nHWgMZzNBo4DrpJ4b**@Kbdo3yx+4ILlFT*wn~DBp}t$y87X5SBMkPSJchbK{|2 z!(&{bHe9S;33XhWbup0$bw&&lhI^4$GB9(+6CwyRXevXcB5h}}&IP3E$6camp_&QM z2$?ca)gLsF0T09(#;M+-oaZ(s=JMY2$ut;vk)_U(FX(iho8)OIdz0$j@Vi>Yu`jTO z^;d4v61Kjfnx?h!thl5NwSpI7mlF+zR6kg5B$#4ecX@q%f^5x)sNVjIfjdJjo)@hb z-DEg@OC3wZc}?tlK12*pK#UfQD#X;d3%Cbb{?;LrDEB?f;P1**mFT#d}UrW<6 z-+oLc?axT5#K;<7>a8Meenp3wpSgzN@mpRaNxMrLLb~#Wj42>JCZZ@oh3IR{Wb!h! z;vyrrkusG+u0pP&nMwpXR{iSFnsXr?lt7y?Ik+SRTB(HLduAhDN@`;4@?+Uz>Zn>(f0peEwkd;3SH13cVYv zH-n+ZC_;}q4m zt9y0`cdqO+??Z6-16%@X2zQ4aoUT>-c?^&&FHTi-uZPUwu(+|j=#$Q#Ow#CP?I!3> z$G<@Ng|eUhl3lOuR0XYFB!>}4h@Oj0YX6JFGZ=G^Op$kq;mQCZs{38by`)owA zM3Iugt2PEah-Na+X zWnDMb3+oTg{ zC|xK`E)c4&D6dvqsa4h2vb{@W z7H$+?3e9<0BU5B9IgtG+n9oAp0T$r+uobGx5^%5?hs8kL;0rD4E&X5bii|vww&uhbNl5AvCJx#f)vM z^})w&QMZeEOA1`+m0z(D49NBA*01zy$rt!WT!TEGFR>h??3BIJ4AM*;{4f|;mcec2 zcFS#Y=|Nx8_Kw?cN}6H3}mWP2jJ$rGO|!{TEx!Uphi!`(_^2vHmFAjp@xx@pRs=F)?`C^yOafa=f6-L{2U8+u)Ang3;n^ zpR?IoR(8-tUajDc_d)8u;Z|$p(u(|7`IwYYL1*{#-#1*CEsf_Vcl|c^Pg~q*V-{@# z19q>psHlj(J<14#wpEotI)9tVkkeMVvV)zYp@WJY3Z-Oi?EvDG1wqi3wh}t6^0z6E zCj4z(AKUWBZ;4x=EJ2*gfZ1zp=xB*H>p2xbM|A*}yDVUU1Ewz;3UX}BLym2H$dT2J z2RX8`L6Bn$8-h44dCV~Mm<1@BT_q6o7zKKa0zF279^3BFV_O}1i~{%uM=u2Z^20a0WZp0seah(7|i{cN!U?;%P0{sIp_z5s{ zxBLMZ_X#j`=l%g0&j~QJqWu9F;%Bg<0r&@C$P-{__4@-bU_$yy`;TUWKS4V&2973` zKS4V&2#)5aKS4V&3XZ0@KS4V&431{XKS4V&4vr?=-=h8V9CTs~98KB31^WFY1gsxF zE5{!W0$>^X3GHYB`7Lk%+{hCn;Ajc@Ezs{92@J=d+4|S{|6kBfjDVvB@wdGFVt}@n^I@Tmpch_%qrct^vSM{2A?E7lD5k*$L%8vNV1x`+w=l6Uu*Nu>2P7 zpV>O0_eUnrZ-M@WtrNNmZ5E3{MRKWWyB=Fye!ry++-yDEA)ipE$UXBxcz{P(e7N^(kqf8yAvZH~+ zQC3j}sPi}`fsS|_KNLp)h_FeaESyjdW`_E=Q2<{@DLyfjy`i0%jf1rv9`|4FvA7km zrPRy{XrG+Ep^~+wzSVyz5@vSx4x*;|b|4^nzTU=Y`lHOK{oXpZaSInr1-7>xI`k{pTd zq#C0I|6k!A3;VXdB_Q^H=nM;e6ClZpPK^R@iU1j2JS}!4FmJNM5D*XqiQoZ34m>L=pf2c z6)1+tMWjFoG^&%yQGbG9z(NNog3Iw8AR;*45r@DoWE2$W z7J!AHLt{sTza??JDH#Idf$(tuC;tnB0Bh9$+{FBI{{4RK!#sMAPOeaio(1nzUKUy>CQ-3&|R*%#x>hD{z+ur z=IgDNY{8P2TPxIk#nYdf`(ooa%;Flq_ztkq2sn1>H7~kPZ&U`q+P>UUI=;Z6?IEJG zOmV4%AipR{Ag^$Q6Kp*ABDHYuOv{^Z&7s--uePi&4RLB~7U&GQ7I$m&9jL6jm-)V0 zQ_kir%-yZ_3VE@=k;%eizH9=1!r^tlz)6r(-$SgXZ0)JxL^q)@&o|t;G1-fj<b5| z7`rd9N^TsyZpp`>t`$;uo&@hkhe7`1SJM*mAvJ+)0c(?^#+u(N4ar+PW>N&#X!F2V zDO~Ut-`7!<`Q>g;fbNlzas`&hlgG|*ksHUcc_eL`bdYqu4<}z4)U^-Lf%Gj3W?UeB?xvzurDdX?Y#gI@Aa(75iQruMK z4PSd0<&~%Iv?e#yJ}3O8mz18*XN;%g;};q@;iZ^@Sq`hHX|7s!InzRz-e?u~{KWOJ zm~qcKYxm`DZL{U>xG_DBnL>YlX$DAcQG32`CxN2&P@Z;}H;#HV4^JSA>Xq5as*=j3 z2|wocu$3Yk)v*Uz4&lrQ-KpkEQl0DVo;;Rqo+CuacEgXBk9ug?LPbdhr47E5ON|T* zNYU(KH`g#f8p;tG-HHIgy-1~=3X)_z;g??X?Z=B}$2RL|6}^5)EwoF_;d!B9NX4(n z<3dBhE`!DXHtyK&tbc@M#9$$4#YGDDrr`O8LU})%{p5^Yh86$LRli~rqNy~u;8i3$ zaqZ57j+ci60f$8q&MUr&UT>6M6I60`r%h8lCHLwum?mtwqkut%!{2BO=e$x>p)QoV zH>!RYW9KUOZNL4X3PI5P2!p3z=obcKg&hF{)x=au&*@hdrUnEnTI%}|ujo3%hili; z=jZp!JW;8_cF}K?%h&LdB z)!2IUUDlR8qNd%59Y>2$bBy6BB{947Wa2!tp}=Jc>~sSJb8k%xhmUDJ826p=cW}$HJoNhe~9UOj~`)9Y# zE#7>VHHSsIk8{ftleFXGg~HS%Jg&8m4b?*5Cxs2DRtVxMgh&+VUdw*0xpR4Sg2aovS_Im5L?+NiD>LbP>x6s>U0sAO?3#|r9?|pel^zZb6|FN%RCJdu z*L3*>_}ty$w7PLmI~|;inHMNb1!C6spvw063aX99sq655{i~ZL2+8_|d_|HlQ3W+Q zg;?==VH{cqM_PyW0bK5lXJ!gi4s;IW4p%n!A z_{4YhBbDNhjjze)VuTlj)r5J3c!Z0*t$Zgi;q{vAH^;!PSMMo)wHq$Pr|b2Byug~R zCWiYtQIeVa-G^B>B|+m zC@##pZ}aQk?lIxNh@(6rF!G)&!s+|o%?a&%54&iuZT=)Ky7mQEbDpaUL;*y}F#NF> z?(@atrqN$NZ>PYkE^d6e#5i@sX)Sx2vsv&3sJf!-HJrwUJxJ1xA%&7|^`WHORIjc} z>HoN#s5*M~0G~{|jWVMWf0Vl)X8quBovi;8RMfCYYTM-HOR5g+evZ2%%q^;0SS2R* zl3w>9bjWX&hCI5kBGcDPOGfLn5v^PfX$bqsL$x1YpE)lE(v+0+Bz6hzx~)sTOsd(W zl(bvktO*x_H*xF@Z+?N`CH1Jq-IUfH%zq?0Xy-dhY{?5B{V}O~&XVHmqxQl6~>I9iIc{CUqBoEqMD(ayq>-`O3s6`JqGOJ^8%Y zua5@=XM2Lmow@7zUvfGPK?s}ewurU})J+eCA%g#{6Bv$UX_=I?zG))V5 z{>Vx?&}w>AikHSVTDbnn8|H(73ghS92bQ>_;DC+XvI`A&YG3gSa&hS$48=HeYF9aU zTYvEvZJxfg5RMUYrp|q5g{ff#8@u*`M}mfCJ$YJs^rf7{2h`-ZZ0PM8%SLIgaXqgu z9U5D(j)|m*t{Wu#(KK08xxutPT^ZX%pZKHYQ^$1AgYo6*91$wTQ4jKUVj*@eJho*N z&Ytx1f=MIfrQ$#&B-mj7O@0IIJMAi2%*(}BjP2Vnkw)IMFNFv-Kmj)*L@C-B@Mq(a z&4($$dw7q`)d?RC1SGgW#UsKiz*?Rd&2RYjrkn^*!nS2tw~J6IkPv#H+eK08UEWng zz;C%|=KET*7$lTa403T(Xkus}xMlU;fJ$T;V(U{SjC@CygRP0ffA+m-H;8f3uNC); z6fqIocU}x!(i<1reVBz?g%^bC&MP_8guS%~c|U)z_1Ng?_Uc=hU3od@Fv$7gdt==m z(-EI@j^vJI!Yq_9nd`-)qe=%O#TrT%K~NuX*~0^USLD@j<_{CKigkRW%P;n?mUTuO zD`NYHH_feU$94}6zc!<4BVy*w|NMZRm)4v_uHF=8y43DJgRIOH&c0`dVLmqb#W3_Vc5KUix^B=o!Ht5tR zusYoCx)R-3^Pb}`evPv?i3Q?oJEWWSBHF0SPCn#sJ2b*GVv=OP${YQCtq6s0okLPE;z3u&6|6qXh1|w9wHVQ#j-fBE} z4o6ZtpgiWSvjaG&$*}kF_iRk0IYJBldGtrjUUcei%q$`Z?4q`ZGyW+f*Q)Lb7XUgG! zY7|qjae#uMyhcecg*D?(QQR{{P*9yO-{9oHvuBJfCWr~(eJwgS)fuIuBC1@;;bjaZ zi)(Y*gU+l4mFLkTd9}7*EOCvj#5b-hSQrr9B>3KlD~Naz>ZE7MVo4l2`h(Y>yR9dc zywSA5RHk94%Vj@zxi{>V$fgrtTfP5$v;o%EnY{;k1Q!DG{pAKzQXdHWeiVOW^i@yg zP_gvkdrv*y6?Jt}+8#0darVT+uwoPWkn9c|%(N1lG=)WJ zXS(n9$ET*2D33EWQ%1eU^QamD?=M?6y-4W17^Lo!mlMbYQYE}U8!dK2{q_se)zP)< zHHw&o(Px;?H%VZ=h!nD5B&IpKOl1yK1J`1FBg`3GWg(_9-}y4L;@2=lM8D1e!i~V( z4zsdhR{TIL8^A-9unZ0d=Rw2Y(D)(}IriXo;F(X=gvmHk>n6>FrF#V2 zo=?2&8&0qjJLU(6U3$gRU{!mqO41lJW$bIXX<>&20ii^d{mW+ROF^5?gsld-lJYF? z*&g>MPZSQTJa4?aiA?jw=;-reTws~~I4qRS=~2uEj*+~{_NBJt(zebPAK6KY@6(wF@D)5- zTT@f#!47{=#o$dqIxH0#@WkuN$4?LCsRqK@9)-0@4Ma{bg)Tk{v0=W-d*#GOCYL0$ zA1HGC!CkmBJ(77>*j2i4jw#;86~sBELn_AyuQbOMTn!@HI}o*1^U&TPmk%X-5-gx+ zTM4#%zBqFQIX*ctA((XQ_U^0lT{)IbldP+eOI&;3KRLj7Yw#Lzofan|7BM_;&#r5^ zbojU?8bRV(&s&}aXGDIN#lLYe?y2{g)mQpO1a3yQu|bdUA60yMQ~`FxAfY6-{oj9L z-(Mv)p-P;~n1;-0%%l_ z{;LX(*wd_jlpAK!(p6RwjQ;NO|5$IaF=Tco`#(H>8z z?%kb{Q?A(G=O$*)z8%HWyQXX;!ESZ8Lb1WLF3$+7+CpAqNHm1KA6SzUeZd~^QO9Uc;)`n-AI8%3s0H=IICow%?IC&=M%zR zK?LheUS3pli=-} z@xEXSp-a;|u=R^=yYD72f;eNjn;y4kO#X9ny( zp56d-IxBS?4*U05ndra8%Ki%asaW5!GCMkf&5e#00lR#DijV;znEyn`fH2aD0NIHc z#ACWNk6^LL<_GZ`(!EH^0TYtF9%r?lV~NWen$$ zeWa2_eWyD(|MiYM|HBI#q3JZ>MzS`pLR-TC@HDNI1Lc?cxtV@g`7ooAcYsG%#THEb zo#vUgU7!4TX9WK@#I)#u?#NY~gsCmp%Lz~mR*xy4XyNmQZ)Q{q-O84lIdEU5E=*7g z&K_vz)HSsx6U(HFI0(jQZ&ffaN3eHYD^-%1w2}brc@1KO^hLgQkQh>w8F_N(cwMv3 zrD&FW{(aVJDtW(Q8pkL_WxCo4ITD8 z5oG&0(eQVW4Z?!}!g+sv4*&wln*FQx6x@-$by4`z4-@D8GtU)VAKhrPy6!(5rMgZM z3Slb6W~3$~s-|l?r<#*0R7}igdVl>T&P=m!OFB;Ya`O#s(9|< z+3?|ZmBPCfd-X*TNnCwILCFWyP&n5;m%UrQ9$lfU>QoNi4RP)j%eIA5Nnru45HEhK zClcnIhsKJLGilB>&Xv!sC#%zFu(VcF?<~=FUN7<~kt{8r>8JJ#c3~}T&x89e7Wjj5WG`N@egrrjQv*wla;k4y}tRs?p^C5Br;NsvM@56IT-2IC? zOwUO$$w&m0$flZ}$=wkh)oMxp#69L|V3K1=V%i*eQ|DTYLbQc|;frdpA2w~aim8Ff zQb|)-?NiNLYPXtcFLA{Ppsw&3OJ5EXdjsCiFz79Q(t2N3xuBF||9R?itb*jUWAWLg ztT4RY8oY=ww#vW^Ap?aMO^-!K3A(PMjM$QTQFrdV9Bhv;E-*5>GZaa_6^RKEtPMtD zch)OE3K+lMnBz@aWwwz}?DzQjD}#iWfsYZ%apqhbv=9Ta=96c=KhbTqy#T>hcgKIWv*J(&9xp6d4H^PE#2?%CeGK$S_+ z{_p^vHYMR>ceg@^I@xYkTVN7q6_a941Hn-Rir zpFGL-l@8nVE!-}-IptiH@Qa2HO*c^y<=u1w_h$}TW?w6IhR+w$d>u*`TrA9v{~wdp ziS(VB0}!mg2IScwtU%hx&f3V)5cmp@YnJ+k^2#7pl%2hqwG{{g*yqyivuejrzr5{9zezhbnPes1t1;~00=SknX7AJyihQd z3j&2AfiwUN%%cegvj88UoSe1M?~D9&g3QGZWeg-txViDb|M>xN!{NXVQDe|wG%h$g zJCFVWS^Y(WfZ^z5?+F@kgHElSq;UaQztXs2JipR_qz3|+?oPZ5fpa5&#RJNrw?mvL z2j=2IFRdqO+;Hw+@xa`0^d8?|${|me;{l^L#-1$413~ZR{gsA1g~tQs2JDev%5kCh zO8i2Dp?CTIN<#t}!e40cQ?df{aHCV>zm(%a@7nr>h5(<&Lm*DK?SIGs0X{8f1O&Z5 z@?;$d2s(lG3k}M1s%;1^^qz%Z%E3Gohk?CIn@pX(3z*o@jy@4fdHTC4+H{8 zIsVEE5}oop$sh86=m8P}K2--20;KJJeHV((7XE_Ah2Hq|3k`T?Jfa;ncEVCbnnhk&_G^*IC# zJJsg^?Npybz^B^_fj~~l3Ic(hnsXrBkkd3c;#40&xM8Q;%ft2acyqAR2a=+8M_l2Ui2XXIM8co=iq3605_mwM>k?XuAI*Z422tTL*d*Im?1iAH*qN|*09J~lSsTIw%*%L8Oycqq|9I^9zvqYnZh)-!&j*Rohl5Wa zM7FcGIXZWY$AjPi<}x5v4Mo5?5M1bNIt0uC2Ltve4-Xdy6buL+jbQD7UXFldvV#84 zN1RWdX#Q!%ITFm@ZqT1Ck~cuYHa5U%4Pe1Tfgl`^zZcE_`x*&H{=JL>=b%q4=fAGT z|J~K`*Afc-=M@x!1ct(YMAe!zTjx0DujE5Qd9Dz@p-C2pmYf^FX cz&RB3;(kJ9ft@VCH;es8%aAZI>@O|*e+5i9aR2}S literal 0 HcmV?d00001 diff --git a/joss_paper/Fig2.pdf b/joss_paper/Fig2.pdf new file mode 100644 index 0000000000000000000000000000000000000000..c36d291f41321b504f16d2582ac14a7df669aaa8 GIT binary patch literal 15761 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 LfPq2!zRdps@dSH% literal 0 HcmV?d00001 diff --git a/joss_paper/paper.md b/joss_paper/paper.md index 981d4b16..1401a11d 100644 --- a/joss_paper/paper.md +++ b/joss_paper/paper.md @@ -29,37 +29,42 @@ bibliography: paper.bib # Summary -alchemlyb is a dedicated open-source software package tailored for the analysis of alchemical free energy calculations, an integral part of computational chemistry and biology, notably in the field of drug discovery. The software spans a wide range of functions, starting with the extraction of raw data from Molecular Dynamics (MD) engines, moving on to data preprocessing tasks such as decorrelation, using various estimators to derive free energy estimates, and finally providing quality analysis tools for data convergence checking. +*Alchemlyb* is a dedicated open-source software package tailored for the analysis of alchemical free energy calculations, an integral part of computational chemistry and biology, notably in the field of drug discovery. The software spans a wide range of functions, starting with the extraction of raw data from Molecular Dynamics (MD) engines, moving on to data preprocessing tasks such as decorrelation, using various estimators to derive free energy estimates, and finally providing quality analysis tools for data convergence checking. -A distinctive attribute of alchemlyb is its streamlined, end-to-end analysis process reminiscent of the now-discontinued alchemical analysis workflow. This user-friendly workflow facilitates navigation through the entire analysis pipeline, from the initial data input stage to the final result derivation, enabling researchers from diverse scientific backgrounds, and not solely computational chemistry specialists, to utilize alchemlyb effectively. +A distinctive attribute of *alchemlyb* is its streamlined, end-to-end analysis process reminiscent of the now-discontinued [alchemical-analysis.py](https://github.com/MobleyLab/alchemical-analysis) workflow. This user-friendly workflow facilitates navigation through the entire analysis pipeline, from the initial data input stage to the final result derivation, enabling researchers from diverse scientific backgrounds, and not solely computational chemistry specialists, to utilize alchemlyb effectively. # Statement of need -In the pharmaceutical sector, the utilization of computational chemistry techniques is integral for evaluating potential drug compounds based on their protein-binding affinity [@deng2009computations]. Notably, relative/absolute binding free energy calculations are routinely employed for this purpose [@merz2010drug]. The resultant free energy data is essential for understanding binding affinity throughout various stages of drug discovery, such as hit identification and lead optimization [@merz2010drug]. The alchemlyb software adeptly processes this data, providing crucial insights and establishing itself as an indispensable asset in computational chemistry. +In the pharmaceutical sector, the utilization of computational chemistry techniques is integral for evaluating potential drug compounds based on their protein-binding affinity [@deng2009computations]. Notably, relative/absolute binding free energy calculations are routinely employed for this purpose [@merz2010drug]. The resultant free energy data is essential for understanding binding affinity throughout various stages of drug discovery, such as hit identification and lead optimization [@merz2010drug]. The *alchemlyb* software adeptly processes this data, providing crucial insights and establishing itself as an indispensable asset in computational chemistry [^1]. +[^1]: As of 29/12/2023, *alchemlyb* has been downloaded 23,922 times from [conda-forge](https://anaconda.org/conda-forge/alchemlyb/files). In the realm of computational research, various molecular dynamics (MD) engines, including GROMACS [@pronk2013gromacs], AMBER [@case2014ff14sb], GOMC [@cummings2021open], and NAMD [@phillips2020scalable], offer distinct tools for conducting free energy calculations. However, the diversity in output formats and analysis tools among different MD engines complicates the research process. Data generated by each engine requires unique processing and analysis methods, hindering seamless collaboration and comparison of results. -Addressing this complexity is the "alchemical–analysis.py" tool [@klimovich2015guidelines], which precedes alchemlyb. Although "alchemical–analysis.py" has been deprecated, alchemlyb continues to provide a unified, engine-agnostic analysis workflow. Unlike its predecessor, alchemlyb breaks down components into individual tools, allowing users to customize their analysis. This innovation enables consistent processing of free energy data from diverse MD engines, facilitating streamlined comparison and combination of results. +Addressing this complexity is the [alchemical-analysis.py](https://github.com/MobleyLab/alchemical-analysis) tool [@klimovich2015guidelines], which precedes *alchemlyb*. Although [alchemical-analysis.py](https://github.com/MobleyLab/alchemical-analysis) has been deprecated, *alchemlyb* continues to provide a unified, engine-agnostic analysis workflow. Unlike its predecessor, *alchemlyb* breaks down components into individual tools, allowing users to customize their analysis. This innovation enables consistent processing of free energy data from diverse MD engines, facilitating streamlined comparison and combination of results. -Notably, alchemlyb's robust and user-friendly nature has led to its integration into other automated workflow libraries such as Biosimspace [@hedges2023suite]. This further enhances its accessibility and usability within broader scientific workflows, reinforcing its position as a versatile and essential tool in the field of computational chemistry. +Notably, *alchemlyb*'s robust and user-friendly nature has led to its integration into other automated workflow libraries such as Biosimspace [@hedges2023suite]. This further enhances its accessibility and usability within broader scientific workflows, reinforcing its position as a versatile and essential tool in the field of computational chemistry. # Implementation The binding free energy of a drug within a protein is defined as the disparity in free energy between the drug's end-state in the protein's binding pocket and its alternative end-state in a solution, typically water. Absolute binding free energy calculations employ a thermodynamic cycle that establishes a connection between these two end-states through two alchemical legs, namely the bound and free legs (Figure 1). In the bound leg, the drug is decoupled from the binding pocket, while in the free leg, the same drug is decoupled from the solvent. The resulting free energy difference represents the energy required to transfer the drug from the solvent to the protein binding pocket, constituting the binding free energy of the drug. -To determine the free energy difference associated with decoupling a drug from its environment, it is essential to ensure sufficient overlap in phase space between the coupled and decoupled states, a condition often challenging to achieve. Overlapping is facilitated by introducing a parameter lambda that connects the two end-states, leading to the creation of a series of intermediate states. Molecular dynamics (MD) engines are employed to simulate the system at these states, generating and accumulating free energy data. +![The thermodynamics cycle of Absolute binding free energy calculation](Fig1.pdf) -Alchemlyb offers specific parsers designed to load raw free energy data from various MD engines, converting them into standard pandas dataframes. Two types of free energy data are considered: potential energy differences between adjacent lambda states, suitable for free energy perturbation (FEP) methods [@zwanzig1954high], and dU/dlambda at all lambda states, suitable for thermodynamic integration (TI) methods [@kirkwood1935statistical]. +To determine the free energy difference associated with decoupling a drug from its environment, it is essential to ensure sufficient overlap in phase space between the coupled and decoupled states, a condition often challenging to achieve. Overlapping is facilitated by introducing a parameter lambda ($\lambda $) that connects the two end-states, leading to the creation of a series of intermediate states. MD engines are employed to simulate the system at these states, generating and accumulating free energy data. -In alchemlyb, TI [@paliwal2011benchmark] and TI with Gaussian quadrature [@gusev2023active] methods are implemented in the TI category. Perturbation category methods include Bennett Acceptance Ratio (BAR) [@bennett1976efficient] and Multistate BAR (MBAR) [@shirts2008statistically]. These methods necessitate uncorrelated samples, and alchemlyb provides tools for data resampling based on autocorrelation times [@chodera2007use]. +*Alchemlyb* offers specific parsers designed to load raw free energy data from various MD engines, converting them into standard pandas dataframes. Two types of free energy data are considered: potential energy differences between adjacent lambda states (u_nk), suitable for free energy perturbation (FEP) methods [@zwanzig1954high], and $dU/d\lambda $ at all lambda states, suitable for thermodynamic integration (TI) methods [@kirkwood1935statistical]. -To evaluate the accuracy of the free energy estimate, alchemlyb offers specific assessment tools. The error of the TI method is correlated with the average curvature [@pham2011identifying], while the error of perturbation methods depends on the overlap in sampled energy distributions [@pohorille2010good]. Alchemlyb visualizes the smoothness of the integrand for TI methods and the overlap matrix for perturbation methods. Additionally, the accumulated samples should be at an equilibrated state, and alchemlyb allows for plotting the convergence of the free energy estimate as a function of simulation time [@yang2004free] to detect potentially un-equilibrated data. +In *alchemlyb*, TI [@paliwal2011benchmark] and TI with Gaussian quadrature [@gusev2023active] methods are implemented in the TI category. Perturbation category methods include Bennett Acceptance Ratio (BAR) [@bennett1976efficient] and Multistate BAR (MBAR) [@shirts2008statistically]. These methods necessitate uncorrelated samples, and *alchemlyb* provides tools for data resampling based on autocorrelation times [@chodera2007use]. +To evaluate the accuracy of the free energy estimate, *alchemlyb* offers specific assessment tools. The error of the TI method is correlated with the average curvature [@pham2011identifying], while the error of perturbation methods depends on the overlap in sampled energy distributions [@pohorille2010good]. *Alchemlyb* visualizes the smoothness of the integrand for TI methods and the overlap matrix for perturbation methods. Additionally, the accumulated samples should be at an equilibrated state, and *alchemlyb* allows for plotting the convergence of the free energy estimate as a function of simulation time [@yang2004free] to detect potentially un-equilibrated data. -Alchemlyb offers all these tools as a library for users to customize each stage of the analysis (Figure 2). Additionally, alchemlyb provides an automated end-to-end tool that reads in the raw input data and performs the decorelation, estimation, and quality plotting of the estimate. This automated workflow allows users to experience a similar process as “alchemical–analysis.py" [@klimovich2015guidelines], which is the predecessor of alchemlyb. + +*Alchemlyb* offers all these tools as a library for users to customize each stage of the analysis (Figure 2). Additionally, *alchemlyb* provides an automated end-to-end tool that reads in the raw input data and performs the decorelation, estimation, and quality plotting of the estimate. This automated workflow allows users to experience a similar process as [alchemical-analysis.py](https://github.com/MobleyLab/alchemical-analysis) [@klimovich2015guidelines], which is the predecessor of *alchemlyb*. + +![The building blocks of *alchemlyb*](Fig2.pdf) # Acknowledgements