You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

3217 lines
1.7 MiB

1 year ago
  1. {
  2. "cells": [
  3. {
  4. "attachments": {},
  5. "cell_type": "markdown",
  6. "metadata": {},
  7. "source": [
  8. "# Import supporting package"
  9. ]
  10. },
  11. {
  12. "cell_type": "code",
  13. "execution_count": 1,
  14. "metadata": {},
  15. "outputs": [],
  16. "source": [
  17. "import xarray as xr\n",
  18. "import numpy as np\n",
  19. "import copy\n",
  20. "\n",
  21. "from uncertainties import ufloat\n",
  22. "from uncertainties import unumpy as unp\n",
  23. "from uncertainties import umath\n",
  24. "import random\n",
  25. "import matplotlib.pyplot as plt\n",
  26. "plt.rcParams['font.size'] = 12\n",
  27. "\n",
  28. "from DataContainer.ReadData import read_hdf5_file\n",
  29. "from Analyser.ImagingAnalyser import ImageAnalyser\n",
  30. "from Analyser.FitAnalyser import FitAnalyser\n",
  31. "from Analyser.FitAnalyser import NewFitModel, DensityProfileBEC2dModel\n",
  32. "from ToolFunction.ToolFunction import *\n",
  33. "\n",
  34. "from scipy.optimize import curve_fit\n",
  35. "\n",
  36. "from ToolFunction.HomeMadeXarrayFunction import errorbar, dataarray_plot_errorbar\n",
  37. "xr.plot.dataarray_plot.errorbar = errorbar\n",
  38. "xr.plot.accessor.DataArrayPlotAccessor.errorbar = dataarray_plot_errorbar\n",
  39. "\n",
  40. "imageAnalyser = ImageAnalyser()\n",
  41. "\n",
  42. "# %matplotlib notebook"
  43. ]
  44. },
  45. {
  46. "attachments": {},
  47. "cell_type": "markdown",
  48. "metadata": {},
  49. "source": [
  50. "## Start a client for parallel computing"
  51. ]
  52. },
  53. {
  54. "cell_type": "code",
  55. "execution_count": 2,
  56. "metadata": {},
  57. "outputs": [
  58. {
  59. "data": {
  60. "text/html": [
  61. "<div>\n",
  62. " <div style=\"width: 24px; height: 24px; background-color: #e1e1e1; border: 3px solid #9D9D9D; border-radius: 5px; position: absolute;\"> </div>\n",
  63. " <div style=\"margin-left: 48px;\">\n",
  64. " <h3 style=\"margin-bottom: 0px;\">Client</h3>\n",
  65. " <p style=\"color: #9D9D9D; margin-bottom: 0px;\">Client-8ba1675f-1745-11ee-81b0-80e82ce2fa8e</p>\n",
  66. " <table style=\"width: 100%; text-align: left;\">\n",
  67. "\n",
  68. " <tr>\n",
  69. " \n",
  70. " <td style=\"text-align: left;\"><strong>Connection method:</strong> Cluster object</td>\n",
  71. " <td style=\"text-align: left;\"><strong>Cluster type:</strong> distributed.LocalCluster</td>\n",
  72. " \n",
  73. " </tr>\n",
  74. "\n",
  75. " \n",
  76. " <tr>\n",
  77. " <td style=\"text-align: left;\">\n",
  78. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:8787/status\" target=\"_blank\">http://127.0.0.1:8787/status</a>\n",
  79. " </td>\n",
  80. " <td style=\"text-align: left;\"></td>\n",
  81. " </tr>\n",
  82. " \n",
  83. "\n",
  84. " </table>\n",
  85. "\n",
  86. " \n",
  87. "\n",
  88. " \n",
  89. " <details>\n",
  90. " <summary style=\"margin-bottom: 20px;\"><h3 style=\"display: inline;\">Cluster Info</h3></summary>\n",
  91. " <div class=\"jp-RenderedHTMLCommon jp-RenderedHTML jp-mod-trusted jp-OutputArea-output\">\n",
  92. " <div style=\"width: 24px; height: 24px; background-color: #e1e1e1; border: 3px solid #9D9D9D; border-radius: 5px; position: absolute;\">\n",
  93. " </div>\n",
  94. " <div style=\"margin-left: 48px;\">\n",
  95. " <h3 style=\"margin-bottom: 0px; margin-top: 0px;\">LocalCluster</h3>\n",
  96. " <p style=\"color: #9D9D9D; margin-bottom: 0px;\">5686383f</p>\n",
  97. " <table style=\"width: 100%; text-align: left;\">\n",
  98. " <tr>\n",
  99. " <td style=\"text-align: left;\">\n",
  100. " <strong>Dashboard:</strong> <a href=\"http://127.0.0.1:8787/status\" target=\"_blank\">http://127.0.0.1:8787/status</a>\n",
  101. " </td>\n",
  102. " <td style=\"text-align: left;\">\n",
  103. " <strong>Workers:</strong> 8\n",
  104. " </td>\n",
  105. " </tr>\n",
  106. " <tr>\n",
  107. " <td style=\"text-align: left;\">\n",
  108. " <strong>Total threads:</strong> 128\n",
  109. " </td>\n",
  110. " <td style=\"text-align: left;\">\n",
  111. " <strong>Total memory:</strong> 149.01 GiB\n",
  112. " </td>\n",
  113. " </tr>\n",
  114. " \n",
  115. " <tr>\n",
  116. " <td style=\"text-align: left;\"><strong>Status:</strong> running</td>\n",
  117. " <td style=\"text-align: left;\"><strong>Using processes:</strong> True</td>\n",
  118. "</tr>\n",
  119. "\n",
  120. " \n",
  121. " </table>\n",
  122. "\n",
  123. " <details>\n",
  124. " <summary style=\"margin-bottom: 20px;\">\n",
  125. " <h3 style=\"display: inline;\">Scheduler Info</h3>\n",
  126. " </summary>\n",
  127. "\n",
  128. " <div style=\"\">\n",
  129. " <div>\n",
  130. " <div style=\"width: 24px; height: 24px; background-color: #FFF7E5; border: 3px solid #FF6132; border-radius: 5px; position: absolute;\"> </div>\n",
  131. " <div style=\"margin-left: 48px;\">\n",
  132. " <h3 style=\"margin-bottom: 0px;\">Scheduler</h3>\n",
  133. " <p style=\"color: #9D9D9D; margin-bottom: 0px;\">Scheduler-579b49b9-56d3-437e-8497-ccb704499216</p>\n",
  134. " <table style=\"width: 100%; text-align: left;\">\n",
  135. " <tr>\n",
  136. " <td style=\"text-align: left;\">\n",
  137. " <strong>Comm:</strong> tcp://127.0.0.1:58438\n",
  138. " </td>\n",
  139. " <td style=\"text-align: left;\">\n",
  140. " <strong>Workers:</strong> 8\n",
  141. " </td>\n",
  142. " </tr>\n",
  143. " <tr>\n",
  144. " <td style=\"text-align: left;\">\n",
  145. " <strong>Dashboard:</strong> <a href=\"http://127.0.0.1:8787/status\" target=\"_blank\">http://127.0.0.1:8787/status</a>\n",
  146. " </td>\n",
  147. " <td style=\"text-align: left;\">\n",
  148. " <strong>Total threads:</strong> 128\n",
  149. " </td>\n",
  150. " </tr>\n",
  151. " <tr>\n",
  152. " <td style=\"text-align: left;\">\n",
  153. " <strong>Started:</strong> Just now\n",
  154. " </td>\n",
  155. " <td style=\"text-align: left;\">\n",
  156. " <strong>Total memory:</strong> 149.01 GiB\n",
  157. " </td>\n",
  158. " </tr>\n",
  159. " </table>\n",
  160. " </div>\n",
  161. " </div>\n",
  162. "\n",
  163. " <details style=\"margin-left: 48px;\">\n",
  164. " <summary style=\"margin-bottom: 20px;\">\n",
  165. " <h3 style=\"display: inline;\">Workers</h3>\n",
  166. " </summary>\n",
  167. "\n",
  168. " \n",
  169. " <div style=\"margin-bottom: 20px;\">\n",
  170. " <div style=\"width: 24px; height: 24px; background-color: #DBF5FF; border: 3px solid #4CC9FF; border-radius: 5px; position: absolute;\"> </div>\n",
  171. " <div style=\"margin-left: 48px;\">\n",
  172. " <details>\n",
  173. " <summary>\n",
  174. " <h4 style=\"margin-bottom: 0px; display: inline;\">Worker: 0</h4>\n",
  175. " </summary>\n",
  176. " <table style=\"width: 100%; text-align: left;\">\n",
  177. " <tr>\n",
  178. " <td style=\"text-align: left;\">\n",
  179. " <strong>Comm: </strong> tcp://127.0.0.1:58495\n",
  180. " </td>\n",
  181. " <td style=\"text-align: left;\">\n",
  182. " <strong>Total threads: </strong> 16\n",
  183. " </td>\n",
  184. " </tr>\n",
  185. " <tr>\n",
  186. " <td style=\"text-align: left;\">\n",
  187. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:58496/status\" target=\"_blank\">http://127.0.0.1:58496/status</a>\n",
  188. " </td>\n",
  189. " <td style=\"text-align: left;\">\n",
  190. " <strong>Memory: </strong> 18.63 GiB\n",
  191. " </td>\n",
  192. " </tr>\n",
  193. " <tr>\n",
  194. " <td style=\"text-align: left;\">\n",
  195. " <strong>Nanny: </strong> tcp://127.0.0.1:58441\n",
  196. " </td>\n",
  197. " <td style=\"text-align: left;\"></td>\n",
  198. " </tr>\n",
  199. " <tr>\n",
  200. " <td colspan=\"2\" style=\"text-align: left;\">\n",
  201. " <strong>Local directory: </strong> C:\\Users\\data\\AppData\\Local\\Temp\\dask-worker-space\\worker-fjkqs65s\n",
  202. " </td>\n",
  203. " </tr>\n",
  204. "\n",
  205. " \n",
  206. "\n",
  207. " \n",
  208. "\n",
  209. " </table>\n",
  210. " </details>\n",
  211. " </div>\n",
  212. " </div>\n",
  213. " \n",
  214. " <div style=\"margin-bottom: 20px;\">\n",
  215. " <div style=\"width: 24px; height: 24px; background-color: #DBF5FF; border: 3px solid #4CC9FF; border-radius: 5px; position: absolute;\"> </div>\n",
  216. " <div style=\"margin-left: 48px;\">\n",
  217. " <details>\n",
  218. " <summary>\n",
  219. " <h4 style=\"margin-bottom: 0px; display: inline;\">Worker: 1</h4>\n",
  220. " </summary>\n",
  221. " <table style=\"width: 100%; text-align: left;\">\n",
  222. " <tr>\n",
  223. " <td style=\"text-align: left;\">\n",
  224. " <strong>Comm: </strong> tcp://127.0.0.1:58478\n",
  225. " </td>\n",
  226. " <td style=\"text-align: left;\">\n",
  227. " <strong>Total threads: </strong> 16\n",
  228. " </td>\n",
  229. " </tr>\n",
  230. " <tr>\n",
  231. " <td style=\"text-align: left;\">\n",
  232. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:58481/status\" target=\"_blank\">http://127.0.0.1:58481/status</a>\n",
  233. " </td>\n",
  234. " <td style=\"text-align: left;\">\n",
  235. " <strong>Memory: </strong> 18.63 GiB\n",
  236. " </td>\n",
  237. " </tr>\n",
  238. " <tr>\n",
  239. " <td style=\"text-align: left;\">\n",
  240. " <strong>Nanny: </strong> tcp://127.0.0.1:58442\n",
  241. " </td>\n",
  242. " <td style=\"text-align: left;\"></td>\n",
  243. " </tr>\n",
  244. " <tr>\n",
  245. " <td colspan=\"2\" style=\"text-align: left;\">\n",
  246. " <strong>Local directory: </strong> C:\\Users\\data\\AppData\\Local\\Temp\\dask-worker-space\\worker-2zpxzh7e\n",
  247. " </td>\n",
  248. " </tr>\n",
  249. "\n",
  250. " \n",
  251. "\n",
  252. " \n",
  253. "\n",
  254. " </table>\n",
  255. " </details>\n",
  256. " </div>\n",
  257. " </div>\n",
  258. " \n",
  259. " <div style=\"margin-bottom: 20px;\">\n",
  260. " <div style=\"width: 24px; height: 24px; background-color: #DBF5FF; border: 3px solid #4CC9FF; border-radius: 5px; position: absolute;\"> </div>\n",
  261. " <div style=\"margin-left: 48px;\">\n",
  262. " <details>\n",
  263. " <summary>\n",
  264. " <h4 style=\"margin-bottom: 0px; display: inline;\">Worker: 2</h4>\n",
  265. " </summary>\n",
  266. " <table style=\"width: 100%; text-align: left;\">\n",
  267. " <tr>\n",
  268. " <td style=\"text-align: left;\">\n",
  269. " <strong>Comm: </strong> tcp://127.0.0.1:58485\n",
  270. " </td>\n",
  271. " <td style=\"text-align: left;\">\n",
  272. " <strong>Total threads: </strong> 16\n",
  273. " </td>\n",
  274. " </tr>\n",
  275. " <tr>\n",
  276. " <td style=\"text-align: left;\">\n",
  277. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:58489/status\" target=\"_blank\">http://127.0.0.1:58489/status</a>\n",
  278. " </td>\n",
  279. " <td style=\"text-align: left;\">\n",
  280. " <strong>Memory: </strong> 18.63 GiB\n",
  281. " </td>\n",
  282. " </tr>\n",
  283. " <tr>\n",
  284. " <td style=\"text-align: left;\">\n",
  285. " <strong>Nanny: </strong> tcp://127.0.0.1:58443\n",
  286. " </td>\n",
  287. " <td style=\"text-align: left;\"></td>\n",
  288. " </tr>\n",
  289. " <tr>\n",
  290. " <td colspan=\"2\" style=\"text-align: left;\">\n",
  291. " <strong>Local directory: </strong> C:\\Users\\data\\AppData\\Local\\Temp\\dask-worker-space\\worker-xj22aq7d\n",
  292. " </td>\n",
  293. " </tr>\n",
  294. "\n",
  295. " \n",
  296. "\n",
  297. " \n",
  298. "\n",
  299. " </table>\n",
  300. " </details>\n",
  301. " </div>\n",
  302. " </div>\n",
  303. " \n",
  304. " <div style=\"margin-bottom: 20px;\">\n",
  305. " <div style=\"width: 24px; height: 24px; background-color: #DBF5FF; border: 3px solid #4CC9FF; border-radius: 5px; position: absolute;\"> </div>\n",
  306. " <div style=\"margin-left: 48px;\">\n",
  307. " <details>\n",
  308. " <summary>\n",
  309. " <h4 style=\"margin-bottom: 0px; display: inline;\">Worker: 3</h4>\n",
  310. " </summary>\n",
  311. " <table style=\"width: 100%; text-align: left;\">\n",
  312. " <tr>\n",
  313. " <td style=\"text-align: left;\">\n",
  314. " <strong>Comm: </strong> tcp://127.0.0.1:58483\n",
  315. " </td>\n",
  316. " <td style=\"text-align: left;\">\n",
  317. " <strong>Total threads: </strong> 16\n",
  318. " </td>\n",
  319. " </tr>\n",
  320. " <tr>\n",
  321. " <td style=\"text-align: left;\">\n",
  322. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:58486/status\" target=\"_blank\">http://127.0.0.1:58486/status</a>\n",
  323. " </td>\n",
  324. " <td style=\"text-align: left;\">\n",
  325. " <strong>Memory: </strong> 18.63 GiB\n",
  326. " </td>\n",
  327. " </tr>\n",
  328. " <tr>\n",
  329. " <td style=\"text-align: left;\">\n",
  330. " <strong>Nanny: </strong> tcp://127.0.0.1:58444\n",
  331. " </td>\n",
  332. " <td style=\"text-align: left;\"></td>\n",
  333. " </tr>\n",
  334. " <tr>\n",
  335. " <td colspan=\"2\" style=\"text-align: left;\">\n",
  336. " <strong>Local directory: </strong> C:\\Users\\data\\AppData\\Local\\Temp\\dask-worker-space\\worker-ywxt37o0\n",
  337. " </td>\n",
  338. " </tr>\n",
  339. "\n",
  340. " \n",
  341. "\n",
  342. " \n",
  343. "\n",
  344. " </table>\n",
  345. " </details>\n",
  346. " </div>\n",
  347. " </div>\n",
  348. " \n",
  349. " <div style=\"margin-bottom: 20px;\">\n",
  350. " <div style=\"width: 24px; height: 24px; background-color: #DBF5FF; border: 3px solid #4CC9FF; border-radius: 5px; position: absolute;\"> </div>\n",
  351. " <div style=\"margin-left: 48px;\">\n",
  352. " <details>\n",
  353. " <summary>\n",
  354. " <h4 style=\"margin-bottom: 0px; display: inline;\">Worker: 4</h4>\n",
  355. " </summary>\n",
  356. " <table style=\"width: 100%; text-align: left;\">\n",
  357. " <tr>\n",
  358. " <td style=\"text-align: left;\">\n",
  359. " <strong>Comm: </strong> tcp://127.0.0.1:58460\n",
  360. " </td>\n",
  361. " <td style=\"text-align: left;\">\n",
  362. " <strong>Total threads: </strong> 16\n",
  363. " </td>\n",
  364. " </tr>\n",
  365. " <tr>\n",
  366. " <td style=\"text-align: left;\">\n",
  367. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:58473/status\" target=\"_blank\">http://127.0.0.1:58473/status</a>\n",
  368. " </td>\n",
  369. " <td style=\"text-align: left;\">\n",
  370. " <strong>Memory: </strong> 18.63 GiB\n",
  371. " </td>\n",
  372. " </tr>\n",
  373. " <tr>\n",
  374. " <td style=\"text-align: left;\">\n",
  375. " <strong>Nanny: </strong> tcp://127.0.0.1:58445\n",
  376. " </td>\n",
  377. " <td style=\"text-align: left;\"></td>\n",
  378. " </tr>\n",
  379. " <tr>\n",
  380. " <td colspan=\"2\" style=\"text-align: left;\">\n",
  381. " <strong>Local directory: </strong> C:\\Users\\data\\AppData\\Local\\Temp\\dask-worker-space\\worker-r165h314\n",
  382. " </td>\n",
  383. " </tr>\n",
  384. "\n",
  385. " \n",
  386. "\n",
  387. " \n",
  388. "\n",
  389. " </table>\n",
  390. " </details>\n",
  391. " </div>\n",
  392. " </div>\n",
  393. " \n",
  394. " <div style=\"margin-bottom: 20px;\">\n",
  395. " <div style=\"width: 24px; height: 24px; background-color: #DBF5FF; border: 3px solid #4CC9FF; border-radius: 5px; position: absolute;\"> </div>\n",
  396. " <div style=\"margin-left: 48px;\">\n",
  397. " <details>\n",
  398. " <summary>\n",
  399. " <h4 style=\"margin-bottom: 0px; display: inline;\">Worker: 5</h4>\n",
  400. " </summary>\n",
  401. " <table style=\"width: 100%; text-align: left;\">\n",
  402. " <tr>\n",
  403. " <td style=\"text-align: left;\">\n",
  404. " <strong>Comm: </strong> tcp://127.0.0.1:58492\n",
  405. " </td>\n",
  406. " <td style=\"text-align: left;\">\n",
  407. " <strong>Total threads: </strong> 16\n",
  408. " </td>\n",
  409. " </tr>\n",
  410. " <tr>\n",
  411. " <td style=\"text-align: left;\">\n",
  412. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:58493/status\" target=\"_blank\">http://127.0.0.1:58493/status</a>\n",
  413. " </td>\n",
  414. " <td style=\"text-align: left;\">\n",
  415. " <strong>Memory: </strong> 18.63 GiB\n",
  416. " </td>\n",
  417. " </tr>\n",
  418. " <tr>\n",
  419. " <td style=\"text-align: left;\">\n",
  420. " <strong>Nanny: </strong> tcp://127.0.0.1:58446\n",
  421. " </td>\n",
  422. " <td style=\"text-align: left;\"></td>\n",
  423. " </tr>\n",
  424. " <tr>\n",
  425. " <td colspan=\"2\" style=\"text-align: left;\">\n",
  426. " <strong>Local directory: </strong> C:\\Users\\data\\AppData\\Local\\Temp\\dask-worker-space\\worker-y9scwwnw\n",
  427. " </td>\n",
  428. " </tr>\n",
  429. "\n",
  430. " \n",
  431. "\n",
  432. " \n",
  433. "\n",
  434. " </table>\n",
  435. " </details>\n",
  436. " </div>\n",
  437. " </div>\n",
  438. " \n",
  439. " <div style=\"margin-bottom: 20px;\">\n",
  440. " <div style=\"width: 24px; height: 24px; background-color: #DBF5FF; border: 3px solid #4CC9FF; border-radius: 5px; position: absolute;\"> </div>\n",
  441. " <div style=\"margin-left: 48px;\">\n",
  442. " <details>\n",
  443. " <summary>\n",
  444. " <h4 style=\"margin-bottom: 0px; display: inline;\">Worker: 6</h4>\n",
  445. " </summary>\n",
  446. " <table style=\"width: 100%; text-align: left;\">\n",
  447. " <tr>\n",
  448. " <td style=\"text-align: left;\">\n",
  449. " <strong>Comm: </strong> tcp://127.0.0.1:58477\n",
  450. " </td>\n",
  451. " <td style=\"text-align: left;\">\n",
  452. " <strong>Total threads: </strong> 16\n",
  453. " </td>\n",
  454. " </tr>\n",
  455. " <tr>\n",
  456. " <td style=\"text-align: left;\">\n",
  457. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:58479/status\" target=\"_blank\">http://127.0.0.1:58479/status</a>\n",
  458. " </td>\n",
  459. " <td style=\"text-align: left;\">\n",
  460. " <strong>Memory: </strong> 18.63 GiB\n",
  461. " </td>\n",
  462. " </tr>\n",
  463. " <tr>\n",
  464. " <td style=\"text-align: left;\">\n",
  465. " <strong>Nanny: </strong> tcp://127.0.0.1:58447\n",
  466. " </td>\n",
  467. " <td style=\"text-align: left;\"></td>\n",
  468. " </tr>\n",
  469. " <tr>\n",
  470. " <td colspan=\"2\" style=\"text-align: left;\">\n",
  471. " <strong>Local directory: </strong> C:\\Users\\data\\AppData\\Local\\Temp\\dask-worker-space\\worker-6gncvkv7\n",
  472. " </td>\n",
  473. " </tr>\n",
  474. "\n",
  475. " \n",
  476. "\n",
  477. " \n",
  478. "\n",
  479. " </table>\n",
  480. " </details>\n",
  481. " </div>\n",
  482. " </div>\n",
  483. " \n",
  484. " <div style=\"margin-bottom: 20px;\">\n",
  485. " <div style=\"width: 24px; height: 24px; background-color: #DBF5FF; border: 3px solid #4CC9FF; border-radius: 5px; position: absolute;\"> </div>\n",
  486. " <div style=\"margin-left: 48px;\">\n",
  487. " <details>\n",
  488. " <summary>\n",
  489. " <h4 style=\"margin-bottom: 0px; display: inline;\">Worker: 7</h4>\n",
  490. " </summary>\n",
  491. " <table style=\"width: 100%; text-align: left;\">\n",
  492. " <tr>\n",
  493. " <td style=\"text-align: left;\">\n",
  494. " <strong>Comm: </strong> tcp://127.0.0.1:58484\n",
  495. " </td>\n",
  496. " <td style=\"text-align: left;\">\n",
  497. " <strong>Total threads: </strong> 16\n",
  498. " </td>\n",
  499. " </tr>\n",
  500. " <tr>\n",
  501. " <td style=\"text-align: left;\">\n",
  502. " <strong>Dashboard: </strong> <a href=\"http://127.0.0.1:58488/status\" target=\"_blank\">http://127.0.0.1:58488/status</a>\n",
  503. " </td>\n",
  504. " <td style=\"text-align: left;\">\n",
  505. " <strong>Memory: </strong> 18.63 GiB\n",
  506. " </td>\n",
  507. " </tr>\n",
  508. " <tr>\n",
  509. " <td style=\"text-align: left;\">\n",
  510. " <strong>Nanny: </strong> tcp://127.0.0.1:58448\n",
  511. " </td>\n",
  512. " <td style=\"text-align: left;\"></td>\n",
  513. " </tr>\n",
  514. " <tr>\n",
  515. " <td colspan=\"2\" style=\"text-align: left;\">\n",
  516. " <strong>Local directory: </strong> C:\\Users\\data\\AppData\\Local\\Temp\\dask-worker-space\\worker-4vducatr\n",
  517. " </td>\n",
  518. " </tr>\n",
  519. "\n",
  520. " \n",
  521. "\n",
  522. " \n",
  523. "\n",
  524. " </table>\n",
  525. " </details>\n",
  526. " </div>\n",
  527. " </div>\n",
  528. " \n",
  529. "\n",
  530. " </details>\n",
  531. "</div>\n",
  532. "\n",
  533. " </details>\n",
  534. " </div>\n",
  535. "</div>\n",
  536. " </details>\n",
  537. " \n",
  538. "\n",
  539. " </div>\n",
  540. "</div>"
  541. ],
  542. "text/plain": [
  543. "<Client: 'tcp://127.0.0.1:58438' processes=8 threads=128, memory=149.01 GiB>"
  544. ]
  545. },
  546. "execution_count": 2,
  547. "metadata": {},
  548. "output_type": "execute_result"
  549. }
  550. ],
  551. "source": [
  552. "from dask.distributed import Client\n",
  553. "client = Client(n_workers=8, threads_per_worker=16, processes=True, memory_limit='20GB')\n",
  554. "client"
  555. ]
  556. },
  557. {
  558. "attachments": {},
  559. "cell_type": "markdown",
  560. "metadata": {},
  561. "source": [
  562. "## Start a client for Mongo DB"
  563. ]
  564. },
  565. {
  566. "cell_type": "code",
  567. "execution_count": 3,
  568. "metadata": {},
  569. "outputs": [],
  570. "source": [
  571. "import pymongo\n",
  572. "import xarray_mongodb\n",
  573. "\n",
  574. "from DataContainer.MongoDB import MongoDB\n",
  575. "\n",
  576. "mongoClient = pymongo.MongoClient('mongodb://control:DyLab2021@127.0.0.1:27017/?authMechanism=DEFAULT')"
  577. ]
  578. },
  579. {
  580. "attachments": {},
  581. "cell_type": "markdown",
  582. "metadata": {},
  583. "source": [
  584. "## Set global path for experiment"
  585. ]
  586. },
  587. {
  588. "cell_type": "code",
  589. "execution_count": 4,
  590. "metadata": {},
  591. "outputs": [],
  592. "source": [
  593. "groupList = [\n",
  594. " \"images/MOT_3D_Camera/in_situ_absorption\",\n",
  595. " \"images/ODT_1_Axis_Camera/in_situ_absorption\",\n",
  596. " \"images/ODT_2_Axis_Camera/in_situ_absorption\",\n",
  597. "]\n",
  598. "\n",
  599. "dskey = {\n",
  600. " \"images/MOT_3D_Camera/in_situ_absorption\": \"camera_0\",\n",
  601. " \"images/ODT_1_Axis_Camera/in_situ_absorption\": \"camera_1\",\n",
  602. " \"images/ODT_2_Axis_Camera/in_situ_absorption\": \"camera_2\",\n",
  603. "}\n"
  604. ]
  605. },
  606. {
  607. "cell_type": "code",
  608. "execution_count": 5,
  609. "metadata": {},
  610. "outputs": [],
  611. "source": [
  612. "img_dir = 'C:/Users/control/DyLab/Experiments/DyBEC/'\n",
  613. "SequenceName = \"Repetition_scan\"\n",
  614. "folderPath = img_dir + SequenceName + \"/\" + get_date()\n",
  615. "\n",
  616. "mongoDB = mongoClient[SequenceName]\n",
  617. "\n",
  618. "DB = MongoDB(mongoClient, mongoDB, date=get_date())"
  619. ]
  620. },
  621. {
  622. "attachments": {},
  623. "cell_type": "markdown",
  624. "metadata": {},
  625. "source": [
  626. "# Repetition Scans"
  627. ]
  628. },
  629. {
  630. "attachments": {},
  631. "cell_type": "markdown",
  632. "metadata": {},
  633. "source": [
  634. "## scan MOT freq"
  635. ]
  636. },
  637. {
  638. "cell_type": "code",
  639. "execution_count": 7,
  640. "metadata": {
  641. "scrolled": false
  642. },
  643. "outputs": [
  644. {
  645. "name": "stdout",
  646. "output_type": "stream",
  647. "text": [
  648. "The detected scaning axes and values are: \n",
  649. "\n",
  650. "{'initial_freq': array([101. , 101.25, 101.5 , 101.75, 102. , 102.25, 102.5 , 102.75,\n",
  651. " 103. , 103.25]), 'runs': array([0., 1., 2.])}\n"
  652. ]
  653. },
  654. {
  655. "data": {
  656. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  657. "text/plain": [
  658. "<IPython.core.display.Javascript object>"
  659. ]
  660. },
  661. "metadata": {},
  662. "output_type": "display_data"
  663. },
  664. {
  665. "data": {
  666. "text/html": [
  667. "<img src=\"
  668. ],
  669. "text/plain": [
  670. "<IPython.core.display.HTML object>"
  671. ]
  672. },
  673. "metadata": {},
  674. "output_type": "display_data"
  675. }
  676. ],
  677. "source": [
  678. "%matplotlib notebook\n",
  679. "shotNum = \"0000\"\n",
  680. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  681. "\n",
  682. "dataSetDict = {\n",
  683. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  684. " for i in range(len(groupList))\n",
  685. "}\n",
  686. "\n",
  687. "dataSet = dataSetDict[\"camera_1\"]\n",
  688. "\n",
  689. "print_scanAxis(dataSet)\n",
  690. "\n",
  691. "scanAxis = get_scanAxis(dataSet)\n",
  692. "\n",
  693. "dataSet = auto_rechunk(dataSet)\n",
  694. "\n",
  695. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  696. "\n",
  697. "imageAnalyser.center = (310, 825)\n",
  698. "imageAnalyser.span = (550, 1250)\n",
  699. "imageAnalyser.fraction = (0.1, 0.1)\n",
  700. "\n",
  701. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  702. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  703. "\n",
  704. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  705. "Ncount_mean = calculate_mean(Ncount)\n",
  706. "Ncount_std = calculate_std(Ncount)\n",
  707. "\n",
  708. "fig = plt.figure()\n",
  709. "ax = fig.gca()\n",
  710. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  711. "plt.xlabel('MOT AOM Freq (MHz)')\n",
  712. "plt.ylabel('NCount')\n",
  713. "plt.tight_layout()\n",
  714. "plt.grid(visible=1)\n",
  715. "plt.show()\n",
  716. "\n",
  717. "# DB.create_global(shotNum, dataSet)\n",
  718. "# DB.add_data(shotNum, dataSet_cropOD, engine='xarray')"
  719. ]
  720. },
  721. {
  722. "attachments": {},
  723. "cell_type": "markdown",
  724. "metadata": {},
  725. "source": [
  726. "## scan Push freq"
  727. ]
  728. },
  729. {
  730. "cell_type": "code",
  731. "execution_count": 9,
  732. "metadata": {
  733. "scrolled": false
  734. },
  735. "outputs": [
  736. {
  737. "name": "stdout",
  738. "output_type": "stream",
  739. "text": [
  740. "The detected scaning axes and values are: \n",
  741. "\n",
  742. "{'push_freq': array([101.1, 101.6, 102.1, 102.6, 103.1, 103.6, 104.1, 104.6, 105.1,\n",
  743. " 105.6, 106.1]), 'runs': array([0., 1., 2.])}\n"
  744. ]
  745. },
  746. {
  747. "data": {
  748. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  749. "text/plain": [
  750. "<IPython.core.display.Javascript object>"
  751. ]
  752. },
  753. "metadata": {},
  754. "output_type": "display_data"
  755. },
  756. {
  757. "data": {
  758. "text/html": [
  759. "<img src=\"
  760. ],
  761. "text/plain": [
  762. "<IPython.core.display.HTML object>"
  763. ]
  764. },
  765. "metadata": {},
  766. "output_type": "display_data"
  767. }
  768. ],
  769. "source": [
  770. "%matplotlib notebook\n",
  771. "shotNum = \"0001\"\n",
  772. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  773. "\n",
  774. "dataSetDict = {\n",
  775. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  776. " for i in range(len(groupList))\n",
  777. "}\n",
  778. "\n",
  779. "dataSet = dataSetDict[\"camera_1\"]\n",
  780. "\n",
  781. "print_scanAxis(dataSet)\n",
  782. "\n",
  783. "scanAxis = get_scanAxis(dataSet)\n",
  784. "\n",
  785. "dataSet = auto_rechunk(dataSet)\n",
  786. "\n",
  787. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  788. "\n",
  789. "imageAnalyser.center = (310, 825)\n",
  790. "imageAnalyser.span = (550, 1250)\n",
  791. "imageAnalyser.fraction = (0.1, 0.1)\n",
  792. "\n",
  793. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  794. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  795. "\n",
  796. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  797. "Ncount_mean = calculate_mean(Ncount)\n",
  798. "Ncount_std = calculate_std(Ncount)\n",
  799. "\n",
  800. "fig = plt.figure()\n",
  801. "ax = fig.gca()\n",
  802. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  803. "plt.xlabel('Push AOM Freq (MHz)')\n",
  804. "plt.ylabel('NCount')\n",
  805. "plt.tight_layout()\n",
  806. "plt.grid(visible=1)\n",
  807. "plt.show()\n",
  808. "\n",
  809. "# DB.create_global(shotNum, dataSet)\n",
  810. "# DB.add_data(shotNum, dataSet_cropOD, engine='xarray')"
  811. ]
  812. },
  813. {
  814. "attachments": {},
  815. "cell_type": "markdown",
  816. "metadata": {},
  817. "source": [
  818. "## scan Z comp current"
  819. ]
  820. },
  821. {
  822. "cell_type": "code",
  823. "execution_count": 24,
  824. "metadata": {
  825. "scrolled": false
  826. },
  827. "outputs": [
  828. {
  829. "name": "stdout",
  830. "output_type": "stream",
  831. "text": [
  832. "The detected scaning axes and values are: \n",
  833. "\n",
  834. "{'compZ_final_current': array([0.242 , 0.2427, 0.2434, 0.2441, 0.2448, 0.2455, 0.2462, 0.2469,\n",
  835. " 0.2476, 0.2483, 0.249 , 0.2497, 0.2504, 0.2511, 0.2518]), 'runs': array([0., 1., 2.])}\n"
  836. ]
  837. },
  838. {
  839. "data": {
  840. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  841. "text/plain": [
  842. "<IPython.core.display.Javascript object>"
  843. ]
  844. },
  845. "metadata": {},
  846. "output_type": "display_data"
  847. },
  848. {
  849. "data": {
  850. "text/html": [
  851. "<img src=\"
  852. ],
  853. "text/plain": [
  854. "<IPython.core.display.HTML object>"
  855. ]
  856. },
  857. "metadata": {},
  858. "output_type": "display_data"
  859. }
  860. ],
  861. "source": [
  862. "%matplotlib notebook\n",
  863. "shotNum = \"0005\"\n",
  864. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  865. "\n",
  866. "dataSetDict = {\n",
  867. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  868. " for i in [0, 1]\n",
  869. "}\n",
  870. "\n",
  871. "dataSet = dataSetDict[\"camera_1\"]\n",
  872. "\n",
  873. "print_scanAxis(dataSet)\n",
  874. "\n",
  875. "scanAxis = get_scanAxis(dataSet)\n",
  876. "\n",
  877. "dataSet = auto_rechunk(dataSet)\n",
  878. "\n",
  879. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  880. "\n",
  881. "imageAnalyser.center = (305, 870)\n",
  882. "imageAnalyser.span = (400, 400)\n",
  883. "imageAnalyser.fraction = (0.1, 0.1)\n",
  884. "\n",
  885. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  886. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  887. "\n",
  888. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  889. "Ncount_mean = calculate_mean(Ncount)\n",
  890. "Ncount_std = calculate_std(Ncount)\n",
  891. "\n",
  892. "fig = plt.figure()\n",
  893. "ax = fig.gca()\n",
  894. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  895. "plt.xlabel('comp Z current (A)')\n",
  896. "plt.ylabel('NCount')\n",
  897. "plt.tight_layout()\n",
  898. "plt.grid(visible=1)\n",
  899. "plt.show()\n",
  900. "\n",
  901. "# DB.create_global(shotNum, dataSet)\n",
  902. "# DB.add_data(shotNum, dataSet_cropOD, engine='xarray')"
  903. ]
  904. },
  905. {
  906. "attachments": {},
  907. "cell_type": "markdown",
  908. "metadata": {},
  909. "source": [
  910. "# Evaporative Cooling"
  911. ]
  912. },
  913. {
  914. "cell_type": "code",
  915. "execution_count": 8,
  916. "metadata": {},
  917. "outputs": [],
  918. "source": [
  919. "img_dir = '//DyLabNAS/Data/'\n",
  920. "SequenceName = \"Evaporative_Cooling\" + \"/\"\n",
  921. "folderPath = img_dir + SequenceName + '2023/06/30'# get_date()\n",
  922. "\n",
  923. "# mongoDB = mongoClient[SequenceName]\n",
  924. "\n",
  925. "# DB = MongoDB(mongoClient, mongoDB, date=get_date())"
  926. ]
  927. },
  928. {
  929. "attachments": {},
  930. "cell_type": "markdown",
  931. "metadata": {},
  932. "source": [
  933. "# Check BEC"
  934. ]
  935. },
  936. {
  937. "cell_type": "code",
  938. "execution_count": 6,
  939. "metadata": {},
  940. "outputs": [
  941. {
  942. "ename": "OSError",
  943. "evalue": "no files to open",
  944. "output_type": "error",
  945. "traceback": [
  946. "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
  947. "\u001b[1;31mOSError\u001b[0m Traceback (most recent call last)",
  948. "\u001b[1;32mf:\\Jianshun\\analyseScript\\20230630_Data_Analysis_2.ipynb Cell 20\u001b[0m in \u001b[0;36m4\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=0'>1</a>\u001b[0m shotNum \u001b[39m=\u001b[39m \u001b[39m\"\u001b[39m\u001b[39m0000\u001b[39m\u001b[39m\"\u001b[39m\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=1'>2</a>\u001b[0m filePath \u001b[39m=\u001b[39m folderPath \u001b[39m+\u001b[39m \u001b[39m\"\u001b[39m\u001b[39m/\u001b[39m\u001b[39m\"\u001b[39m \u001b[39m+\u001b[39m shotNum \u001b[39m+\u001b[39m \u001b[39m\"\u001b[39m\u001b[39m/*.h5\u001b[39m\u001b[39m\"\u001b[39m\n\u001b[1;32m----> <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=3'>4</a>\u001b[0m dataSetDict \u001b[39m=\u001b[39m {\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=4'>5</a>\u001b[0m dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=5'>6</a>\u001b[0m \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m [\u001b[39m0\u001b[39m]\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=6'>7</a>\u001b[0m }\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=8'>9</a>\u001b[0m dataSet \u001b[39m=\u001b[39m dataSetDict[\u001b[39m\"\u001b[39m\u001b[39mcamera_0\u001b[39m\u001b[39m\"\u001b[39m]\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=10'>11</a>\u001b[0m print_scanAxis(dataSet)\n",
  949. "\u001b[1;32mf:\\Jianshun\\analyseScript\\20230630_Data_Analysis_2.ipynb Cell 20\u001b[0m in \u001b[0;36m5\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=0'>1</a>\u001b[0m shotNum \u001b[39m=\u001b[39m \u001b[39m\"\u001b[39m\u001b[39m0000\u001b[39m\u001b[39m\"\u001b[39m\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=1'>2</a>\u001b[0m filePath \u001b[39m=\u001b[39m folderPath \u001b[39m+\u001b[39m \u001b[39m\"\u001b[39m\u001b[39m/\u001b[39m\u001b[39m\"\u001b[39m \u001b[39m+\u001b[39m shotNum \u001b[39m+\u001b[39m \u001b[39m\"\u001b[39m\u001b[39m/*.h5\u001b[39m\u001b[39m\"\u001b[39m\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=3'>4</a>\u001b[0m dataSetDict \u001b[39m=\u001b[39m {\n\u001b[1;32m----> <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=4'>5</a>\u001b[0m dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=5'>6</a>\u001b[0m \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m [\u001b[39m0\u001b[39m]\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=6'>7</a>\u001b[0m }\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=8'>9</a>\u001b[0m dataSet \u001b[39m=\u001b[39m dataSetDict[\u001b[39m\"\u001b[39m\u001b[39mcamera_0\u001b[39m\u001b[39m\"\u001b[39m]\n\u001b[0;32m <a href='vscode-notebook-cell:/f%3A/Jianshun/analyseScript/20230630_Data_Analysis_2.ipynb#X25sZmlsZQ%3D%3D?line=10'>11</a>\u001b[0m print_scanAxis(dataSet)\n",
  950. "File \u001b[1;32mf:\\Jianshun\\analyseScript\\DataContainer\\ReadData.py:150\u001b[0m, in \u001b[0;36mread_hdf5_file\u001b[1;34m(filePath, group, datesetOfGlobal, preprocess, join, parallel, engine, phony_dims, excludeAxis, maxFileNum, **kwargs)\u001b[0m\n\u001b[0;32m 139\u001b[0m kwargs\u001b[39m.\u001b[39mupdate(\n\u001b[0;32m 140\u001b[0m {\n\u001b[0;32m 141\u001b[0m \u001b[39m'\u001b[39m\u001b[39mjoin\u001b[39m\u001b[39m'\u001b[39m: join, \n\u001b[1;32m (...)\u001b[0m\n\u001b[0;32m 146\u001b[0m }\n\u001b[0;32m 147\u001b[0m )\n\u001b[0;32m 149\u001b[0m \u001b[39mif\u001b[39;00m datesetOfGlobal \u001b[39mis\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m--> 150\u001b[0m datesetOfGlobal \u001b[39m=\u001b[39m xr\u001b[39m.\u001b[39;49mopen_mfdataset(\n\u001b[0;32m 151\u001b[0m fullFilePath, \n\u001b[0;32m 152\u001b[0m group\u001b[39m=\u001b[39;49m\u001b[39m\"\u001b[39;49m\u001b[39mglobals\u001b[39;49m\u001b[39m\"\u001b[39;49m, \n\u001b[0;32m 153\u001b[0m concat_dim\u001b[39m=\u001b[39;49m\u001b[39m\"\u001b[39;49m\u001b[39mfileNum\u001b[39;49m\u001b[39m\"\u001b[39;49m, \n\u001b[0;32m 154\u001b[0m combine\u001b[39m=\u001b[39;49m\u001b[39m\"\u001b[39;49m\u001b[39mnested\u001b[39;49m\u001b[39m\"\u001b[39;49m, \n\u001b[0;32m 155\u001b[0m preprocess\u001b[39m=\u001b[39;49m_read_shot_number_from_hdf5, \n\u001b[0;32m 156\u001b[0m engine\u001b[39m=\u001b[39;49m\u001b[39m\"\u001b[39;49m\u001b[39mh5netcdf\u001b[39;49m\u001b[39m\"\u001b[39;49m, \n\u001b[0;32m 157\u001b[0m phony_dims\u001b[39m=\u001b[39;49m\u001b[39m\"\u001b[39;49m\u001b[39maccess\u001b[39;49m\u001b[39m\"\u001b[39;49m, \n\u001b[0;32m 158\u001b[0m combine_attrs\u001b[39m=\u001b[39;49m_read_globals_attrs,\n\u001b[0;32m 159\u001b[0m parallel\u001b[39m=\u001b[39;49m\u001b[39mTrue\u001b[39;49;00m, )\n\u001b[0;32m 161\u001b[0m datesetOfGlobal\u001b[39m.\u001b[39mattrs[\u001b[39m'\u001b[39m\u001b[39mscanAxis\u001b[39m\u001b[39m'\u001b[39m] \u001b[39m=\u001b[39m np\u001b[39m.\u001b[39msetdiff1d(datesetOfGlobal\u001b[39m.\u001b[39mattrs[\u001b[39m'\u001b[39m\u001b[39mscanAxis\u001b[39m\u001b[39m'\u001b[39m], excludeAxis)\n\u001b[0;32m 163\u001b[0m _assgin_scan_axis \u001b[39m=\u001b[39m partial(_assign_scan_axis_partial, datesetOfGlobal\u001b[39m=\u001b[39mdatesetOfGlobal, fullFilePath\u001b[39m=\u001b[39mfullFilePath)\n",
  951. "File \u001b[1;32m~\\AppData\\Roaming\\Python\\Python39\\site-packages\\xarray\\backends\\api.py:947\u001b[0m, in \u001b[0;36mopen_mfdataset\u001b[1;34m(paths, chunks, concat_dim, compat, preprocess, engine, data_vars, coords, combine, parallel, join, attrs_file, combine_attrs, **kwargs)\u001b[0m\n\u001b[0;32m 944\u001b[0m paths \u001b[39m=\u001b[39m [os\u001b[39m.\u001b[39mfspath(p) \u001b[39mif\u001b[39;00m \u001b[39misinstance\u001b[39m(p, os\u001b[39m.\u001b[39mPathLike) \u001b[39melse\u001b[39;00m p \u001b[39mfor\u001b[39;00m p \u001b[39min\u001b[39;00m paths]\n\u001b[0;32m 946\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m paths:\n\u001b[1;32m--> 947\u001b[0m \u001b[39mraise\u001b[39;00m \u001b[39mOSError\u001b[39;00m(\u001b[39m\"\u001b[39m\u001b[39mno files to open\u001b[39m\u001b[39m\"\u001b[39m)\n\u001b[0;32m 949\u001b[0m \u001b[39mif\u001b[39;00m combine \u001b[39m==\u001b[39m \u001b[39m\"\u001b[39m\u001b[39mnested\u001b[39m\u001b[39m\"\u001b[39m:\n\u001b[0;32m 950\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39misinstance\u001b[39m(concat_dim, (\u001b[39mstr\u001b[39m, DataArray)) \u001b[39mor\u001b[39;00m concat_dim \u001b[39mis\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n",
  952. "\u001b[1;31mOSError\u001b[0m: no files to open"
  953. ]
  954. }
  955. ],
  956. "source": [
  957. "shotNum = \"0000\"\n",
  958. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  959. "\n",
  960. "dataSetDict = {\n",
  961. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  962. " for i in [0]\n",
  963. "}\n",
  964. "\n",
  965. "dataSet = dataSetDict[\"camera_0\"]\n",
  966. "\n",
  967. "print_scanAxis(dataSet)\n",
  968. "\n",
  969. "scanAxis = get_scanAxis(dataSet)\n",
  970. "\n",
  971. "dataSet = auto_rechunk(dataSet)\n",
  972. "\n",
  973. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  974. "\n",
  975. "imageAnalyser.center = (880, 990)\n",
  976. "imageAnalyser.span = (150, 150)\n",
  977. "imageAnalyser.fraction = (0.1, 0.1)\n",
  978. "\n",
  979. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  980. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  981. "\n",
  982. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  983. "Ncount_mean = calculate_mean(Ncount)\n",
  984. "Ncount_std = calculate_std(Ncount)\n",
  985. "\n",
  986. "fig = plt.figure()\n",
  987. "ax = fig.gca()\n",
  988. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='-ob')\n",
  989. "plt.xlabel('comp Z current (A)')\n",
  990. "plt.ylabel('NCount')\n",
  991. "plt.tight_layout()\n",
  992. "plt.grid(visible=1)\n",
  993. "plt.show()\n",
  994. "\n",
  995. "# DB.create_global(shotNum, dataSet)\n",
  996. "# DB.add_data(shotNum, dataSet_cropOD, engine='xarray')"
  997. ]
  998. },
  999. {
  1000. "cell_type": "code",
  1001. "execution_count": 36,
  1002. "metadata": {},
  1003. "outputs": [
  1004. {
  1005. "name": "stdout",
  1006. "output_type": "stream",
  1007. "text": [
  1008. "The detected scaning axes and values are: \n",
  1009. "\n",
  1010. "{'compZ_current_sg': array([0.195, 0.196, 0.197, 0.198, 0.199, 0.2 , 0.201, 0.202, 0.203,\n",
  1011. " 0.204]), 'runs': array([0., 1., 2.])}\n"
  1012. ]
  1013. },
  1014. {
  1015. "data": {
  1016. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1017. "text/plain": [
  1018. "<IPython.core.display.Javascript object>"
  1019. ]
  1020. },
  1021. "metadata": {},
  1022. "output_type": "display_data"
  1023. },
  1024. {
  1025. "data": {
  1026. "text/html": [
  1027. "<img src=\"
  1028. ],
  1029. "text/plain": [
  1030. "<IPython.core.display.HTML object>"
  1031. ]
  1032. },
  1033. "metadata": {},
  1034. "output_type": "display_data"
  1035. }
  1036. ],
  1037. "source": [
  1038. "shotNum = \"0001\"\n",
  1039. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  1040. "\n",
  1041. "dataSetDict = {\n",
  1042. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  1043. " for i in [0]\n",
  1044. "}\n",
  1045. "\n",
  1046. "dataSet = dataSetDict[\"camera_0\"]\n",
  1047. "\n",
  1048. "print_scanAxis(dataSet)\n",
  1049. "\n",
  1050. "scanAxis = get_scanAxis(dataSet)\n",
  1051. "\n",
  1052. "dataSet = auto_rechunk(dataSet)\n",
  1053. "\n",
  1054. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  1055. "\n",
  1056. "imageAnalyser.center = (880, 990)\n",
  1057. "imageAnalyser.span = (150, 150)\n",
  1058. "imageAnalyser.fraction = (0.1, 0.1)\n",
  1059. "\n",
  1060. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  1061. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  1062. "\n",
  1063. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  1064. "Ncount_mean = calculate_mean(Ncount)\n",
  1065. "Ncount_std = calculate_std(Ncount)\n",
  1066. "\n",
  1067. "fig = plt.figure()\n",
  1068. "ax = fig.gca()\n",
  1069. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='-ob')\n",
  1070. "plt.xlabel('comp Z current (A)')\n",
  1071. "plt.ylabel('NCount')\n",
  1072. "plt.tight_layout()\n",
  1073. "plt.grid(visible=1)\n",
  1074. "plt.show()\n",
  1075. "\n",
  1076. "# DB.create_global(shotNum, dataSet)\n",
  1077. "# DB.add_data(shotNum, dataSet_cropOD, engine='xarray')"
  1078. ]
  1079. },
  1080. {
  1081. "attachments": {},
  1082. "cell_type": "markdown",
  1083. "metadata": {},
  1084. "source": [
  1085. "## Measure magnification of side-imaging again"
  1086. ]
  1087. },
  1088. {
  1089. "cell_type": "code",
  1090. "execution_count": 99,
  1091. "metadata": {
  1092. "scrolled": false
  1093. },
  1094. "outputs": [
  1095. {
  1096. "name": "stdout",
  1097. "output_type": "stream",
  1098. "text": [
  1099. "The detected scaning axes and values are: \n",
  1100. "\n",
  1101. "{'TOF_free': array([0.005, 0.006, 0.007, 0.008, 0.009, 0.01 , 0.011, 0.012, 0.013,\n",
  1102. " 0.014, 0.015, 0.016, 0.017, 0.018, 0.019, 0.02 , 0.021]), 'runs': array([0., 1., 2.])}\n"
  1103. ]
  1104. },
  1105. {
  1106. "data": {
  1107. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1108. "text/plain": [
  1109. "<IPython.core.display.Javascript object>"
  1110. ]
  1111. },
  1112. "metadata": {},
  1113. "output_type": "display_data"
  1114. },
  1115. {
  1116. "data": {
  1117. "text/html": [
  1118. "<img src=\"
  1119. ],
  1120. "text/plain": [
  1121. "<IPython.core.display.HTML object>"
  1122. ]
  1123. },
  1124. "metadata": {},
  1125. "output_type": "display_data"
  1126. }
  1127. ],
  1128. "source": [
  1129. "shotNum = \"0005\"\n",
  1130. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  1131. "\n",
  1132. "dataSetDict = {\n",
  1133. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  1134. " for i in [0]\n",
  1135. "}\n",
  1136. "\n",
  1137. "dataSet = dataSetDict[\"camera_0\"]\n",
  1138. "\n",
  1139. "print_scanAxis(dataSet)\n",
  1140. "\n",
  1141. "scanAxis = get_scanAxis(dataSet)\n",
  1142. "\n",
  1143. "dataSet = auto_rechunk(dataSet)\n",
  1144. "\n",
  1145. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  1146. "\n",
  1147. "imageAnalyser.center = (550, 990)\n",
  1148. "imageAnalyser.span = (1000, 200)\n",
  1149. "imageAnalyser.fraction = (0.1, 0.1)\n",
  1150. "\n",
  1151. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  1152. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  1153. "\n",
  1154. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  1155. "Ncount_mean = calculate_mean(Ncount)\n",
  1156. "Ncount_std = calculate_std(Ncount)\n",
  1157. "\n",
  1158. "fig = plt.figure()\n",
  1159. "ax = fig.gca()\n",
  1160. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  1161. "plt.xlabel('TOF (s)')\n",
  1162. "plt.ylabel('NCount')\n",
  1163. "plt.tight_layout()\n",
  1164. "plt.grid(visible=1)\n",
  1165. "plt.show()"
  1166. ]
  1167. },
  1168. {
  1169. "cell_type": "code",
  1170. "execution_count": 100,
  1171. "metadata": {},
  1172. "outputs": [
  1173. {
  1174. "data": {
  1175. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1176. "text/plain": [
  1177. "<IPython.core.display.Javascript object>"
  1178. ]
  1179. },
  1180. "metadata": {},
  1181. "output_type": "display_data"
  1182. },
  1183. {
  1184. "data": {
  1185. "text/html": [
  1186. "<img src=\"
  1187. ],
  1188. "text/plain": [
  1189. "<IPython.core.display.HTML object>"
  1190. ]
  1191. },
  1192. "metadata": {},
  1193. "output_type": "display_data"
  1194. }
  1195. ],
  1196. "source": [
  1197. "remove_bad_shots(dataSet_cropOD, TOF_free=0.005)\n",
  1198. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  1199. "Ncount_mean = calculate_mean(Ncount)\n",
  1200. "Ncount_std = calculate_std(Ncount)\n",
  1201. "\n",
  1202. "fig = plt.figure()\n",
  1203. "ax = fig.gca()\n",
  1204. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  1205. "plt.xlabel('TOF (s)')\n",
  1206. "plt.ylabel('NCount')\n",
  1207. "plt.tight_layout()\n",
  1208. "plt.grid(visible=1)\n",
  1209. "plt.show()"
  1210. ]
  1211. },
  1212. {
  1213. "cell_type": "code",
  1214. "execution_count": 101,
  1215. "metadata": {
  1216. "scrolled": false
  1217. },
  1218. "outputs": [],
  1219. "source": [
  1220. "dataSet_cropOD = dataSet_cropOD[1:-1, :, :, :]\n",
  1221. "dataSet_cropOD_chunk = dataSet_cropOD.chunk((1, 1, 1000, 200))\n",
  1222. "fitAnalyser = FitAnalyser(\"Gaussian-2D\", fitDim=2)\n",
  1223. "params = fitAnalyser.guess(dataSet_cropOD_chunk, dask=\"parallelized\")\n",
  1224. "fitResult = fitAnalyser.fit(dataSet_cropOD_chunk, params, dask=\"parallelized\").load()"
  1225. ]
  1226. },
  1227. {
  1228. "cell_type": "code",
  1229. "execution_count": 102,
  1230. "metadata": {},
  1231. "outputs": [
  1232. {
  1233. "data": {
  1234. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1235. "text/plain": [
  1236. "<IPython.core.display.Javascript object>"
  1237. ]
  1238. },
  1239. "metadata": {},
  1240. "output_type": "display_data"
  1241. },
  1242. {
  1243. "data": {
  1244. "text/html": [
  1245. "<img src=\"
  1246. ],
  1247. "text/plain": [
  1248. "<IPython.core.display.HTML object>"
  1249. ]
  1250. },
  1251. "metadata": {},
  1252. "output_type": "display_data"
  1253. }
  1254. ],
  1255. "source": [
  1256. "val = fitAnalyser.get_fit_value(fitResult)\n",
  1257. "std = fitAnalyser.get_fit_std(fitResult)\n",
  1258. "\n",
  1259. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(350), dask=\"parallelized\").load()\n",
  1260. "\n",
  1261. "# dataKey = 'sigmax'\n",
  1262. "dataKey = 'centerx'\n",
  1263. "# dataKey = 'sigmay'\n",
  1264. "# dataKey = 'centery'\n",
  1265. "\n",
  1266. "val_mean = val[dataKey].mean(dim='runs')\n",
  1267. "std_mean = val[dataKey].std(dim='runs')\n",
  1268. "\n",
  1269. "fig = plt.figure()\n",
  1270. "ax = fig.gca()\n",
  1271. "\n",
  1272. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  1273. "\n",
  1274. "plt.grid()\n",
  1275. "plt.show()"
  1276. ]
  1277. },
  1278. {
  1279. "cell_type": "code",
  1280. "execution_count": 103,
  1281. "metadata": {},
  1282. "outputs": [
  1283. {
  1284. "data": {
  1285. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1286. "text/plain": [
  1287. "<IPython.core.display.Javascript object>"
  1288. ]
  1289. },
  1290. "metadata": {},
  1291. "output_type": "display_data"
  1292. },
  1293. {
  1294. "data": {
  1295. "text/html": [
  1296. "<img src=\"
  1297. ],
  1298. "text/plain": [
  1299. "<IPython.core.display.HTML object>"
  1300. ]
  1301. },
  1302. "metadata": {},
  1303. "output_type": "display_data"
  1304. },
  1305. {
  1306. "name": "stdout",
  1307. "output_type": "stream",
  1308. "text": [
  1309. "M = 2.3513 ± 0.0036 \n"
  1310. ]
  1311. }
  1312. ],
  1313. "source": [
  1314. "def free_fall(x, A, B):\n",
  1315. " return A*(x**2) + B\n",
  1316. "\n",
  1317. "fitModel_freefall = NewFitModel(free_fall)\n",
  1318. "fitAnalyser_freefall = FitAnalyser(fitModel_freefall, fitDim=1)\n",
  1319. "\n",
  1320. "params = fitAnalyser_freefall.fitModel.make_params()\n",
  1321. "params.add(name=\"A\", value= 1e6, max = np.inf, min =-np.inf, vary = True)\n",
  1322. "params.add(name=\"B\", value= 1000, max = np.inf, min =-np.inf, vary = True)\n",
  1323. "\n",
  1324. "fitResult_freefall = fitAnalyser_freefall.fit(val_mean, params, x='TOF_free', dask=\"parallelized\")\n",
  1325. "\n",
  1326. "val = fitAnalyser_freefall.get_fit_value(fitResult_freefall)\n",
  1327. "std = fitAnalyser_freefall.get_fit_std(fitResult_freefall)\n",
  1328. "\n",
  1329. "fit_vals = tuple([val['A'].item(), val['B'].item()])\n",
  1330. "\n",
  1331. "fig = plt.figure()\n",
  1332. "ax = fig.gca()\n",
  1333. "val_mean.plot.errorbar(ax=ax, yerr=std_mean, fmt='or')\n",
  1334. "tof = np.linspace(5,21,50)*1e-3\n",
  1335. "plt.plot(tof, free_fall(tof, *fit_vals), 'b--',label='fit: A=%5.3f, B=%5.3f' % fit_vals)\n",
  1336. "plt.grid(visible =1)\n",
  1337. "plt.xlabel('TOF (s)')\n",
  1338. "plt.ylabel('Cloud Center (pixels)')\n",
  1339. "plt.legend()\n",
  1340. "plt.show()\n",
  1341. "\n",
  1342. "#pixel= 3.45e-6\n",
  1343. "pixel = 5.86e-6\n",
  1344. "g = 9.80998\n",
  1345. "M = val['A'].item() * 2 * pixel/g\n",
  1346. "dM = std['A'].item() * 2 * pixel/g\n",
  1347. "\n",
  1348. "print('M = %.4f \\u00B1 %.4f '% tuple([M,dM]))"
  1349. ]
  1350. },
  1351. {
  1352. "attachments": {},
  1353. "cell_type": "markdown",
  1354. "metadata": {},
  1355. "source": [
  1356. "## Measure temperature at the end of evaporative cooling 2, truncation 0.7"
  1357. ]
  1358. },
  1359. {
  1360. "cell_type": "code",
  1361. "execution_count": 9,
  1362. "metadata": {},
  1363. "outputs": [
  1364. {
  1365. "name": "stdout",
  1366. "output_type": "stream",
  1367. "text": [
  1368. "The detected scaning axes and values are: \n",
  1369. "\n",
  1370. "{'TOF_free': array([0.002, 0.003, 0.004, 0.005, 0.006, 0.007, 0.008, 0.009, 0.01 ,\n",
  1371. " 0.011, 0.012, 0.013, 0.014, 0.015]), 'runs': array([0., 1., 2.])}\n"
  1372. ]
  1373. },
  1374. {
  1375. "data": {
  1376. "image/png": "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
  1377. "text/plain": [
  1378. "<Figure size 640x480 with 1 Axes>"
  1379. ]
  1380. },
  1381. "metadata": {},
  1382. "output_type": "display_data"
  1383. }
  1384. ],
  1385. "source": [
  1386. "shotNum = \"0007\"\n",
  1387. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  1388. "\n",
  1389. "dataSetDict = {\n",
  1390. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  1391. " for i in [0]\n",
  1392. "}\n",
  1393. "\n",
  1394. "dataSet = dataSetDict[\"camera_0\"]\n",
  1395. "\n",
  1396. "print_scanAxis(dataSet)\n",
  1397. "\n",
  1398. "scanAxis = get_scanAxis(dataSet)\n",
  1399. "\n",
  1400. "dataSet = auto_rechunk(dataSet)\n",
  1401. "\n",
  1402. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  1403. "\n",
  1404. "imageAnalyser.center = (350, 990)\n",
  1405. "imageAnalyser.span = (650, 200)\n",
  1406. "imageAnalyser.fraction = (0.1, 0.1)\n",
  1407. "\n",
  1408. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  1409. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  1410. "\n",
  1411. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  1412. "Ncount_mean = calculate_mean(Ncount)\n",
  1413. "Ncount_std = calculate_std(Ncount)\n",
  1414. "\n",
  1415. "fig = plt.figure()\n",
  1416. "ax = fig.gca()\n",
  1417. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  1418. "plt.xlabel('TOF (s)')\n",
  1419. "plt.ylabel('NCount')\n",
  1420. "plt.tight_layout()\n",
  1421. "plt.grid(visible=1)\n",
  1422. "plt.show()"
  1423. ]
  1424. },
  1425. {
  1426. "cell_type": "code",
  1427. "execution_count": 10,
  1428. "metadata": {},
  1429. "outputs": [],
  1430. "source": [
  1431. "dataSet_cropOD_chunk = dataSet_cropOD.chunk((1, 1, 650, 200))\n",
  1432. "fitAnalyser = FitAnalyser(\"Gaussian-2D\", fitDim=2)\n",
  1433. "params = fitAnalyser.guess(dataSet_cropOD_chunk, dask=\"parallelized\")\n",
  1434. "fitResult = fitAnalyser.fit(dataSet_cropOD_chunk, params, dask=\"parallelized\").load()"
  1435. ]
  1436. },
  1437. {
  1438. "cell_type": "code",
  1439. "execution_count": 18,
  1440. "metadata": {},
  1441. "outputs": [
  1442. {
  1443. "name": "stdout",
  1444. "output_type": "stream",
  1445. "text": [
  1446. "3.769727404282448\n",
  1447. "0.07242840439128356\n"
  1448. ]
  1449. }
  1450. ],
  1451. "source": [
  1452. "data = fitAnalyser.get_fit_value(fitResult)\n",
  1453. "\n",
  1454. "print(data.amplitude.sel(TOF_free=0.01).mean('runs').item() * 147 / 1e5)\n",
  1455. "print(data.amplitude.sel(TOF_free=0.01).std('runs').item() * 147 / 1e5)"
  1456. ]
  1457. },
  1458. {
  1459. "cell_type": "code",
  1460. "execution_count": 123,
  1461. "metadata": {},
  1462. "outputs": [
  1463. {
  1464. "data": {
  1465. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1466. "text/plain": [
  1467. "<IPython.core.display.Javascript object>"
  1468. ]
  1469. },
  1470. "metadata": {},
  1471. "output_type": "display_data"
  1472. },
  1473. {
  1474. "data": {
  1475. "text/html": [
  1476. "<img src=\"
  1477. ],
  1478. "text/plain": [
  1479. "<IPython.core.display.HTML object>"
  1480. ]
  1481. },
  1482. "metadata": {},
  1483. "output_type": "display_data"
  1484. }
  1485. ],
  1486. "source": [
  1487. "val = fitAnalyser.get_fit_value(fitResult)\n",
  1488. "std = fitAnalyser.get_fit_std(fitResult)\n",
  1489. "\n",
  1490. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(350), dask=\"parallelized\").load()\n",
  1491. "\n",
  1492. "dataKey = 'sigmax'\n",
  1493. "# dataKey = 'centerx'\n",
  1494. "# dataKey = 'sigmay'\n",
  1495. "# dataKey = 'centery'\n",
  1496. "\n",
  1497. "val_mean = val[dataKey].mean(dim='runs')\n",
  1498. "std_mean = val[dataKey].std(dim='runs')\n",
  1499. "\n",
  1500. "fig = plt.figure()\n",
  1501. "ax = fig.gca()\n",
  1502. "\n",
  1503. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  1504. "\n",
  1505. "plt.grid()\n",
  1506. "plt.show()"
  1507. ]
  1508. },
  1509. {
  1510. "cell_type": "code",
  1511. "execution_count": 119,
  1512. "metadata": {},
  1513. "outputs": [
  1514. {
  1515. "data": {
  1516. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1517. "text/plain": [
  1518. "<IPython.core.display.Javascript object>"
  1519. ]
  1520. },
  1521. "metadata": {},
  1522. "output_type": "display_data"
  1523. },
  1524. {
  1525. "data": {
  1526. "text/html": [
  1527. "<img src=\"
  1528. ],
  1529. "text/plain": [
  1530. "<IPython.core.display.HTML object>"
  1531. ]
  1532. },
  1533. "metadata": {},
  1534. "output_type": "display_data"
  1535. }
  1536. ],
  1537. "source": [
  1538. "val = fitAnalyser.get_fit_value(fitResult)\n",
  1539. "std = fitAnalyser.get_fit_std(fitResult)\n",
  1540. "\n",
  1541. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(950), dask=\"parallelized\").load()\n",
  1542. "\n",
  1543. "# dataKey = 'sigmax'\n",
  1544. "# dataKey = 'centerx'\n",
  1545. "dataKey = 'sigmay'\n",
  1546. "# dataKey = 'centery'\n",
  1547. "\n",
  1548. "val_mean = val[dataKey].mean(dim='runs')\n",
  1549. "std_mean = val[dataKey].std(dim='runs')\n",
  1550. "\n",
  1551. "fig = plt.figure()\n",
  1552. "ax = fig.gca()\n",
  1553. "\n",
  1554. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  1555. "\n",
  1556. "plt.grid()\n",
  1557. "plt.show()"
  1558. ]
  1559. },
  1560. {
  1561. "cell_type": "code",
  1562. "execution_count": 125,
  1563. "metadata": {},
  1564. "outputs": [
  1565. {
  1566. "data": {
  1567. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1568. "text/plain": [
  1569. "<IPython.core.display.Javascript object>"
  1570. ]
  1571. },
  1572. "metadata": {},
  1573. "output_type": "display_data"
  1574. },
  1575. {
  1576. "data": {
  1577. "text/html": [
  1578. "<img src=\"
  1579. ],
  1580. "text/plain": [
  1581. "<IPython.core.display.HTML object>"
  1582. ]
  1583. },
  1584. "metadata": {},
  1585. "output_type": "display_data"
  1586. },
  1587. {
  1588. "name": "stdout",
  1589. "output_type": "stream",
  1590. "text": [
  1591. "T = 0.526 ± 0.006 uK\n"
  1592. ]
  1593. }
  1594. ],
  1595. "source": [
  1596. "def expansion(x, A, B):\n",
  1597. " return np.sqrt(A*x*x+B)\n",
  1598. "\n",
  1599. "val_truncated = val_mean[0:]\n",
  1600. "std_mean_truncated = std_mean[0:]\n",
  1601. "\n",
  1602. "fitModel_temperature = NewFitModel(expansion)\n",
  1603. "fitAnalyser_temperature = FitAnalyser(fitModel_temperature, fitDim=1)\n",
  1604. "\n",
  1605. "params = fitAnalyser_temperature.fitModel.make_params()\n",
  1606. "params.add(name=\"A\", value= 1e6, max = np.inf, min = 1, vary = True)\n",
  1607. "params.add(name=\"B\", value= 1000, max = np.inf, min = 0, vary = True)\n",
  1608. "\n",
  1609. "fitResult_temperature = fitAnalyser_temperature.fit(val_truncated, params, x='TOF_free', dask=\"parallelized\")\n",
  1610. "\n",
  1611. "val = fitAnalyser_temperature.get_fit_value(fitResult_temperature)\n",
  1612. "std = fitAnalyser_temperature.get_fit_std(fitResult_temperature)\n",
  1613. "\n",
  1614. "fit_vals = tuple([val['A'].item(), val['B'].item()])\n",
  1615. "fit_vals_std = tuple([std['A'].item(), std['B'].item()])\n",
  1616. "\n",
  1617. "tof = (np.arange(2,16,0.1)*1e-3)\n",
  1618. "\n",
  1619. "fig = plt.figure()\n",
  1620. "ax = fig.gca()\n",
  1621. "val_mean.plot.errorbar(ax=ax, yerr=std_mean, fmt='or')\n",
  1622. "plt.plot(tof, expansion(tof, *fit_vals), 'b--',\n",
  1623. " label='fit: A=%.3f, B=%.3f' % tuple(fit_vals))\n",
  1624. "plt.xlabel('TOF (s)')\n",
  1625. "plt.ylabel('Cloud Width - Vertical (pixels)')\n",
  1626. "#plt.ylabel('Cloud Width - Horizontal (pixels)')\n",
  1627. "plt.tight_layout()\n",
  1628. "plt.grid(visible=1)\n",
  1629. "plt.legend()\n",
  1630. "\n",
  1631. "\n",
  1632. "m = 164*1.673e-27\n",
  1633. "kb = 1.38e-23\n",
  1634. "pixel = 5.86e-6\n",
  1635. "M = 2.3513\n",
  1636. "\n",
  1637. "T = fit_vals[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  1638. "dT = fit_vals_std[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  1639. "\n",
  1640. "print('T = %.3f \\u00B1 %.3f uK'% tuple([T,dT]))"
  1641. ]
  1642. },
  1643. {
  1644. "attachments": {},
  1645. "cell_type": "markdown",
  1646. "metadata": {},
  1647. "source": [
  1648. "## Measure temperature at the end of evaporative cooling 2, truncation 0.65"
  1649. ]
  1650. },
  1651. {
  1652. "cell_type": "code",
  1653. "execution_count": 19,
  1654. "metadata": {},
  1655. "outputs": [
  1656. {
  1657. "name": "stdout",
  1658. "output_type": "stream",
  1659. "text": [
  1660. "The detected scaning axes and values are: \n",
  1661. "\n",
  1662. "{'TOF_free': array([0.002, 0.003, 0.004, 0.005, 0.006, 0.007, 0.008, 0.009, 0.01 ,\n",
  1663. " 0.011, 0.012, 0.013, 0.014, 0.015]), 'runs': array([0., 1., 2.])}\n"
  1664. ]
  1665. },
  1666. {
  1667. "data": {
  1668. "image/png": "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
  1669. "text/plain": [
  1670. "<Figure size 640x480 with 1 Axes>"
  1671. ]
  1672. },
  1673. "metadata": {},
  1674. "output_type": "display_data"
  1675. }
  1676. ],
  1677. "source": [
  1678. "shotNum = \"0008\"\n",
  1679. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  1680. "\n",
  1681. "dataSetDict = {\n",
  1682. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  1683. " for i in [0]\n",
  1684. "}\n",
  1685. "\n",
  1686. "dataSet = dataSetDict[\"camera_0\"]\n",
  1687. "\n",
  1688. "print_scanAxis(dataSet)\n",
  1689. "\n",
  1690. "scanAxis = get_scanAxis(dataSet)\n",
  1691. "\n",
  1692. "dataSet = auto_rechunk(dataSet)\n",
  1693. "\n",
  1694. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  1695. "\n",
  1696. "imageAnalyser.center = (350, 990)\n",
  1697. "imageAnalyser.span = (650, 200)\n",
  1698. "imageAnalyser.fraction = (0.1, 0.1)\n",
  1699. "\n",
  1700. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  1701. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  1702. "\n",
  1703. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  1704. "Ncount_mean = calculate_mean(Ncount)\n",
  1705. "Ncount_std = calculate_std(Ncount)\n",
  1706. "\n",
  1707. "fig = plt.figure()\n",
  1708. "ax = fig.gca()\n",
  1709. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  1710. "plt.xlabel('TOF (s)')\n",
  1711. "plt.ylabel('NCount')\n",
  1712. "plt.tight_layout()\n",
  1713. "plt.grid(visible=1)\n",
  1714. "plt.show()"
  1715. ]
  1716. },
  1717. {
  1718. "cell_type": "code",
  1719. "execution_count": 20,
  1720. "metadata": {},
  1721. "outputs": [],
  1722. "source": [
  1723. "dataSet_cropOD_chunk = dataSet_cropOD.chunk((1, 1, 650, 200))\n",
  1724. "fitAnalyser = FitAnalyser(\"Gaussian-2D\", fitDim=2)\n",
  1725. "params = fitAnalyser.guess(dataSet_cropOD_chunk, dask=\"parallelized\")\n",
  1726. "fitResult = fitAnalyser.fit(dataSet_cropOD_chunk, params, dask=\"parallelized\").load()"
  1727. ]
  1728. },
  1729. {
  1730. "cell_type": "code",
  1731. "execution_count": 21,
  1732. "metadata": {},
  1733. "outputs": [
  1734. {
  1735. "name": "stdout",
  1736. "output_type": "stream",
  1737. "text": [
  1738. "4.158908069274802\n",
  1739. "0.17858152215917347\n"
  1740. ]
  1741. }
  1742. ],
  1743. "source": [
  1744. "data = fitAnalyser.get_fit_value(fitResult)\n",
  1745. "\n",
  1746. "print(data.amplitude.sel(TOF_free=0.01).mean('runs').item() * 147 / 1e5)\n",
  1747. "print(data.amplitude.sel(TOF_free=0.01).std('runs').item() * 147 / 1e5)"
  1748. ]
  1749. },
  1750. {
  1751. "cell_type": "code",
  1752. "execution_count": 109,
  1753. "metadata": {},
  1754. "outputs": [
  1755. {
  1756. "data": {
  1757. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1758. "text/plain": [
  1759. "<IPython.core.display.Javascript object>"
  1760. ]
  1761. },
  1762. "metadata": {},
  1763. "output_type": "display_data"
  1764. },
  1765. {
  1766. "data": {
  1767. "text/html": [
  1768. "<img src=\"
  1769. ],
  1770. "text/plain": [
  1771. "<IPython.core.display.HTML object>"
  1772. ]
  1773. },
  1774. "metadata": {},
  1775. "output_type": "display_data"
  1776. }
  1777. ],
  1778. "source": [
  1779. "val = fitAnalyser.get_fit_value(fitResult)\n",
  1780. "std = fitAnalyser.get_fit_std(fitResult)\n",
  1781. "\n",
  1782. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(350), dask=\"parallelized\").load()\n",
  1783. "\n",
  1784. "dataKey = 'sigmax'\n",
  1785. "# dataKey = 'centerx'\n",
  1786. "# dataKey = 'sigmay'\n",
  1787. "# dataKey = 'centery'\n",
  1788. "\n",
  1789. "val_mean = val[dataKey].mean(dim='runs')\n",
  1790. "std_mean = val[dataKey].std(dim='runs')\n",
  1791. "\n",
  1792. "fig = plt.figure()\n",
  1793. "ax = fig.gca()\n",
  1794. "\n",
  1795. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  1796. "\n",
  1797. "plt.grid()\n",
  1798. "plt.show()"
  1799. ]
  1800. },
  1801. {
  1802. "cell_type": "code",
  1803. "execution_count": 112,
  1804. "metadata": {},
  1805. "outputs": [
  1806. {
  1807. "data": {
  1808. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1809. "text/plain": [
  1810. "<IPython.core.display.Javascript object>"
  1811. ]
  1812. },
  1813. "metadata": {},
  1814. "output_type": "display_data"
  1815. },
  1816. {
  1817. "data": {
  1818. "text/html": [
  1819. "<img src=\"
  1820. ],
  1821. "text/plain": [
  1822. "<IPython.core.display.HTML object>"
  1823. ]
  1824. },
  1825. "metadata": {},
  1826. "output_type": "display_data"
  1827. }
  1828. ],
  1829. "source": [
  1830. "val = fitAnalyser.get_fit_value(fitResult)\n",
  1831. "std = fitAnalyser.get_fit_std(fitResult)\n",
  1832. "\n",
  1833. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(950), dask=\"parallelized\").load()\n",
  1834. "\n",
  1835. "# dataKey = 'sigmax'\n",
  1836. "# dataKey = 'centerx'\n",
  1837. "dataKey = 'sigmay'\n",
  1838. "# dataKey = 'centery'\n",
  1839. "\n",
  1840. "val_mean = val[dataKey].mean(dim='runs')\n",
  1841. "std_mean = val[dataKey].std(dim='runs')\n",
  1842. "\n",
  1843. "fig = plt.figure()\n",
  1844. "ax = fig.gca()\n",
  1845. "\n",
  1846. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  1847. "\n",
  1848. "plt.grid()\n",
  1849. "plt.show()"
  1850. ]
  1851. },
  1852. {
  1853. "cell_type": "code",
  1854. "execution_count": 114,
  1855. "metadata": {},
  1856. "outputs": [
  1857. {
  1858. "data": {
  1859. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  1860. "text/plain": [
  1861. "<IPython.core.display.Javascript object>"
  1862. ]
  1863. },
  1864. "metadata": {},
  1865. "output_type": "display_data"
  1866. },
  1867. {
  1868. "data": {
  1869. "text/html": [
  1870. "<img src=\"
  1871. ],
  1872. "text/plain": [
  1873. "<IPython.core.display.HTML object>"
  1874. ]
  1875. },
  1876. "metadata": {},
  1877. "output_type": "display_data"
  1878. },
  1879. {
  1880. "name": "stdout",
  1881. "output_type": "stream",
  1882. "text": [
  1883. "T = 0.649 ± 0.005 uK\n"
  1884. ]
  1885. }
  1886. ],
  1887. "source": [
  1888. "def expansion(x, A, B):\n",
  1889. " return np.sqrt(A*x*x+B)\n",
  1890. "\n",
  1891. "val_truncated = val_mean[2:]\n",
  1892. "std_mean_truncated = std_mean[2:]\n",
  1893. "\n",
  1894. "fitModel_temperature = NewFitModel(expansion)\n",
  1895. "fitAnalyser_temperature = FitAnalyser(fitModel_temperature, fitDim=1)\n",
  1896. "\n",
  1897. "params = fitAnalyser_temperature.fitModel.make_params()\n",
  1898. "params.add(name=\"A\", value= 1e6, max = np.inf, min = 1, vary = True)\n",
  1899. "params.add(name=\"B\", value= 1000, max = np.inf, min = 0, vary = True)\n",
  1900. "\n",
  1901. "fitResult_temperature = fitAnalyser_temperature.fit(val_truncated, params, x='TOF_free', dask=\"parallelized\")\n",
  1902. "\n",
  1903. "val = fitAnalyser_temperature.get_fit_value(fitResult_temperature)\n",
  1904. "std = fitAnalyser_temperature.get_fit_std(fitResult_temperature)\n",
  1905. "\n",
  1906. "fit_vals = tuple([val['A'].item(), val['B'].item()])\n",
  1907. "fit_vals_std = tuple([std['A'].item(), std['B'].item()])\n",
  1908. "\n",
  1909. "tof = (np.arange(2,16,0.1)*1e-3)\n",
  1910. "\n",
  1911. "fig = plt.figure()\n",
  1912. "ax = fig.gca()\n",
  1913. "val_mean.plot.errorbar(ax=ax, yerr=std_mean, fmt='or')\n",
  1914. "plt.plot(tof, expansion(tof, *fit_vals), 'b--',\n",
  1915. " label='fit: A=%.3f, B=%.3f' % tuple(fit_vals))\n",
  1916. "plt.xlabel('TOF (s)')\n",
  1917. "#plt.ylabel('Cloud Width - Vertical (pixels)')\n",
  1918. "plt.ylabel('Cloud Width - Horizontal (pixels)')\n",
  1919. "plt.tight_layout()\n",
  1920. "plt.grid(visible=1)\n",
  1921. "plt.legend()\n",
  1922. "\n",
  1923. "\n",
  1924. "m = 164*1.673e-27\n",
  1925. "kb = 1.38e-23\n",
  1926. "pixel = 5.86e-6\n",
  1927. "M = 2.3513\n",
  1928. "\n",
  1929. "T = fit_vals[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  1930. "dT = fit_vals_std[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  1931. "\n",
  1932. "print('T = %.3f \\u00B1 %.3f uK'% tuple([T,dT]))"
  1933. ]
  1934. },
  1935. {
  1936. "attachments": {},
  1937. "cell_type": "markdown",
  1938. "metadata": {},
  1939. "source": [
  1940. "## Measure temperature at the end of evaporative cooling 2, truncation 0.6"
  1941. ]
  1942. },
  1943. {
  1944. "cell_type": "code",
  1945. "execution_count": 22,
  1946. "metadata": {},
  1947. "outputs": [
  1948. {
  1949. "name": "stdout",
  1950. "output_type": "stream",
  1951. "text": [
  1952. "The detected scaning axes and values are: \n",
  1953. "\n",
  1954. "{'TOF_free': array([0.002, 0.003, 0.004, 0.005, 0.006, 0.007, 0.008, 0.009, 0.01 ,\n",
  1955. " 0.011, 0.012, 0.013, 0.014, 0.015]), 'runs': array([0., 1., 2.])}\n"
  1956. ]
  1957. },
  1958. {
  1959. "data": {
  1960. "image/png": "iVBORw0KGgoAAAANSUhEUgAAAm8AAAHQCAYAAAD3Qo21AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAA9hAAAPYQGoP6dpAABT40lEQVR4nO3de1yUdd7/8fcoOHLQDBDUwKzcZPGAxSayu6ZmEp7WQ3pX/mhTo/ptmlpt5AEL1kPunbWai7WVq+ahg61aVioIWnvnMd3uBVu7f5vWGq2heMBAcdDr9wf3TIwDeoGDM5e8no8Hj5zv9Z3vfL8fxuntdRqbYRiGAAAAYAlNfD0BAAAAmEd4AwAAsBDCGwAAgIUQ3gAAACyE8AYAAGAhhDcAAAALIbwBAABYCOENAADAQgJ8PYGrxfnz5/Xdd9+pRYsWstlsvp4OAACwGMMwdOrUKbVr105NmtS+f43w5iXfffedYmJifD0NAABgcYcOHVJ0dHSt2wlvXtKiRQtJVQVv2bKl18d3OBzKyclRcnKyAgMDvT7+1YI6mUetzKFO5lAnc6iTeY2xVqWlpYqJiXFlitoQ3rzEeai0ZcuWDRbegoOD1bJly0bzJq4P6mQetTKHOplDncyhTuY15lpd6vQrLlgAAACwEMIbAACAhRDeAAAALITwBgAAYCGENwAAAAshvAEAAFgI4Q0AAMBCCG8AAAAWQngDAACwEMIbAACAhRDeAAAALITwBgAAYCGENwAAAAshvAEAAFgI4Q0AAMBCCG8AADRiZWWSzVb1U1bm69nADMIbAACAhRDeAAAALITwBgAAYCGENwAAAAshvAEAAFgI4Q0AAMBCCG8AAAAWEuDrCQDeUlYmhYYGShqq48cdatXK1zNyzqnqzz/8IIWE+HY+AADrY88bAACAhRDeAAAALITwBgAAYCE+D2+ff/65Bg0apPbt2ysoKEhhYWFKSkrSihUr3PqNGTNGNpvN4yc2NrbGcRcuXKjY2FjZ7XbdcMMNysrKksPh8OhXXFysMWPGKCIiQsHBwUpKSlJeXl6DrBUAAOBy+fyChRMnTigmJkb33XefrrvuOpWVlWnlypW6//779fXXXysjI8PVNygoSPn5+W7PDwoK8hhz9uzZmjFjhqZMmaLk5GTt3r1bGRkZKioq0quvvurqV1FRoX79+unEiRNasGCBIiMjlZ2drZSUFG3evFm9e/duuIUDAADUg8/DW58+fdSnTx+3tsGDB+vgwYN69dVX3cJbkyZN1LNnz4uOV1JSolmzZumhhx7SnDlzXK/hcDiUkZGhyZMnKy4uTpK0ePFiFRYWatu2bUpKSpIk9e3bV/Hx8UpPT9fOnTu9uFIAAIDL5/PDprWJiIhQQEDds+XGjRt15swZjR071q197NixMgxD69atc7WtXbtWnTp1cgU3SQoICFBqaqp27dqloqKies8fAACgIfhNeDt//rwqKyt15MgRLVq0SJs2bdLTTz/t1uf06dNq06aNmjZtqujoaE2YMEHHjh1z61NYWChJ6tq1q1t727ZtFRER4dru7NutWzePuTjb9u3b55W1AcDVrKxMatYsUMOGDVVZma9n47+oE7zF54dNnR599FH96U9/kiQ1a9ZML730kh555BHX9vj4eMXHx6tLly6SpI8//lh/+MMflJeXp927dyv0f++EWlJSIrvdrpAa7oYaFhamkpIS1+OSkhKFhYXV2M+5vTYVFRWqqKhwPS4tLZUkORyOGi+MuFzOMRti7KtFVWkC//fPDvlDqfxxTk68p8yhTpfmz+9zf+KvdfLfeTW+v3tm1+o34W3atGlKS0tTcXGx1q9frwkTJqisrEy//e1vJUmPP/64W//+/fvrlltu0ciRI/Xaa6+5bbfZbLW+zoXb6tK3uueee05ZWVke7Tk5OQoODq71eZcrNze3wca2ujNnmkoaLEnKz89X8+bnfDshuc9p06ZNfjGnC/GeMoc61c4f/+75I3+tk79/TjWmv3vl5eWm+vlNeGvfvr3at28vSRo4cKAkaerUqXrggQfUunXrGp8zfPhwhYSEaMeOHa628PBwnTlzRuXl5R4h6tixY0pISHDrW9PeNeeh2Jr2yjlNnTpVTzzxhOtxaWmpYmJilJycrJYtW15quXXmcDiUm5ur/v37KzAw0OvjXw2qH4a444471KqV7+tUfU533XWXX309Fu8pc6jTpfnj3z1/5K918tfPqcb4d895FO9S/Ca8XahHjx565ZVXdODAgVrDmyQZhqEmTX48dc95rltBQYESExNd7YcPH9bRo0ddh12dfQsKCjzGdLZV73shu90uu93u0R4YGNigb7KGHt/KqpfFX+rkOSffzaU2/lIrf0edauePf/f8kb/Wyd8/p/ypVg3N7Dr95oKFC23ZskVNmjTRjTfeWGufd999V+Xl5W63D0lJSVHz5s21dOlSt75Lly6VzWbTsGHDXG3Dhw/X/v373W4JUllZqRUrVigxMVHt2rXz2noAAAC8wed73h5++GG1bNlSPXr0UFRUlI4eParVq1fr7bff1lNPPaXWrVvrm2++0ejRo3XvvfeqY8eOstls+vjjjzV//nx17txZaWlprvHCwsKUkZGhGTNmKCwszHWT3szMTKWlpbnu8SZJ48aNU3Z2tkaNGqW5c+cqMjJSixYt0pdffqnNmzf7ohwAAFxR56qd4vbJJ1JystS0qe/mg0vzeXhLSkrSkiVLtGzZMp04cUKhoaGKj4/X8uXLlZqaKklq2bKloqKi9OKLL+r777/XuXPndP3112vixImaNm2ax5Wl06dPV4sWLZSdna158+apTZs2mjJliqZPn+7Wz263Ky8vT+np6XrsscdUXl6u7t27a8OGDXy7AgDgqrdmjTRx4o+PBw6UoqOlBQukESN8Ny9cnM/D29ixYz1uqHuha6+9VmvWrKnTuBMnTtTE6u/IWkRFRWnZsmV1GhsAAKtbs0YaOVIyDPf2oqKq9nffJcD5K7895w0AADSMc+ekSZM8g5v0Y9vkye6HVOE/CG8AADQyf/2r9O23tW83DOnQoap+8D+ENwAAGpl//9u7/XBlEd4AAGhk2rb1bj9cWYQ3XDWqn5vxX/9l41wNAKhFr15VV5XW9i2QNpsUE1PVD/6H8Iarwpo1UrVb+GnIkAB16FDVDgBw17Rp1e1AJM8A53w8fz73e/NXhDdYnvNy96Ii93bn5e4EOADwNGJE1e1ALvwyoehobhPi7whvsDQudweA+hsxQvriix8ff/SRdPAgwc3fEd5gaVzuDgCXp/qh0dtv51CpFRDeYGlc7g4AaGwIb7A0LncHADQ2hDdYGpe7A6hJWVnV33+brerPwNWE8AZL43J3AEBjQ3iD5XG5OwCgMQnw9QQAbxgxQrrzTumaa6oer19fqQEDAtjjhqtOWZkUGlr15x9+kEJCfDsfoCFUvc8DJQ3V8eMOtWrl6xn5F/a84apRPaj98pcGwQ24QvhqOjQG/nQeJeENAGpRViY1axaoYcOG+vzD2l/x1XTAlUd4AwDUC19NB/gG4Q0AUGd8NR3gO4Q3AECd8dV0aEicR3lxhDcAQJ3x1XRoKP56HmX1APnJJ77dq0x4AwDUGV9Nh4bgr+dRXhgoBw6UTwMl4Q0AUGd8NR28zV/Po/THQEl4AwDUGV9NB2/zx/Mo/TVQEt6ABuRP50gA3sZX08Gb/PE8Sn8MlBLhDWgw/naOBNAQRoyQvvjix8fr11fq4EGCG+rOH8+j9MdAKRHegAbhj+dIAA3FH7+azh/3enP7i4vzx/Mo/TFQSoQ3wOv89RwJoLHwx73e/nr7C3/ij+dR+mOglAhvgNf56zkSQGPgj3u9/XFO1YWEVH0uGUbVn33J386j9MdAKRHeAK/z13MkgKudP+719sc5+Tt/O4/S3wKlRHgDvM5fz5EArnb+uNfbH+dkBf52HuWFgfKjj+TTQBngm5cFrl7OcySKimr+17bNVrXdlzcvLSuTQkMDJQ3V8eMOtWrlu7kA3uKPe739cU6on+oB8vbbfXsPQ5/vefv88881aNAgtW/fXkFBQQoLC1NSUpJ
  1961. "text/plain": [
  1962. "<Figure size 640x480 with 1 Axes>"
  1963. ]
  1964. },
  1965. "metadata": {},
  1966. "output_type": "display_data"
  1967. }
  1968. ],
  1969. "source": [
  1970. "shotNum = \"0009\"\n",
  1971. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  1972. "\n",
  1973. "dataSetDict = {\n",
  1974. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  1975. " for i in [0]\n",
  1976. "}\n",
  1977. "\n",
  1978. "dataSet = dataSetDict[\"camera_0\"]\n",
  1979. "\n",
  1980. "print_scanAxis(dataSet)\n",
  1981. "\n",
  1982. "scanAxis = get_scanAxis(dataSet)\n",
  1983. "\n",
  1984. "dataSet = auto_rechunk(dataSet)\n",
  1985. "\n",
  1986. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  1987. "\n",
  1988. "imageAnalyser.center = (350, 990)\n",
  1989. "imageAnalyser.span = (650, 200)\n",
  1990. "imageAnalyser.fraction = (0.1, 0.1)\n",
  1991. "\n",
  1992. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  1993. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  1994. "\n",
  1995. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  1996. "Ncount_mean = calculate_mean(Ncount)\n",
  1997. "Ncount_std = calculate_std(Ncount)\n",
  1998. "\n",
  1999. "fig = plt.figure()\n",
  2000. "ax = fig.gca()\n",
  2001. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  2002. "plt.xlabel('TOF (s)')\n",
  2003. "plt.ylabel('NCount')\n",
  2004. "plt.tight_layout()\n",
  2005. "plt.grid(visible=1)\n",
  2006. "plt.show()"
  2007. ]
  2008. },
  2009. {
  2010. "cell_type": "code",
  2011. "execution_count": 23,
  2012. "metadata": {},
  2013. "outputs": [],
  2014. "source": [
  2015. "dataSet_cropOD_chunk = dataSet_cropOD.chunk((1, 1, 650, 200))\n",
  2016. "fitAnalyser = FitAnalyser(\"Gaussian-2D\", fitDim=2)\n",
  2017. "params = fitAnalyser.guess(dataSet_cropOD_chunk, dask=\"parallelized\")\n",
  2018. "fitResult = fitAnalyser.fit(dataSet_cropOD_chunk, params, dask=\"parallelized\").load()"
  2019. ]
  2020. },
  2021. {
  2022. "cell_type": "code",
  2023. "execution_count": 24,
  2024. "metadata": {},
  2025. "outputs": [
  2026. {
  2027. "name": "stdout",
  2028. "output_type": "stream",
  2029. "text": [
  2030. "4.809698089774189\n",
  2031. "0.160561481247611\n"
  2032. ]
  2033. }
  2034. ],
  2035. "source": [
  2036. "data = fitAnalyser.get_fit_value(fitResult)\n",
  2037. "\n",
  2038. "print(data.amplitude.sel(TOF_free=0.01).mean('runs').item() * 147 / 1e5)\n",
  2039. "print(data.amplitude.sel(TOF_free=0.01).std('runs').item() * 147 / 1e5)"
  2040. ]
  2041. },
  2042. {
  2043. "cell_type": "code",
  2044. "execution_count": 134,
  2045. "metadata": {},
  2046. "outputs": [
  2047. {
  2048. "data": {
  2049. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2050. "text/plain": [
  2051. "<IPython.core.display.Javascript object>"
  2052. ]
  2053. },
  2054. "metadata": {},
  2055. "output_type": "display_data"
  2056. },
  2057. {
  2058. "data": {
  2059. "text/html": [
  2060. "<img src=\"
  2061. ],
  2062. "text/plain": [
  2063. "<IPython.core.display.HTML object>"
  2064. ]
  2065. },
  2066. "metadata": {},
  2067. "output_type": "display_data"
  2068. }
  2069. ],
  2070. "source": [
  2071. "val = fitAnalyser.get_fit_value(fitResult)\n",
  2072. "std = fitAnalyser.get_fit_std(fitResult)\n",
  2073. "\n",
  2074. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(350), dask=\"parallelized\").load()\n",
  2075. "\n",
  2076. "dataKey = 'sigmax'\n",
  2077. "# dataKey = 'centerx'\n",
  2078. "# dataKey = 'sigmay'\n",
  2079. "# dataKey = 'centery'\n",
  2080. "\n",
  2081. "val_mean = val[dataKey].mean(dim='runs')\n",
  2082. "std_mean = val[dataKey].std(dim='runs')\n",
  2083. "\n",
  2084. "fig = plt.figure()\n",
  2085. "ax = fig.gca()\n",
  2086. "\n",
  2087. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  2088. "\n",
  2089. "plt.grid()\n",
  2090. "plt.show()"
  2091. ]
  2092. },
  2093. {
  2094. "cell_type": "code",
  2095. "execution_count": 132,
  2096. "metadata": {},
  2097. "outputs": [
  2098. {
  2099. "data": {
  2100. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2101. "text/plain": [
  2102. "<IPython.core.display.Javascript object>"
  2103. ]
  2104. },
  2105. "metadata": {},
  2106. "output_type": "display_data"
  2107. },
  2108. {
  2109. "data": {
  2110. "text/html": [
  2111. "<img src=\"
  2112. ],
  2113. "text/plain": [
  2114. "<IPython.core.display.HTML object>"
  2115. ]
  2116. },
  2117. "metadata": {},
  2118. "output_type": "display_data"
  2119. }
  2120. ],
  2121. "source": [
  2122. "val = fitAnalyser.get_fit_value(fitResult)\n",
  2123. "std = fitAnalyser.get_fit_std(fitResult)\n",
  2124. "\n",
  2125. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(950), dask=\"parallelized\").load()\n",
  2126. "\n",
  2127. "# dataKey = 'sigmax'\n",
  2128. "# dataKey = 'centerx'\n",
  2129. "dataKey = 'sigmay'\n",
  2130. "# dataKey = 'centery'\n",
  2131. "\n",
  2132. "val_mean = val[dataKey].mean(dim='runs')\n",
  2133. "std_mean = val[dataKey].std(dim='runs')\n",
  2134. "\n",
  2135. "fig = plt.figure()\n",
  2136. "ax = fig.gca()\n",
  2137. "\n",
  2138. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  2139. "\n",
  2140. "plt.grid()\n",
  2141. "plt.show()"
  2142. ]
  2143. },
  2144. {
  2145. "cell_type": "code",
  2146. "execution_count": 136,
  2147. "metadata": {},
  2148. "outputs": [
  2149. {
  2150. "data": {
  2151. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2152. "text/plain": [
  2153. "<IPython.core.display.Javascript object>"
  2154. ]
  2155. },
  2156. "metadata": {},
  2157. "output_type": "display_data"
  2158. },
  2159. {
  2160. "data": {
  2161. "text/html": [
  2162. "<img src=\"
  2163. ],
  2164. "text/plain": [
  2165. "<IPython.core.display.HTML object>"
  2166. ]
  2167. },
  2168. "metadata": {},
  2169. "output_type": "display_data"
  2170. },
  2171. {
  2172. "name": "stdout",
  2173. "output_type": "stream",
  2174. "text": [
  2175. "T = 0.858 ± 0.004 uK\n"
  2176. ]
  2177. }
  2178. ],
  2179. "source": [
  2180. "def expansion(x, A, B):\n",
  2181. " return np.sqrt(A*x*x+B)\n",
  2182. "\n",
  2183. "val_truncated = val_mean[2:]\n",
  2184. "std_mean_truncated = std_mean[2:]\n",
  2185. "\n",
  2186. "fitModel_temperature = NewFitModel(expansion)\n",
  2187. "fitAnalyser_temperature = FitAnalyser(fitModel_temperature, fitDim=1)\n",
  2188. "\n",
  2189. "params = fitAnalyser_temperature.fitModel.make_params()\n",
  2190. "params.add(name=\"A\", value= 1e6, max = np.inf, min = 1, vary = True)\n",
  2191. "params.add(name=\"B\", value= 1000, max = np.inf, min = 0, vary = True)\n",
  2192. "\n",
  2193. "fitResult_temperature = fitAnalyser_temperature.fit(val_truncated, params, x='TOF_free', dask=\"parallelized\")\n",
  2194. "\n",
  2195. "val = fitAnalyser_temperature.get_fit_value(fitResult_temperature)\n",
  2196. "std = fitAnalyser_temperature.get_fit_std(fitResult_temperature)\n",
  2197. "\n",
  2198. "fit_vals = tuple([val['A'].item(), val['B'].item()])\n",
  2199. "fit_vals_std = tuple([std['A'].item(), std['B'].item()])\n",
  2200. "\n",
  2201. "tof = (np.arange(2,16,0.1)*1e-3)\n",
  2202. "\n",
  2203. "fig = plt.figure()\n",
  2204. "ax = fig.gca()\n",
  2205. "val_mean.plot.errorbar(ax=ax, yerr=std_mean, fmt='or')\n",
  2206. "plt.plot(tof, expansion(tof, *fit_vals), 'b--',\n",
  2207. " label='fit: A=%.3f, B=%.3f' % tuple(fit_vals))\n",
  2208. "plt.xlabel('TOF (s)')\n",
  2209. "plt.ylabel('Cloud Width - Vertical (pixels)')\n",
  2210. "# plt.ylabel('Cloud Width - Horizontal (pixels)')\n",
  2211. "plt.tight_layout()\n",
  2212. "plt.grid(visible=1)\n",
  2213. "plt.legend()\n",
  2214. "\n",
  2215. "\n",
  2216. "m = 164*1.673e-27\n",
  2217. "kb = 1.38e-23\n",
  2218. "pixel = 5.86e-6\n",
  2219. "M = 2.3513\n",
  2220. "\n",
  2221. "T = fit_vals[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  2222. "dT = fit_vals_std[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  2223. "\n",
  2224. "print('T = %.3f \\u00B1 %.3f uK'% tuple([T,dT]))"
  2225. ]
  2226. },
  2227. {
  2228. "attachments": {},
  2229. "cell_type": "markdown",
  2230. "metadata": {},
  2231. "source": [
  2232. "## Measure temperature at the end of evaporative cooling 2, truncation 0.675"
  2233. ]
  2234. },
  2235. {
  2236. "cell_type": "code",
  2237. "execution_count": 25,
  2238. "metadata": {},
  2239. "outputs": [
  2240. {
  2241. "name": "stdout",
  2242. "output_type": "stream",
  2243. "text": [
  2244. "The detected scaning axes and values are: \n",
  2245. "\n",
  2246. "{'TOF_free': array([0.002, 0.003, 0.004, 0.005, 0.006, 0.007, 0.008, 0.009, 0.01 ,\n",
  2247. " 0.011, 0.012, 0.013, 0.014, 0.015]), 'runs': array([0., 1., 2.])}\n"
  2248. ]
  2249. },
  2250. {
  2251. "data": {
  2252. "image/png": "iVBORw0KGgoAAAANSUhEUgAAAm8AAAHPCAYAAAAFwj37AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAA9hAAAPYQGoP6dpAABKyUlEQVR4nO3de3hU5b328XsgYcgBxCQEAgSxUk0jEDRVSFvKSWJEKeet5cUKNLRv5ahuU46aKCBu0UJptFVTQAFtcYOKCiQkoFYOIrzuEizuvRUVghgIYGhCwiSs9480Y4aZkJUwyayVfD/XlcvMs571zLN+TmZu1mkchmEYAgAAgC20CvQEAAAAYB7hDQAAwEYIbwAAADZCeAMAALARwhsAAICNEN4AAABshPAGAABgI0GBnkBzcfHiRR0/flzt2rWTw+EI9HQAAIDNGIahc+fOqUuXLmrVqvb9a4Q3Pzl+/LhiY2MDPQ0AAGBzR48eVbdu3WpdTnjzk3bt2kmqKnj79u39Pr7L5VJ2draSk5MVHBzs9/GbC+pkHrUyhzqZQ53MoU7mtcRaFRcXKzY21p0pakN485PqQ6Xt27dvtPAWGhqq9u3bt5gXcUNQJ/OolTnUyRzqZA51Mq8l16qu06+4YAEAAMBGCG8AAAA2QngDAACwEcIbAACAjRDeAAAAbITwBgAAYCOENwAAABshvAEAANgI4Q0AAMBGCG8AAAA2QngDAACwkYCHt48//lh33nmnunfvrpCQEEVERCgpKUlr16716nvgwAHddtttCg8PV4cOHTRmzBh9/vnnPsdduXKl4uLi5HQ6de211yojI0Mul8urX2FhoSZNmqSoqCiFhoYqKSlJubm5ft9OAAAAfwh4eDt79qxiY2O1ZMkSvfPOO3rppZfUo0cP3XvvvVq0aJG73+HDhzVo0CBduHBBf/3rX/XnP/9Z//3f/60BAwbo5MmTHmMuXrxYs2bN0pgxY7Rt2zbdf//9WrJkiaZNm+bRr7y8XEOHDlVubq5WrFihN954Q506dVJKSorefffdJtl+AACA+ggK9AQGDRqkQYMGebTdddddOnLkiJ5//nktWLBAkvTII4/I6XTqrbfeUvv27SVJiYmJ+v73v69ly5bpySeflCQVFRVp0aJFmjp1qpYsWeJ+DpfLpQULFmj27NmKj4+XJGVlZSk/P1+7du1SUlKSJGnw4MFKSEhQWlqa9u7d2xQlAAAAMC3ge95qExUVpaCgqmxZUVGht956S2PHjnUHN0m65pprNHjwYG3atMndtnXrVpWVlWny5Mke402ePFmGYej11193t23atEk33HCDO7hJUlBQkCZOnKgPP/xQBQUFjbR1AAAADRPwPW/VLl68qIsXL+rMmTPasGGDtm3bpj/84Q+SpM8++0znz59Xnz59vNbr06ePcnJyVFZWprZt2yo/P1+S1Lt3b49+MTExioqKci+XpPz8fA0YMMDnmJJ06NAhde3a1ed8y8vLVV5e7n5cXFwsSXK5XD7PrbtS1WM2xtjNCXUyj1qZQ53MoU7mWLFOJSXS1VcHS5LOnHEpLCzAE/oXK9aqsZndVsuEt/vvv19/+tOfJElt2rTR73//e/3617+WVHUoVJIiIiK81ouIiJBhGDpz5oxiYmJUVFQkp9OpMB+vvoiICPdY1ePWNmbN5/XliSeeUEZGhld7dna2QkNDL7epVyQnJ6fRxm5OqJN51Moc6mQOdTLHSnUqK2st6S5J0rZt29S2bWVgJ3QJK9WqsZWWlprqZ5nwNm/ePKWmpqqwsFCbN2/W9OnTVVJSon//939393E4HLWuX3OZ2X717VvT3Llz9eCDD7ofFxcXKzY2VsnJyR6Hdv3F5XIpJydHw4YNU3BwsN/Hby6ok3nUyhzqZA51MseKdSop+e7322+/3VJ73qxWq8ZWfRSvLpYJb927d1f37t0lScOHD5dUFZDuu+8+RUZGSvK9J+z06dNyOBzq0KGDJCkyMlJlZWUqLS312gN2+vRpJSYmuh9HRkbWOqbke09fNafTKafT6dUeHBzcqC+yxh6/uaBO5lErc6iTOdTJHCvVqeY0quYVuLn4YqVaNTaz22nZCxZuvfVWVVRU6PPPP9d1112nkJAQHTx40KvfwYMH1bNnT7Vt21bSd+e6Xdr3xIkTOnXqlHr16uVu6927d61jSvLoCwAAYAWWDW87duxQq1at9L3vfU9BQUEaMWKENm7cqHPnzrn7fPXVV9qxY4fGjBnjbktJSVHbtm21evVqj/FWr14th8OhUaNGudtGjx6tw4cPe9wSpKKiQmvXrlW/fv3UpUuXRts+AACAhgj4YdNf/epXat++vW699VZ16tRJp06d0oYNG/SXv/xFDz/8sDp27ChJysjI0C233KK77rpLc+bMUVlZmR555BFFRUXpoYceco8XERGhBQsWaOHChYqIiFBycrL27dun9PR0paamuu/xJklTpkxRZmamxo8fr6VLlyo6OlrPPvusPv30U23fvr3JawEAAFCXgIe3pKQkrVq1SmvWrNHZs2cVHh6uhIQEvfzyy5o4caK7X1xcnHbu3Knf/va3GjdunIKCgjRkyBAtW7bMHfCqzZ8/X+3atVNmZqaWLVumzp07a86cOZo/f75HP6fTqdzcXKWlpWnGjBkqLS1V3759tWXLFg0cOLBJth8AAKA+Ah7eJk+e7HVD3dokJiaa3iM2c+ZMzZw5s85+nTp10po1a0yNCQAAEGiWPecNAAAA3ghvAAAANkJ4AwAAsBHCGwAAgI0Q3gAAAGyE8AYAAGAjhDcAAAAbIbwBAADYCOENAADARghvAAAANkJ4AwAAsBHCGwAAgI0Q3gAAAGyE8AYAAGAjhDcAAAAbIbwBAADYCOENAIAWrLLyu9/fe8/zMayJ8AYAQBMoKZHatAnWqFEjVVIS6NlU2bhRio//7vHw4VKPHlXtsC7CGwAALdDGjdK4cVJBgWd7QUFVOwHOughvAAC0MJWV0qxZkmF4L6tumz2bQ6hWRXgDAKCFef996dix2pcbhnT0aFU/WA/hDQCAFubrr/3bD02L8AYAQAsTE+PffmhaQYGeAADA3kpKpPDwYEkjdeaMSx06BHpGqMuAAVK3blUXJ/g6783hqFo+YEDTzw11Y88bAAAtTOvW0ooVVb87HJ7Lqh8vX17VD9ZDeAMAoAUaM0Z67TWpSxfP9m7dqtrHjAnMvFA3DpsCANBCjRkj3XabdNVVVY/feUdKTmaPm9Wx5w0AgBasZlD76U8JbnZAeAMAGykpqTonyeGQZb5iCUDTIrwBAADUwUr/cCK8AQAA2AjhDQAAwEYIbwAAADZCeAMANDtWOj8J8DfCGwAAgI0Q3gAAAOpQWfnd7++95/m4qRHeAAAALmPjRik+/rvHw4dLPXpUtQcC4Q0AAKAWGzdK48ZJBQWe7QUFVe2BCHCENwAAAB8qK6VZsyTD8F5W3TZ7dtMfQiW8AQAA+PD++9KxY7UvNwzp6NGqfk2J8AYAuCI19zr87W+OgJ7IDfjT11/7t5+/EN4AAA126YncI0YEBfREbsCfYmL8289fAh7e8vLyNGXKFMXFxSksLExdu3bVyJEjtX//fo9+Doej1p+4uDhTfZcuXer1/IWFhZo0aZKioqIUGhqqpKQk5ebmNuo2o+XgRqFozqx4IjfgTwMGSN26Vb2H++JwSLGxVf2aUlDTPp235557TkVFRZo1a5bi4+N18uRJPf300+rfv7+2bdumIUOGSJJ2797tte7evXs1e/ZsjR492mvZuHHj9NBDD3m0de/e3eNxeXm5hg4dqrNnz2rFihWKjo5WZmamUlJStH37dg0cONCPWwoAzUddJ3I7HFUnco8cKbVu3eTTA/yidWtpxYqqf4w4HJ6v9+pAt3x507/GAx7eMjMzFR0d7dGWkpKinj17asmSJe7w1r9/f691//SnP8nhcOiXv/yl17JOnTr5XKemrKws5efna9euXUpKSpIkDR48WAkJCUpLS9PevXsbulkA0KzV50TuQYOabFqA340ZI732mjRzpude5m7dqoLbmDFNP6eAHza9NLhJUnh
  2253. "text/plain": [
  2254. "<Figure size 640x480 with 1 Axes>"
  2255. ]
  2256. },
  2257. "metadata": {},
  2258. "output_type": "display_data"
  2259. }
  2260. ],
  2261. "source": [
  2262. "shotNum = \"0010\"\n",
  2263. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  2264. "\n",
  2265. "dataSetDict = {\n",
  2266. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  2267. " for i in [0]\n",
  2268. "}\n",
  2269. "\n",
  2270. "dataSet = dataSetDict[\"camera_0\"]\n",
  2271. "\n",
  2272. "print_scanAxis(dataSet)\n",
  2273. "\n",
  2274. "scanAxis = get_scanAxis(dataSet)\n",
  2275. "\n",
  2276. "dataSet = auto_rechunk(dataSet)\n",
  2277. "\n",
  2278. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  2279. "\n",
  2280. "imageAnalyser.center = (350, 990)\n",
  2281. "imageAnalyser.span = (650, 200)\n",
  2282. "imageAnalyser.fraction = (0.1, 0.1)\n",
  2283. "\n",
  2284. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  2285. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  2286. "\n",
  2287. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  2288. "Ncount_mean = calculate_mean(Ncount)\n",
  2289. "Ncount_std = calculate_std(Ncount)\n",
  2290. "\n",
  2291. "fig = plt.figure()\n",
  2292. "ax = fig.gca()\n",
  2293. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  2294. "plt.xlabel('TOF (s)')\n",
  2295. "plt.ylabel('NCount')\n",
  2296. "plt.tight_layout()\n",
  2297. "plt.grid(visible=1)\n",
  2298. "plt.show()"
  2299. ]
  2300. },
  2301. {
  2302. "cell_type": "code",
  2303. "execution_count": 26,
  2304. "metadata": {},
  2305. "outputs": [],
  2306. "source": [
  2307. "dataSet_cropOD_chunk = dataSet_cropOD.chunk((1, 1, 650, 200))\n",
  2308. "fitAnalyser = FitAnalyser(\"Gaussian-2D\", fitDim=2)\n",
  2309. "params = fitAnalyser.guess(dataSet_cropOD_chunk, dask=\"parallelized\")\n",
  2310. "fitResult = fitAnalyser.fit(dataSet_cropOD_chunk, params, dask=\"parallelized\").load()"
  2311. ]
  2312. },
  2313. {
  2314. "cell_type": "code",
  2315. "execution_count": 27,
  2316. "metadata": {},
  2317. "outputs": [
  2318. {
  2319. "name": "stdout",
  2320. "output_type": "stream",
  2321. "text": [
  2322. "4.027352128668683\n",
  2323. "0.03427747912979168\n"
  2324. ]
  2325. }
  2326. ],
  2327. "source": [
  2328. "data = fitAnalyser.get_fit_value(fitResult)\n",
  2329. "\n",
  2330. "print(data.amplitude.sel(TOF_free=0.01).mean('runs').item() * 147 / 1e5)\n",
  2331. "print(data.amplitude.sel(TOF_free=0.01).std('runs').item() * 147 / 1e5)"
  2332. ]
  2333. },
  2334. {
  2335. "cell_type": "code",
  2336. "execution_count": 147,
  2337. "metadata": {},
  2338. "outputs": [
  2339. {
  2340. "data": {
  2341. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2342. "text/plain": [
  2343. "<IPython.core.display.Javascript object>"
  2344. ]
  2345. },
  2346. "metadata": {},
  2347. "output_type": "display_data"
  2348. },
  2349. {
  2350. "data": {
  2351. "text/html": [
  2352. "<img src=\"
  2353. ],
  2354. "text/plain": [
  2355. "<IPython.core.display.HTML object>"
  2356. ]
  2357. },
  2358. "metadata": {},
  2359. "output_type": "display_data"
  2360. }
  2361. ],
  2362. "source": [
  2363. "val = fitAnalyser.get_fit_value(fitResult)\n",
  2364. "std = fitAnalyser.get_fit_std(fitResult)\n",
  2365. "\n",
  2366. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(350), dask=\"parallelized\").load()\n",
  2367. "\n",
  2368. "dataKey = 'sigmax'\n",
  2369. "# dataKey = 'centerx'\n",
  2370. "# dataKey = 'sigmay'\n",
  2371. "# dataKey = 'centery'\n",
  2372. "\n",
  2373. "val_mean = val[dataKey].mean(dim='runs')\n",
  2374. "std_mean = val[dataKey].std(dim='runs')\n",
  2375. "\n",
  2376. "fig = plt.figure()\n",
  2377. "ax = fig.gca()\n",
  2378. "\n",
  2379. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  2380. "\n",
  2381. "plt.grid()\n",
  2382. "plt.show()"
  2383. ]
  2384. },
  2385. {
  2386. "cell_type": "code",
  2387. "execution_count": 150,
  2388. "metadata": {},
  2389. "outputs": [
  2390. {
  2391. "data": {
  2392. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2393. "text/plain": [
  2394. "<IPython.core.display.Javascript object>"
  2395. ]
  2396. },
  2397. "metadata": {},
  2398. "output_type": "display_data"
  2399. },
  2400. {
  2401. "data": {
  2402. "text/html": [
  2403. "<img src=\"
  2404. ],
  2405. "text/plain": [
  2406. "<IPython.core.display.HTML object>"
  2407. ]
  2408. },
  2409. "metadata": {},
  2410. "output_type": "display_data"
  2411. }
  2412. ],
  2413. "source": [
  2414. "val = fitAnalyser.get_fit_value(fitResult)\n",
  2415. "std = fitAnalyser.get_fit_std(fitResult)\n",
  2416. "\n",
  2417. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(950), dask=\"parallelized\").load()\n",
  2418. "\n",
  2419. "# dataKey = 'sigmax'\n",
  2420. "# dataKey = 'centerx'\n",
  2421. "dataKey = 'sigmay'\n",
  2422. "# dataKey = 'centery'\n",
  2423. "\n",
  2424. "val_mean = val[dataKey].mean(dim='runs')\n",
  2425. "std_mean = val[dataKey].std(dim='runs')\n",
  2426. "\n",
  2427. "fig = plt.figure()\n",
  2428. "ax = fig.gca()\n",
  2429. "\n",
  2430. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  2431. "\n",
  2432. "plt.grid()\n",
  2433. "plt.show()"
  2434. ]
  2435. },
  2436. {
  2437. "cell_type": "code",
  2438. "execution_count": 152,
  2439. "metadata": {},
  2440. "outputs": [
  2441. {
  2442. "data": {
  2443. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2444. "text/plain": [
  2445. "<IPython.core.display.Javascript object>"
  2446. ]
  2447. },
  2448. "metadata": {},
  2449. "output_type": "display_data"
  2450. },
  2451. {
  2452. "data": {
  2453. "text/html": [
  2454. "<img src=\"
  2455. ],
  2456. "text/plain": [
  2457. "<IPython.core.display.HTML object>"
  2458. ]
  2459. },
  2460. "metadata": {},
  2461. "output_type": "display_data"
  2462. },
  2463. {
  2464. "name": "stdout",
  2465. "output_type": "stream",
  2466. "text": [
  2467. "T = 0.553 ± 0.004 uK\n"
  2468. ]
  2469. }
  2470. ],
  2471. "source": [
  2472. "def expansion(x, A, B):\n",
  2473. " return np.sqrt(A*x*x+B)\n",
  2474. "\n",
  2475. "val_truncated = val_mean[2:]\n",
  2476. "std_mean_truncated = std_mean[2:]\n",
  2477. "\n",
  2478. "fitModel_temperature = NewFitModel(expansion)\n",
  2479. "fitAnalyser_temperature = FitAnalyser(fitModel_temperature, fitDim=1)\n",
  2480. "\n",
  2481. "params = fitAnalyser_temperature.fitModel.make_params()\n",
  2482. "params.add(name=\"A\", value= 1e6, max = np.inf, min = 1, vary = True)\n",
  2483. "params.add(name=\"B\", value= 1000, max = np.inf, min = 0, vary = True)\n",
  2484. "\n",
  2485. "fitResult_temperature = fitAnalyser_temperature.fit(val_truncated, params, x='TOF_free', dask=\"parallelized\")\n",
  2486. "\n",
  2487. "val = fitAnalyser_temperature.get_fit_value(fitResult_temperature)\n",
  2488. "std = fitAnalyser_temperature.get_fit_std(fitResult_temperature)\n",
  2489. "\n",
  2490. "fit_vals = tuple([val['A'].item(), val['B'].item()])\n",
  2491. "fit_vals_std = tuple([std['A'].item(), std['B'].item()])\n",
  2492. "\n",
  2493. "tof = (np.arange(2,16,0.1)*1e-3)\n",
  2494. "\n",
  2495. "fig = plt.figure()\n",
  2496. "ax = fig.gca()\n",
  2497. "val_mean.plot.errorbar(ax=ax, yerr=std_mean, fmt='or')\n",
  2498. "plt.plot(tof, expansion(tof, *fit_vals), 'b--',\n",
  2499. " label='fit: A=%.3f, B=%.3f' % tuple(fit_vals))\n",
  2500. "plt.xlabel('TOF (s)')\n",
  2501. "# plt.ylabel('Cloud Width - Vertical (pixels)')\n",
  2502. "plt.ylabel('Cloud Width - Horizontal (pixels)')\n",
  2503. "plt.tight_layout()\n",
  2504. "plt.grid(visible=1)\n",
  2505. "plt.legend()\n",
  2506. "\n",
  2507. "\n",
  2508. "m = 164*1.673e-27\n",
  2509. "kb = 1.38e-23\n",
  2510. "pixel = 5.86e-6\n",
  2511. "M = 2.3513\n",
  2512. "\n",
  2513. "T = fit_vals[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  2514. "dT = fit_vals_std[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  2515. "\n",
  2516. "print('T = %.3f \\u00B1 %.3f uK'% tuple([T,dT]))"
  2517. ]
  2518. },
  2519. {
  2520. "attachments": {},
  2521. "cell_type": "markdown",
  2522. "metadata": {},
  2523. "source": [
  2524. "## Measure temperature at the end of evaporative cooling 2, truncation 0.725"
  2525. ]
  2526. },
  2527. {
  2528. "cell_type": "code",
  2529. "execution_count": 28,
  2530. "metadata": {},
  2531. "outputs": [
  2532. {
  2533. "name": "stdout",
  2534. "output_type": "stream",
  2535. "text": [
  2536. "The detected scaning axes and values are: \n",
  2537. "\n",
  2538. "{'TOF_free': array([0.002, 0.003, 0.004, 0.005, 0.006, 0.007, 0.008, 0.009, 0.01 ,\n",
  2539. " 0.011, 0.012, 0.013, 0.014, 0.015]), 'runs': array([0., 1., 2.])}\n"
  2540. ]
  2541. },
  2542. {
  2543. "data": {
  2544. "image/png": "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
  2545. "text/plain": [
  2546. "<Figure size 640x480 with 1 Axes>"
  2547. ]
  2548. },
  2549. "metadata": {},
  2550. "output_type": "display_data"
  2551. }
  2552. ],
  2553. "source": [
  2554. "shotNum = \"0011\"\n",
  2555. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  2556. "\n",
  2557. "dataSetDict = {\n",
  2558. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i])\n",
  2559. " for i in [0]\n",
  2560. "}\n",
  2561. "\n",
  2562. "dataSet = dataSetDict[\"camera_0\"]\n",
  2563. "\n",
  2564. "print_scanAxis(dataSet)\n",
  2565. "\n",
  2566. "scanAxis = get_scanAxis(dataSet)\n",
  2567. "\n",
  2568. "dataSet = auto_rechunk(dataSet)\n",
  2569. "\n",
  2570. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  2571. "\n",
  2572. "imageAnalyser.center = (350, 990)\n",
  2573. "imageAnalyser.span = (650, 200)\n",
  2574. "imageAnalyser.fraction = (0.1, 0.1)\n",
  2575. "\n",
  2576. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  2577. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  2578. "\n",
  2579. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  2580. "Ncount_mean = calculate_mean(Ncount)\n",
  2581. "Ncount_std = calculate_std(Ncount)\n",
  2582. "\n",
  2583. "fig = plt.figure()\n",
  2584. "ax = fig.gca()\n",
  2585. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  2586. "plt.xlabel('TOF (s)')\n",
  2587. "plt.ylabel('NCount')\n",
  2588. "plt.tight_layout()\n",
  2589. "plt.grid(visible=1)\n",
  2590. "plt.show()"
  2591. ]
  2592. },
  2593. {
  2594. "cell_type": "code",
  2595. "execution_count": 29,
  2596. "metadata": {},
  2597. "outputs": [],
  2598. "source": [
  2599. "dataSet_cropOD_chunk = dataSet_cropOD.chunk((1, 1, 650, 200))\n",
  2600. "fitAnalyser = FitAnalyser(\"Gaussian-2D\", fitDim=2)\n",
  2601. "params = fitAnalyser.guess(dataSet_cropOD_chunk, dask=\"parallelized\")\n",
  2602. "fitResult = fitAnalyser.fit(dataSet_cropOD_chunk, params, dask=\"parallelized\").load()"
  2603. ]
  2604. },
  2605. {
  2606. "cell_type": "code",
  2607. "execution_count": 30,
  2608. "metadata": {},
  2609. "outputs": [
  2610. {
  2611. "name": "stdout",
  2612. "output_type": "stream",
  2613. "text": [
  2614. "3.338057111672083\n",
  2615. "0.07935760046682089\n"
  2616. ]
  2617. }
  2618. ],
  2619. "source": [
  2620. "data = fitAnalyser.get_fit_value(fitResult)\n",
  2621. "\n",
  2622. "print(data.amplitude.sel(TOF_free=0.01).mean('runs').item() * 147 / 1e5)\n",
  2623. "print(data.amplitude.sel(TOF_free=0.01).std('runs').item() * 147 / 1e5)"
  2624. ]
  2625. },
  2626. {
  2627. "cell_type": "code",
  2628. "execution_count": 160,
  2629. "metadata": {},
  2630. "outputs": [
  2631. {
  2632. "data": {
  2633. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2634. "text/plain": [
  2635. "<IPython.core.display.Javascript object>"
  2636. ]
  2637. },
  2638. "metadata": {},
  2639. "output_type": "display_data"
  2640. },
  2641. {
  2642. "data": {
  2643. "text/html": [
  2644. "<img src=\"
  2645. ],
  2646. "text/plain": [
  2647. "<IPython.core.display.HTML object>"
  2648. ]
  2649. },
  2650. "metadata": {},
  2651. "output_type": "display_data"
  2652. }
  2653. ],
  2654. "source": [
  2655. "val = fitAnalyser.get_fit_value(fitResult)\n",
  2656. "std = fitAnalyser.get_fit_std(fitResult)\n",
  2657. "\n",
  2658. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(350), dask=\"parallelized\").load()\n",
  2659. "\n",
  2660. "dataKey = 'sigmax'\n",
  2661. "# dataKey = 'centerx'\n",
  2662. "# dataKey = 'sigmay'\n",
  2663. "# dataKey = 'centery'\n",
  2664. "\n",
  2665. "val_mean = val[dataKey].mean(dim='runs')\n",
  2666. "std_mean = val[dataKey].std(dim='runs')\n",
  2667. "\n",
  2668. "fig = plt.figure()\n",
  2669. "ax = fig.gca()\n",
  2670. "\n",
  2671. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  2672. "\n",
  2673. "plt.grid()\n",
  2674. "plt.show()"
  2675. ]
  2676. },
  2677. {
  2678. "cell_type": "code",
  2679. "execution_count": 162,
  2680. "metadata": {},
  2681. "outputs": [
  2682. {
  2683. "data": {
  2684. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2685. "text/plain": [
  2686. "<IPython.core.display.Javascript object>"
  2687. ]
  2688. },
  2689. "metadata": {},
  2690. "output_type": "display_data"
  2691. },
  2692. {
  2693. "data": {
  2694. "text/html": [
  2695. "<img src=\"
  2696. ],
  2697. "text/plain": [
  2698. "<IPython.core.display.HTML object>"
  2699. ]
  2700. },
  2701. "metadata": {},
  2702. "output_type": "display_data"
  2703. }
  2704. ],
  2705. "source": [
  2706. "val = fitAnalyser.get_fit_value(fitResult)\n",
  2707. "std = fitAnalyser.get_fit_std(fitResult)\n",
  2708. "\n",
  2709. "fitCurve = fitAnalyser.eval(fitResult, x=np.arange(990), y=np.arange(950), dask=\"parallelized\").load()\n",
  2710. "\n",
  2711. "# dataKey = 'sigmax'\n",
  2712. "# dataKey = 'centerx'\n",
  2713. "dataKey = 'sigmay'\n",
  2714. "# dataKey = 'centery'\n",
  2715. "\n",
  2716. "val_mean = val[dataKey].mean(dim='runs')\n",
  2717. "std_mean = val[dataKey].std(dim='runs')\n",
  2718. "\n",
  2719. "fig = plt.figure()\n",
  2720. "ax = fig.gca()\n",
  2721. "\n",
  2722. "val_mean.plot.errorbar(yerr=std_mean, fmt='--ob')\n",
  2723. "\n",
  2724. "plt.grid()\n",
  2725. "plt.show()"
  2726. ]
  2727. },
  2728. {
  2729. "cell_type": "code",
  2730. "execution_count": 164,
  2731. "metadata": {},
  2732. "outputs": [
  2733. {
  2734. "data": {
  2735. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2736. "text/plain": [
  2737. "<IPython.core.display.Javascript object>"
  2738. ]
  2739. },
  2740. "metadata": {},
  2741. "output_type": "display_data"
  2742. },
  2743. {
  2744. "data": {
  2745. "text/html": [
  2746. "<img src=\"
  2747. ],
  2748. "text/plain": [
  2749. "<IPython.core.display.HTML object>"
  2750. ]
  2751. },
  2752. "metadata": {},
  2753. "output_type": "display_data"
  2754. },
  2755. {
  2756. "name": "stdout",
  2757. "output_type": "stream",
  2758. "text": [
  2759. "T = 0.432 ± 0.004 uK\n"
  2760. ]
  2761. }
  2762. ],
  2763. "source": [
  2764. "def expansion(x, A, B):\n",
  2765. " return np.sqrt(A*x*x+B)\n",
  2766. "\n",
  2767. "val_truncated = val_mean[3:]\n",
  2768. "std_mean_truncated = std_mean[3:]\n",
  2769. "\n",
  2770. "fitModel_temperature = NewFitModel(expansion)\n",
  2771. "fitAnalyser_temperature = FitAnalyser(fitModel_temperature, fitDim=1)\n",
  2772. "\n",
  2773. "params = fitAnalyser_temperature.fitModel.make_params()\n",
  2774. "params.add(name=\"A\", value= 1e6, max = np.inf, min = 1, vary = True)\n",
  2775. "params.add(name=\"B\", value= 1000, max = np.inf, min = 0, vary = True)\n",
  2776. "\n",
  2777. "fitResult_temperature = fitAnalyser_temperature.fit(val_truncated, params, x='TOF_free', dask=\"parallelized\")\n",
  2778. "\n",
  2779. "val = fitAnalyser_temperature.get_fit_value(fitResult_temperature)\n",
  2780. "std = fitAnalyser_temperature.get_fit_std(fitResult_temperature)\n",
  2781. "\n",
  2782. "fit_vals = tuple([val['A'].item(), val['B'].item()])\n",
  2783. "fit_vals_std = tuple([std['A'].item(), std['B'].item()])\n",
  2784. "\n",
  2785. "tof = (np.arange(2,16,0.1)*1e-3)\n",
  2786. "\n",
  2787. "fig = plt.figure()\n",
  2788. "ax = fig.gca()\n",
  2789. "val_mean.plot.errorbar(ax=ax, yerr=std_mean, fmt='or')\n",
  2790. "plt.plot(tof, expansion(tof, *fit_vals), 'b--',\n",
  2791. " label='fit: A=%.3f, B=%.3f' % tuple(fit_vals))\n",
  2792. "plt.xlabel('TOF (s)')\n",
  2793. "# plt.ylabel('Cloud Width - Vertical (pixels)')\n",
  2794. "plt.ylabel('Cloud Width - Horizontal (pixels)')\n",
  2795. "plt.tight_layout()\n",
  2796. "plt.grid(visible=1)\n",
  2797. "plt.legend()\n",
  2798. "\n",
  2799. "\n",
  2800. "m = 164*1.673e-27\n",
  2801. "kb = 1.38e-23\n",
  2802. "pixel = 5.86e-6\n",
  2803. "M = 2.3513\n",
  2804. "\n",
  2805. "T = fit_vals[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  2806. "dT = fit_vals_std[0] * (m/kb) * ((pixel*pixel)/(M*M)) / (1e-6)\n",
  2807. "\n",
  2808. "print('T = %.3f \\u00B1 %.3f uK'% tuple([T,dT]))"
  2809. ]
  2810. },
  2811. {
  2812. "cell_type": "code",
  2813. "execution_count": null,
  2814. "metadata": {},
  2815. "outputs": [],
  2816. "source": []
  2817. },
  2818. {
  2819. "cell_type": "code",
  2820. "execution_count": null,
  2821. "metadata": {},
  2822. "outputs": [],
  2823. "source": []
  2824. },
  2825. {
  2826. "cell_type": "code",
  2827. "execution_count": null,
  2828. "metadata": {},
  2829. "outputs": [],
  2830. "source": []
  2831. },
  2832. {
  2833. "cell_type": "code",
  2834. "execution_count": null,
  2835. "metadata": {},
  2836. "outputs": [],
  2837. "source": []
  2838. },
  2839. {
  2840. "cell_type": "code",
  2841. "execution_count": null,
  2842. "metadata": {},
  2843. "outputs": [],
  2844. "source": []
  2845. },
  2846. {
  2847. "cell_type": "code",
  2848. "execution_count": null,
  2849. "metadata": {},
  2850. "outputs": [],
  2851. "source": []
  2852. },
  2853. {
  2854. "cell_type": "code",
  2855. "execution_count": null,
  2856. "metadata": {},
  2857. "outputs": [],
  2858. "source": []
  2859. },
  2860. {
  2861. "cell_type": "code",
  2862. "execution_count": null,
  2863. "metadata": {},
  2864. "outputs": [],
  2865. "source": []
  2866. },
  2867. {
  2868. "cell_type": "code",
  2869. "execution_count": null,
  2870. "metadata": {},
  2871. "outputs": [],
  2872. "source": []
  2873. },
  2874. {
  2875. "cell_type": "code",
  2876. "execution_count": null,
  2877. "metadata": {},
  2878. "outputs": [],
  2879. "source": []
  2880. },
  2881. {
  2882. "cell_type": "code",
  2883. "execution_count": null,
  2884. "metadata": {},
  2885. "outputs": [],
  2886. "source": []
  2887. },
  2888. {
  2889. "cell_type": "code",
  2890. "execution_count": null,
  2891. "metadata": {},
  2892. "outputs": [],
  2893. "source": []
  2894. },
  2895. {
  2896. "cell_type": "code",
  2897. "execution_count": null,
  2898. "metadata": {},
  2899. "outputs": [],
  2900. "source": []
  2901. },
  2902. {
  2903. "cell_type": "code",
  2904. "execution_count": null,
  2905. "metadata": {},
  2906. "outputs": [],
  2907. "source": []
  2908. },
  2909. {
  2910. "cell_type": "code",
  2911. "execution_count": null,
  2912. "metadata": {},
  2913. "outputs": [],
  2914. "source": []
  2915. },
  2916. {
  2917. "cell_type": "code",
  2918. "execution_count": null,
  2919. "metadata": {},
  2920. "outputs": [],
  2921. "source": []
  2922. },
  2923. {
  2924. "cell_type": "code",
  2925. "execution_count": null,
  2926. "metadata": {},
  2927. "outputs": [],
  2928. "source": []
  2929. },
  2930. {
  2931. "cell_type": "code",
  2932. "execution_count": null,
  2933. "metadata": {},
  2934. "outputs": [],
  2935. "source": []
  2936. },
  2937. {
  2938. "cell_type": "code",
  2939. "execution_count": null,
  2940. "metadata": {},
  2941. "outputs": [],
  2942. "source": []
  2943. },
  2944. {
  2945. "cell_type": "code",
  2946. "execution_count": null,
  2947. "metadata": {},
  2948. "outputs": [],
  2949. "source": []
  2950. },
  2951. {
  2952. "cell_type": "code",
  2953. "execution_count": null,
  2954. "metadata": {},
  2955. "outputs": [],
  2956. "source": []
  2957. },
  2958. {
  2959. "cell_type": "code",
  2960. "execution_count": 78,
  2961. "metadata": {},
  2962. "outputs": [
  2963. {
  2964. "name": "stdout",
  2965. "output_type": "stream",
  2966. "text": [
  2967. "The detected scaning axes and values are: \n",
  2968. "\n",
  2969. "{'carrier_freq': array([8.325, 8.33 , 8.335, 8.34 , 8.345, 8.35 , 8.355, 8.36 , 8.365,\n",
  2970. " 8.37 , 8.375, 8.38 , 8.385, 8.39 , 8.395, 8.4 , 8.405, 8.41 ,\n",
  2971. " 8.415, 8.42 , 8.425, 8.43 , 8.435, 8.44 , 8.445])}\n"
  2972. ]
  2973. },
  2974. {
  2975. "data": {
  2976. "application/javascript": "/* Put everything inside the global mpl namespace */\n/* global mpl */\nwindow.mpl = {};\n\nmpl.get_websocket_type = function () {\n if (typeof WebSocket !== 'undefined') {\n return WebSocket;\n } else if (typeof MozWebSocket !== 'undefined') {\n return MozWebSocket;\n } else {\n alert(\n 'Your browser does not have WebSocket support. ' +\n 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n 'Firefox 4 and 5 are also supported but you ' +\n 'have to enable WebSockets in about:config.'\n );\n }\n};\n\nmpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n this.id = figure_id;\n\n this.ws = websocket;\n\n this.supports_binary = this.ws.binaryType !== undefined;\n\n if (!this.supports_binary) {\n var warnings = document.getElementById('mpl-warnings');\n if (warnings) {\n warnings.style.display = 'block';\n warnings.textContent =\n 'This browser does not support binary websocket messages. ' +\n 'Performance may be slow.';\n }\n }\n\n this.imageObj = new Image();\n\n this.context = undefined;\n this.message = undefined;\n this.canvas = undefined;\n this.rubberband_canvas = undefined;\n this.rubberband_context = undefined;\n this.format_dropdown = undefined;\n\n this.image_mode = 'full';\n\n this.root = document.createElement('div');\n this.root.setAttribute('style', 'display: inline-block');\n this._root_extra_style(this.root);\n\n parent_element.appendChild(this.root);\n\n this._init_header(this);\n this._init_canvas(this);\n this._init_toolbar(this);\n\n var fig = this;\n\n this.waiting = false;\n\n this.ws.onopen = function () {\n fig.send_message('supports_binary', { value: fig.supports_binary });\n fig.send_message('send_image_mode', {});\n if (fig.ratio !== 1) {\n fig.send_message('set_device_pixel_ratio', {\n device_pixel_ratio: fig.ratio,\n });\n }\n fig.send_message('refresh', {});\n };\n\n this.imageObj.onload = function () {\n if (fig.image_mode === 'full') {\n // Full images could contain transparency (where diff images\n // almost always do), so we need to clear the canvas so that\n // there is no ghosting.\n fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n }\n fig.context.drawImage(fig.imageObj, 0, 0);\n };\n\n this.imageObj.onunload = function () {\n fig.ws.close();\n };\n\n this.ws.onmessage = this._make_on_message_function(this);\n\n this.ondownload = ondownload;\n};\n\nmpl.figure.prototype._init_header = function () {\n var titlebar = document.createElement('div');\n titlebar.classList =\n 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n var titletext = document.createElement('div');\n titletext.classList = 'ui-dialog-title';\n titletext.setAttribute(\n 'style',\n 'width: 100%; text-align: center; padding: 3px;'\n );\n titlebar.appendChild(titletext);\n this.root.appendChild(titlebar);\n this.header = titletext;\n};\n\nmpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n\nmpl.figure.prototype._init_canvas = function () {\n var fig = this;\n\n var canvas_div = (this.canvas_div = document.createElement('div'));\n canvas_div.setAttribute(\n 'style',\n 'border: 1px solid #ddd;' +\n 'box-sizing: content-box;' +\n 'clear: both;' +\n 'min-height: 1px;' +\n 'min-width: 1px;' +\n 'outline: 0;' +\n 'overflow: hidden;' +\n 'position: relative;' +\n 'resize: both;'\n );\n\n function on_keyboard_event_closure(name) {\n return function (event) {\n return fig.key
  2977. "text/plain": [
  2978. "<IPython.core.display.Javascript object>"
  2979. ]
  2980. },
  2981. "metadata": {},
  2982. "output_type": "display_data"
  2983. },
  2984. {
  2985. "data": {
  2986. "text/html": [
  2987. "<img src=\"
  2988. ],
  2989. "text/plain": [
  2990. "<IPython.core.display.HTML object>"
  2991. ]
  2992. },
  2993. "metadata": {},
  2994. "output_type": "display_data"
  2995. }
  2996. ],
  2997. "source": [
  2998. "%matplotlib notebook\n",
  2999. "shotNum = \"0024\"\n",
  3000. "filePath = folderPath + \"/\" + shotNum + \"/*.h5\"\n",
  3001. "\n",
  3002. "dataSetDict = {\n",
  3003. " dskey[groupList[i]]: read_hdf5_file(filePath, groupList[i], excludeAxis = ['sweep_start_freq', 'sweep_stop_freq'])\n",
  3004. " for i in [0]\n",
  3005. "}\n",
  3006. "\n",
  3007. "dataSet = dataSetDict[\"camera_0\"]\n",
  3008. "\n",
  3009. "print_scanAxis(dataSet)\n",
  3010. "\n",
  3011. "scanAxis = get_scanAxis(dataSet)\n",
  3012. "\n",
  3013. "dataSet = auto_rechunk(dataSet)\n",
  3014. "\n",
  3015. "dataSet = imageAnalyser.get_absorption_images(dataSet)\n",
  3016. "\n",
  3017. "imageAnalyser.center = (135, 990)\n",
  3018. "imageAnalyser.span = (250, 250)\n",
  3019. "imageAnalyser.fraction = (0.1, 0.1)\n",
  3020. "\n",
  3021. "dataSet_cropOD = imageAnalyser.crop_image(dataSet.OD)\n",
  3022. "dataSet_cropOD = imageAnalyser.substract_offset(dataSet_cropOD).load()\n",
  3023. "\n",
  3024. "Ncount = imageAnalyser.get_Ncount(dataSet_cropOD)\n",
  3025. "Ncount_mean = calculate_mean(Ncount)\n",
  3026. "Ncount_std = calculate_std(Ncount)\n",
  3027. "\n",
  3028. "fig = plt.figure()\n",
  3029. "ax = fig.gca()\n",
  3030. "Ncount_mean.plot.errorbar(ax=ax, yerr = Ncount_std, fmt='ob')\n",
  3031. "\n",
  3032. "plt.ylabel('NCount')\n",
  3033. "plt.tight_layout()\n",
  3034. "#plt.ylim([0, 3500])\n",
  3035. "plt.grid(visible=1)\n",
  3036. "plt.show()"
  3037. ]
  3038. },
  3039. {
  3040. "cell_type": "code",
  3041. "execution_count": 81,
  3042. "metadata": {
  3043. "scrolled": false
  3044. },
  3045. "outputs": [
  3046. {
  3047. "name": "stdout",
  3048. "output_type": "stream",
  3049. "text": [
  3050. "[0.002, 0.003, 0.004, 0.005, 0.006, 0.007, 0.008, 0.009, 0.01, 0.011, 0.012, 0.013, 0.014, 0.015]\n",
  3051. "14\n"
  3052. ]
  3053. },
  3054. {
  3055. "data": {
  3056. "text/plain": [
  3057. "0.008499999999999999"
  3058. ]
  3059. },
  3060. "execution_count": 81,
  3061. "metadata": {},
  3062. "output_type": "execute_result"
  3063. }
  3064. ],
  3065. "source": [
  3066. "l = list(np.arange(2e-3, 16e-3, 1e-3))\n",
  3067. "# l = np.logspace(np.log10(250e-6), np.log10(500e-3), num=15)\n",
  3068. "\n",
  3069. "l = [round(item, 7) for item in l]\n",
  3070. "#random.shuffle(l)\n",
  3071. "\n",
  3072. "print(l)\n",
  3073. "print(len(l))\n",
  3074. "np.mean(l)"
  3075. ]
  3076. },
  3077. {
  3078. "cell_type": "code",
  3079. "execution_count": null,
  3080. "metadata": {},
  3081. "outputs": [],
  3082. "source": [
  3083. "10.6 / 1e3"
  3084. ]
  3085. },
  3086. {
  3087. "cell_type": "code",
  3088. "execution_count": null,
  3089. "metadata": {},
  3090. "outputs": [],
  3091. "source": [
  3092. "pixel = 5.86e-6\n",
  3093. "M = 0.6827\n",
  3094. "F = (1/(0.3725*8.4743e-14)) * (pixel / M)**2\n",
  3095. "NCount = 85000\n",
  3096. "AtomNumber = NCount * F / 1e8\n",
  3097. "print(AtomNumber)\n"
  3098. ]
  3099. },
  3100. {
  3101. "cell_type": "code",
  3102. "execution_count": null,
  3103. "metadata": {},
  3104. "outputs": [],
  3105. "source": [
  3106. "muB = 9.274e-24\n",
  3107. "hbar = 6.626e-34 / (2 * np.pi)\n",
  3108. "gJ = 1.24\n",
  3109. "Delta = 2 * np.pi * 100 * 1e3\n",
  3110. "\n",
  3111. "Bz = (Delta*hbar) / (muB*gJ)\n",
  3112. "print(Bz * 1e4)"
  3113. ]
  3114. },
  3115. {
  3116. "attachments": {},
  3117. "cell_type": "markdown",
  3118. "metadata": {},
  3119. "source": [
  3120. "## ODT 1 Calibration"
  3121. ]
  3122. },
  3123. {
  3124. "cell_type": "code",
  3125. "execution_count": 165,
  3126. "metadata": {},
  3127. "outputs": [
  3128. {
  3129. "name": "stdout",
  3130. "output_type": "stream",
  3131. "text": [
  3132. "14.912\n",
  3133. "1.171\n",
  3134. "299.302\n"
  3135. ]
  3136. }
  3137. ],
  3138. "source": [
  3139. "v_high = 2.7\n",
  3140. "\"\"\"High Power\"\"\"\n",
  3141. "P_arm1_high = 5.776 * v_high - 0.683\n",
  3142. "\n",
  3143. "v_mid = 0.2076\n",
  3144. "\"\"\"Intermediate Power\"\"\"\n",
  3145. "P_arm1_mid = 5.815 * v_mid - 0.03651\n",
  3146. "\n",
  3147. "v_low = 0.062\n",
  3148. "\"\"\"Low Power\"\"\"\n",
  3149. "P_arm1_low = 5271 * v_low - 27.5\n",
  3150. "\n",
  3151. "print(round(P_arm1_high, 3))\n",
  3152. "print(round(P_arm1_mid, 3))\n",
  3153. "print(round(P_arm1_low, 3))"
  3154. ]
  3155. },
  3156. {
  3157. "attachments": {},
  3158. "cell_type": "markdown",
  3159. "metadata": {},
  3160. "source": [
  3161. "## ODT 2 Power Calibration"
  3162. ]
  3163. },
  3164. {
  3165. "cell_type": "code",
  3166. "execution_count": 166,
  3167. "metadata": {},
  3168. "outputs": [
  3169. {
  3170. "name": "stdout",
  3171. "output_type": "stream",
  3172. "text": [
  3173. "1.874\n"
  3174. ]
  3175. }
  3176. ],
  3177. "source": [
  3178. "v = 0.842\n",
  3179. "P_arm2 = 2.302 * v - 0.06452\n",
  3180. "print(round(P_arm2, 3))"
  3181. ]
  3182. },
  3183. {
  3184. "cell_type": "code",
  3185. "execution_count": null,
  3186. "metadata": {},
  3187. "outputs": [],
  3188. "source": []
  3189. }
  3190. ],
  3191. "metadata": {
  3192. "kernelspec": {
  3193. "display_name": "Python 3 (ipykernel)",
  3194. "language": "python",
  3195. "name": "python3"
  3196. },
  3197. "language_info": {
  3198. "codemirror_mode": {
  3199. "name": "ipython",
  3200. "version": 3
  3201. },
  3202. "file_extension": ".py",
  3203. "mimetype": "text/x-python",
  3204. "name": "python",
  3205. "nbconvert_exporter": "python",
  3206. "pygments_lexer": "ipython3",
  3207. "version": "3.9.12"
  3208. },
  3209. "vscode": {
  3210. "interpreter": {
  3211. "hash": "c05913ad4f24fdc6b2418069394dc5835b1981849b107c9ba6df693aafd66650"
  3212. }
  3213. }
  3214. },
  3215. "nbformat": 4,
  3216. "nbformat_minor": 2
  3217. }