main.tex 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. \documentclass[a4paper]{article}
  2. %% Language and font encodings
  3. \usepackage[english]{babel}
  4. \usepackage[utf8x]{inputenc}
  5. \usepackage[T1]{fontenc}
  6. %% Sets page size and margins
  7. \usepackage[a4paper,top=3cm,bottom=2cm,left=3cm,right=3cm,marginparwidth=1.75cm]{geometry}
  8. %% Useful packages
  9. \usepackage{amsmath}
  10. \usepackage{graphicx}
  11. \usepackage[colorinlistoftodos]{todonotes}
  12. \usepackage[colorlinks=true, allcolors=blue]{hyperref}
  13. \begin{document}
  14. \begin{center}
  15. Response Letter
  16. \end{center}
  17. Dear Editor,
  18. \vspace{10pt}
  19. We thank the referees for the detailed reports and constructive comments for our manuscript
  20. entitled ``Mie calculation of electromagnetic near-field for a multilayered sphere''
  21. by K. Ladutenko, U. Pal, A. Rivera and O. Pe\~na (CPC manuscript CPC-D-15-00354).
  22. We have try to address all the comments and the detailed response to all the comments
  23. as well as the summary of the changes made to the manuscript are included below. All
  24. the changes in the manuscript are marked in green.
  25. \vspace{10pt}
  26. \\
  27. Sincerely Yours,\\
  28. On behalf of the authors,\\
  29. %TODO add name
  30. \vspace{10pt}
  31. \newpage
  32. \textbf{Reviewer \#1 comments}
  33. \vspace{0.5em}
  34. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  35. \quad & There are several alternatives currently available, Mathematica GLMT Scripts, for example. It provides both near- and far-field results for multilayered sphere. Moreover, Mathematica can handle Bessel functions up to arbitrary precision without any difficulties, and the code is very transparent and compact.
  36. \end{tabular}
  37. \vspace{0.5em}
  38. We are aware of Mathematica GLMT Scripts and although it has interesting posibilities, we consider that both codes are not exactly comparable and, in any case, our code has some advantages:
  39. \begin{itemize}
  40. \item It should be noted that the authors of Mathematica GLMT regularly use Scattnlay [M. Selmke, M. Braun, F. Cichos, arXiv:1105.3815v1 (2011); M. Selmke, M. Braun, F. Cichos, arXiv:1109.2772 (2011); M. Selmke, M. Braun, F. Cichos, ACS Nano 6 (2012) 2741–2749; M. Selmke, F. Cichos, J. Opt. Soc. Am. A 31 (2014) 2370–2384; M. Selmke, J. Quant. Spectrosc. Radiat. Transf. 162 (2015) 175–183] and their scripts (at least the initial versions) were heavily based on our code. Indeed, even now most of their varibles use exactly the same names than Scattnlay. Hence, it is safe to say that Mathematica GLMT is a derivative work of our code, even if both projects have diverged over time.
  41. \item You need to buy Mathematica license to use this script, which limits the availability of the code.
  42. \item As it is published at \verb+http://photonicsdesign.jimdo.com/software/+ it does not provide any appropriate license conditions. Particularly, it is not clear if the code can be distributed, to modified (e.g. to put your own model parameters) or usable for academic or corporate research, etc. Our code Scattnlay is distributed under GPL (version 3) --- a well-known permissive license for open source software.
  43. \item This script does not provide near-field evaluation inside the particle, at least none of the provided examples have it. This is trivial (and indeed it is possible with any Mie-type code) because for the calculation of the near-field outside the particle one only needs the scattering coefficients.
  44. \item Mathematica GLMT does not use Mathematica's ability to provide arbitrary precision for calculation of Mie coefficients for multilayer sphere. Actually GLMT Script itself references our previous paper in CPC, and uses the same evaluation of spherical functions via series with the same error due to $N_{\mathrm{stop}}$ selection. Equations needed to do the evaluation of the near-field distribution inside the multilayered spherical particle are provided in our present manuscript and, to the best of our knowledge, those optimized expressions are not currently available anywhere else.
  45. \end{itemize}
  46. The only code known to us that provides similar posibilities is MSTM by Mackowski and Mishchenko. However, it uses the T-matrix approach to do the evaluation (which is considerably less efficient for the case of concentric spheres) and has no usage license defined. Actually, we have verified our code against MSTM results too but choose not to include them in the manuscript due to abovementioned license restrictions of MSTM.
  47. \vspace{0.5em}
  48. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  49. \quad & The only advantage I see of the algorithm presented here is the speed, since it is implemented in the newest C++ language. But, to prove it benchmarking should be performed.
  50. \end{tabular}
  51. \vspace{0.5em}
  52. We have dedicated a lot of effort in order to improve the speed and accuracy of our implementation. For instance, we have done an extensive optimization of the previous code that lead to more than a two-fold speed-up. However, this is by no means the main point of the manuscript. We thank the reviewer for the comment because it shows that our initial version of the manuscript does not stress the novelty enough. Some aspects of our work not available anywhere else are:
  53. \begin{itemize}
  54. \item We have provided for the first time explicit expressions for Mie expansion coefficients inside the sphere.
  55. \item We have proposed the calculation of the vector spherical harmonics in terms of the Ricatti-Bessel functions and their logarithmic derivatives and have proven the correctness of this approach.
  56. \item We have verified the accuracy of the resulting implementation by the comparing its results against similar other codes and full-wave 3D simulations.
  57. \end{itemize}
  58. The manuscript has been modified in order to clarify the novelty.
  59. %TODO - stress novelty in the abstract, manuscript, and in the conclusion:
  60. \vspace{0.5em}
  61. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  62. \quad & For currently presented test runs only core-shell structures are selected. The last example is, actually, from the same authors, which looks really confusing, since, I guess, they've used exactly this code. So, they are test themselves with the same code - kind of weird.
  63. \end{tabular}
  64. \vspace{0.5em}
  65. Near-field calculations in our previous paper were obtained with full-wave commercial 3D electromagnetic simulation software CST MWS because this calculation was not available in Scattnlay at this time. Actually, this work inspired us to develop the near-field calculations in Scattnlay. However, the comment is very relevant bacause the lack of clarification in our manuscript can easily lead to misunderstanding. We have modified the manuscript after the corresponding reference ``reported recently [10]'' to include the following sentence ``, where we obtained near-field distribution using full-wave commercial 3D electromagnetic simulation software CST MWS[TODO add link to cst.com in references ]''. Hopefully this will avoid confusions with this comparison.
  66. On the other hand, we restricted ourselves mostly to compare against core-shell cases due to the lack of analytic software (including usage statements in the software license) to calculate the near-field of multilayered spheres but it should be noted that the results shown in Figure 4b correspond to a PEC sphere covered by 32 dielectric layers. There we verified the multilayered case against full-wave simulation done with finite-element method using CST MWS and finite-difference time-domain method using Lumerical FDTD. After doing this we are pretty sure that our code provides correct results (at least for the tested range of input parameters). As it was stated in ``Restrictions'' line of ``Program description'' section large complex part of layers refractive index leads to convergence problems. Note that usage of full-wave 3D simulation required 4-5 orders of magnitude more computational resources (time) to get e.g. total scattering cross-section with a comparable accuracy.
  67. \vspace{0.5em}
  68. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  69. \quad & Also, in Fig. 2 they compare published and their results. But in all other figures they show only their results and refer to the literature for comparison. They should present all test and original results in the current manuscript.
  70. \end{tabular}
  71. \vspace{0.5em}
  72. In Fig.2 we are not comparing with published results. Instead, we have downloaded the BHFIELD code developed by Suzuki and Lee and calculated the same example with our codes and with referenced software. To make it cleared we have changed the manuscript: instead of ``For this, we calculated electric and magnetic fields for the example provided with their computer code'' we write ``For this, we calculated electric and magnetic fields using the example provided with their computer code''. As for other figures, we only reference the relevant papers (see the corresponding references) because we do not have permission to reprint figures from those journals.
  73. \vspace{0.5em}
  74. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  75. \quad & On another note, since there are plenty of Mie based simulators which can be found at scattport.org I would encourage the authors to add GUI to their code to provide more flexibility and user-friendly environment. Otherwise, it's easier to code generalised Mie solution in Mathematica, which is perfectly suitable for it, and I don't see any advantage of the current program compare to others. Near field can now also be accessed in other programs I've mentioned and found at scattport.org
  76. \end{tabular}
  77. \vspace{0.5em}
  78. We have checked each and every program listed at ``Mie type codes'' section (\href{http://www.scattport.org/index.php/light-scattering-software/mie-type-codes}{link}\footnote{http://www.scattport.org/index.php/light-scattering-software/mie-type-codes}) of Scattport before starting the development of our code (fall of 2014). While the software list is very large, most of the listed codes re-implement Mie solution as it was published in classical book of Bohren and Huffman ``Absorption and Scattering of Light by Small Particles'' (usually referenced as BHMIE) or re-implement MIEV0 code by Wiscombe. The few original approaches that we found were referenced in the manuscript as [11-18,22,23]. Note, that most of these implementations cannot evaluate field distribution inside the particle and those who can are restricted to the case of particles with one (bulk sphere) or two (core-shell) layers.
  79. We totally agree with the reviewer in that it is a good idea to provide a GUI and such interface, named \href{http://www.scattport.org/index.php/programs-menu/mie-type-codes-menu/391-mielab}{MieLab}\footnote{http://www.scattport.org/index.php/programs-menu/mie-type-codes-menu/391-mielab}, exists for our previous code (restricted to far-field calculations). We have every intention of expanding MieLab to cover near-field calculations but this will not be inmediately because adding a GUI is a very time consuming task and we have no funding for this task. Moreover, it should be noted that the paper describing our previous GUI-less code has more than 50 citations at the moment as it is listed in Scopus database. Hence, we beliebe that this code and the accompanying manuscript are valuable even without GUI. As an intermediate solution we provide bindings to Python language, which are the part of the released code. It can provide good enough plotting (see figures 2,3, and 4 in the manuscript) via MatPlotLib module and Python syntax is about the same complexity as used by Mathematica or Matlab. However, unlike those programs, Python can be used free of charge.
  80. \newpage
  81. \section{Reviewer \#2}
  82. First of all we would like to thank this reviewer for his/her detailed review and would like to add to the ``Acknowledgements'' section the following text ``The authors thank the anonymous reviewers for their valuable comments.''
  83. \vspace{0.5em}
  84. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  85. \quad &
  86. The paper does not make any claim to originality as far as the algorithm is concerned.
  87. \end{tabular}
  88. \vspace{0.5em}
  89. COPY-PASTE from the answer to reviewer 1: We have dedicated a lot of effort in order to improve the speed and accuracy of our implementation. For instance, we have done an extensive optimization of the previous code that lead to more than a two-fold speed-up. However, this is by no means the main point of the manuscript. We thank the reviewer for the comment because it shows that our initial version of the manuscript does not stress the novelty enough. Some aspects of our work not available anywhere else are:
  90. \begin{itemize}
  91. \item We have provided for the first time explicit expressions for Mie expansion coefficients inside the sphere.
  92. \item We have proposed the calculation of the vector spherical harmonics in terms of the Ricatti-Bessel functions and their logarithmic derivatives and have proven the correctness of this approach.
  93. \item We have verified the accuracy of the resulting implementation by the comparing its results against similar other codes and full-wave 3D simulations.
  94. \end{itemize}
  95. The manuscript has been modified in order to clarify the novelty.
  96. \vspace{0.5em}
  97. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  98. \quad & The authors’ citation list does acknowledge some of this earlier work.
  99. The first recursive algorithm for the multi-layered sphere known to this
  100. reviewer was published by Wait [2] in 1963, although this work does not
  101. address the numerical issues tackled by the approach of Yang. The algorithm
  102. is described in a 1970 textbook [3].
  103. \end{tabular}
  104. \vspace{0.5em}
  105. We already provided Ref.~13 in the manuscript to Wait's paper. However, we found a small typo in our manuscript that has been corrected. According to the journal`s web-site the Wait paper was published in 1962 \href{http://link.springer.com/article/10.1007/BF02923455}{http://link.springer.com/article/10.1007/BF02923455}).
  106. \vspace{0.5em}
  107. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  108. \quad &
  109. The introductory section of the write-up includes an incidental citation of the
  110. authors’ reference [18], which is a paper on the T-matrix method. This re-
  111. viewer understands the T-matrix method as being applicable to a collection
  112. of spheres side-by-side, not to a multi-layered sphere defined by concentric
  113. spherical shells. If the authors agree, reference [18] should be omitted.
  114. \end{tabular}
  115. \vspace{0.5em}
  116. No, the only restriction of T-matrix formulation as stated in Ref.~18 is that spheres surfaces should not intersect. This way it is quite legal to use several spheres embedded into each other to simulate a stratified sphere, which is an object of interest in the presented manuscript and this way is highly relevant to the subject of our work. However, T-matrix is considerably less efficient than Mie theory for the case of concentric spheres. Moreover, MSTM does not provide any appropriate license condition, particularly it is not clear if is it valid or not to distribute, modify (e.g. to put your own model parameters) or use this code for academic or corporate research, etc. Scattnlay is distributed under GPL (version 3) --- a well-known permissive license for open source software. See the details at the MSTM web-page \href{http://www.eng.auburn.edu/~dmckwski/scatcodes/}{http://www.eng.auburn.edu/~dmckwski/scatcodes/}
  117. \vspace{0.5em}
  118. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  119. \quad &
  120. This reviewer approves of the level of detail provided by the authors in
  121. their derivation of the background theory and their algorithm. However, he
  122. makes the following suggestion to improve the logical progression of the de-
  123. velopment and to avoid the near-repetition of the definition of the spherical
  124. waves occurring in equations (2.1)–(2.4) and (9.1)–(9.4).
  125. First, the reader could be given more guidance to the source of the
  126. definitions by including the section in the citation of Bohren and Huffman
  127. and the continue as follows: “Vector spherical harmonics can be calculated
  128. using the expressions [12, Section 4.3], re-stated in terms of Ricatti-Bessel
  129. functions for numerical reasons [17] as. . . ” followed by equations (9.1)–(9.4).
  130. The definitions of $r_{n}$ , $\psi_{n}$ , $\zeta_{n}$ , $D^{(1)}_{n}$ and $D^{(3)}_{n}$ should be given at this early
  131. point in the presentation so that they are ready to be used in equations
  132. (5.1)–(5.4), (6.1)–(6.4) and (7.1)–(7.4), rather than being left until later.
  133. If the authors choose to leave equations (2.1)–(2.4) as they occur in the
  134. submitted version of the paper, they should correct the inconsistency in
  135. notation: superscript (j) is used in (2.1) but (i) is used in (2.2)–(2.4).
  136. \end{tabular}
  137. \vspace{0.5em}
  138. We have modified the paper according to the referee suggestion and further simplified eq. 6.1 - 7.4 (now eq. 7.1 - 8.5). We are very grateful for this suggestion since the explanation is now clearer and much more compact.
  139. \vspace{0.5em}
  140. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  141. \quad & This reviewer failed to reproduce the derivation of equations (6.1)–(6.4)
  142. until he realised that there is a typographical error in equation (7.4), which
  143. should read
  144. \begin{equation*}
  145. T_4(m_{l+1}x_l) = c^{(l+1)}_{n} D^{(1)}_{n}(m_{l+1}x_l) \psi_{n}(m_{l+1}x_l)
  146. - b^{(l+1)}_{n} D^{(3)}_{n}(m_{l+1}x_l) \zeta_{n} (m_{l+1}x_l)\:,
  147. \end{equation*}
  148. The authors must correct this error and confirm that the correct T 4 has been
  149. used in the code.
  150. \end{tabular}
  151. \vspace{0.5em}
  152. Thank you for pointing this out, for sure this is a typo which we had corrected in the updated manuscript. The code has the correct equation from the beginning ( \href{https://github.com/ovidiopr/scattnlay/blob/c72d4e94dee437cb6a4f170580dc13a4a4638f05/src/nmie-impl.hpp#L960}{link} \footnote{https://github.com/ovidiopr/scattnlay/blob/c72d4e94dee437cb6a4f170580dc13a4a4638f05/src/nmie-impl.hpp\#L960 } goes to the exact position in the code). Our derivation with the correct equation is also available \href{https://github.com/ovidiopr/scattnlay/blob/c72d4e94dee437cb6a4f170580dc13a4a4638f05/doc/EvalField.ipynb}{online}\footnote{https://github.com/ovidiopr/scattnlay/blob/c72d4e94dee437cb6a4f170580dc13a4a4638f05/doc/EvalField.ipynb}, see the output of the cell at the end of the file just after the word ``Finally''. The result was re-checked by substituting into initial equations and the error was corrected in the revised manuscript.
  153. \vspace{0.5em}
  154. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  155. \quad &
  156. The authors have repeated the misunderstanding of Yang [1] regarding
  157. the justification of the boundary conditions at the centre of the sphere:
  158. $a_n^{(1)} = 0$ and $b_n^{(1)} = 0$. The correct reason is given by Bohren and Huffman [4]
  159. in their Sections 4.3 and 8.1. The point is that only the $j_n (kr)$ dependence
  160. gives a finite, non-singular behaviour at the origin, and so can be the only
  161. radial dependence occurring in the spherical wave expansion of the fields
  162. in the core, region 1. A radial dependence of $j_n (kr)$ represents a standing
  163. wave, that is, a superposition of both incoming and outgoing waves.
  164. \end{tabular}
  165. \vspace{0.5em}
  166. We would like to thank the reviewer for provided explanation and we will add the discussion about the singularity of Bessel functions to the manuscript. It is clear now, that this part of the manuscript was badly written, a more correct way is to say ```Absence of outward waves that enter the inner layer from the central point gives an additional condition for the expansion coefficients:'''
  167. TODO We should add this description to the manuscript too.
  168. \vspace{0.5em}
  169. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  170. \quad &
  171. The authors mention that the code can accommodate a perfectly-conduct-
  172. ing shell. Perfect conductor (PEC) is an idealisation that must be distin-
  173. guished from real conductors. The only place a PEC layer should appear in
  174. the model is at the core. It is futile to enclose other materials inside a PEC
  175. shell since such a shell would exclude all fields from its interior.
  176. There are several omissions from the reference list.
  177. \end{tabular}
  178. \vspace{0.5em}
  179. gsdfgsdf
  180. \vspace{0.5em}
  181. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  182. \quad &
  183. No DOIs are given for [8], [9] and [22] and no ISBN is given for [12]. Several authors have second
  184. initials which have been omitted: J.R. Wait for [13] and M.V. Bashevoy,
  185. V.A. Fedotov and N.I. Zheludev for [20]. The final page number for [19]
  186. should be given; this reviewer cannot ascertain whether it is 4735 or 4736
  187. since he does not have ready access to the full paper. The full citation
  188. for [21] is Nat. Commun. 5:3402(2014). [26] appears to be an unpublished
  189. report, so readers should be told how to access it; a URL should be given.
  190. \end{tabular}
  191. \vspace{0.5em}
  192. \vspace{0.5em}
  193. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  194. \quad &
  195. The Code Package
  196. This reviewer has successfully compiled the standalone programs and run
  197. the supplied tests. However, he has failed to compile the python and cython
  198. extensions.
  199. The authors should put much more effort into providing a greatly ex-
  200. panded README file, the first place any new user would look. Step-by-step
  201. instructions should be provided in detail for the compilation of the various
  202. programs in the package including any unusual dependencies on external li-
  203. braries and commands. Step-by-step instructions for running the programs
  204. should also be given, with an explanation of the command-line arguments
  205. and expected outputs.
  206. \end{tabular}
  207. \vspace{0.5em}
  208. \vspace{0.5em}
  209. \begin{tabular}[!H]{l|p{0.9\textwidth}}
  210. \quad &
  211. Recommendations
  212. This paper and code should not be published in their present form.
  213. They may be suitable for publication if the authors accept the sugges-
  214. tions and undertake the extensions and revisions described above.
  215. The editors should refer any revisions to this reviewer to confirm that
  216. the authors have acted on his suggestions and taken his recommendations
  217. seriously.
  218. The authors have chosen to use make their code publicly available on
  219. the Web as well as submitting it to the CPC Library. The editors must
  220. confirm that this action does not prevent the addition of the code to the
  221. CPC Library.
  222. \end{tabular}
  223. \vspace{0.5em}
  224. %\bibliographystyle{alpha}
  225. %\bibliography{sample}
  226. \end{document}