Pre assembly
							
								
								
									
										
											BIN
										
									
								
								figures/3d-eg.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 278 KiB | 
							
								
								
									
										15601
									
								
								figures/3d-eg.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.0 MiB | 
| Before Width: | Height: | Size: 28 KiB After Width: | Height: | Size: 30 KiB | 
| Before Width: | Height: | Size: 58 KiB After Width: | Height: | Size: 64 KiB | 
| @ -6,7 +6,7 @@ | ||||
|   <rdf:RDF xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"> | ||||
|    <cc:Work> | ||||
|     <dc:type rdf:resource="http://purl.org/dc/dcmitype/StillImage"/> | ||||
|     <dc:date>2023-03-19T17:50:24.307870</dc:date> | ||||
|     <dc:date>2023-03-20T14:45:47.028340</dc:date> | ||||
|     <dc:format>image/svg+xml</dc:format> | ||||
|     <dc:creator> | ||||
|      <cc:Agent> | ||||
| @ -19941,7 +19941,7 @@ L 69.30995 185.298806 | ||||
| L 69.27936 184.051652  | ||||
| L 69.248771 203.146032  | ||||
| z | ||||
| " clip-path="url(#p7359cb4da0)" style="fill: #1f77b4; fill-opacity: 0.2"/> | ||||
| " clip-path="url(#p28f5ccc9c9)" style="fill: #1f77b4; fill-opacity: 0.2"/> | ||||
|    </g> | ||||
|    <g id="PolyCollection_2"> | ||||
|     <path d="M 69.248771 141.251975  | ||||
| @ -39847,18 +39847,18 @@ L 69.30995 141.251975 | ||||
| L 69.27936 141.251975  | ||||
| L 69.248771 141.251975  | ||||
| z | ||||
| " clip-path="url(#p7359cb4da0)" style="fill: #ff7f0e; fill-opacity: 0.2"/> | ||||
| " clip-path="url(#p28f5ccc9c9)" style="fill: #ff7f0e; fill-opacity: 0.2"/> | ||||
|    </g> | ||||
|    <g id="matplotlib.axis_1"> | ||||
|     <g id="xtick_1"> | ||||
|      <g id="line2d_1"> | ||||
|       <defs> | ||||
|        <path id="mb417bdf40e" d="M 0 0  | ||||
|        <path id="m48e8f083ea" d="M 0 0  | ||||
| L 0 3.5  | ||||
| " style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </defs> | ||||
|       <g> | ||||
|        <use xlink:href="#mb417bdf40e" x="67.688716" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m48e8f083ea" x="67.688716" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_1"> | ||||
| @ -39894,7 +39894,7 @@ z | ||||
|     <g id="xtick_2"> | ||||
|      <g id="line2d_2"> | ||||
|       <g> | ||||
|        <use xlink:href="#mb417bdf40e" x="128.867337" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m48e8f083ea" x="128.867337" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_2"> | ||||
| @ -39936,7 +39936,7 @@ z | ||||
|     <g id="xtick_3"> | ||||
|      <g id="line2d_3"> | ||||
|       <g> | ||||
|        <use xlink:href="#mb417bdf40e" x="190.045957" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m48e8f083ea" x="190.045957" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_3"> | ||||
| @ -39973,7 +39973,7 @@ z | ||||
|     <g id="xtick_4"> | ||||
|      <g id="line2d_4"> | ||||
|       <g> | ||||
|        <use xlink:href="#mb417bdf40e" x="251.224577" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m48e8f083ea" x="251.224577" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_4"> | ||||
| @ -40021,7 +40021,7 @@ z | ||||
|     <g id="xtick_5"> | ||||
|      <g id="line2d_5"> | ||||
|       <g> | ||||
|        <use xlink:href="#mb417bdf40e" x="312.403198" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m48e8f083ea" x="312.403198" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_5"> | ||||
| @ -40078,7 +40078,7 @@ z | ||||
|     <g id="xtick_6"> | ||||
|      <g id="line2d_6"> | ||||
|       <g> | ||||
|        <use xlink:href="#mb417bdf40e" x="373.581818" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m48e8f083ea" x="373.581818" y="384.48" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_6"> | ||||
| @ -40160,12 +40160,12 @@ z | ||||
|     <g id="ytick_1"> | ||||
|      <g id="line2d_7"> | ||||
|       <defs> | ||||
|        <path id="med592cd34a" d="M 0 0  | ||||
|        <path id="m09236f74c5" d="M 0 0  | ||||
| L -3.5 0  | ||||
| " style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </defs> | ||||
|       <g> | ||||
|        <use xlink:href="#med592cd34a" x="54" y="349.49529" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m09236f74c5" x="54" y="349.49529" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_8"> | ||||
| @ -40190,7 +40190,7 @@ z | ||||
|     <g id="ytick_2"> | ||||
|      <g id="line2d_8"> | ||||
|       <g> | ||||
|        <use xlink:href="#med592cd34a" x="54" y="280.080852" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m09236f74c5" x="54" y="280.080852" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_9"> | ||||
| @ -40206,7 +40206,7 @@ z | ||||
|     <g id="ytick_3"> | ||||
|      <g id="line2d_9"> | ||||
|       <g> | ||||
|        <use xlink:href="#med592cd34a" x="54" y="210.666413" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m09236f74c5" x="54" y="210.666413" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_10"> | ||||
| @ -40234,7 +40234,7 @@ z | ||||
|     <g id="ytick_4"> | ||||
|      <g id="line2d_10"> | ||||
|       <g> | ||||
|        <use xlink:href="#med592cd34a" x="54" y="141.251975" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m09236f74c5" x="54" y="141.251975" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_11"> | ||||
| @ -40250,7 +40250,7 @@ z | ||||
|     <g id="ytick_5"> | ||||
|      <g id="line2d_11"> | ||||
|       <g> | ||||
|        <use xlink:href="#med592cd34a" x="54" y="71.837536" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|        <use xlink:href="#m09236f74c5" x="54" y="71.837536" style="stroke: #000000; stroke-width: 0.8"/> | ||||
|       </g> | ||||
|      </g> | ||||
|      <g id="text_12"> | ||||
| @ -44173,12 +44173,12 @@ L 373.367693 83.888254 | ||||
| L 373.398282 83.979329  | ||||
| L 373.52064 84.31475  | ||||
| L 373.581818 84.183869  | ||||
| " clip-path="url(#p7359cb4da0)" style="fill: none; stroke: #1f77b4; stroke-width: 1.5; stroke-linecap: square"/> | ||||
| " clip-path="url(#p28f5ccc9c9)" style="fill: none; stroke: #1f77b4; stroke-width: 1.5; stroke-linecap: square"/> | ||||
|    </g> | ||||
|    <g id="line2d_13"> | ||||
|     <path d="M 69.218182 175.959194  | ||||
| L 373.581818 175.959194  | ||||
| " clip-path="url(#p7359cb4da0)" style="fill: none; stroke: #ff0000; stroke-width: 1.5; stroke-linecap: square"/> | ||||
| " clip-path="url(#p28f5ccc9c9)" style="fill: none; stroke: #ff0000; stroke-width: 1.5; stroke-linecap: square"/> | ||||
|    </g> | ||||
|    <g id="patch_3"> | ||||
|     <path d="M 54 384.48  | ||||
| @ -44523,7 +44523,7 @@ z | ||||
|   </g> | ||||
|  </g> | ||||
|  <defs> | ||||
|   <clipPath id="p7359cb4da0"> | ||||
|   <clipPath id="p28f5ccc9c9"> | ||||
|    <rect x="54" y="51.84" width="334.8" height="332.64"/> | ||||
|   </clipPath> | ||||
|  </defs> | ||||
|  | ||||
| Before Width: | Height: | Size: 1.0 MiB After Width: | Height: | Size: 1.0 MiB | 
							
								
								
									
										21
									
								
								graphs/3d-eg.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,21 @@ | ||||
| from lib.lib import read_xy_alt, read_load | ||||
| import matplotlib as mpl | ||||
| from mpl_toolkits.mplot3d import Axes3D | ||||
| import numpy as np | ||||
| import matplotlib.pyplot as plt | ||||
| 
 | ||||
| full_data = read_load("/Users/joshuacoles/Developer/checkouts/jc3091/CompB DLA/data-analysis/data/rust-3d", read_xy_alt) | ||||
| run1 = full_data[full_data.run == '1'] | ||||
| 
 | ||||
| max_actual_radius = max(run1.x.abs().max(), run1.y.abs().max(), run1.z.abs().max()) | ||||
| max_radius = int(np.exp2(np.floor(np.log2(max_actual_radius)) + 1)) | ||||
| data = np.zeros((max_radius * 2, max_radius * 2, max_radius * 2)) | ||||
| data[run1.x + max_radius, run1.y + max_radius, run1.z + max_radius] = 1 | ||||
| 
 | ||||
| # %% | ||||
| fig = plt.figure(figsize=(10, 10)) | ||||
| ax = fig.add_subplot(projection='3d') | ||||
| ax.scatter(run1.x, run1.y, run1.z, c=run1.N) | ||||
| 
 | ||||
| fig.savefig("../figures/3d-eg.png") | ||||
| fig.savefig("../figures/3d-eg.svg") | ||||
| @ -41,8 +41,8 @@ nc_fd(direct_meaned_by_N, label="IPC + 3D Direct", color="tab:blue", no_error=Tr | ||||
| nc_fd(rust_direct_meaned_by_N, label="NF 3D Direct", color="tab:orange", no_error=True) | ||||
| nc_fd(rust_offaxis_meaned_by_N, label="NF 3D Off-axis", color="tab:purple", linestyle='dashdot', no_error=True) | ||||
| 
 | ||||
| plt.plot([np.min(c_direct_neighbours.N), np.max(c_direct_neighbours.N)], [2.5, 2.5], color='tab:red', label='Literature') | ||||
| # plt.fill_between(c_direct_neighbours.N, 2.5 - 0.01, 2.5 + 0.01, alpha=0.2, color='tab:red', label='Literature error band') | ||||
| plt.plot([np.min(c_direct_neighbours.N), np.max(c_direct_neighbours.N)], [2.51, 2.51], color='tab:red', label='Literature') | ||||
| # plt.fill_between(c_direct_neighbours.N, 2.51 - 0.01, 2.51 + 0.01, alpha=0.2, color='tab:red', label='Literature error band') | ||||
| 
 | ||||
| plt.xlabel("$N_C$") | ||||
| plt.ylabel("$fd$ (instantaneous)") | ||||
|  | ||||
| @ -54,6 +54,7 @@ df = read_xy_alt( | ||||
|     "/Users/joshuacoles/Developer/checkouts/jc3091/CompB DLA/data-analysis/data/alpha/1.csv" | ||||
| ) | ||||
| 
 | ||||
| max_actual_radius = max(df.x.abs().max(), df.y.abs().max()) | ||||
| max_radius = int(np.exp2(np.floor(np.log2(max_actual_radius)) + 1)) | ||||
| data = np.zeros((max_radius * 2, max_radius * 2)) | ||||
| data[df.x + max_radius, df.y + max_radius] = 1 | ||||
|  | ||||
							
								
								
									
										78
									
								
								lib/fd.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,78 @@ | ||||
| #!/usr/bin/env python3 | ||||
| # -*- coding: utf-8 -*- | ||||
| """ | ||||
| Created on Mon Sep 16 09:47:15 2019 | ||||
| @author: daniel | ||||
| """ | ||||
| import numpy as np | ||||
| import matplotlib.pyplot as plt | ||||
| 
 | ||||
| 
 | ||||
| def fractal_dimension(array, max_box_size=None, min_box_size=1, n_samples=20, n_offsets=0, plot=False): | ||||
|     """Calculates the fractal dimension of a 3D numpy array. | ||||
| 
 | ||||
|     Args: | ||||
|         array (np.ndarray): The array to calculate the fractal dimension of. | ||||
|         max_box_size (int): The largest box size, given as the power of 2 so that | ||||
|                             2**max_box_size gives the sidelength of the largest box. | ||||
|         min_box_size (int): The smallest box size, given as the power of 2 so that | ||||
|                             2**min_box_size gives the sidelength of the smallest box. | ||||
|                             Default value 1. | ||||
|         n_samples (int): number of scales to measure over. | ||||
|         n_offsets (int): number of offsets to search over to find the smallest set N(s) to | ||||
|                        cover  all voxels>0. | ||||
|         plot (bool): set to true to see the analytical plot of a calculation. | ||||
| 
 | ||||
| 
 | ||||
|     """ | ||||
|     # determine the scales to measure on | ||||
|     if max_box_size == None: | ||||
|         # default max size is the largest power of 2 that fits in the smallest dimension of the array: | ||||
|         max_box_size = int(np.floor(np.log2(np.min(array.shape)))) | ||||
|     scales = np.floor(np.logspace(max_box_size, min_box_size, num=n_samples, base=2)) | ||||
|     scales = np.unique(scales)  # remove duplicates that could occur as a result of the floor | ||||
| 
 | ||||
|     # get the locations of all non-zero pixels | ||||
|     locs = np.where(array > 0) | ||||
|     voxels = np.array([(x, y, z) for x, y, z in zip(*locs)]) | ||||
| 
 | ||||
|     # count the minimum amount of boxes touched | ||||
|     Ns = [] | ||||
|     # loop over all scales | ||||
|     for scale in scales: | ||||
|         touched = [] | ||||
|         if n_offsets == 0: | ||||
|             offsets = [0] | ||||
|         else: | ||||
|             offsets = np.linspace(0, scale, n_offsets) | ||||
|         # search over all offsets | ||||
|         for offset in offsets: | ||||
|             bin_edges = [np.arange(0, i, scale) for i in array.shape] | ||||
|             bin_edges = [np.hstack([0 - offset, x + offset]) for x in bin_edges] | ||||
|             H1, e = np.histogramdd(voxels, bins=bin_edges) | ||||
|             touched.append(np.sum(H1 > 0)) | ||||
|         Ns.append(touched) | ||||
|     Ns = np.array(Ns) | ||||
| 
 | ||||
|     # From all sets N found, keep the smallest one at each scale | ||||
|     Ns = Ns.min(axis=1) | ||||
| 
 | ||||
|     # Only keep scales at which Ns changed | ||||
|     scales = np.array([np.min(scales[Ns == x]) for x in np.unique(Ns)]) | ||||
| 
 | ||||
|     Ns = np.unique(Ns) | ||||
|     Ns = Ns[Ns > 0] | ||||
|     scales = scales[:len(Ns)] | ||||
|     # perform fit | ||||
|     coeffs = np.polyfit(np.log(1 / scales), np.log(Ns), 1) | ||||
| 
 | ||||
|     # make plot | ||||
|     if plot: | ||||
|         fig, ax = plt.subplots(figsize=(8, 6)) | ||||
|         ax.scatter(np.log(1 / scales), np.log(np.unique(Ns)), c="teal", label="Measured ratios") | ||||
|         ax.set_ylabel("$\log N(\epsilon)$") | ||||
|         ax.set_xlabel("$\log 1/ \epsilon$") | ||||
|         fitted_y_vals = np.polyval(coeffs, np.log(1 / scales)) | ||||
|         ax.plot(np.log(1 / scales), fitted_y_vals, "k--", label=f"Fit: {np.round(coeffs[0], 3)}X+{coeffs[1]}") | ||||
|         ax.legend(); | ||||
|     return (coeffs[0]) | ||||
							
								
								
									
										1755
									
								
								notebooks/.ipynb_checkpoints/bc1-checkpoint.ipynb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										312
									
								
								notebooks/bc1.ipynb
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,312 @@ | ||||
| { | ||||
|  "cells": [ | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 14, | ||||
|    "metadata": { | ||||
|     "collapsed": true | ||||
|    }, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "\"\"\"\n", | ||||
|     "Created on Mon Sep 16 09:47:15 2019\n", | ||||
|     "@author: daniel\n", | ||||
|     "\"\"\"\n", | ||||
|     "import numpy as np\n", | ||||
|     "import matplotlib.pyplot as plt\n", | ||||
|     "\n", | ||||
|     "\n", | ||||
|     "def fractal_dimension(array, max_box_size=None, min_box_size=1, n_samples=20, n_offsets=0, plot=False):\n", | ||||
|     "    \"\"\"Calculates the fractal dimension of a 3D numpy array.\n", | ||||
|     "\n", | ||||
|     "    Args:\n", | ||||
|     "        array (np.ndarray): The array to calculate the fractal dimension of.\n", | ||||
|     "        max_box_size (int): The largest box size, given as the power of 2 so that\n", | ||||
|     "                            2**max_box_size gives the sidelength of the largest box.\n", | ||||
|     "        min_box_size (int): The smallest box size, given as the power of 2 so that\n", | ||||
|     "                            2**min_box_size gives the sidelength of the smallest box.\n", | ||||
|     "                            Default value 1.\n", | ||||
|     "        n_samples (int): number of scales to measure over.\n", | ||||
|     "        n_offsets (int): number of offsets to search over to find the smallest set N(s) to\n", | ||||
|     "                       cover  all voxels>0.\n", | ||||
|     "        plot (bool): set to true to see the analytical plot of a calculation.\n", | ||||
|     "\n", | ||||
|     "\n", | ||||
|     "    \"\"\"\n", | ||||
|     "    # determine the scales to measure on\n", | ||||
|     "    if max_box_size == None:\n", | ||||
|     "        # default max size is the largest power of 2 that fits in the smallest dimension of the array:\n", | ||||
|     "        max_box_size = int(np.floor(np.log2(np.min(array.shape))))\n", | ||||
|     "    scales = np.floor(np.logspace(max_box_size, min_box_size, num=n_samples, base=2))\n", | ||||
|     "    scales = np.unique(scales)  # remove duplicates that could occur as a result of the floor\n", | ||||
|     "\n", | ||||
|     "    # get the locations of all non-zero pixels\n", | ||||
|     "    locs = np.where(array > 0)\n", | ||||
|     "    voxels = np.array([(x, y, z) for x, y, z in zip(*locs)])\n", | ||||
|     "\n", | ||||
|     "    # count the minimum amount of boxes touched\n", | ||||
|     "    Ns = []\n", | ||||
|     "    # loop over all scales\n", | ||||
|     "    for scale in scales:\n", | ||||
|     "        touched = []\n", | ||||
|     "        if n_offsets == 0:\n", | ||||
|     "            offsets = [0]\n", | ||||
|     "        else:\n", | ||||
|     "            offsets = np.linspace(0, scale, n_offsets)\n", | ||||
|     "        # search over all offsets\n", | ||||
|     "        for offset in offsets:\n", | ||||
|     "            bin_edges = [np.arange(0, i, scale) for i in array.shape]\n", | ||||
|     "            bin_edges = [np.hstack([0 - offset, x + offset]) for x in bin_edges]\n", | ||||
|     "            H1, e = np.histogramdd(voxels, bins=bin_edges)\n", | ||||
|     "            touched.append(np.sum(H1 > 0))\n", | ||||
|     "        Ns.append(touched)\n", | ||||
|     "    Ns = np.array(Ns)\n", | ||||
|     "\n", | ||||
|     "    # From all sets N found, keep the smallest one at each scale\n", | ||||
|     "    Ns = Ns.min(axis=1)\n", | ||||
|     "\n", | ||||
|     "    # Only keep scales at which Ns changed\n", | ||||
|     "    scales = np.array([np.min(scales[Ns == x]) for x in np.unique(Ns)])\n", | ||||
|     "\n", | ||||
|     "    Ns = np.unique(Ns)\n", | ||||
|     "    Ns = Ns[Ns > 0]\n", | ||||
|     "    scales = scales[:len(Ns)]\n", | ||||
|     "    # perform fit\n", | ||||
|     "    coeffs = np.polyfit(np.log(1 / scales), np.log(Ns), 1)\n", | ||||
|     "\n", | ||||
|     "    # make plot\n", | ||||
|     "    if plot:\n", | ||||
|     "        fig, ax = plt.subplots(figsize=(8, 6))\n", | ||||
|     "        ax.scatter(np.log(1 / scales), np.log(np.unique(Ns)), c=\"teal\", label=\"Measured ratios\")\n", | ||||
|     "        ax.set_ylabel(\"$\\log N(\\epsilon)$\")\n", | ||||
|     "        ax.set_xlabel(\"$\\log 1/ \\epsilon$\")\n", | ||||
|     "        fitted_y_vals = np.polyval(coeffs, np.log(1 / scales))\n", | ||||
|     "        ax.plot(np.log(1 / scales), fitted_y_vals, \"k--\", label=f\"Fit: {np.round(coeffs[0], 3)}X+{coeffs[1]}\")\n", | ||||
|     "        ax.legend();\n", | ||||
|     "    return (coeffs[0])\n" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 15, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "from lib.lib import read_xy_alt, read_load\n", | ||||
|     "\n", | ||||
|     "full_data = read_load(\"/Users/joshuacoles/Developer/checkouts/jc3091/CompB DLA/data-analysis/data/rust-3d\", read_xy_alt)\n", | ||||
|     "df = full_data[full_data.run == '1']" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 16, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "max_actual_radius = max(df.x.abs().max(), df.y.abs().max(), df.z.abs().max())\n", | ||||
|     "max_radius = int(np.exp2(np.floor(np.log2(max_actual_radius)) + 1))\n", | ||||
|     "data = np.zeros((max_radius * 2, max_radius * 2, max_radius * 2))\n", | ||||
|     "data[df.x + max_radius, df.y + max_radius, df.z + max_radius] = 1" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 17, | ||||
|    "metadata": {}, | ||||
|    "outputs": [ | ||||
|     { | ||||
|      "data": { | ||||
|       "text/plain": "(128, 128, 128)" | ||||
|      }, | ||||
|      "execution_count": 17, | ||||
|      "metadata": {}, | ||||
|      "output_type": "execute_result" | ||||
|     } | ||||
|    ], | ||||
|    "source": [ | ||||
|     "data.shape" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 18, | ||||
|    "metadata": {}, | ||||
|    "outputs": [ | ||||
|     { | ||||
|      "data": { | ||||
|       "text/plain": "5000.0" | ||||
|      }, | ||||
|      "execution_count": 18, | ||||
|      "metadata": {}, | ||||
|      "output_type": "execute_result" | ||||
|     } | ||||
|    ], | ||||
|    "source": [ | ||||
|     "data.sum()" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 19, | ||||
|    "metadata": {}, | ||||
|    "outputs": [ | ||||
|     { | ||||
|      "data": { | ||||
|       "text/plain": "(5000, 8)" | ||||
|      }, | ||||
|      "execution_count": 19, | ||||
|      "metadata": {}, | ||||
|      "output_type": "execute_result" | ||||
|     } | ||||
|    ], | ||||
|    "source": [ | ||||
|     "df.shape" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 20, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "dfs = []\n", | ||||
|     "for _, df in full_data.groupby('run'):\n", | ||||
|     "    max_actual_radius = max(df.x.abs().max(), df.y.abs().max(), df.z.abs().max())\n", | ||||
|     "    max_radius = int(np.exp2(np.floor(np.log2(max_actual_radius)) + 1))\n", | ||||
|     "    data = np.zeros((max_radius * 2, max_radius * 2, max_radius * 2))\n", | ||||
|     "    data[df.x + max_radius, df.y + max_radius, df.z + max_radius] = 1\n", | ||||
|     "    dfs.append(fractal_dimension(data))" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 23, | ||||
|    "metadata": {}, | ||||
|    "outputs": [ | ||||
|     { | ||||
|      "data": { | ||||
|       "text/plain": "0.1543448984741014" | ||||
|      }, | ||||
|      "execution_count": 23, | ||||
|      "metadata": {}, | ||||
|      "output_type": "execute_result" | ||||
|     } | ||||
|    ], | ||||
|    "source": [ | ||||
|     "np.mean(np.array(dfs))" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": null, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "plt.scatter(run1.x, run1.y, run1.z)" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": null, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "from mpl_toolkits.mplot3d import Axes3D\n" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": null, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "%matplotlib" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": null, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "import matplotlib as mpl\n", | ||||
|     "from mpl_toolkits.mplot3d import Axes3D\n", | ||||
|     "import numpy as np\n", | ||||
|     "import matplotlib.pyplot as plt\n" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": null, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "fig = plt.figure(figsize=(10, 10))\n", | ||||
|     "ax = fig.add_subplot(projection='3d')\n", | ||||
|     "ax.scatter(run1.x, run1.y,run1.z, c=run1.N)\n", | ||||
|     "fig" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": null, | ||||
|    "metadata": {}, | ||||
|    "outputs": [], | ||||
|    "source": [ | ||||
|     "run1" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": 24, | ||||
|    "metadata": {}, | ||||
|    "outputs": [ | ||||
|     { | ||||
|      "ename": "ModuleNotFoundError", | ||||
|      "evalue": "No module named 'mpld3'", | ||||
|      "output_type": "error", | ||||
|      "traceback": [ | ||||
|       "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m", | ||||
|       "\u001B[0;31mModuleNotFoundError\u001B[0m                       Traceback (most recent call last)", | ||||
|       "Cell \u001B[0;32mIn[24], line 1\u001B[0m\n\u001B[0;32m----> 1\u001B[0m \u001B[38;5;28;01mimport\u001B[39;00m \u001B[38;5;21;01mmatplotlib\u001B[39;00m\u001B[38;5;21;01m.\u001B[39;00m\u001B[38;5;21;01mpyplot\u001B[39;00m \u001B[38;5;28;01mas\u001B[39;00m \u001B[38;5;21;01mplt\u001B[39;00m\u001B[38;5;241m,\u001B[39m \u001B[38;5;21;01mmpld3\u001B[39;00m\n", | ||||
|       "\u001B[0;31mModuleNotFoundError\u001B[0m: No module named 'mpld3'" | ||||
|      ] | ||||
|     } | ||||
|    ], | ||||
|    "source": [ | ||||
|     "import matplotlib.pyplot as plt, mpld3" | ||||
|    ] | ||||
|   }, | ||||
|   { | ||||
|    "cell_type": "code", | ||||
|    "execution_count": null, | ||||
|    "outputs": [], | ||||
|    "source": [], | ||||
|    "metadata": { | ||||
|     "collapsed": false | ||||
|    } | ||||
|   } | ||||
|  ], | ||||
|  "metadata": { | ||||
|   "kernelspec": { | ||||
|    "display_name": "Python 3 (ipykernel)", | ||||
|    "language": "python", | ||||
|    "name": "python3" | ||||
|   }, | ||||
|   "language_info": { | ||||
|    "codemirror_mode": { | ||||
|     "name": "ipython", | ||||
|     "version": 3 | ||||
|    }, | ||||
|    "file_extension": ".py", | ||||
|    "mimetype": "text/x-python", | ||||
|    "name": "python", | ||||
|    "nbconvert_exporter": "python", | ||||
|    "pygments_lexer": "ipython3", | ||||
|    "version": "3.10.6" | ||||
|   } | ||||
|  }, | ||||
|  "nbformat": 4, | ||||
|  "nbformat_minor": 1 | ||||
| } | ||||
							
								
								
									
										162
									
								
								poetry.lock
									
									
									
										generated
									
									
									
								
							
							
						
						| @ -157,14 +157,14 @@ files = [ | ||||
| 
 | ||||
| [[package]] | ||||
| name = "beautifulsoup4" | ||||
| version = "4.11.2" | ||||
| version = "4.12.0" | ||||
| description = "Screen-scraping library" | ||||
| category = "main" | ||||
| optional = false | ||||
| python-versions = ">=3.6.0" | ||||
| files = [ | ||||
|     {file = "beautifulsoup4-4.11.2-py3-none-any.whl", hash = "sha256:0e79446b10b3ecb499c1556f7e228a53e64a2bfcebd455f370d8927cb5b59e39"}, | ||||
|     {file = "beautifulsoup4-4.11.2.tar.gz", hash = "sha256:bc4bdda6717de5a2987436fb8d72f45dc90dd856bdfd512a1314ce90349a0106"}, | ||||
|     {file = "beautifulsoup4-4.12.0-py3-none-any.whl", hash = "sha256:2130a5ad7f513200fae61a17abb5e338ca980fa28c439c0571014bc0217e9591"}, | ||||
|     {file = "beautifulsoup4-4.12.0.tar.gz", hash = "sha256:c5fceeaec29d09c84970e47c65f2f0efe57872f7cff494c9691a26ec0ff13234"}, | ||||
| ] | ||||
| 
 | ||||
| [package.dependencies] | ||||
| @ -1970,89 +1970,89 @@ files = [ | ||||
| 
 | ||||
| [[package]] | ||||
| name = "pyzmq" | ||||
| version = "25.0.1" | ||||
| version = "25.0.2" | ||||
| description = "Python bindings for 0MQ" | ||||
| category = "main" | ||||
| optional = false | ||||
| python-versions = ">=3.6" | ||||
| files = [ | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-macosx_10_15_universal2.whl", hash = "sha256:94f65e13e6df035b0ae90d49adfe7891aa4e7bdeaa65265729fecc04ab3eb0fe"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:f0399450d970990705ce47ed65f5efed3e4627dfc80628c3798100e7b72e023b"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:f29709b0431668a967d7ff0394b00a865e7b7dde827ee0a47938b705b7c4aec3"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4fee9420b34c0ab426f105926a701a3d73f878fe77f07a1b92e0b78d1e2c795c"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:57be375c6bc66b0f685cd298e5c1c3d7ee34a254145b8087aed6e25db372b0f3"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-manylinux_2_28_x86_64.whl", hash = "sha256:a3309b2c5a5be3d48c9ade77b340361764449aa22854ac65935b1e6c0cdabe2c"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:7574d24579e83ee8c5d3b14769e7ba895161c43a601e911dd89d449e545e00ad"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:041d617091258133e602919b28fdce4d3e2f8aedcd1e8b34c599653bc288d59e"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:7897ba8c3fedc6b3023bad676ceb69dbf90c077ff18ae3133ba43db47417cc72"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-win32.whl", hash = "sha256:c462f70dadbd4649e572ca7cd1e7cf3305a8c2afc53b84214c0a7c0c3af8a657"}, | ||||
|     {file = "pyzmq-25.0.1-cp310-cp310-win_amd64.whl", hash = "sha256:e3a721710992cf0e213bbb7be48fb0f32202e8d01f556c196c870373bb9ad4f4"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-macosx_10_15_universal2.whl", hash = "sha256:b0a0fcf56279b9f3acc9b36a83feb7640c51b0db444b6870e4406d002be1d514"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:95aff52fc847ea5755d2370f86e379ba2ed6eb67a0a6f90f0e8e99c553693b81"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b55366e6c11e1ef7403d072b9867b62cf63eebd31dd038ef65bc8d65572854f6"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:64a2bc72bcad705ee42a8fe877478ddadb7e260e806562833d3d814125e28a44"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:0ca66aa24422d7f324acd5cb7fc7df616eb6f0205e059393fb108702e33e90c7"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-manylinux_2_28_x86_64.whl", hash = "sha256:58d5dfec2e2befd09b04c4683b3c984d2203cf6e054d0f9786be3826737ad612"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:3549292d65987e422e2c9f105b1485448381f489d8a6b6b040fc8b8f497bd578"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:5b1ca8b0df50d1ac88857ffe9ebd1347e0a5bb5f6e1d99940fdd7df0ffdefb49"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:a1a107e89cdcf799060ba4fa85fd3c942e19df7b24eb2600618b2406cc73c18e"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-win32.whl", hash = "sha256:0f22ba4e9041549a5a3f5a545169dda52fa0aa7b5ef46b336cbe6679c4c3c134"}, | ||||
|     {file = "pyzmq-25.0.1-cp311-cp311-win_amd64.whl", hash = "sha256:0644c0d5c73e4bfeee8148f638ab16ad783df1c4d6c2f968552a26a43fb002a1"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:c5eb4b17d73b1fc208a4faa6b5918983ccc961770aa37741891f61db302dae4e"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:649dd55948144a108041397f07c1299086ce1c85c2e166831db3a33dac1d0c7f"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-manylinux_2_5_i686.manylinux1_i686.whl", hash = "sha256:c99fd8d3efc138d6a7fb1e822133f62bb18ffec66dc6d398dcb2ac2ab8eb2cb0"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-manylinux_2_5_x86_64.manylinux1_x86_64.whl", hash = "sha256:d72d69d4bb37c05a446d10bc40b391cf8fb7572654fb73fa69e7d2a395197e65"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-musllinux_1_1_aarch64.whl", hash = "sha256:036dbf8373aed4ccf56d58c561b23601b8f33919ec1093d8c77b37ac1259702d"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-musllinux_1_1_i686.whl", hash = "sha256:861c37649c75a2ecfc2034a32b9d5ca744e1e0cddcbf65afbd8027cf7d9755be"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-musllinux_1_1_x86_64.whl", hash = "sha256:92f04d63aecbb71d41f7db5f988167ef429f96d8197fd46684688cdb513e8a2e"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-win32.whl", hash = "sha256:866a4e918f1f4b2f83e9982b817df257910e3e50e456ffa74f141a10adcd11d1"}, | ||||
|     {file = "pyzmq-25.0.1-cp36-cp36m-win_amd64.whl", hash = "sha256:ec29c880b82cd38a63810a93b77e13f167e05732049101947772eed9ae805097"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:0241a334e39aa74e4ba0ae5f9e29521f1b48b8d56bf707f25f322c04eb423e99"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:f3b7032f55b1ed2cd8c349a89e467dca2338b7765fab82cb64c3504e49adaf51"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.whl", hash = "sha256:960f98f562ee6a50ecf283bc62479d00f5ee10e9068a21683b9e961cd87c9261"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-manylinux_2_5_x86_64.manylinux1_x86_64.whl", hash = "sha256:835da498b71570d56e5526de4d5b36fa10dd9b8a82e2c405f963afeb51ff5bdc"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-musllinux_1_1_aarch64.whl", hash = "sha256:21de2ef6099fa8d6a3c2dc15aaca58e9f9ffdcc7b82a246590aa9564815699d9"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:1e448a5a294958e915a7e1b664e6fbfcd3814989d381fb068673317f6f3ea3f8"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:40d909bdc8a2d64ad260925154712602ee6a0425ae0b08bce78a19adfdc2f05b"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-win32.whl", hash = "sha256:6ff37f2b818df25c887fd40bb434569db7ff66b35f5dfff6f40cc476aee92e3f"}, | ||||
|     {file = "pyzmq-25.0.1-cp37-cp37m-win_amd64.whl", hash = "sha256:f66ee27a0221771bbaa2cce456e8ca890569c3d18b08b955eb6420c12516537c"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-macosx_10_15_universal2.whl", hash = "sha256:1003bbae89435eadec03b4fa3bb6516dd1529fb09ae5704284f7400cc77009ba"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:dde7a65a8bfa88aa1721add504320f8344272542291ce4e7c77993fa32901567"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:20b6155429d3b57e9e7bd11f1680985ef8b5b0868f1a64073fb8c01326c7c80c"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:e37a764cbf91c1ed9a02e4fede79a414284aca2a0b7d92d82a3c7b82d678ec2d"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:aa56a362066b3a853a64d35693a08046f640961efcc0e7643768916403e72e70"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:c4bdf1241886d39d816535d3ef9fc325bbf02470c9fd5f2cb62706eeb834f7f2"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:446acbac24427ef42bff61a807ddcad8d03df78fb976184a4d7d6f4b1e7d8a67"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:b39847501d229e5fab155d88a565edfb182cdd3f7046f15a7f2df9c77cdc422d"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-win32.whl", hash = "sha256:cba6b81b653d789d76e438c2e77b49f610b23e84b3bb43b99100f08a0a5d637b"}, | ||||
|     {file = "pyzmq-25.0.1-cp38-cp38-win_amd64.whl", hash = "sha256:6eca6b90c4fb290efd27582780b5eaf048887a32b2c5fcd6330819192cb07b38"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-macosx_10_15_universal2.whl", hash = "sha256:58207a6709e53b723105bac6bb3c6795ee134f7e71351f39c09d52ac235c6b0d"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:c62084f37682e7ee4064e8310078be4f6f7687bf528ae5761e2ba7216c5b8949"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:9c44e9f04f8ed99c6f2e9e49f29d400d7557dd9e9e3f64e1e8a595aedc4258a2"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:c635d1c40d341835066931a018e378428dfbe0347ed4bb45a6b57f7d8c34196e"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:eef93b5574c9ff36b4be376555efd369bd55b99bcc7be72f23bd38102dd9392b"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:44bc81099ab33388f6c061c1b194307d877428cb2b18282d0385584d5c73ed72"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:6d988844ed6caa21b0076b64671e83a136d93c57f1ae5a72b915661af55d313b"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:9d5eb6e88ae8a8734f239ffe1ed90559a426cf5b859b8ee66e0cd43fc5daf5c9"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-win32.whl", hash = "sha256:f6b45db9de4c8adbf5fda58e827a32315d282cfb01e54dc74e7c7ccc0988c010"}, | ||||
|     {file = "pyzmq-25.0.1-cp39-cp39-win_amd64.whl", hash = "sha256:47eeb94b78aa442568b85ad28f85bd37a9c3c34d052cbf8ebf8622c45f23a9cd"}, | ||||
|     {file = "pyzmq-25.0.1-pp37-pypy37_pp73-macosx_10_9_x86_64.whl", hash = "sha256:0ed7475f3adf0c7750d75740b3267947b501a33f4625ceae709fda2e75ec9ed7"}, | ||||
|     {file = "pyzmq-25.0.1-pp37-pypy37_pp73-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:6d09c22ed4d0afcc662d17c2429a03fc1fae7fe7e3bc1f413e744bccfeaabdc3"}, | ||||
|     {file = "pyzmq-25.0.1-pp37-pypy37_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:703ec5f5a8369c09d8f3eb626358bdb590a2b1375bcce8b7da01b3a03f8b8668"}, | ||||
|     {file = "pyzmq-25.0.1-pp37-pypy37_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:20aea31cc0d1f6c3fb4685db08b4c771545cf3fed3c4b4c8942c0a4e97042ec8"}, | ||||
|     {file = "pyzmq-25.0.1-pp37-pypy37_pp73-win_amd64.whl", hash = "sha256:b1c03b942557bb366fd3dc377a15763d5d688de1328228136c75e50f968333cc"}, | ||||
|     {file = "pyzmq-25.0.1-pp38-pypy38_pp73-macosx_10_9_x86_64.whl", hash = "sha256:4e8a5ced9d92837f52ccdae6351c627b5012669727bc3eede2dc0f581eca1d0e"}, | ||||
|     {file = "pyzmq-25.0.1-pp38-pypy38_pp73-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:d78f840d88244272fb7252e47522b1179833aff7ec64583bda3d21259c9c2c20"}, | ||||
|     {file = "pyzmq-25.0.1-pp38-pypy38_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:c3f78fa80780e24d294f9421123cb3bd3b68677953c53da85273a22d1c983298"}, | ||||
|     {file = "pyzmq-25.0.1-pp38-pypy38_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:4f6de4305e02560111a5d4555758faa85d44a5bff70cccff58dbf30c81a079f0"}, | ||||
|     {file = "pyzmq-25.0.1-pp38-pypy38_pp73-win_amd64.whl", hash = "sha256:34a1b1a8ce9b20e01aba71b9279d9b1d4e5980a6a4e42092180e16628a444ca1"}, | ||||
|     {file = "pyzmq-25.0.1-pp39-pypy39_pp73-macosx_10_9_x86_64.whl", hash = "sha256:625759a0112af7c3fb560de5724d749729f00b901f7625d1a3f3fb38897544b1"}, | ||||
|     {file = "pyzmq-25.0.1-pp39-pypy39_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:8cff159b21438c24476a49865f3d5700c9cc5833600661bc0e672decec2ff357"}, | ||||
|     {file = "pyzmq-25.0.1-pp39-pypy39_pp73-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4cc47652d990de9ef967c494c526d73920ef064fef0444355a7cebec6fc50542"}, | ||||
|     {file = "pyzmq-25.0.1-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:44db5162a6881f7d740dec65917f38f9bfbc5ad9a10e06d7d5deebb27eb63939"}, | ||||
|     {file = "pyzmq-25.0.1-pp39-pypy39_pp73-manylinux_2_28_x86_64.whl", hash = "sha256:f38bf2c60a3f7b87cf5177043eb7a331a4f53bc9305a2452decbd42ad0c98741"}, | ||||
|     {file = "pyzmq-25.0.1-pp39-pypy39_pp73-win_amd64.whl", hash = "sha256:b1cf4becd15669bc62a41c1b1bb742e22ac25965134e4254cde82a4dc2554b1b"}, | ||||
|     {file = "pyzmq-25.0.1.tar.gz", hash = "sha256:44a24f7ce44e70d20e2a4c9ba5af70b4611df7a4b920eed2c8e0bdd5a5af225f"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-macosx_10_15_universal2.whl", hash = "sha256:ac178e666c097c8d3deb5097b58cd1316092fc43e8ef5b5fdb259b51da7e7315"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:659e62e1cbb063151c52f5b01a38e1df6b54feccfa3e2509d44c35ca6d7962ee"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:8280ada89010735a12b968ec3ea9a468ac2e04fddcc1cede59cb7f5178783b9c"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:a9b5eeb5278a8a636bb0abdd9ff5076bcbb836cd2302565df53ff1fa7d106d54"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:9a2e5fe42dfe6b73ca120b97ac9f34bfa8414feb15e00e37415dbd51cf227ef6"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-manylinux_2_28_x86_64.whl", hash = "sha256:827bf60e749e78acb408a6c5af6688efbc9993e44ecc792b036ec2f4b4acf485"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:7b504ae43d37e282301da586529e2ded8b36d4ee2cd5e6db4386724ddeaa6bbc"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:cb1f69a0a2a2b1aae8412979dd6293cc6bcddd4439bf07e4758d864ddb112354"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:2b9c9cc965cdf28381e36da525dcb89fc1571d9c54800fdcd73e3f73a2fc29bd"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-win32.whl", hash = "sha256:24abbfdbb75ac5039205e72d6c75f10fc39d925f2df8ff21ebc74179488ebfca"}, | ||||
|     {file = "pyzmq-25.0.2-cp310-cp310-win_amd64.whl", hash = "sha256:6a821a506822fac55d2df2085a52530f68ab15ceed12d63539adc32bd4410f6e"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-macosx_10_15_universal2.whl", hash = "sha256:9af0bb0277e92f41af35e991c242c9c71920169d6aa53ade7e444f338f4c8128"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:54a96cf77684a3a537b76acfa7237b1e79a8f8d14e7f00e0171a94b346c5293e"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:88649b19ede1cab03b96b66c364cbbf17c953615cdbc844f7f6e5f14c5e5261c"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:715cff7644a80a7795953c11b067a75f16eb9fc695a5a53316891ebee7f3c9d5"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:312b3f0f066b4f1d17383aae509bacf833ccaf591184a1f3c7a1661c085063ae"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-manylinux_2_28_x86_64.whl", hash = "sha256:d488c5c8630f7e782e800869f82744c3aca4aca62c63232e5d8c490d3d66956a"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:38d9f78d69bcdeec0c11e0feb3bc70f36f9b8c44fc06e5d06d91dc0a21b453c7"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:3059a6a534c910e1d5d068df42f60d434f79e6cc6285aa469b384fa921f78cf8"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:6526d097b75192f228c09d48420854d53dfbc7abbb41b0e26f363ccb26fbc177"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-win32.whl", hash = "sha256:5c5fbb229e40a89a2fe73d0c1181916f31e30f253cb2d6d91bea7927c2e18413"}, | ||||
|     {file = "pyzmq-25.0.2-cp311-cp311-win_amd64.whl", hash = "sha256:ed15e3a2c3c2398e6ae5ce86d6a31b452dfd6ad4cd5d312596b30929c4b6e182"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:032f5c8483c85bf9c9ca0593a11c7c749d734ce68d435e38c3f72e759b98b3c9"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:374b55516393bfd4d7a7daa6c3b36d6dd6a31ff9d2adad0838cd6a203125e714"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-manylinux_2_5_i686.manylinux1_i686.whl", hash = "sha256:08bfcc21b5997a9be4fefa405341320d8e7f19b4d684fb9c0580255c5bd6d695"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-manylinux_2_5_x86_64.manylinux1_x86_64.whl", hash = "sha256:1a843d26a8da1b752c74bc019c7b20e6791ee813cd6877449e6a1415589d22ff"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-musllinux_1_1_aarch64.whl", hash = "sha256:b48616a09d7df9dbae2f45a0256eee7b794b903ddc6d8657a9948669b345f220"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-musllinux_1_1_i686.whl", hash = "sha256:d4427b4a136e3b7f85516c76dd2e0756c22eec4026afb76ca1397152b0ca8145"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-musllinux_1_1_x86_64.whl", hash = "sha256:26b0358e8933990502f4513c991c9935b6c06af01787a36d133b7c39b1df37fa"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-win32.whl", hash = "sha256:c8fedc3ccd62c6b77dfe6f43802057a803a411ee96f14e946f4a76ec4ed0e117"}, | ||||
|     {file = "pyzmq-25.0.2-cp36-cp36m-win_amd64.whl", hash = "sha256:2da6813b7995b6b1d1307329c73d3e3be2fd2d78e19acfc4eff2e27262732388"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:a35960c8b2f63e4ef67fd6731851030df68e4b617a6715dd11b4b10312d19fef"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:eef2a0b880ab40aca5a878933376cb6c1ec483fba72f7f34e015c0f675c90b20"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.whl", hash = "sha256:85762712b74c7bd18e340c3639d1bf2f23735a998d63f46bb6584d904b5e401d"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-manylinux_2_5_x86_64.manylinux1_x86_64.whl", hash = "sha256:64812f29d6eee565e129ca14b0c785744bfff679a4727137484101b34602d1a7"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-musllinux_1_1_aarch64.whl", hash = "sha256:510d8e55b3a7cd13f8d3e9121edf0a8730b87d925d25298bace29a7e7bc82810"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:b164cc3c8acb3d102e311f2eb6f3c305865ecb377e56adc015cb51f721f1dda6"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:28fdb9224a258134784a9cf009b59265a9dde79582fb750d4e88a6bcbc6fa3dc"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-win32.whl", hash = "sha256:dd771a440effa1c36d3523bc6ba4e54ff5d2e54b4adcc1e060d8f3ca3721d228"}, | ||||
|     {file = "pyzmq-25.0.2-cp37-cp37m-win_amd64.whl", hash = "sha256:9bdc40efb679b9dcc39c06d25629e55581e4c4f7870a5e88db4f1c51ce25e20d"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-macosx_10_15_universal2.whl", hash = "sha256:1f82906a2d8e4ee310f30487b165e7cc8ed09c009e4502da67178b03083c4ce0"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:21ec0bf4831988af43c8d66ba3ccd81af2c5e793e1bf6790eb2d50e27b3c570a"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:abbce982a17c88d2312ec2cf7673985d444f1beaac6e8189424e0a0e0448dbb3"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:9e1d2f2d86fc75ed7f8845a992c5f6f1ab5db99747fb0d78b5e4046d041164d2"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:a2e92ff20ad5d13266bc999a29ed29a3b5b101c21fdf4b2cf420c09db9fb690e"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:edbbf06cc2719889470a8d2bf5072bb00f423e12de0eb9ffec946c2c9748e149"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:77942243ff4d14d90c11b2afd8ee6c039b45a0be4e53fb6fa7f5e4fd0b59da39"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:ab046e9cb902d1f62c9cc0eca055b1d11108bdc271caf7c2171487298f229b56"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-win32.whl", hash = "sha256:ad761cfbe477236802a7ab2c080d268c95e784fe30cafa7e055aacd1ca877eb0"}, | ||||
|     {file = "pyzmq-25.0.2-cp38-cp38-win_amd64.whl", hash = "sha256:8560756318ec7c4c49d2c341012167e704b5a46d9034905853c3d1ade4f55bee"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-macosx_10_15_universal2.whl", hash = "sha256:ab2c056ac503f25a63f6c8c6771373e2a711b98b304614151dfb552d3d6c81f6"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:cca8524b61c0eaaa3505382dc9b9a3bc8165f1d6c010fdd1452c224225a26689"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:cfb9f7eae02d3ac42fbedad30006b7407c984a0eb4189a1322241a20944d61e5"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:5eaeae038c68748082137d6896d5c4db7927e9349237ded08ee1bbd94f7361c9"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:4a31992a8f8d51663ebf79df0df6a04ffb905063083d682d4380ab8d2c67257c"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:6a979e59d2184a0c8f2ede4b0810cbdd86b64d99d9cc8a023929e40dce7c86cc"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:1f124cb73f1aa6654d31b183810febc8505fd0c597afa127c4f40076be4574e0"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:65c19a63b4a83ae45d62178b70223adeee5f12f3032726b897431b6553aa25af"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-win32.whl", hash = "sha256:83d822e8687621bed87404afc1c03d83fa2ce39733d54c2fd52d8829edb8a7ff"}, | ||||
|     {file = "pyzmq-25.0.2-cp39-cp39-win_amd64.whl", hash = "sha256:24683285cc6b7bf18ad37d75b9db0e0fefe58404e7001f1d82bf9e721806daa7"}, | ||||
|     {file = "pyzmq-25.0.2-pp37-pypy37_pp73-macosx_10_9_x86_64.whl", hash = "sha256:4a4b4261eb8f9ed71f63b9eb0198dd7c934aa3b3972dac586d0ef502ba9ab08b"}, | ||||
|     {file = "pyzmq-25.0.2-pp37-pypy37_pp73-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:62ec8d979f56c0053a92b2b6a10ff54b9ec8a4f187db2b6ec31ee3dd6d3ca6e2"}, | ||||
|     {file = "pyzmq-25.0.2-pp37-pypy37_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:affec1470351178e892121b3414c8ef7803269f207bf9bef85f9a6dd11cde264"}, | ||||
|     {file = "pyzmq-25.0.2-pp37-pypy37_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:ffc71111433bd6ec8607a37b9211f4ef42e3d3b271c6d76c813669834764b248"}, | ||||
|     {file = "pyzmq-25.0.2-pp37-pypy37_pp73-win_amd64.whl", hash = "sha256:6fadc60970714d86eff27821f8fb01f8328dd36bebd496b0564a500fe4a9e354"}, | ||||
|     {file = "pyzmq-25.0.2-pp38-pypy38_pp73-macosx_10_9_x86_64.whl", hash = "sha256:269968f2a76c0513490aeb3ba0dc3c77b7c7a11daa894f9d1da88d4a0db09835"}, | ||||
|     {file = "pyzmq-25.0.2-pp38-pypy38_pp73-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:f7c8b8368e84381ae7c57f1f5283b029c888504aaf4949c32e6e6fb256ec9bf0"}, | ||||
|     {file = "pyzmq-25.0.2-pp38-pypy38_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:25e6873a70ad5aa31e4a7c41e5e8c709296edef4a92313e1cd5fc87bbd1874e2"}, | ||||
|     {file = "pyzmq-25.0.2-pp38-pypy38_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b733076ff46e7db5504c5e7284f04a9852c63214c74688bdb6135808531755a3"}, | ||||
|     {file = "pyzmq-25.0.2-pp38-pypy38_pp73-win_amd64.whl", hash = "sha256:a6f6ae12478fdc26a6d5fdb21f806b08fa5403cd02fd312e4cb5f72df078f96f"}, | ||||
|     {file = "pyzmq-25.0.2-pp39-pypy39_pp73-macosx_10_9_x86_64.whl", hash = "sha256:67da1c213fbd208906ab3470cfff1ee0048838365135a9bddc7b40b11e6d6c89"}, | ||||
|     {file = "pyzmq-25.0.2-pp39-pypy39_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:531e36d9fcd66f18de27434a25b51d137eb546931033f392e85674c7a7cea853"}, | ||||
|     {file = "pyzmq-25.0.2-pp39-pypy39_pp73-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:34a6fddd159ff38aa9497b2e342a559f142ab365576284bc8f77cb3ead1f79c5"}, | ||||
|     {file = "pyzmq-25.0.2-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b491998ef886662c1f3d49ea2198055a9a536ddf7430b051b21054f2a5831800"}, | ||||
|     {file = "pyzmq-25.0.2-pp39-pypy39_pp73-manylinux_2_28_x86_64.whl", hash = "sha256:5d496815074e3e3d183fe2c7fcea2109ad67b74084c254481f87b64e04e9a471"}, | ||||
|     {file = "pyzmq-25.0.2-pp39-pypy39_pp73-win_amd64.whl", hash = "sha256:56a94ab1d12af982b55ca96c6853db6ac85505e820d9458ac76364c1998972f4"}, | ||||
|     {file = "pyzmq-25.0.2.tar.gz", hash = "sha256:6b8c1bbb70e868dc88801aa532cae6bd4e3b5233784692b786f17ad2962e5149"}, | ||||
| ] | ||||
| 
 | ||||
| [package.dependencies] | ||||
|  | ||||