|
2 | 2 | "cells": [
|
3 | 3 | {
|
4 | 4 | "cell_type": "markdown",
|
| 5 | + "id": "7d00c63281a63fa0", |
| 6 | + "metadata": { |
| 7 | + "collapsed": false |
| 8 | + }, |
5 | 9 | "source": [
|
6 | 10 | "# Passivate Slab Surface\n",
|
7 | 11 | "\n",
|
|
20 | 24 | "1. Surface atoms are detected by analyzing atomic positions along z-axis\n",
|
21 | 25 | "1. \"Shadowing radius\" controls the exclusion of atoms below the surface ones from being passivated\n",
|
22 | 26 | "1. Passivants are added at specified bond lengths from surface atoms"
|
23 |
| - ], |
24 |
| - "metadata": { |
25 |
| - "collapsed": false |
26 |
| - }, |
27 |
| - "id": "7d00c63281a63fa0" |
| 27 | + ] |
28 | 28 | },
|
29 | 29 | {
|
30 | 30 | "cell_type": "markdown",
|
| 31 | + "id": "d80280b47f767281", |
| 32 | + "metadata": { |
| 33 | + "collapsed": false |
| 34 | + }, |
31 | 35 | "source": [
|
32 | 36 | "## 1. Prepare the Environment\n",
|
33 | 37 | "### 1.1. Set up the notebook\n",
|
|
36 | 40 | "Visualization of the parameters of passivation on the image below:\n",
|
37 | 41 | "\n",
|
38 | 42 | "<img src=\"https://i.imgur.com/sVd7BWn.png\" alt=\"Passivation parameters\" width=\"600\"/>\n"
|
39 |
| - ], |
40 |
| - "metadata": { |
41 |
| - "collapsed": false |
42 |
| - }, |
43 |
| - "id": "d80280b47f767281" |
| 43 | + ] |
44 | 44 | },
|
45 | 45 | {
|
46 | 46 | "cell_type": "code",
|
| 47 | + "execution_count": 5, |
| 48 | + "id": "92b3518bebdcf547", |
| 49 | + "metadata": { |
| 50 | + "collapsed": false |
| 51 | + }, |
47 | 52 | "outputs": [],
|
48 | 53 | "source": [
|
49 | 54 | "# Material selection\n",
|
|
58 | 63 | "SHADOWING_RADIUS = 2.5 # Radius to exclude subsurface atoms, in Angstroms\n",
|
59 | 64 | "DEPTH = 5.0 # How deep to look for surface atoms, in Angstroms\n",
|
60 | 65 | "\n",
|
61 |
| - "# Slab parameters for creating a new slab if provided material is not a slab\n", |
| 66 | + "BYPASS_SLAB_CREATION = False # If True, will use input material directly\n", |
| 67 | + "\n", |
| 68 | + "# Slab parameters for creating a new slab if previous option is set to True\n", |
62 | 69 | "DEFAULT_SLAB_PARAMETERS = {\n",
|
63 | 70 | " \"miller_indices\": (0, 0, 1),\n",
|
64 | 71 | " \"thickness\": 3,\n",
|
|
70 | 77 | "# Visualization parameters\n",
|
71 | 78 | "SHOW_INTERMEDIATE_STEPS = True\n",
|
72 | 79 | "CELL_REPETITIONS_FOR_VISUALIZATION = [1, 1, 1] # Structure repeat in view"
|
73 |
| - ], |
74 |
| - "metadata": { |
75 |
| - "collapsed": false |
76 |
| - }, |
77 |
| - "id": "92b3518bebdcf547", |
78 |
| - "execution_count": null |
| 80 | + ] |
79 | 81 | },
|
80 | 82 | {
|
81 | 83 | "cell_type": "markdown",
|
82 |
| - "source": [ |
83 |
| - "### 1.2. Install packages\n", |
84 |
| - "The step executes only in Pyodide environment. For other environments, the packages should be installed via `pip install`." |
85 |
| - ], |
| 84 | + "id": "11bd9b5fca1510fc", |
86 | 85 | "metadata": {
|
87 | 86 | "collapsed": false
|
88 | 87 | },
|
89 |
| - "id": "11bd9b5fca1510fc" |
| 88 | + "source": [ |
| 89 | + "### 1.2. Install packages\n", |
| 90 | + "The step executes only in Pyodide environment. For other environments, the packages should be installed via `pip install`." |
| 91 | + ] |
90 | 92 | },
|
91 | 93 | {
|
92 | 94 | "cell_type": "code",
|
| 95 | + "execution_count": 6, |
| 96 | + "id": "42863fe84bfab53c", |
| 97 | + "metadata": { |
| 98 | + "collapsed": false |
| 99 | + }, |
93 | 100 | "outputs": [],
|
94 | 101 | "source": [
|
95 | 102 | "import sys\n",
|
|
101 | 108 | " from utils.jupyterlite import install_packages\n",
|
102 | 109 | "\n",
|
103 | 110 | " await install_packages(\"\")"
|
104 |
| - ], |
105 |
| - "metadata": { |
106 |
| - "collapsed": false |
107 |
| - }, |
108 |
| - "id": "42863fe84bfab53c", |
109 |
| - "execution_count": null |
| 111 | + ] |
110 | 112 | },
|
111 | 113 | {
|
112 | 114 | "cell_type": "markdown",
|
113 |
| - "source": [ |
114 |
| - "### 1.3. Load and preview input material" |
115 |
| - ], |
| 115 | + "id": "6983ab284dff18c0", |
116 | 116 | "metadata": {
|
117 | 117 | "collapsed": false
|
118 | 118 | },
|
119 |
| - "id": "6983ab284dff18c0" |
| 119 | + "source": [ |
| 120 | + "### 1.3. Load and preview input material" |
| 121 | + ] |
120 | 122 | },
|
121 | 123 | {
|
122 | 124 | "cell_type": "code",
|
| 125 | + "execution_count": null, |
| 126 | + "id": "a51551f4af6456c7", |
| 127 | + "metadata": { |
| 128 | + "collapsed": false |
| 129 | + }, |
123 | 130 | "outputs": [],
|
124 | 131 | "source": [
|
125 | 132 | "from utils.jupyterlite import get_materials\n",
|
126 | 133 | "from utils.visualize import visualize_materials\n",
|
127 | 134 | "\n",
|
128 | 135 | "materials = get_materials(globals())"
|
129 |
| - ], |
130 |
| - "metadata": { |
131 |
| - "collapsed": false |
132 |
| - }, |
133 |
| - "id": "a51551f4af6456c7", |
134 |
| - "execution_count": null |
| 136 | + ] |
135 | 137 | },
|
136 | 138 | {
|
137 | 139 | "cell_type": "markdown",
|
138 |
| - "source": [ |
139 |
| - "### 1.4. Create a slab if the input material is not a slab" |
140 |
| - ], |
| 140 | + "id": "6b929ffec7c4876e", |
141 | 141 | "metadata": {
|
142 | 142 | "collapsed": false
|
143 | 143 | },
|
144 |
| - "id": "6b929ffec7c4876e" |
| 144 | + "source": [ |
| 145 | + "### 1.4. Create a slab if the input material is not a slab" |
| 146 | + ] |
145 | 147 | },
|
146 | 148 | {
|
147 | 149 | "cell_type": "code",
|
| 150 | + "execution_count": null, |
| 151 | + "id": "ad71f877f76f0550", |
| 152 | + "metadata": { |
| 153 | + "collapsed": false |
| 154 | + }, |
148 | 155 | "outputs": [],
|
149 | 156 | "source": [
|
150 | 157 | "from mat3ra.made.tools.build.slab import create_slab_if_not, SlabConfiguration\n",
|
|
159 | 166 | " xy_supercell_matrix=DEFAULT_SLAB_PARAMETERS[\"xy_supercell_matrix\"]\n",
|
160 | 167 | ")\n",
|
161 | 168 | "\n",
|
162 |
| - "slab = create_slab_if_not(material, default_slab_config)\n", |
| 169 | + "slab = material if BYPASS_SLAB_CREATION else create_slab_if_not(material, default_slab_config)\n", |
163 | 170 | "\n",
|
164 | 171 | "if SHOW_INTERMEDIATE_STEPS:\n",
|
165 | 172 | " print(\"Initial slab structure:\")\n",
|
166 | 173 | " visualize_materials(slab, repetitions=CELL_REPETITIONS_FOR_VISUALIZATION)\n",
|
167 | 174 | " visualize_materials(slab, repetitions=CELL_REPETITIONS_FOR_VISUALIZATION, rotation=\"-90x\")"
|
168 |
| - ], |
169 |
| - "metadata": { |
170 |
| - "collapsed": false |
171 |
| - }, |
172 |
| - "id": "ad71f877f76f0550", |
173 |
| - "execution_count": null |
| 175 | + ] |
174 | 176 | },
|
175 | 177 | {
|
176 | 178 | "cell_type": "markdown",
|
177 |
| - "source": [ |
178 |
| - "## 2. Create target material\n", |
179 |
| - "### 2.1. Set up passivation configuration and builder\n" |
180 |
| - ], |
| 179 | + "id": "cee250785246811a", |
181 | 180 | "metadata": {
|
182 | 181 | "collapsed": false
|
183 | 182 | },
|
184 |
| - "id": "cee250785246811a" |
| 183 | + "source": [ |
| 184 | + "## 2. Create target material\n", |
| 185 | + "### 2.1. Set up passivation configuration and builder\n" |
| 186 | + ] |
185 | 187 | },
|
186 | 188 | {
|
187 | 189 | "cell_type": "code",
|
| 190 | + "execution_count": 9, |
| 191 | + "id": "7e26e8e7fb8319a", |
| 192 | + "metadata": { |
| 193 | + "collapsed": false |
| 194 | + }, |
188 | 195 | "outputs": [],
|
189 | 196 | "source": [
|
190 | 197 | "from mat3ra.made.tools.build.passivation import (\n",
|
|
206 | 213 | ")\n",
|
207 | 214 | "\n",
|
208 | 215 | "builder = SurfacePassivationBuilder(build_parameters=builder_params)"
|
209 |
| - ], |
210 |
| - "metadata": { |
211 |
| - "collapsed": false |
212 |
| - }, |
213 |
| - "id": "7e26e8e7fb8319a", |
214 |
| - "execution_count": null |
| 216 | + ] |
215 | 217 | },
|
216 | 218 | {
|
217 | 219 | "cell_type": "markdown",
|
218 |
| - "source": [ |
219 |
| - "### 2.2. Generate passivated structure\n" |
220 |
| - ], |
| 220 | + "id": "2950f29de8bc79b2", |
221 | 221 | "metadata": {
|
222 | 222 | "collapsed": false
|
223 | 223 | },
|
224 |
| - "id": "2950f29de8bc79b2" |
| 224 | + "source": [ |
| 225 | + "### 2.2. Generate passivated structure\n" |
| 226 | + ] |
225 | 227 | },
|
226 | 228 | {
|
227 | 229 | "cell_type": "code",
|
| 230 | + "execution_count": null, |
| 231 | + "id": "a4ed473eb2129ac4", |
| 232 | + "metadata": { |
| 233 | + "collapsed": false |
| 234 | + }, |
228 | 235 | "outputs": [],
|
229 | 236 | "source": [
|
230 | 237 | "from mat3ra.made.tools.build.passivation import create_passivation\n",
|
|
236 | 243 | "print(f\"Bond length: {BOND_LENGTH} Å\")\n",
|
237 | 244 | "print(f\"Surfaces passivated: {SURFACE}\")\n",
|
238 | 245 | "print(f\"Number of atoms: {len(passivated_slab.basis.elements.ids)}\")"
|
239 |
| - ], |
240 |
| - "metadata": { |
241 |
| - "collapsed": false |
242 |
| - }, |
243 |
| - "id": "a4ed473eb2129ac4", |
244 |
| - "execution_count": null |
| 246 | + ] |
245 | 247 | },
|
246 | 248 | {
|
247 | 249 | "cell_type": "markdown",
|
248 |
| - "source": [ |
249 |
| - "## 3. Visualize the result" |
250 |
| - ], |
| 250 | + "id": "56ec05c6ed2f91cd", |
251 | 251 | "metadata": {
|
252 | 252 | "collapsed": false
|
253 | 253 | },
|
254 |
| - "id": "56ec05c6ed2f91cd" |
| 254 | + "source": [ |
| 255 | + "## 3. Visualize the result" |
| 256 | + ] |
255 | 257 | },
|
256 | 258 | {
|
257 | 259 | "cell_type": "code",
|
| 260 | + "execution_count": null, |
| 261 | + "id": "c4b5e1e0ec0ab02a", |
| 262 | + "metadata": { |
| 263 | + "collapsed": false |
| 264 | + }, |
258 | 265 | "outputs": [],
|
259 | 266 | "source": [
|
260 | 267 | "print(\"Final passivated structure:\")\n",
|
261 | 268 | "visualize_materials(passivated_slab, repetitions=CELL_REPETITIONS_FOR_VISUALIZATION)\n",
|
262 | 269 | "visualize_materials(passivated_slab, repetitions=CELL_REPETITIONS_FOR_VISUALIZATION, rotation=\"-90x\")"
|
263 |
| - ], |
264 |
| - "metadata": { |
265 |
| - "collapsed": false |
266 |
| - }, |
267 |
| - "id": "c4b5e1e0ec0ab02a", |
268 |
| - "execution_count": null |
| 270 | + ] |
269 | 271 | },
|
270 | 272 | {
|
271 | 273 | "cell_type": "markdown",
|
272 |
| - "source": [ |
273 |
| - "### 4. Pass data to the outside runtime\n" |
274 |
| - ], |
| 274 | + "id": "eab7e14d2c7880a5", |
275 | 275 | "metadata": {
|
276 | 276 | "collapsed": false
|
277 | 277 | },
|
278 |
| - "id": "eab7e14d2c7880a5" |
| 278 | + "source": [ |
| 279 | + "### 4. Pass data to the outside runtime\n" |
| 280 | + ] |
279 | 281 | },
|
280 | 282 | {
|
281 | 283 | "cell_type": "code",
|
| 284 | + "execution_count": null, |
| 285 | + "id": "d66a15a29d27c6ea", |
| 286 | + "metadata": { |
| 287 | + "collapsed": false |
| 288 | + }, |
282 | 289 | "outputs": [],
|
283 | 290 | "source": [
|
284 | 291 | "from utils.jupyterlite import set_materials\n",
|
285 | 292 | "\n",
|
286 | 293 | "set_materials(passivated_slab)"
|
287 |
| - ], |
288 |
| - "metadata": { |
289 |
| - "collapsed": false |
290 |
| - }, |
291 |
| - "id": "d66a15a29d27c6ea", |
292 |
| - "execution_count": null |
| 294 | + ] |
293 | 295 | }
|
294 | 296 | ],
|
295 | 297 | "metadata": {
|
296 | 298 | "kernelspec": {
|
297 |
| - "display_name": "Python 3", |
| 299 | + "display_name": ".venv-3.11", |
298 | 300 | "language": "python",
|
299 | 301 | "name": "python3"
|
300 | 302 | },
|
301 | 303 | "language_info": {
|
302 | 304 | "codemirror_mode": {
|
303 | 305 | "name": "ipython",
|
304 |
| - "version": 2 |
| 306 | + "version": 3 |
305 | 307 | },
|
306 | 308 | "file_extension": ".py",
|
307 | 309 | "mimetype": "text/x-python",
|
308 | 310 | "name": "python",
|
309 | 311 | "nbconvert_exporter": "python",
|
310 |
| - "pygments_lexer": "ipython2", |
311 |
| - "version": "2.7.6" |
| 312 | + "pygments_lexer": "ipython3", |
| 313 | + "version": "3.11.7" |
312 | 314 | }
|
313 | 315 | },
|
314 | 316 | "nbformat": 4,
|
|
0 commit comments