From 9c1fa4384221db4b440ba18c3716a603e5f3c7e8 Mon Sep 17 00:00:00 2001 From: Alexander Puck Neuwirth Date: Wed, 9 Oct 2024 22:18:48 +0200 Subject: [PATCH] copy -> clone --- debug/histo1d.ipynb | 305 +++++++++++++++------ src/babyyoda/Histo1D_v2.py | 8 +- src/babyyoda/grogu/histo1d_v2.py | 2 +- tests/grogu/uhi/test_gg_histo1d_slicing.py | 8 +- 4 files changed, 230 insertions(+), 93 deletions(-) diff --git a/debug/histo1d.ipynb b/debug/histo1d.ipynb index cc9437a..a13c521 100644 --- a/debug/histo1d.ipynb +++ b/debug/histo1d.ipynb @@ -2,12 +2,13 @@ "cells": [ { "cell_type": "code", - "execution_count": 1, + "execution_count": 16, "id": "4045b3af-f990-4dbb-990f-937c5ddeee26", "metadata": {}, "outputs": [], "source": [ "import babyyoda as grogu\n", + "from babyyoda import loc\n", "import matplotlib.pyplot as plt" ] }, @@ -18,15 +19,28 @@ "metadata": {}, "outputs": [ { - "ename": "AttributeError", - "evalue": "'yoda.core.HistoBin1D' object has no attribute 'errW'", - "output_type": "error", - "traceback": [ - "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m", - "\u001b[0;31mAttributeError\u001b[0m Traceback (most recent call last)", - "Cell \u001b[0;32mIn[2], line 3\u001b[0m\n\u001b[1;32m 1\u001b[0m hists \u001b[38;5;241m=\u001b[39m grogu\u001b[38;5;241m.\u001b[39mread_yoda(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m../tests/test_histo1d_v2.yoda\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m 2\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m b \u001b[38;5;129;01min\u001b[39;00m hists[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m/\u001b[39m\u001b[38;5;124m\"\u001b[39m]:\n\u001b[0;32m----> 3\u001b[0m \u001b[38;5;28mprint\u001b[39m(b\u001b[38;5;241m.\u001b[39msumW(), \u001b[43mb\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43merrW\u001b[49m()\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m2\u001b[39m)\n\u001b[1;32m 4\u001b[0m hists[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m/\u001b[39m\u001b[38;5;124m\"\u001b[39m]\u001b[38;5;241m.\u001b[39mvariances()\n", - "\u001b[0;31mAttributeError\u001b[0m: 'yoda.core.HistoBin1D' object has no attribute 'errW'" + "name": "stdout", + "output_type": "stream", + "text": [ + "3.0 1.541103500742244\n", + "3.0 0.9354143466934853\n", + "4.0 1.0606601717798212\n", + "5.0 1.1726039399558574\n", + "6.0 1.2747548783981961\n", + "7.0 1.3693063937629153\n", + "8.0 1.4577379737113252\n", + "8.0 1.9364916731037085\n" ] + }, + { + "data": { + "text/plain": [ + "array([ 9.5, 3.5, 4.5, 5.5, 6.5, 7.5, 8.5, 15. ])" + ] + }, + "execution_count": 2, + "metadata": {}, + "output_type": "execute_result" } ], "source": [ @@ -38,10 +52,35 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 3, "id": "b75dee9c-0432-4ddb-99f6-53f294b5e122", "metadata": {}, - "outputs": [], + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "3.0 1.541103500742244\n", + "3.0 0.9354143466934853\n", + "4.0 1.0606601717798212\n", + "5.0 1.1726039399558574\n", + "6.0 1.2747548783981961\n", + "7.0 1.3693063937629153\n", + "8.0 1.4577379737113252\n", + "8.0 1.9364916731037085\n" + ] + }, + { + "data": { + "text/plain": [ + "array([ 9.5, 3.5, 4.5, 5.5, 6.5, 7.5, 8.5, 15. ])" + ] + }, + "execution_count": 3, + "metadata": {}, + "output_type": "execute_result" + } + ], "source": [ "hists = grogu.read_grogu(\"../tests/test_histo1d_v2.yoda\")\n", "for b in hists[\"/\"]:\n", @@ -51,10 +90,31 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 4, "id": "9e7f5fc2-0126-4a97-b4ab-2b1539245987", "metadata": {}, - "outputs": [], + "outputs": [ + { + "data": { + "text/plain": [ + "" + ] + }, + "execution_count": 4, + "metadata": {}, + "output_type": "execute_result" + }, + { + "data": { + "image/png": "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", + "text/plain": [ + "
" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], "source": [ "hists = grogu.read_grogu(\"../tests/test_histo1d_v2.yoda\")\n", "hists[\"/\"].plot()\n", @@ -65,21 +125,57 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 17, "id": "88fe7219-6233-4574-a5f2-8a7ae69975c9", "metadata": {}, - "outputs": [], + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + " 3 5 None\n" + ] + }, + { + "ename": "AttributeError", + "evalue": "'yoda.core.BinnedHisto1D' object has no attribute 'copy'", + "output_type": "error", + "traceback": [ + "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m", + "\u001b[0;31mAttributeError\u001b[0m Traceback (most recent call last)", + "Cell \u001b[0;32mIn[17], line 2\u001b[0m\n\u001b[1;32m 1\u001b[0m hists \u001b[38;5;241m=\u001b[39m grogu\u001b[38;5;241m.\u001b[39mread_yoda(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m../tests/test_histo1d_v2.yoda\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m----> 2\u001b[0m \u001b[43mhists\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m/\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m[\u001b[49m\u001b[43mloc\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m4\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m:\u001b[49m\u001b[43mloc\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m6\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m]\u001b[49m\n", + "File \u001b[0;32m~/.local/lib/python3.12/site-packages/babyyoda/Histo1D_v2.py:154\u001b[0m, in \u001b[0;36mHISTO1D_V2.__getitem__\u001b[0;34m(self, slices)\u001b[0m\n\u001b[1;32m 152\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m stop \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m 153\u001b[0m stop \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[0;32m--> 154\u001b[0m sc \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcopy\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m 155\u001b[0m sc\u001b[38;5;241m.\u001b[39mrebinTo(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mxEdges()[start:stop])\n\u001b[1;32m 156\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m sc\n", + "File \u001b[0;32m~/.local/lib/python3.12/site-packages/babyyoda/Histo1D_v2.py:67\u001b[0m, in \u001b[0;36mHISTO1D_V2.copy\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m 66\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mcopy\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[0;32m---> 67\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m HISTO1D_V2(\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mtarget\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcopy\u001b[49m())\n", + "\u001b[0;31mAttributeError\u001b[0m: 'yoda.core.BinnedHisto1D' object has no attribute 'copy'" + ] + } + ], "source": [ "hists = grogu.read_yoda(\"../tests/test_histo1d_v2.yoda\")\n", - "hists[\"/\"]" + "hists[\"/\"][loc(4) : loc(6)]" ] }, { "cell_type": "code", - "execution_count": null, + "execution_count": 6, "id": "4d72c698-ab00-4ff8-be33-833260b1fc01", "metadata": {}, - "outputs": [], + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "39.0 28.0\n", + "0.2727272727272727 648.0\n", + "0.17391304347826086 1239.6521739130435\n", + "0.1282051282051282 2030.7692307692307\n", + "0.1016949152542373 274.5762711864407\n", + "0.08433734939759036 382.5542168674699\n", + "0.07207207207207207 508.5405405405405\n", + "1.1428571428571428 1157.142857142857\n" + ] + } + ], "source": [ "for b in hists[\"/\"]:\n", " print(b.variance(), b.xVariance())" @@ -87,7 +183,7 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 7, "id": "159c7b2f-e18e-43f6-a630-c6f9ac062a25", "metadata": {}, "outputs": [], @@ -98,60 +194,130 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 8, "id": "2773a80a-4f50-456c-b2a5-b4db8d3d719b", "metadata": {}, - "outputs": [], + "outputs": [ + { + "data": { + "text/plain": [ + "" + ] + }, + "execution_count": 8, + "metadata": {}, + "output_type": "execute_result" + } + ], "source": [ "hists[\"/\"][grogu.loc(3.5) + 1]" ] }, { "cell_type": "code", - "execution_count": null, + "execution_count": 9, "id": "d0cecc9f-4f12-4b70-b4cc-72442582dabc", "metadata": {}, - "outputs": [], + "outputs": [ + { + "data": { + "text/plain": [ + "array([3., 3., 4., 5., 6., 7., 8., 8.])" + ] + }, + "execution_count": 9, + "metadata": {}, + "output_type": "execute_result" + } + ], "source": [ "hists[\"/\"].values()" ] }, { "cell_type": "code", - "execution_count": null, + "execution_count": 10, "id": "bef63e37-e04d-4541-8eb5-bf11b315fcf8", "metadata": {}, - "outputs": [], + "outputs": [ + { + "data": { + "text/plain": [ + "array([ 9.5, 3.5, 4.5, 5.5, 6.5, 7.5, 8.5, 15. ])" + ] + }, + "execution_count": 10, + "metadata": {}, + "output_type": "execute_result" + } + ], "source": [ "hists[\"/\"].variances()" ] }, { "cell_type": "code", - "execution_count": null, + "execution_count": 11, "id": "9391df8c-07f5-4777-87dc-619e3ff9c8e5", "metadata": {}, - "outputs": [], + "outputs": [ + { + "data": { + "text/plain": [ + "5.0" + ] + }, + "execution_count": 11, + "metadata": {}, + "output_type": "execute_result" + } + ], "source": [ "hists[\"/\"].counts()[0]" ] }, { "cell_type": "code", - "execution_count": null, + "execution_count": 12, "id": "26407638-40d0-4f73-81d1-6a795a8a6d5f", "metadata": {}, - "outputs": [], + "outputs": [ + { + "data": { + "text/plain": [ + "array([ 9.5, 3.5, 4.5, 5.5, 6.5, 7.5, 8.5, 15. ])" + ] + }, + "execution_count": 12, + "metadata": {}, + "output_type": "execute_result" + } + ], "source": [ "hists[\"/\"].sumW2s()" ] }, { "cell_type": "code", - "execution_count": null, + "execution_count": 13, "id": "878a5396-f255-4d82-a21e-0c00c356d532", "metadata": {}, - "outputs": [], + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "3.0 1.541103500742244\n", + "3.0 0.9354143466934853\n", + "4.0 1.0606601717798212\n", + "5.0 1.1726039399558574\n", + "6.0 1.2747548783981961\n", + "7.0 1.3693063937629153\n", + "8.0 1.4577379737113252\n", + "8.0 1.9364916731037085\n" + ] + } + ], "source": [ "for b in hists[\"/\"]:\n", " print(b.sumW(), b.errW() / 2)" @@ -159,10 +325,23 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 14, "id": "0cbcb048-ab07-49ad-8759-3f8a371a0a42", "metadata": {}, - "outputs": [], + "outputs": [ + { + "ename": "AttributeError", + "evalue": "'HISTO1D_V2' object and target have no attribute 'yVals'", + "output_type": "error", + "traceback": [ + "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m", + "\u001b[0;31mAttributeError\u001b[0m Traceback (most recent call last)", + "Cell \u001b[0;32mIn[14], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mhists\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m/\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43myVals\u001b[49m()\n", + "File \u001b[0;32m~/.local/lib/python3.12/site-packages/babyyoda/Histo1D_v2.py:40\u001b[0m, in \u001b[0;36mHISTO1D_V2.__getattr__\u001b[0;34m(self, name)\u001b[0m\n\u001b[1;32m 38\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m \u001b[38;5;28mhasattr\u001b[39m(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtarget, name):\n\u001b[1;32m 39\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mgetattr\u001b[39m(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtarget, name)\n\u001b[0;32m---> 40\u001b[0m \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mAttributeError\u001b[39;00m(\n\u001b[1;32m 41\u001b[0m \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mtype\u001b[39m(\u001b[38;5;28mself\u001b[39m)\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__name__\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m object and target have no attribute \u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mname\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m 42\u001b[0m )\n", + "\u001b[0;31mAttributeError\u001b[0m: 'HISTO1D_V2' object and target have no attribute 'yVals'" + ] + } + ], "source": [ "hists[\"/\"].yVals()" ] @@ -181,7 +360,7 @@ }, { "cell_type": "code", - "execution_count": 3, + "execution_count": null, "id": "0b9b6237-bf2c-42d8-87d9-f9e45d108a7b", "metadata": {}, "outputs": [], @@ -191,55 +370,25 @@ }, { "cell_type": "code", - "execution_count": 4, + "execution_count": null, "id": "a78c6ed3-af01-4ae5-8ee2-098c0d1ddb5d", "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "array([[1.5411035 , 1.5411035 ],\n", - " [1.87082869, 1.87082869],\n", - " [2.12132034, 2.12132034],\n", - " [2.34520788, 2.34520788],\n", - " [2.54950976, 2.54950976],\n", - " [2.73861279, 2.73861279],\n", - " [2.91547595, 2.91547595],\n", - " [1.93649167, 1.93649167]])" - ] - }, - "execution_count": 4, - "metadata": {}, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "h.mkScatter().yErrs()" ] }, { "cell_type": "code", - "execution_count": 5, + "execution_count": null, "id": "4268e817-fb1c-4b80-933c-384f7e7cb984", "metadata": {}, - "outputs": [ - { - "ename": "AttributeError", - "evalue": "'yoda.core.HistoBin1D' object has no attribute 'val'", - "output_type": "error", - "traceback": [ - "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m", - "\u001b[0;31mAttributeError\u001b[0m Traceback (most recent call last)", - "Cell \u001b[0;32mIn[5], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mh\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbinAt\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m5\u001b[39;49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mval\u001b[49m()\n", - "\u001b[0;31mAttributeError\u001b[0m: 'yoda.core.HistoBin1D' object has no attribute 'val'" - ] - } - ], + "outputs": [], "source": [] }, { "cell_type": "code", - "execution_count": 7, + "execution_count": null, "id": "b21bc5fc-7a38-428b-807f-607d262fd35d", "metadata": {}, "outputs": [], @@ -249,7 +398,7 @@ }, { "cell_type": "code", - "execution_count": 12, + "execution_count": null, "id": "c50b2e7e-ab28-47b3-93b1-4d887326c2d1", "metadata": {}, "outputs": [], @@ -259,22 +408,10 @@ }, { "cell_type": "code", - "execution_count": 17, + "execution_count": null, "id": "4a6dd955-aab4-40a4-97fd-0605ea7c38ee", "metadata": {}, - "outputs": [ - { - "ename": "AttributeError", - "evalue": "'yoda.core.HistoBin1D' object has no attribute 'reset'", - "output_type": "error", - "traceback": [ - "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m", - "\u001b[0;31mAttributeError\u001b[0m Traceback (most recent call last)", - "Cell \u001b[0;32mIn[17], line 2\u001b[0m\n\u001b[1;32m 1\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m b \u001b[38;5;129;01min\u001b[39;00m hh\u001b[38;5;241m.\u001b[39mbins():\n\u001b[0;32m----> 2\u001b[0m \u001b[43mb\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreset\u001b[49m()\n", - "\u001b[0;31mAttributeError\u001b[0m: 'yoda.core.HistoBin1D' object has no attribute 'reset'" - ] - } - ], + "outputs": [], "source": [ "for b in hh.bins():\n", " b.reset()" diff --git a/src/babyyoda/Histo1D_v2.py b/src/babyyoda/Histo1D_v2.py index a9f4e85..49e6cb3 100644 --- a/src/babyyoda/Histo1D_v2.py +++ b/src/babyyoda/Histo1D_v2.py @@ -62,8 +62,8 @@ def __call__(self, *args, **kwargs): # YODA compatibility code (dropped legacy code?) ######################################################## - def copy(self): - return HISTO1D_V2(self.target.copy()) + def clone(self): + return HISTO1D_V2(self.target.clone()) def overflow(self): # if target has overflow method, call it @@ -143,14 +143,14 @@ def __getitem__(self, slices): if isinstance(step, rebin): if start is None: start = 0 - cs = self.copy() + cs = self.clone() cs.rebinBy(step.factor, start, stop) return cs print(f" {start} {stop} {step}") if stop is not None: stop += 1 - sc = self.copy() + sc = self.clone() sc.rebinTo(self.xEdges()[start:stop]) return sc diff --git a/src/babyyoda/grogu/histo1d_v2.py b/src/babyyoda/grogu/histo1d_v2.py index a9bbd23..e0ab466 100644 --- a/src/babyyoda/grogu/histo1d_v2.py +++ b/src/babyyoda/grogu/histo1d_v2.py @@ -159,7 +159,7 @@ def __post_init__(self): # YODA compatibilty code ############################################ - def copy(self): + def clone(self): return GROGU_HISTO1D_V2( d_key=self.d_key, d_path=self.d_path, diff --git a/tests/grogu/uhi/test_gg_histo1d_slicing.py b/tests/grogu/uhi/test_gg_histo1d_slicing.py index 84e9038..0e4c9fc 100644 --- a/tests/grogu/uhi/test_gg_histo1d_slicing.py +++ b/tests/grogu/uhi/test_gg_histo1d_slicing.py @@ -16,16 +16,16 @@ def get_histo1d(): def test_slicing_everything(): yuhi1d = get_histo1d() - assert yuhi1d.copy() != yuhi1d - assert_histo1d(yuhi1d.copy(), yuhi1d) + assert yuhi1d.clone() != yuhi1d + assert_histo1d(yuhi1d.clone(), yuhi1d) assert yuhi1d[:] != yuhi1d assert_histo1d(yuhi1d[:], yuhi1d) - assert yuhi1d.copy()[:] != yuhi1d + assert yuhi1d.clone()[:] != yuhi1d def test_slicing_subset(): yuhi1d = get_histo1d() - assert yuhi1d.copy()[1:3] != yuhi1d + assert yuhi1d.clone()[1:3] != yuhi1d assert yuhi1d[1:3] != yuhi1d[1:3] assert_histo1d(yuhi1d[1:3], yuhi1d[1:3]) assert yuhi1d[1:3][0].sumW() == yuhi1d[1].sumW()