Spaces:
Sleeping
Sleeping
<!-- Generated by Cython 3.0.11 --> | |
<html> | |
<head> | |
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> | |
<title>Cython: processing.pyx</title> | |
<style type="text/css"> | |
body.cython { font-family: courier; font-size: 12; } | |
.cython.tag { } | |
.cython.line { color: #000000; margin: 0em } | |
.cython.code { font-size: 9; color: #444444; display: none; margin: 0px 0px 0px 8px; border-left: 8px none; } | |
.cython.line .run { background-color: #B0FFB0; } | |
.cython.line .mis { background-color: #FFB0B0; } | |
.cython.code.run { border-left: 8px solid #B0FFB0; } | |
.cython.code.mis { border-left: 8px solid #FFB0B0; } | |
.cython.code .py_c_api { color: red; } | |
.cython.code .py_macro_api { color: #FF7000; } | |
.cython.code .pyx_c_api { color: #FF3000; } | |
.cython.code .pyx_macro_api { color: #FF7000; } | |
.cython.code .refnanny { color: #FFA000; } | |
.cython.code .trace { color: #FFA000; } | |
.cython.code .error_goto { color: #FFA000; } | |
.cython.code .coerce { color: #008000; border: 1px dotted #008000 } | |
.cython.code .py_attr { color: #FF0000; font-weight: bold; } | |
.cython.code .c_attr { color: #0000FF; } | |
.cython.code .py_call { color: #FF0000; font-weight: bold; } | |
.cython.code .c_call { color: #0000FF; } | |
.cython.score-0 {background-color: #FFFFff;} | |
.cython.score-1 {background-color: #FFFFe7;} | |
.cython.score-2 {background-color: #FFFFd4;} | |
.cython.score-3 {background-color: #FFFFc4;} | |
.cython.score-4 {background-color: #FFFFb6;} | |
.cython.score-5 {background-color: #FFFFaa;} | |
.cython.score-6 {background-color: #FFFF9f;} | |
.cython.score-7 {background-color: #FFFF96;} | |
.cython.score-8 {background-color: #FFFF8d;} | |
.cython.score-9 {background-color: #FFFF86;} | |
.cython.score-10 {background-color: #FFFF7f;} | |
.cython.score-11 {background-color: #FFFF79;} | |
.cython.score-12 {background-color: #FFFF73;} | |
.cython.score-13 {background-color: #FFFF6e;} | |
.cython.score-14 {background-color: #FFFF6a;} | |
.cython.score-15 {background-color: #FFFF66;} | |
.cython.score-16 {background-color: #FFFF62;} | |
.cython.score-17 {background-color: #FFFF5e;} | |
.cython.score-18 {background-color: #FFFF5b;} | |
.cython.score-19 {background-color: #FFFF57;} | |
.cython.score-20 {background-color: #FFFF55;} | |
.cython.score-21 {background-color: #FFFF52;} | |
.cython.score-22 {background-color: #FFFF4f;} | |
.cython.score-23 {background-color: #FFFF4d;} | |
.cython.score-24 {background-color: #FFFF4b;} | |
.cython.score-25 {background-color: #FFFF48;} | |
.cython.score-26 {background-color: #FFFF46;} | |
.cython.score-27 {background-color: #FFFF44;} | |
.cython.score-28 {background-color: #FFFF43;} | |
.cython.score-29 {background-color: #FFFF41;} | |
.cython.score-30 {background-color: #FFFF3f;} | |
.cython.score-31 {background-color: #FFFF3e;} | |
.cython.score-32 {background-color: #FFFF3c;} | |
.cython.score-33 {background-color: #FFFF3b;} | |
.cython.score-34 {background-color: #FFFF39;} | |
.cython.score-35 {background-color: #FFFF38;} | |
.cython.score-36 {background-color: #FFFF37;} | |
.cython.score-37 {background-color: #FFFF36;} | |
.cython.score-38 {background-color: #FFFF35;} | |
.cython.score-39 {background-color: #FFFF34;} | |
.cython.score-40 {background-color: #FFFF33;} | |
.cython.score-41 {background-color: #FFFF32;} | |
.cython.score-42 {background-color: #FFFF31;} | |
.cython.score-43 {background-color: #FFFF30;} | |
.cython.score-44 {background-color: #FFFF2f;} | |
.cython.score-45 {background-color: #FFFF2e;} | |
.cython.score-46 {background-color: #FFFF2d;} | |
.cython.score-47 {background-color: #FFFF2c;} | |
.cython.score-48 {background-color: #FFFF2b;} | |
.cython.score-49 {background-color: #FFFF2b;} | |
.cython.score-50 {background-color: #FFFF2a;} | |
.cython.score-51 {background-color: #FFFF29;} | |
.cython.score-52 {background-color: #FFFF29;} | |
.cython.score-53 {background-color: #FFFF28;} | |
.cython.score-54 {background-color: #FFFF27;} | |
.cython.score-55 {background-color: #FFFF27;} | |
.cython.score-56 {background-color: #FFFF26;} | |
.cython.score-57 {background-color: #FFFF26;} | |
.cython.score-58 {background-color: #FFFF25;} | |
.cython.score-59 {background-color: #FFFF24;} | |
.cython.score-60 {background-color: #FFFF24;} | |
.cython.score-61 {background-color: #FFFF23;} | |
.cython.score-62 {background-color: #FFFF23;} | |
.cython.score-63 {background-color: #FFFF22;} | |
.cython.score-64 {background-color: #FFFF22;} | |
.cython.score-65 {background-color: #FFFF22;} | |
.cython.score-66 {background-color: #FFFF21;} | |
.cython.score-67 {background-color: #FFFF21;} | |
.cython.score-68 {background-color: #FFFF20;} | |
.cython.score-69 {background-color: #FFFF20;} | |
.cython.score-70 {background-color: #FFFF1f;} | |
.cython.score-71 {background-color: #FFFF1f;} | |
.cython.score-72 {background-color: #FFFF1f;} | |
.cython.score-73 {background-color: #FFFF1e;} | |
.cython.score-74 {background-color: #FFFF1e;} | |
.cython.score-75 {background-color: #FFFF1e;} | |
.cython.score-76 {background-color: #FFFF1d;} | |
.cython.score-77 {background-color: #FFFF1d;} | |
.cython.score-78 {background-color: #FFFF1c;} | |
.cython.score-79 {background-color: #FFFF1c;} | |
.cython.score-80 {background-color: #FFFF1c;} | |
.cython.score-81 {background-color: #FFFF1c;} | |
.cython.score-82 {background-color: #FFFF1b;} | |
.cython.score-83 {background-color: #FFFF1b;} | |
.cython.score-84 {background-color: #FFFF1b;} | |
.cython.score-85 {background-color: #FFFF1a;} | |
.cython.score-86 {background-color: #FFFF1a;} | |
.cython.score-87 {background-color: #FFFF1a;} | |
.cython.score-88 {background-color: #FFFF1a;} | |
.cython.score-89 {background-color: #FFFF19;} | |
.cython.score-90 {background-color: #FFFF19;} | |
.cython.score-91 {background-color: #FFFF19;} | |
.cython.score-92 {background-color: #FFFF19;} | |
.cython.score-93 {background-color: #FFFF18;} | |
.cython.score-94 {background-color: #FFFF18;} | |
.cython.score-95 {background-color: #FFFF18;} | |
.cython.score-96 {background-color: #FFFF18;} | |
.cython.score-97 {background-color: #FFFF17;} | |
.cython.score-98 {background-color: #FFFF17;} | |
.cython.score-99 {background-color: #FFFF17;} | |
.cython.score-100 {background-color: #FFFF17;} | |
.cython.score-101 {background-color: #FFFF16;} | |
.cython.score-102 {background-color: #FFFF16;} | |
.cython.score-103 {background-color: #FFFF16;} | |
.cython.score-104 {background-color: #FFFF16;} | |
.cython.score-105 {background-color: #FFFF16;} | |
.cython.score-106 {background-color: #FFFF15;} | |
.cython.score-107 {background-color: #FFFF15;} | |
.cython.score-108 {background-color: #FFFF15;} | |
.cython.score-109 {background-color: #FFFF15;} | |
.cython.score-110 {background-color: #FFFF15;} | |
.cython.score-111 {background-color: #FFFF15;} | |
.cython.score-112 {background-color: #FFFF14;} | |
.cython.score-113 {background-color: #FFFF14;} | |
.cython.score-114 {background-color: #FFFF14;} | |
.cython.score-115 {background-color: #FFFF14;} | |
.cython.score-116 {background-color: #FFFF14;} | |
.cython.score-117 {background-color: #FFFF14;} | |
.cython.score-118 {background-color: #FFFF13;} | |
.cython.score-119 {background-color: #FFFF13;} | |
.cython.score-120 {background-color: #FFFF13;} | |
.cython.score-121 {background-color: #FFFF13;} | |
.cython.score-122 {background-color: #FFFF13;} | |
.cython.score-123 {background-color: #FFFF13;} | |
.cython.score-124 {background-color: #FFFF13;} | |
.cython.score-125 {background-color: #FFFF12;} | |
.cython.score-126 {background-color: #FFFF12;} | |
.cython.score-127 {background-color: #FFFF12;} | |
.cython.score-128 {background-color: #FFFF12;} | |
.cython.score-129 {background-color: #FFFF12;} | |
.cython.score-130 {background-color: #FFFF12;} | |
.cython.score-131 {background-color: #FFFF12;} | |
.cython.score-132 {background-color: #FFFF11;} | |
.cython.score-133 {background-color: #FFFF11;} | |
.cython.score-134 {background-color: #FFFF11;} | |
.cython.score-135 {background-color: #FFFF11;} | |
.cython.score-136 {background-color: #FFFF11;} | |
.cython.score-137 {background-color: #FFFF11;} | |
.cython.score-138 {background-color: #FFFF11;} | |
.cython.score-139 {background-color: #FFFF11;} | |
.cython.score-140 {background-color: #FFFF11;} | |
.cython.score-141 {background-color: #FFFF10;} | |
.cython.score-142 {background-color: #FFFF10;} | |
.cython.score-143 {background-color: #FFFF10;} | |
.cython.score-144 {background-color: #FFFF10;} | |
.cython.score-145 {background-color: #FFFF10;} | |
.cython.score-146 {background-color: #FFFF10;} | |
.cython.score-147 {background-color: #FFFF10;} | |
.cython.score-148 {background-color: #FFFF10;} | |
.cython.score-149 {background-color: #FFFF10;} | |
.cython.score-150 {background-color: #FFFF0f;} | |
.cython.score-151 {background-color: #FFFF0f;} | |
.cython.score-152 {background-color: #FFFF0f;} | |
.cython.score-153 {background-color: #FFFF0f;} | |
.cython.score-154 {background-color: #FFFF0f;} | |
.cython.score-155 {background-color: #FFFF0f;} | |
.cython.score-156 {background-color: #FFFF0f;} | |
.cython.score-157 {background-color: #FFFF0f;} | |
.cython.score-158 {background-color: #FFFF0f;} | |
.cython.score-159 {background-color: #FFFF0f;} | |
.cython.score-160 {background-color: #FFFF0f;} | |
.cython.score-161 {background-color: #FFFF0e;} | |
.cython.score-162 {background-color: #FFFF0e;} | |
.cython.score-163 {background-color: #FFFF0e;} | |
.cython.score-164 {background-color: #FFFF0e;} | |
.cython.score-165 {background-color: #FFFF0e;} | |
.cython.score-166 {background-color: #FFFF0e;} | |
.cython.score-167 {background-color: #FFFF0e;} | |
.cython.score-168 {background-color: #FFFF0e;} | |
.cython.score-169 {background-color: #FFFF0e;} | |
.cython.score-170 {background-color: #FFFF0e;} | |
.cython.score-171 {background-color: #FFFF0e;} | |
.cython.score-172 {background-color: #FFFF0e;} | |
.cython.score-173 {background-color: #FFFF0d;} | |
.cython.score-174 {background-color: #FFFF0d;} | |
.cython.score-175 {background-color: #FFFF0d;} | |
.cython.score-176 {background-color: #FFFF0d;} | |
.cython.score-177 {background-color: #FFFF0d;} | |
.cython.score-178 {background-color: #FFFF0d;} | |
.cython.score-179 {background-color: #FFFF0d;} | |
.cython.score-180 {background-color: #FFFF0d;} | |
.cython.score-181 {background-color: #FFFF0d;} | |
.cython.score-182 {background-color: #FFFF0d;} | |
.cython.score-183 {background-color: #FFFF0d;} | |
.cython.score-184 {background-color: #FFFF0d;} | |
.cython.score-185 {background-color: #FFFF0d;} | |
.cython.score-186 {background-color: #FFFF0d;} | |
.cython.score-187 {background-color: #FFFF0c;} | |
.cython.score-188 {background-color: #FFFF0c;} | |
.cython.score-189 {background-color: #FFFF0c;} | |
.cython.score-190 {background-color: #FFFF0c;} | |
.cython.score-191 {background-color: #FFFF0c;} | |
.cython.score-192 {background-color: #FFFF0c;} | |
.cython.score-193 {background-color: #FFFF0c;} | |
.cython.score-194 {background-color: #FFFF0c;} | |
.cython.score-195 {background-color: #FFFF0c;} | |
.cython.score-196 {background-color: #FFFF0c;} | |
.cython.score-197 {background-color: #FFFF0c;} | |
.cython.score-198 {background-color: #FFFF0c;} | |
.cython.score-199 {background-color: #FFFF0c;} | |
.cython.score-200 {background-color: #FFFF0c;} | |
.cython.score-201 {background-color: #FFFF0c;} | |
.cython.score-202 {background-color: #FFFF0c;} | |
.cython.score-203 {background-color: #FFFF0b;} | |
.cython.score-204 {background-color: #FFFF0b;} | |
.cython.score-205 {background-color: #FFFF0b;} | |
.cython.score-206 {background-color: #FFFF0b;} | |
.cython.score-207 {background-color: #FFFF0b;} | |
.cython.score-208 {background-color: #FFFF0b;} | |
.cython.score-209 {background-color: #FFFF0b;} | |
.cython.score-210 {background-color: #FFFF0b;} | |
.cython.score-211 {background-color: #FFFF0b;} | |
.cython.score-212 {background-color: #FFFF0b;} | |
.cython.score-213 {background-color: #FFFF0b;} | |
.cython.score-214 {background-color: #FFFF0b;} | |
.cython.score-215 {background-color: #FFFF0b;} | |
.cython.score-216 {background-color: #FFFF0b;} | |
.cython.score-217 {background-color: #FFFF0b;} | |
.cython.score-218 {background-color: #FFFF0b;} | |
.cython.score-219 {background-color: #FFFF0b;} | |
.cython.score-220 {background-color: #FFFF0b;} | |
.cython.score-221 {background-color: #FFFF0b;} | |
.cython.score-222 {background-color: #FFFF0a;} | |
.cython.score-223 {background-color: #FFFF0a;} | |
.cython.score-224 {background-color: #FFFF0a;} | |
.cython.score-225 {background-color: #FFFF0a;} | |
.cython.score-226 {background-color: #FFFF0a;} | |
.cython.score-227 {background-color: #FFFF0a;} | |
.cython.score-228 {background-color: #FFFF0a;} | |
.cython.score-229 {background-color: #FFFF0a;} | |
.cython.score-230 {background-color: #FFFF0a;} | |
.cython.score-231 {background-color: #FFFF0a;} | |
.cython.score-232 {background-color: #FFFF0a;} | |
.cython.score-233 {background-color: #FFFF0a;} | |
.cython.score-234 {background-color: #FFFF0a;} | |
.cython.score-235 {background-color: #FFFF0a;} | |
.cython.score-236 {background-color: #FFFF0a;} | |
.cython.score-237 {background-color: #FFFF0a;} | |
.cython.score-238 {background-color: #FFFF0a;} | |
.cython.score-239 {background-color: #FFFF0a;} | |
.cython.score-240 {background-color: #FFFF0a;} | |
.cython.score-241 {background-color: #FFFF0a;} | |
.cython.score-242 {background-color: #FFFF0a;} | |
.cython.score-243 {background-color: #FFFF0a;} | |
.cython.score-244 {background-color: #FFFF0a;} | |
.cython.score-245 {background-color: #FFFF0a;} | |
.cython.score-246 {background-color: #FFFF09;} | |
.cython.score-247 {background-color: #FFFF09;} | |
.cython.score-248 {background-color: #FFFF09;} | |
.cython.score-249 {background-color: #FFFF09;} | |
.cython.score-250 {background-color: #FFFF09;} | |
.cython.score-251 {background-color: #FFFF09;} | |
.cython.score-252 {background-color: #FFFF09;} | |
.cython.score-253 {background-color: #FFFF09;} | |
.cython.score-254 {background-color: #FFFF09;} | |
pre { line-height: 125%; } | |
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } | |
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } | |
td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } | |
span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } | |
.cython .hll { background-color: #ffffcc } | |
.cython { background: #f8f8f8; } | |
.cython .c { color: #3D7B7B; font-style: italic } /* Comment */ | |
.cython .err { border: 1px solid #FF0000 } /* Error */ | |
.cython .k { color: #008000; font-weight: bold } /* Keyword */ | |
.cython .o { color: #666666 } /* Operator */ | |
.cython .ch { color: #3D7B7B; font-style: italic } /* Comment.Hashbang */ | |
.cython .cm { color: #3D7B7B; font-style: italic } /* Comment.Multiline */ | |
.cython .cp { color: #9C6500 } /* Comment.Preproc */ | |
.cython .cpf { color: #3D7B7B; font-style: italic } /* Comment.PreprocFile */ | |
.cython .c1 { color: #3D7B7B; font-style: italic } /* Comment.Single */ | |
.cython .cs { color: #3D7B7B; font-style: italic } /* Comment.Special */ | |
.cython .gd { color: #A00000 } /* Generic.Deleted */ | |
.cython .ge { font-style: italic } /* Generic.Emph */ | |
.cython .gr { color: #E40000 } /* Generic.Error */ | |
.cython .gh { color: #000080; font-weight: bold } /* Generic.Heading */ | |
.cython .gi { color: #008400 } /* Generic.Inserted */ | |
.cython .go { color: #717171 } /* Generic.Output */ | |
.cython .gp { color: #000080; font-weight: bold } /* Generic.Prompt */ | |
.cython .gs { font-weight: bold } /* Generic.Strong */ | |
.cython .gu { color: #800080; font-weight: bold } /* Generic.Subheading */ | |
.cython .gt { color: #0044DD } /* Generic.Traceback */ | |
.cython .kc { color: #008000; font-weight: bold } /* Keyword.Constant */ | |
.cython .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */ | |
.cython .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */ | |
.cython .kp { color: #008000 } /* Keyword.Pseudo */ | |
.cython .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */ | |
.cython .kt { color: #B00040 } /* Keyword.Type */ | |
.cython .m { color: #666666 } /* Literal.Number */ | |
.cython .s { color: #BA2121 } /* Literal.String */ | |
.cython .na { color: #687822 } /* Name.Attribute */ | |
.cython .nb { color: #008000 } /* Name.Builtin */ | |
.cython .nc { color: #0000FF; font-weight: bold } /* Name.Class */ | |
.cython .no { color: #880000 } /* Name.Constant */ | |
.cython .nd { color: #AA22FF } /* Name.Decorator */ | |
.cython .ni { color: #717171; font-weight: bold } /* Name.Entity */ | |
.cython .ne { color: #CB3F38; font-weight: bold } /* Name.Exception */ | |
.cython .nf { color: #0000FF } /* Name.Function */ | |
.cython .nl { color: #767600 } /* Name.Label */ | |
.cython .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */ | |
.cython .nt { color: #008000; font-weight: bold } /* Name.Tag */ | |
.cython .nv { color: #19177C } /* Name.Variable */ | |
.cython .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */ | |
.cython .w { color: #bbbbbb } /* Text.Whitespace */ | |
.cython .mb { color: #666666 } /* Literal.Number.Bin */ | |
.cython .mf { color: #666666 } /* Literal.Number.Float */ | |
.cython .mh { color: #666666 } /* Literal.Number.Hex */ | |
.cython .mi { color: #666666 } /* Literal.Number.Integer */ | |
.cython .mo { color: #666666 } /* Literal.Number.Oct */ | |
.cython .sa { color: #BA2121 } /* Literal.String.Affix */ | |
.cython .sb { color: #BA2121 } /* Literal.String.Backtick */ | |
.cython .sc { color: #BA2121 } /* Literal.String.Char */ | |
.cython .dl { color: #BA2121 } /* Literal.String.Delimiter */ | |
.cython .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */ | |
.cython .s2 { color: #BA2121 } /* Literal.String.Double */ | |
.cython .se { color: #AA5D1F; font-weight: bold } /* Literal.String.Escape */ | |
.cython .sh { color: #BA2121 } /* Literal.String.Heredoc */ | |
.cython .si { color: #A45A77; font-weight: bold } /* Literal.String.Interpol */ | |
.cython .sx { color: #008000 } /* Literal.String.Other */ | |
.cython .sr { color: #A45A77 } /* Literal.String.Regex */ | |
.cython .s1 { color: #BA2121 } /* Literal.String.Single */ | |
.cython .ss { color: #19177C } /* Literal.String.Symbol */ | |
.cython .bp { color: #008000 } /* Name.Builtin.Pseudo */ | |
.cython .fm { color: #0000FF } /* Name.Function.Magic */ | |
.cython .vc { color: #19177C } /* Name.Variable.Class */ | |
.cython .vg { color: #19177C } /* Name.Variable.Global */ | |
.cython .vi { color: #19177C } /* Name.Variable.Instance */ | |
.cython .vm { color: #19177C } /* Name.Variable.Magic */ | |
.cython .il { color: #666666 } /* Literal.Number.Integer.Long */ | |
</style> | |
</head> | |
<body class="cython"> | |
<p><span style="border-bottom: solid 1px grey;">Generated by Cython 3.0.11</span></p> | |
<p> | |
<span style="background-color: #FFFF00">Yellow lines</span> hint at Python interaction.<br /> | |
Click on a line that starts with a "<code>+</code>" to see the C code that Cython generated for it. | |
</p> | |
<p>Raw output: <a href="processing.c">processing.c</a></p> | |
<div class="cython"><pre class="cython line score-8" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">001</span>: <span class="c"># File: processing.pyx</span></pre> | |
<pre class='cython code score-8 '> __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(0);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2); | |
if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_d, __pyx_n_s_test, __pyx_t_2) < 0) <span class='error_goto'>__PYX_ERR(0, 1, __pyx_L1_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0; | |
</pre><pre class="cython line score-0"> <span class="">002</span>: <span class="c"># cython: language_level=3, boundscheck=False, wraparound=False, nonecheck=False, cdivision=True</span></pre> | |
<pre class="cython line score-0"> <span class="">003</span>: </pre> | |
<pre class="cython line score-8" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">004</span>: <span class="k">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span></pre> | |
<pre class='cython code score-8 '> __pyx_t_2 = <span class='pyx_c_api'>__Pyx_ImportDottedModule</span>(__pyx_n_s_numpy, NULL);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 4, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2); | |
if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_d, __pyx_n_s_np, __pyx_t_2) < 0) <span class='error_goto'>__PYX_ERR(0, 4, __pyx_L1_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0; | |
</pre><pre class="cython line score-0"> <span class="">005</span>: <span class="k">cimport</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span></pre> | |
<pre class="cython line score-8" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">006</span>: <span class="k">import</span> <span class="nn">pandas</span> <span class="k">as</span> <span class="nn">pd</span></pre> | |
<pre class='cython code score-8 '> __pyx_t_2 = <span class='pyx_c_api'>__Pyx_ImportDottedModule</span>(__pyx_n_s_pandas, NULL);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2); | |
if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_d, __pyx_n_s_pd, __pyx_t_2) < 0) <span class='error_goto'>__PYX_ERR(0, 6, __pyx_L1_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0; | |
</pre><pre class="cython line score-0"> <span class="">007</span>: <span class="k">cimport</span> <span class="nn">pandas</span> <span class="k">as</span> <span class="nn">pd</span></pre> | |
<pre class="cython line score-0"> <span class="">008</span>: <span class="k">from</span> <span class="nn">libc.math</span> <span class="k">cimport</span> <span class="n">isnan</span></pre> | |
<pre class="cython line score-0"> <span class="">009</span>: <span class="k">from</span> <span class="nn">cpython.mem</span> <span class="k">cimport</span> <span class="n">PyMem_Malloc</span><span class="p">,</span> <span class="n">PyMem_Free</span></pre> | |
<pre class="cython line score-0"> <span class="">010</span>: </pre> | |
<pre class="cython line score-0"> <span class="">011</span>: <span class="c"># Define C types for better performance</span></pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">012</span>: <span class="k">ctypedef</span> <span class="n">np</span><span class="o">.</span><span class="n">float32_t</span> <span class="n">DTYPE_t</span></pre> | |
<pre class='cython code score-0 '>typedef __pyx_t_5numpy_float32_t __pyx_t_13processing_cy_DTYPE_t; | |
</pre><pre class="cython line score-0"> <span class="">013</span>: <span class="k">ctypedef</span> <span class="n">np</span><span class="o">.</span><span class="n">int32_t</span> <span class="n">ITYPE_t</span></pre> | |
<pre class="cython line score-0"> <span class="">014</span>: </pre> | |
<pre class="cython line score-162" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">015</span>: <span class="k">def</span> <span class="nf">process_bbox_depth_cy</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">ndarray</span><span class="p">[</span><span class="n">DTYPE_t</span><span class="p">,</span> <span class="n">ndim</span><span class="o">=</span><span class="mf">2</span><span class="p">]</span> <span class="n">depth_map</span><span class="p">,</span></pre> | |
<pre class='cython code score-162 '>/* Python wrapper */ | |
static PyObject *__pyx_pw_13processing_cy_1process_bbox_depth_cy(PyObject *__pyx_self, | |
#if CYTHON_METH_FASTCALL | |
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds | |
#else | |
PyObject *__pyx_args, PyObject *__pyx_kwds | |
#endif | |
); /*proto*/ | |
<span class='py_macro_api'>PyDoc_STRVAR</span>(__pyx_doc_13processing_cy_process_bbox_depth_cy, "\n Optimized bbox depth calculations using Cython\n "); | |
static PyMethodDef __pyx_mdef_13processing_cy_1process_bbox_depth_cy = {"process_bbox_depth_cy", (PyCFunction)(void*)(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_13processing_cy_1process_bbox_depth_cy, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_13processing_cy_process_bbox_depth_cy}; | |
static PyObject *__pyx_pw_13processing_cy_1process_bbox_depth_cy(PyObject *__pyx_self, | |
#if CYTHON_METH_FASTCALL | |
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds | |
#else | |
PyObject *__pyx_args, PyObject *__pyx_kwds | |
#endif | |
) { | |
PyArrayObject *__pyx_v_depth_map = 0; | |
int __pyx_v_y_min; | |
int __pyx_v_y_max; | |
int __pyx_v_x_min; | |
int __pyx_v_x_max; | |
#if !CYTHON_METH_FASTCALL | |
CYTHON_UNUSED Py_ssize_t __pyx_nargs; | |
#endif | |
CYTHON_UNUSED PyObject *const *__pyx_kwvalues; | |
PyObject *__pyx_r = 0; | |
<span class='refnanny'>__Pyx_RefNannyDeclarations</span> | |
<span class='refnanny'>__Pyx_RefNannySetupContext</span>("process_bbox_depth_cy (wrapper)", 0); | |
#if !CYTHON_METH_FASTCALL | |
#if CYTHON_ASSUME_SAFE_MACROS | |
__pyx_nargs = <span class='py_macro_api'>PyTuple_GET_SIZE</span>(__pyx_args); | |
#else | |
__pyx_nargs = <span class='py_c_api'>PyTuple_Size</span>(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; | |
#endif | |
#endif | |
__pyx_kwvalues = <span class='pyx_c_api'>__Pyx_KwValues_FASTCALL</span>(__pyx_args, __pyx_nargs); | |
{ | |
PyObject **__pyx_pyargnames[] = {&__pyx_n_s_depth_map,&__pyx_n_s_y_min,&__pyx_n_s_y_max,&__pyx_n_s_x_min,&__pyx_n_s_x_max,0}; | |
PyObject* values[5] = {0,0,0,0,0}; | |
if (__pyx_kwds) { | |
Py_ssize_t kw_args; | |
switch (__pyx_nargs) { | |
case 5: values[4] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 4); | |
CYTHON_FALLTHROUGH; | |
case 4: values[3] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 3); | |
CYTHON_FALLTHROUGH; | |
case 3: values[2] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 2); | |
CYTHON_FALLTHROUGH; | |
case 2: values[1] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 1); | |
CYTHON_FALLTHROUGH; | |
case 1: values[0] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 0); | |
CYTHON_FALLTHROUGH; | |
case 0: break; | |
default: goto __pyx_L5_argtuple_error; | |
} | |
kw_args = <span class='pyx_c_api'>__Pyx_NumKwargs_FASTCALL</span>(__pyx_kwds); | |
switch (__pyx_nargs) { | |
case 0: | |
if (likely((values[0] = <span class='pyx_c_api'>__Pyx_GetKwValue_FASTCALL</span>(__pyx_kwds, __pyx_kwvalues, __pyx_n_s_depth_map)) != 0)) { | |
(void)<span class='pyx_c_api'>__Pyx_Arg_NewRef_FASTCALL</span>(values[0]); | |
kw_args--; | |
} | |
else if (unlikely(<span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
else goto __pyx_L5_argtuple_error; | |
CYTHON_FALLTHROUGH; | |
case 1: | |
if (likely((values[1] = <span class='pyx_c_api'>__Pyx_GetKwValue_FASTCALL</span>(__pyx_kwds, __pyx_kwvalues, __pyx_n_s_y_min)) != 0)) { | |
(void)<span class='pyx_c_api'>__Pyx_Arg_NewRef_FASTCALL</span>(values[1]); | |
kw_args--; | |
} | |
else if (unlikely(<span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
else { | |
<span class='pyx_c_api'>__Pyx_RaiseArgtupleInvalid</span>("process_bbox_depth_cy", 1, 5, 5, 1); <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
} | |
CYTHON_FALLTHROUGH; | |
case 2: | |
if (likely((values[2] = <span class='pyx_c_api'>__Pyx_GetKwValue_FASTCALL</span>(__pyx_kwds, __pyx_kwvalues, __pyx_n_s_y_max)) != 0)) { | |
(void)<span class='pyx_c_api'>__Pyx_Arg_NewRef_FASTCALL</span>(values[2]); | |
kw_args--; | |
} | |
else if (unlikely(<span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
else { | |
<span class='pyx_c_api'>__Pyx_RaiseArgtupleInvalid</span>("process_bbox_depth_cy", 1, 5, 5, 2); <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
} | |
CYTHON_FALLTHROUGH; | |
case 3: | |
if (likely((values[3] = <span class='pyx_c_api'>__Pyx_GetKwValue_FASTCALL</span>(__pyx_kwds, __pyx_kwvalues, __pyx_n_s_x_min)) != 0)) { | |
(void)<span class='pyx_c_api'>__Pyx_Arg_NewRef_FASTCALL</span>(values[3]); | |
kw_args--; | |
} | |
else if (unlikely(<span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
else { | |
<span class='pyx_c_api'>__Pyx_RaiseArgtupleInvalid</span>("process_bbox_depth_cy", 1, 5, 5, 3); <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
} | |
CYTHON_FALLTHROUGH; | |
case 4: | |
if (likely((values[4] = <span class='pyx_c_api'>__Pyx_GetKwValue_FASTCALL</span>(__pyx_kwds, __pyx_kwvalues, __pyx_n_s_x_max)) != 0)) { | |
(void)<span class='pyx_c_api'>__Pyx_Arg_NewRef_FASTCALL</span>(values[4]); | |
kw_args--; | |
} | |
else if (unlikely(<span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
else { | |
<span class='pyx_c_api'>__Pyx_RaiseArgtupleInvalid</span>("process_bbox_depth_cy", 1, 5, 5, 4); <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
} | |
} | |
if (unlikely(kw_args > 0)) { | |
const Py_ssize_t kwd_pos_args = __pyx_nargs; | |
if (unlikely(<span class='pyx_c_api'>__Pyx_ParseOptionalKeywords</span>(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values + 0, kwd_pos_args, "process_bbox_depth_cy") < 0)) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
} | |
} else if (unlikely(__pyx_nargs != 5)) { | |
goto __pyx_L5_argtuple_error; | |
} else { | |
values[0] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 0); | |
values[1] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 1); | |
values[2] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 2); | |
values[3] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 3); | |
values[4] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 4); | |
} | |
__pyx_v_depth_map = ((PyArrayObject *)values[0]); | |
__pyx_v_y_min = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(values[1]); if (unlikely((__pyx_v_y_min == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 16, __pyx_L3_error)</span> | |
__pyx_v_y_max = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(values[2]); if (unlikely((__pyx_v_y_max == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 16, __pyx_L3_error)</span> | |
__pyx_v_x_min = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(values[3]); if (unlikely((__pyx_v_x_min == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 16, __pyx_L3_error)</span> | |
__pyx_v_x_max = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(values[4]); if (unlikely((__pyx_v_x_max == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 16, __pyx_L3_error)</span> | |
} | |
goto __pyx_L6_skip; | |
__pyx_L5_argtuple_error:; | |
<span class='pyx_c_api'>__Pyx_RaiseArgtupleInvalid</span>("process_bbox_depth_cy", 1, 5, 5, __pyx_nargs); <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L3_error)</span> | |
__pyx_L6_skip:; | |
goto __pyx_L4_argument_unpacking_done; | |
__pyx_L3_error:; | |
{ | |
Py_ssize_t __pyx_temp; | |
for (__pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { | |
<span class='pyx_c_api'>__Pyx_Arg_XDECREF_FASTCALL</span>(values[__pyx_temp]); | |
} | |
} | |
<span class='pyx_c_api'>__Pyx_AddTraceback</span>("processing_cy.process_bbox_depth_cy", __pyx_clineno, __pyx_lineno, __pyx_filename); | |
<span class='refnanny'>__Pyx_RefNannyFinishContext</span>(); | |
return NULL; | |
__pyx_L4_argument_unpacking_done:; | |
if (unlikely(!<span class='pyx_c_api'>__Pyx_ArgTypeTest</span>(((PyObject *)__pyx_v_depth_map), __pyx_ptype_5numpy_ndarray, 1, "depth_map", 0))) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L1_error)</span> | |
__pyx_r = __pyx_pf_13processing_cy_process_bbox_depth_cy(__pyx_self, __pyx_v_depth_map, __pyx_v_y_min, __pyx_v_y_max, __pyx_v_x_min, __pyx_v_x_max); | |
int __pyx_lineno = 0; | |
const char *__pyx_filename = NULL; | |
int __pyx_clineno = 0; | |
/* function exit code */ | |
goto __pyx_L0; | |
__pyx_L1_error:; | |
__pyx_r = NULL; | |
__pyx_L0:; | |
{ | |
Py_ssize_t __pyx_temp; | |
for (__pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { | |
<span class='pyx_c_api'>__Pyx_Arg_XDECREF_FASTCALL</span>(values[__pyx_temp]); | |
} | |
} | |
<span class='refnanny'>__Pyx_RefNannyFinishContext</span>(); | |
return __pyx_r; | |
} | |
static PyObject *__pyx_pf_13processing_cy_process_bbox_depth_cy(CYTHON_UNUSED PyObject *__pyx_self, PyArrayObject *__pyx_v_depth_map, int __pyx_v_y_min, int __pyx_v_y_max, int __pyx_v_x_min, int __pyx_v_x_max) { | |
int __pyx_v_i; | |
int __pyx_v_j; | |
int __pyx_v_count; | |
double __pyx_v_sum_val; | |
double __pyx_v_mean_val; | |
PyArrayObject *__pyx_v_flat_vals = 0; | |
int __pyx_v_flat_size; | |
__Pyx_LocalBuf_ND __pyx_pybuffernd_depth_map; | |
__Pyx_Buffer __pyx_pybuffer_depth_map; | |
__Pyx_LocalBuf_ND __pyx_pybuffernd_flat_vals; | |
__Pyx_Buffer __pyx_pybuffer_flat_vals; | |
PyObject *__pyx_r = NULL; | |
__pyx_pybuffer_flat_vals.pybuffer.buf = NULL; | |
__pyx_pybuffer_flat_vals.refcount = 0; | |
__pyx_pybuffernd_flat_vals.data = NULL; | |
__pyx_pybuffernd_flat_vals.rcbuffer = &__pyx_pybuffer_flat_vals; | |
__pyx_pybuffer_depth_map.pybuffer.buf = NULL; | |
__pyx_pybuffer_depth_map.refcount = 0; | |
__pyx_pybuffernd_depth_map.data = NULL; | |
__pyx_pybuffernd_depth_map.rcbuffer = &__pyx_pybuffer_depth_map; | |
{ | |
__Pyx_BufFmt_StackElem __pyx_stack[1]; | |
if (unlikely(<span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&__pyx_pybuffernd_depth_map.rcbuffer->pybuffer, (PyObject*)__pyx_v_depth_map, &__Pyx_TypeInfo_nn___pyx_t_13processing_cy_DTYPE_t, PyBUF_FORMAT| PyBUF_STRIDES, 2, 0, __pyx_stack) == -1)) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L1_error)</span> | |
} | |
__pyx_pybuffernd_depth_map.diminfo[0].strides = __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.strides[0]; __pyx_pybuffernd_depth_map.diminfo[0].shape = __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.shape[0]; __pyx_pybuffernd_depth_map.diminfo[1].strides = __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.strides[1]; __pyx_pybuffernd_depth_map.diminfo[1].shape = __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.shape[1]; | |
/* … */ | |
/* function exit code */ | |
__pyx_L1_error:; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_10); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_11); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_12); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_13); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_14); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_21); | |
{ PyObject *__pyx_type, *__pyx_value, *__pyx_tb; | |
__Pyx_PyThreadState_declare | |
__Pyx_PyThreadState_assign | |
<span class='pyx_c_api'>__Pyx_ErrFetch</span>(&__pyx_type, &__pyx_value, &__pyx_tb); | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_depth_map.rcbuffer->pybuffer); | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_flat_vals.rcbuffer->pybuffer); | |
<span class='pyx_c_api'>__Pyx_ErrRestore</span>(__pyx_type, __pyx_value, __pyx_tb);} | |
<span class='pyx_c_api'>__Pyx_AddTraceback</span>("processing_cy.process_bbox_depth_cy", __pyx_clineno, __pyx_lineno, __pyx_filename); | |
__pyx_r = NULL; | |
goto __pyx_L2; | |
__pyx_L0:; | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_depth_map.rcbuffer->pybuffer); | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_flat_vals.rcbuffer->pybuffer); | |
__pyx_L2:; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_flat_vals); | |
<span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_r); | |
<span class='refnanny'>__Pyx_RefNannyFinishContext</span>(); | |
return __pyx_r; | |
} | |
/* … */ | |
__pyx_tuple__4 = <span class='py_c_api'>PyTuple_Pack</span>(12, __pyx_n_s_depth_map, __pyx_n_s_y_min, __pyx_n_s_y_max, __pyx_n_s_x_min, __pyx_n_s_x_max, __pyx_n_s_i, __pyx_n_s_j, __pyx_n_s_count, __pyx_n_s_sum_val, __pyx_n_s_mean_val, __pyx_n_s_flat_vals, __pyx_n_s_flat_size);<span class='error_goto'> if (unlikely(!__pyx_tuple__4)) __PYX_ERR(0, 15, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_tuple__4); | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_tuple__4); | |
/* … */ | |
__pyx_t_2 = <span class='pyx_c_api'>__Pyx_CyFunction_New</span>(&__pyx_mdef_13processing_cy_1process_bbox_depth_cy, 0, __pyx_n_s_process_bbox_depth_cy, NULL, __pyx_n_s_processing_cy, __pyx_d, ((PyObject *)__pyx_codeobj__5));<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 15, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2); | |
if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_d, __pyx_n_s_process_bbox_depth_cy, __pyx_t_2) < 0) <span class='error_goto'>__PYX_ERR(0, 15, __pyx_L1_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0; | |
__pyx_codeobj__5 = (PyObject*)<span class='pyx_c_api'>__Pyx_PyCode_New</span>(5, 0, 0, 12, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__4, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_processing_pyx, __pyx_n_s_process_bbox_depth_cy, 15, __pyx_empty_bytes);<span class='error_goto'> if (unlikely(!__pyx_codeobj__5)) __PYX_ERR(0, 15, __pyx_L1_error)</span> | |
</pre><pre class="cython line score-0"> <span class="">016</span>: <span class="nb">int</span> <span class="n">y_min</span><span class="p">,</span> <span class="nb">int</span> <span class="n">y_max</span><span class="p">,</span> <span class="nb">int</span> <span class="n">x_min</span><span class="p">,</span> <span class="nb">int</span> <span class="n">x_max</span><span class="p">):</span></pre> | |
<pre class="cython line score-0"> <span class="">017</span>: <span class="w"> </span><span class="sd">"""</span></pre> | |
<pre class="cython line score-0"> <span class="">018</span>: <span class="sd"> Optimized bbox depth calculations using Cython</span></pre> | |
<pre class="cython line score-0"> <span class="">019</span>: <span class="sd"> """</span></pre> | |
<pre class="cython line score-0"> <span class="">020</span>: <span class="k">cdef</span><span class="p">:</span></pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">021</span>: <span class="nb">int</span> <span class="n">i</span><span class="p">,</span> <span class="n">j</span><span class="p">,</span> <span class="n">count</span> <span class="o">=</span> <span class="mf">0</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_count = 0; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">022</span>: <span class="n">double</span> <span class="n">sum_val</span> <span class="o">=</span> <span class="mf">0.0</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_sum_val = 0.0; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">023</span>: <span class="n">double</span> <span class="n">mean_val</span> <span class="o">=</span> <span class="mf">0.0</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_mean_val = 0.0; | |
</pre><pre class="cython line score-0"> <span class="">024</span>: <span class="n">np</span><span class="o">.</span><span class="n">ndarray</span><span class="p">[</span><span class="n">DTYPE_t</span><span class="p">,</span> <span class="n">ndim</span><span class="o">=</span><span class="mf">1</span><span class="p">]</span> <span class="n">flat_vals</span></pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">025</span>: <span class="nb">int</span> <span class="n">flat_size</span> <span class="o">=</span> <span class="mf">0</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_flat_size = 0; | |
</pre><pre class="cython line score-0"> <span class="">026</span>: </pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">027</span>: <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">y_min</span><span class="p">,</span> <span class="n">y_max</span><span class="p">):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_1 = __pyx_v_y_max; | |
__pyx_t_2 = __pyx_t_1; | |
for (__pyx_t_3 = __pyx_v_y_min; __pyx_t_3 < __pyx_t_2; __pyx_t_3+=1) { | |
__pyx_v_i = __pyx_t_3; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">028</span>: <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">x_min</span><span class="p">,</span> <span class="n">x_max</span><span class="p">):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_4 = __pyx_v_x_max; | |
__pyx_t_5 = __pyx_t_4; | |
for (__pyx_t_6 = __pyx_v_x_min; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) { | |
__pyx_v_j = __pyx_t_6; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">029</span>: <span class="k">if</span> <span class="ow">not</span> <span class="n">isnan</span><span class="p">(</span><span class="n">depth_map</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">j</span><span class="p">]):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_7 = __pyx_v_i; | |
__pyx_t_8 = __pyx_v_j; | |
__pyx_t_9 = (!isnan((*__Pyx_BufPtrStrided2d(__pyx_t_13processing_cy_DTYPE_t *, __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.buf, __pyx_t_7, __pyx_pybuffernd_depth_map.diminfo[0].strides, __pyx_t_8, __pyx_pybuffernd_depth_map.diminfo[1].strides)))); | |
if (__pyx_t_9) { | |
/* … */ | |
} | |
} | |
} | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">030</span>: <span class="n">sum_val</span> <span class="o">+=</span> <span class="n">depth_map</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">j</span><span class="p">]</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_8 = __pyx_v_i; | |
__pyx_t_7 = __pyx_v_j; | |
__pyx_v_sum_val = (__pyx_v_sum_val + (*__Pyx_BufPtrStrided2d(__pyx_t_13processing_cy_DTYPE_t *, __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.buf, __pyx_t_8, __pyx_pybuffernd_depth_map.diminfo[0].strides, __pyx_t_7, __pyx_pybuffernd_depth_map.diminfo[1].strides))); | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">031</span>: <span class="n">count</span> <span class="o">+=</span> <span class="mf">1</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_count = (__pyx_v_count + 1); | |
</pre><pre class="cython line score-0"> <span class="">032</span>: </pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">033</span>: <span class="k">if</span> <span class="n">count</span> <span class="o">></span> <span class="mf">0</span><span class="p">:</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_9 = (__pyx_v_count > 0); | |
if (__pyx_t_9) { | |
/* … */ | |
} | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">034</span>: <span class="n">mean_val</span> <span class="o">=</span> <span class="n">sum_val</span> <span class="o">/</span> <span class="n">count</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_mean_val = (__pyx_v_sum_val / ((double)__pyx_v_count)); | |
</pre><pre class="cython line score-0"> <span class="">035</span>: </pre> | |
<pre class="cython line score-0"> <span class="">036</span>: <span class="c"># Create array for trimmed mean calculation</span></pre> | |
<pre class="cython line score-52" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">037</span>: <span class="n">flat_vals</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">zeros</span><span class="p">(</span><span class="n">count</span><span class="p">,</span> <span class="n">dtype</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">float32</span><span class="p">)</span></pre> | |
<pre class='cython code score-52 '> <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_10, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_10); | |
__pyx_t_11 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_10, __pyx_n_s_zeros);<span class='error_goto'> if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_11); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_10); __pyx_t_10 = 0; | |
__pyx_t_10 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_v_count);<span class='error_goto'> if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_10); | |
__pyx_t_12 = <span class='py_c_api'>PyTuple_New</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_12); | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_10); | |
if (<span class='pyx_c_api'>__Pyx_PyTuple_SET_ITEM</span>(__pyx_t_12, 0, __pyx_t_10)) <span class='error_goto'>__PYX_ERR(0, 37, __pyx_L1_error)</span>; | |
__pyx_t_10 = 0; | |
__pyx_t_10 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_10); | |
<span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_13, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_13); | |
__pyx_t_14 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_13, __pyx_n_s_float32);<span class='error_goto'> if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_14); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_13); __pyx_t_13 = 0; | |
if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_t_10, __pyx_n_s_dtype, __pyx_t_14) < 0) <span class='error_goto'>__PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_14); __pyx_t_14 = 0; | |
__pyx_t_14 = <span class='pyx_c_api'>__Pyx_PyObject_Call</span>(__pyx_t_11, __pyx_t_12, __pyx_t_10);<span class='error_goto'> if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 37, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_14); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_11); __pyx_t_11 = 0; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_12); __pyx_t_12 = 0; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_10); __pyx_t_10 = 0; | |
if (!(likely(((__pyx_t_14) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_14, __pyx_ptype_5numpy_ndarray))))) <span class='error_goto'>__PYX_ERR(0, 37, __pyx_L1_error)</span> | |
__pyx_t_15 = ((PyArrayObject *)__pyx_t_14); | |
{ | |
__Pyx_BufFmt_StackElem __pyx_stack[1]; | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_flat_vals.rcbuffer->pybuffer); | |
__pyx_t_1 = <span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&__pyx_pybuffernd_flat_vals.rcbuffer->pybuffer, (PyObject*)__pyx_t_15, &__Pyx_TypeInfo_nn___pyx_t_13processing_cy_DTYPE_t, PyBUF_FORMAT| PyBUF_STRIDES| PyBUF_WRITABLE, 1, 0, __pyx_stack); | |
if (unlikely(__pyx_t_1 < 0)) { | |
<span class='py_c_api'>PyErr_Fetch</span>(&__pyx_t_16, &__pyx_t_17, &__pyx_t_18); | |
if (unlikely(<span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&__pyx_pybuffernd_flat_vals.rcbuffer->pybuffer, (PyObject*)__pyx_v_flat_vals, &__Pyx_TypeInfo_nn___pyx_t_13processing_cy_DTYPE_t, PyBUF_FORMAT| PyBUF_STRIDES| PyBUF_WRITABLE, 1, 0, __pyx_stack) == -1)) { | |
Py_XDECREF(__pyx_t_16); Py_XDECREF(__pyx_t_17); Py_XDECREF(__pyx_t_18); | |
<span class='pyx_c_api'>__Pyx_RaiseBufferFallbackError</span>(); | |
} else { | |
<span class='py_c_api'>PyErr_Restore</span>(__pyx_t_16, __pyx_t_17, __pyx_t_18); | |
} | |
__pyx_t_16 = __pyx_t_17 = __pyx_t_18 = 0; | |
} | |
__pyx_pybuffernd_flat_vals.diminfo[0].strides = __pyx_pybuffernd_flat_vals.rcbuffer->pybuffer.strides[0]; __pyx_pybuffernd_flat_vals.diminfo[0].shape = __pyx_pybuffernd_flat_vals.rcbuffer->pybuffer.shape[0]; | |
if (unlikely((__pyx_t_1 < 0))) <span class='error_goto'>__PYX_ERR(0, 37, __pyx_L1_error)</span> | |
} | |
__pyx_t_15 = 0; | |
__pyx_v_flat_vals = ((PyArrayObject *)__pyx_t_14); | |
__pyx_t_14 = 0; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">038</span>: <span class="n">flat_size</span> <span class="o">=</span> <span class="mf">0</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_flat_size = 0; | |
</pre><pre class="cython line score-0"> <span class="">039</span>: </pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">040</span>: <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">y_min</span><span class="p">,</span> <span class="n">y_max</span><span class="p">):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_1 = __pyx_v_y_max; | |
__pyx_t_2 = __pyx_t_1; | |
for (__pyx_t_3 = __pyx_v_y_min; __pyx_t_3 < __pyx_t_2; __pyx_t_3+=1) { | |
__pyx_v_i = __pyx_t_3; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">041</span>: <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">x_min</span><span class="p">,</span> <span class="n">x_max</span><span class="p">):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_4 = __pyx_v_x_max; | |
__pyx_t_5 = __pyx_t_4; | |
for (__pyx_t_6 = __pyx_v_x_min; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) { | |
__pyx_v_j = __pyx_t_6; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">042</span>: <span class="k">if</span> <span class="ow">not</span> <span class="n">isnan</span><span class="p">(</span><span class="n">depth_map</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">j</span><span class="p">]):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_7 = __pyx_v_i; | |
__pyx_t_8 = __pyx_v_j; | |
__pyx_t_9 = (!isnan((*__Pyx_BufPtrStrided2d(__pyx_t_13processing_cy_DTYPE_t *, __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.buf, __pyx_t_7, __pyx_pybuffernd_depth_map.diminfo[0].strides, __pyx_t_8, __pyx_pybuffernd_depth_map.diminfo[1].strides)))); | |
if (__pyx_t_9) { | |
/* … */ | |
} | |
} | |
} | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">043</span>: <span class="n">flat_vals</span><span class="p">[</span><span class="n">flat_size</span><span class="p">]</span> <span class="o">=</span> <span class="n">depth_map</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">j</span><span class="p">]</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_8 = __pyx_v_i; | |
__pyx_t_7 = __pyx_v_j; | |
__pyx_t_19 = __pyx_v_flat_size; | |
*__Pyx_BufPtrStrided1d(__pyx_t_13processing_cy_DTYPE_t *, __pyx_pybuffernd_flat_vals.rcbuffer->pybuffer.buf, __pyx_t_19, __pyx_pybuffernd_flat_vals.diminfo[0].strides) = (*__Pyx_BufPtrStrided2d(__pyx_t_13processing_cy_DTYPE_t *, __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.buf, __pyx_t_8, __pyx_pybuffernd_depth_map.diminfo[0].strides, __pyx_t_7, __pyx_pybuffernd_depth_map.diminfo[1].strides)); | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">044</span>: <span class="n">flat_size</span> <span class="o">+=</span> <span class="mf">1</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_flat_size = (__pyx_v_flat_size + 1); | |
</pre><pre class="cython line score-0"> <span class="">045</span>: </pre> | |
<pre class="cython line score-67" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">046</span>: <span class="k">return</span> <span class="n">mean_val</span><span class="p">,</span> <span class="n">np</span><span class="o">.</span><span class="n">median</span><span class="p">(</span><span class="n">flat_vals</span><span class="p">),</span> <span class="n">np</span><span class="o">.</span><span class="n">percentile</span><span class="p">(</span><span class="n">flat_vals</span><span class="p">,</span> <span class="p">[</span><span class="mf">20</span><span class="p">,</span> <span class="mf">80</span><span class="p">])</span></pre> | |
<pre class='cython code score-67 '> <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_r); | |
__pyx_t_14 = <span class='py_c_api'>PyFloat_FromDouble</span>(__pyx_v_mean_val);<span class='error_goto'> if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_14); | |
<span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_12, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_12); | |
__pyx_t_11 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_12, __pyx_n_s_median);<span class='error_goto'> if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_11); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_12); __pyx_t_12 = 0; | |
__pyx_t_12 = NULL; | |
__pyx_t_20 = 0; | |
#if CYTHON_UNPACK_METHODS | |
if (unlikely(<span class='py_c_api'>PyMethod_Check</span>(__pyx_t_11))) { | |
__pyx_t_12 = <span class='py_macro_api'>PyMethod_GET_SELF</span>(__pyx_t_11); | |
if (likely(__pyx_t_12)) { | |
PyObject* function = <span class='py_macro_api'>PyMethod_GET_FUNCTION</span>(__pyx_t_11); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_12); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(function); | |
<span class='pyx_macro_api'>__Pyx_DECREF_SET</span>(__pyx_t_11, function); | |
__pyx_t_20 = 1; | |
} | |
} | |
#endif | |
{ | |
PyObject *__pyx_callargs[2] = {__pyx_t_12, ((PyObject *)__pyx_v_flat_vals)}; | |
__pyx_t_10 = <span class='pyx_c_api'>__Pyx_PyObject_FastCall</span>(__pyx_t_11, __pyx_callargs+1-__pyx_t_20, 1+__pyx_t_20); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_12); __pyx_t_12 = 0; | |
if (unlikely(!__pyx_t_10)) <span class='error_goto'>__PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_10); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_11); __pyx_t_11 = 0; | |
} | |
<span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_12, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_12); | |
__pyx_t_13 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_12, __pyx_n_s_percentile);<span class='error_goto'> if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_13); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_12); __pyx_t_12 = 0; | |
__pyx_t_12 = <span class='py_c_api'>PyList_New</span>(2);<span class='error_goto'> if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_12); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_int_20); | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_int_20); | |
if (<span class='pyx_c_api'>__Pyx_PyList_SET_ITEM</span>(__pyx_t_12, 0, __pyx_int_20)) <span class='error_goto'>__PYX_ERR(0, 46, __pyx_L1_error)</span>; | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_int_80); | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_int_80); | |
if (<span class='pyx_c_api'>__Pyx_PyList_SET_ITEM</span>(__pyx_t_12, 1, __pyx_int_80)) <span class='error_goto'>__PYX_ERR(0, 46, __pyx_L1_error)</span>; | |
__pyx_t_21 = NULL; | |
__pyx_t_20 = 0; | |
#if CYTHON_UNPACK_METHODS | |
if (unlikely(<span class='py_c_api'>PyMethod_Check</span>(__pyx_t_13))) { | |
__pyx_t_21 = <span class='py_macro_api'>PyMethod_GET_SELF</span>(__pyx_t_13); | |
if (likely(__pyx_t_21)) { | |
PyObject* function = <span class='py_macro_api'>PyMethod_GET_FUNCTION</span>(__pyx_t_13); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_21); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(function); | |
<span class='pyx_macro_api'>__Pyx_DECREF_SET</span>(__pyx_t_13, function); | |
__pyx_t_20 = 1; | |
} | |
} | |
#endif | |
{ | |
PyObject *__pyx_callargs[3] = {__pyx_t_21, ((PyObject *)__pyx_v_flat_vals), __pyx_t_12}; | |
__pyx_t_11 = <span class='pyx_c_api'>__Pyx_PyObject_FastCall</span>(__pyx_t_13, __pyx_callargs+1-__pyx_t_20, 2+__pyx_t_20); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_21); __pyx_t_21 = 0; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_12); __pyx_t_12 = 0; | |
if (unlikely(!__pyx_t_11)) <span class='error_goto'>__PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_11); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_13); __pyx_t_13 = 0; | |
} | |
__pyx_t_13 = <span class='py_c_api'>PyTuple_New</span>(3);<span class='error_goto'> if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 46, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_13); | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_14); | |
if (<span class='pyx_c_api'>__Pyx_PyTuple_SET_ITEM</span>(__pyx_t_13, 0, __pyx_t_14)) <span class='error_goto'>__PYX_ERR(0, 46, __pyx_L1_error)</span>; | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_10); | |
if (<span class='pyx_c_api'>__Pyx_PyTuple_SET_ITEM</span>(__pyx_t_13, 1, __pyx_t_10)) <span class='error_goto'>__PYX_ERR(0, 46, __pyx_L1_error)</span>; | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_11); | |
if (<span class='pyx_c_api'>__Pyx_PyTuple_SET_ITEM</span>(__pyx_t_13, 2, __pyx_t_11)) <span class='error_goto'>__PYX_ERR(0, 46, __pyx_L1_error)</span>; | |
__pyx_t_14 = 0; | |
__pyx_t_10 = 0; | |
__pyx_t_11 = 0; | |
__pyx_r = __pyx_t_13; | |
__pyx_t_13 = 0; | |
goto __pyx_L0; | |
</pre><pre class="cython line score-0"> <span class="">047</span>: </pre> | |
<pre class="cython line score-94" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">048</span>: <span class="k">def</span> <span class="nf">handle_overlaps_cy</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">ndarray</span><span class="p">[</span><span class="n">DTYPE_t</span><span class="p">,</span> <span class="n">ndim</span><span class="o">=</span><span class="mf">2</span><span class="p">]</span> <span class="n">depth_map</span><span class="p">,</span></pre> | |
<pre class='cython code score-94 '>/* Python wrapper */ | |
static PyObject *__pyx_pw_13processing_cy_3handle_overlaps_cy(PyObject *__pyx_self, | |
#if CYTHON_METH_FASTCALL | |
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds | |
#else | |
PyObject *__pyx_args, PyObject *__pyx_kwds | |
#endif | |
); /*proto*/ | |
<span class='py_macro_api'>PyDoc_STRVAR</span>(__pyx_doc_13processing_cy_2handle_overlaps_cy, "\n Optimized overlap handling using Cython\n "); | |
static PyMethodDef __pyx_mdef_13processing_cy_3handle_overlaps_cy = {"handle_overlaps_cy", (PyCFunction)(void*)(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_13processing_cy_3handle_overlaps_cy, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_13processing_cy_2handle_overlaps_cy}; | |
static PyObject *__pyx_pw_13processing_cy_3handle_overlaps_cy(PyObject *__pyx_self, | |
#if CYTHON_METH_FASTCALL | |
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds | |
#else | |
PyObject *__pyx_args, PyObject *__pyx_kwds | |
#endif | |
) { | |
CYTHON_UNUSED PyArrayObject *__pyx_v_depth_map = 0; | |
PyArrayObject *__pyx_v_boxes = 0; | |
#if !CYTHON_METH_FASTCALL | |
CYTHON_UNUSED Py_ssize_t __pyx_nargs; | |
#endif | |
CYTHON_UNUSED PyObject *const *__pyx_kwvalues; | |
PyObject *__pyx_r = 0; | |
<span class='refnanny'>__Pyx_RefNannyDeclarations</span> | |
<span class='refnanny'>__Pyx_RefNannySetupContext</span>("handle_overlaps_cy (wrapper)", 0); | |
#if !CYTHON_METH_FASTCALL | |
#if CYTHON_ASSUME_SAFE_MACROS | |
__pyx_nargs = <span class='py_macro_api'>PyTuple_GET_SIZE</span>(__pyx_args); | |
#else | |
__pyx_nargs = <span class='py_c_api'>PyTuple_Size</span>(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; | |
#endif | |
#endif | |
__pyx_kwvalues = <span class='pyx_c_api'>__Pyx_KwValues_FASTCALL</span>(__pyx_args, __pyx_nargs); | |
{ | |
PyObject **__pyx_pyargnames[] = {&__pyx_n_s_depth_map,&__pyx_n_s_boxes,0}; | |
PyObject* values[2] = {0,0}; | |
if (__pyx_kwds) { | |
Py_ssize_t kw_args; | |
switch (__pyx_nargs) { | |
case 2: values[1] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 1); | |
CYTHON_FALLTHROUGH; | |
case 1: values[0] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 0); | |
CYTHON_FALLTHROUGH; | |
case 0: break; | |
default: goto __pyx_L5_argtuple_error; | |
} | |
kw_args = <span class='pyx_c_api'>__Pyx_NumKwargs_FASTCALL</span>(__pyx_kwds); | |
switch (__pyx_nargs) { | |
case 0: | |
if (likely((values[0] = <span class='pyx_c_api'>__Pyx_GetKwValue_FASTCALL</span>(__pyx_kwds, __pyx_kwvalues, __pyx_n_s_depth_map)) != 0)) { | |
(void)<span class='pyx_c_api'>__Pyx_Arg_NewRef_FASTCALL</span>(values[0]); | |
kw_args--; | |
} | |
else if (unlikely(<span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L3_error)</span> | |
else goto __pyx_L5_argtuple_error; | |
CYTHON_FALLTHROUGH; | |
case 1: | |
if (likely((values[1] = <span class='pyx_c_api'>__Pyx_GetKwValue_FASTCALL</span>(__pyx_kwds, __pyx_kwvalues, __pyx_n_s_boxes)) != 0)) { | |
(void)<span class='pyx_c_api'>__Pyx_Arg_NewRef_FASTCALL</span>(values[1]); | |
kw_args--; | |
} | |
else if (unlikely(<span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L3_error)</span> | |
else { | |
<span class='pyx_c_api'>__Pyx_RaiseArgtupleInvalid</span>("handle_overlaps_cy", 1, 2, 2, 1); <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L3_error)</span> | |
} | |
} | |
if (unlikely(kw_args > 0)) { | |
const Py_ssize_t kwd_pos_args = __pyx_nargs; | |
if (unlikely(<span class='pyx_c_api'>__Pyx_ParseOptionalKeywords</span>(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values + 0, kwd_pos_args, "handle_overlaps_cy") < 0)) <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L3_error)</span> | |
} | |
} else if (unlikely(__pyx_nargs != 2)) { | |
goto __pyx_L5_argtuple_error; | |
} else { | |
values[0] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 0); | |
values[1] = <span class='pyx_c_api'>__Pyx_Arg_FASTCALL</span>(__pyx_args, 1); | |
} | |
__pyx_v_depth_map = ((PyArrayObject *)values[0]); | |
__pyx_v_boxes = ((PyArrayObject *)values[1]); | |
} | |
goto __pyx_L6_skip; | |
__pyx_L5_argtuple_error:; | |
<span class='pyx_c_api'>__Pyx_RaiseArgtupleInvalid</span>("handle_overlaps_cy", 1, 2, 2, __pyx_nargs); <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L3_error)</span> | |
__pyx_L6_skip:; | |
goto __pyx_L4_argument_unpacking_done; | |
__pyx_L3_error:; | |
{ | |
Py_ssize_t __pyx_temp; | |
for (__pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { | |
<span class='pyx_c_api'>__Pyx_Arg_XDECREF_FASTCALL</span>(values[__pyx_temp]); | |
} | |
} | |
<span class='pyx_c_api'>__Pyx_AddTraceback</span>("processing_cy.handle_overlaps_cy", __pyx_clineno, __pyx_lineno, __pyx_filename); | |
<span class='refnanny'>__Pyx_RefNannyFinishContext</span>(); | |
return NULL; | |
__pyx_L4_argument_unpacking_done:; | |
if (unlikely(!<span class='pyx_c_api'>__Pyx_ArgTypeTest</span>(((PyObject *)__pyx_v_depth_map), __pyx_ptype_5numpy_ndarray, 1, "depth_map", 0))) <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L1_error)</span> | |
if (unlikely(!<span class='pyx_c_api'>__Pyx_ArgTypeTest</span>(((PyObject *)__pyx_v_boxes), __pyx_ptype_5numpy_ndarray, 1, "boxes", 0))) <span class='error_goto'>__PYX_ERR(0, 49, __pyx_L1_error)</span> | |
__pyx_r = __pyx_pf_13processing_cy_2handle_overlaps_cy(__pyx_self, __pyx_v_depth_map, __pyx_v_boxes); | |
int __pyx_lineno = 0; | |
const char *__pyx_filename = NULL; | |
int __pyx_clineno = 0; | |
/* function exit code */ | |
goto __pyx_L0; | |
__pyx_L1_error:; | |
__pyx_r = NULL; | |
__pyx_L0:; | |
{ | |
Py_ssize_t __pyx_temp; | |
for (__pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { | |
<span class='pyx_c_api'>__Pyx_Arg_XDECREF_FASTCALL</span>(values[__pyx_temp]); | |
} | |
} | |
<span class='refnanny'>__Pyx_RefNannyFinishContext</span>(); | |
return __pyx_r; | |
} | |
static PyObject *__pyx_pf_13processing_cy_2handle_overlaps_cy(CYTHON_UNUSED PyObject *__pyx_self, CYTHON_UNUSED PyArrayObject *__pyx_v_depth_map, PyArrayObject *__pyx_v_boxes) { | |
int __pyx_v_n_boxes; | |
int __pyx_v_i; | |
int __pyx_v_j; | |
int __pyx_v_y_min1; | |
int __pyx_v_y_max1; | |
int __pyx_v_x_min1; | |
int __pyx_v_x_max1; | |
int __pyx_v_y_min2; | |
int __pyx_v_y_max2; | |
int __pyx_v_x_min2; | |
int __pyx_v_x_max2; | |
double __pyx_v_area1; | |
double __pyx_v_area2; | |
double __pyx_v_area_intersection; | |
int *__pyx_v_to_remove; | |
PyObject *__pyx_v_y_min_int = NULL; | |
PyObject *__pyx_v_y_max_int = NULL; | |
PyObject *__pyx_v_x_min_int = NULL; | |
PyObject *__pyx_v_x_max_int = NULL; | |
int __pyx_7genexpr__pyx_v_i; | |
__Pyx_LocalBuf_ND __pyx_pybuffernd_boxes; | |
__Pyx_Buffer __pyx_pybuffer_boxes; | |
__Pyx_LocalBuf_ND __pyx_pybuffernd_depth_map; | |
__Pyx_Buffer __pyx_pybuffer_depth_map; | |
PyObject *__pyx_r = NULL; | |
__pyx_pybuffer_depth_map.pybuffer.buf = NULL; | |
__pyx_pybuffer_depth_map.refcount = 0; | |
__pyx_pybuffernd_depth_map.data = NULL; | |
__pyx_pybuffernd_depth_map.rcbuffer = &__pyx_pybuffer_depth_map; | |
__pyx_pybuffer_boxes.pybuffer.buf = NULL; | |
__pyx_pybuffer_boxes.refcount = 0; | |
__pyx_pybuffernd_boxes.data = NULL; | |
__pyx_pybuffernd_boxes.rcbuffer = &__pyx_pybuffer_boxes; | |
{ | |
__Pyx_BufFmt_StackElem __pyx_stack[1]; | |
if (unlikely(<span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&__pyx_pybuffernd_depth_map.rcbuffer->pybuffer, (PyObject*)__pyx_v_depth_map, &__Pyx_TypeInfo_nn___pyx_t_13processing_cy_DTYPE_t, PyBUF_FORMAT| PyBUF_STRIDES, 2, 0, __pyx_stack) == -1)) <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L1_error)</span> | |
} | |
__pyx_pybuffernd_depth_map.diminfo[0].strides = __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.strides[0]; __pyx_pybuffernd_depth_map.diminfo[0].shape = __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.shape[0]; __pyx_pybuffernd_depth_map.diminfo[1].strides = __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.strides[1]; __pyx_pybuffernd_depth_map.diminfo[1].shape = __pyx_pybuffernd_depth_map.rcbuffer->pybuffer.shape[1]; | |
{ | |
__Pyx_BufFmt_StackElem __pyx_stack[1]; | |
if (unlikely(<span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&__pyx_pybuffernd_boxes.rcbuffer->pybuffer, (PyObject*)__pyx_v_boxes, &__Pyx_TypeInfo_nn___pyx_t_13processing_cy_ITYPE_t, PyBUF_FORMAT| PyBUF_STRIDES, 2, 0, __pyx_stack) == -1)) <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L1_error)</span> | |
} | |
__pyx_pybuffernd_boxes.diminfo[0].strides = __pyx_pybuffernd_boxes.rcbuffer->pybuffer.strides[0]; __pyx_pybuffernd_boxes.diminfo[0].shape = __pyx_pybuffernd_boxes.rcbuffer->pybuffer.shape[0]; __pyx_pybuffernd_boxes.diminfo[1].strides = __pyx_pybuffernd_boxes.rcbuffer->pybuffer.strides[1]; __pyx_pybuffernd_boxes.diminfo[1].shape = __pyx_pybuffernd_boxes.rcbuffer->pybuffer.shape[1]; | |
/* … */ | |
/* function exit code */ | |
__pyx_L1_error:; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_6); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_7); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_8); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_9); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_10); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_11); | |
{ PyObject *__pyx_type, *__pyx_value, *__pyx_tb; | |
__Pyx_PyThreadState_declare | |
__Pyx_PyThreadState_assign | |
<span class='pyx_c_api'>__Pyx_ErrFetch</span>(&__pyx_type, &__pyx_value, &__pyx_tb); | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_boxes.rcbuffer->pybuffer); | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_depth_map.rcbuffer->pybuffer); | |
<span class='pyx_c_api'>__Pyx_ErrRestore</span>(__pyx_type, __pyx_value, __pyx_tb);} | |
<span class='pyx_c_api'>__Pyx_AddTraceback</span>("processing_cy.handle_overlaps_cy", __pyx_clineno, __pyx_lineno, __pyx_filename); | |
__pyx_r = NULL; | |
goto __pyx_L2; | |
__pyx_L0:; | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_boxes.rcbuffer->pybuffer); | |
<span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&__pyx_pybuffernd_depth_map.rcbuffer->pybuffer); | |
__pyx_L2:; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_v_y_min_int); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_v_y_max_int); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_v_x_min_int); | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_v_x_max_int); | |
<span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_r); | |
<span class='refnanny'>__Pyx_RefNannyFinishContext</span>(); | |
return __pyx_r; | |
} | |
/* … */ | |
__pyx_tuple__6 = <span class='py_c_api'>PyTuple_Pack</span>(22, __pyx_n_s_depth_map, __pyx_n_s_boxes, __pyx_n_s_n_boxes, __pyx_n_s_i, __pyx_n_s_j, __pyx_n_s_y_min1, __pyx_n_s_y_max1, __pyx_n_s_x_min1, __pyx_n_s_x_max1, __pyx_n_s_y_min2, __pyx_n_s_y_max2, __pyx_n_s_x_min2, __pyx_n_s_x_max2, __pyx_n_s_area1, __pyx_n_s_area2, __pyx_n_s_area_intersection, __pyx_n_s_to_remove, __pyx_n_s_y_min_int, __pyx_n_s_y_max_int, __pyx_n_s_x_min_int, __pyx_n_s_x_max_int, __pyx_n_s_i);<span class='error_goto'> if (unlikely(!__pyx_tuple__6)) __PYX_ERR(0, 48, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_tuple__6); | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_tuple__6); | |
/* … */ | |
__pyx_t_2 = <span class='pyx_c_api'>__Pyx_CyFunction_New</span>(&__pyx_mdef_13processing_cy_3handle_overlaps_cy, 0, __pyx_n_s_handle_overlaps_cy, NULL, __pyx_n_s_processing_cy, __pyx_d, ((PyObject *)__pyx_codeobj__7));<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 48, __pyx_L1_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2); | |
if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_d, __pyx_n_s_handle_overlaps_cy, __pyx_t_2) < 0) <span class='error_goto'>__PYX_ERR(0, 48, __pyx_L1_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0; | |
</pre><pre class="cython line score-0"> <span class="">049</span>: <span class="n">np</span><span class="o">.</span><span class="n">ndarray</span><span class="p">[</span><span class="n">ITYPE_t</span><span class="p">,</span> <span class="n">ndim</span><span class="o">=</span><span class="mf">2</span><span class="p">]</span> <span class="n">boxes</span><span class="p">):</span></pre> | |
<pre class="cython line score-0"> <span class="">050</span>: <span class="w"> </span><span class="sd">"""</span></pre> | |
<pre class="cython line score-0"> <span class="">051</span>: <span class="sd"> Optimized overlap handling using Cython</span></pre> | |
<pre class="cython line score-0"> <span class="">052</span>: <span class="sd"> """</span></pre> | |
<pre class="cython line score-0"> <span class="">053</span>: <span class="k">cdef</span><span class="p">:</span></pre> | |
<pre class="cython line score-5" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">054</span>: <span class="nb">int</span> <span class="n">n_boxes</span> <span class="o">=</span> <span class="n">boxes</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mf">0</span><span class="p">]</span></pre> | |
<pre class='cython code score-5 '> __pyx_t_1 = __pyx_f_5numpy_7ndarray_5shape_shape(((PyArrayObject *)__pyx_v_boxes)); if (unlikely(__pyx_t_1 == ((npy_intp *)NULL) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 54, __pyx_L1_error)</span> | |
__pyx_v_n_boxes = (__pyx_t_1[0]); | |
</pre><pre class="cython line score-0"> <span class="">055</span>: <span class="nb">int</span> <span class="n">i</span><span class="p">,</span> <span class="n">j</span></pre> | |
<pre class="cython line score-0"> <span class="">056</span>: <span class="nb">int</span> <span class="n">y_min1</span><span class="p">,</span> <span class="n">y_max1</span><span class="p">,</span> <span class="n">x_min1</span><span class="p">,</span> <span class="n">x_max1</span></pre> | |
<pre class="cython line score-0"> <span class="">057</span>: <span class="nb">int</span> <span class="n">y_min2</span><span class="p">,</span> <span class="n">y_max2</span><span class="p">,</span> <span class="n">x_min2</span><span class="p">,</span> <span class="n">x_max2</span></pre> | |
<pre class="cython line score-0"> <span class="">058</span>: <span class="n">double</span> <span class="n">area1</span><span class="p">,</span> <span class="n">area2</span><span class="p">,</span> <span class="n">area_intersection</span></pre> | |
<pre class="cython line score-5" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">059</span>: <span class="nb">bint</span><span class="o">*</span> <span class="n">to_remove</span> <span class="o">=</span> <span class="o"><</span><span class="nb">bint</span><span class="o">*></span><span class="n">PyMem_Malloc</span><span class="p">(</span><span class="n">n_boxes</span> <span class="o">*</span> <span class="n">sizeof</span><span class="p">(</span><span class="nb">bint</span><span class="p">))</span></pre> | |
<pre class='cython code score-5 '> __pyx_v_to_remove = ((int *)<span class='py_c_api'>PyMem_Malloc</span>((__pyx_v_n_boxes * (sizeof(int))))); | |
</pre><pre class="cython line score-0"> <span class="">060</span>: </pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">061</span>: <span class="k">if</span> <span class="ow">not</span> <span class="n">to_remove</span><span class="p">:</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_2 = (!(__pyx_v_to_remove != 0)); | |
if (unlikely(__pyx_t_2)) { | |
/* … */ | |
} | |
</pre><pre class="cython line score-5" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">062</span>: <span class="k">raise</span> <span class="ne">MemoryError</span><span class="p">()</span></pre> | |
<pre class='cython code score-5 '> <span class='py_c_api'>PyErr_NoMemory</span>(); <span class='error_goto'>__PYX_ERR(0, 62, __pyx_L1_error)</span> | |
</pre><pre class="cython line score-0"> <span class="">063</span>: </pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">064</span>: <span class="k">try</span><span class="p">:</span></pre> | |
<pre class='cython code score-0 '> /*try:*/ { | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">065</span>: <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n_boxes</span><span class="p">):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_3 = __pyx_v_n_boxes; | |
__pyx_t_4 = __pyx_t_3; | |
for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { | |
__pyx_v_i = __pyx_t_5; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">066</span>: <span class="n">to_remove</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="bp">False</span></pre> | |
<pre class='cython code score-0 '> (__pyx_v_to_remove[__pyx_v_i]) = 0; | |
} | |
</pre><pre class="cython line score-0"> <span class="">067</span>: </pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">068</span>: <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n_boxes</span><span class="p">):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_3 = __pyx_v_n_boxes; | |
__pyx_t_4 = __pyx_t_3; | |
for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { | |
__pyx_v_i = __pyx_t_5; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">069</span>: <span class="k">if</span> <span class="n">to_remove</span><span class="p">[</span><span class="n">i</span><span class="p">]:</span></pre> | |
<pre class='cython code score-0 '> if ((__pyx_v_to_remove[__pyx_v_i])) { | |
/* … */ | |
} | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">070</span>: <span class="k">continue</span></pre> | |
<pre class='cython code score-0 '> goto __pyx_L9_continue; | |
</pre><pre class="cython line score-0"> <span class="">071</span>: </pre> | |
<pre class="cython line score-85" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">072</span>: <span class="n">y_min1</span><span class="p">,</span> <span class="n">x_min1</span><span class="p">,</span> <span class="n">y_max1</span><span class="p">,</span> <span class="n">x_max1</span> <span class="o">=</span> <span class="n">boxes</span><span class="p">[</span><span class="n">i</span><span class="p">]</span></pre> | |
<pre class='cython code score-85 '> __pyx_t_6 = <span class='pyx_c_api'>__Pyx_GetItemInt</span>(((PyObject *)__pyx_v_boxes), __pyx_v_i, int, 1, __Pyx_PyInt_From_int, 0, 0, 0);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 72, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
if ((likely(<span class='py_c_api'>PyTuple_CheckExact</span>(__pyx_t_6))) || (<span class='py_c_api'>PyList_CheckExact</span>(__pyx_t_6))) { | |
PyObject* sequence = __pyx_t_6; | |
Py_ssize_t size = <span class='pyx_c_api'>__Pyx_PySequence_SIZE</span>(sequence); | |
if (unlikely(size != 4)) { | |
if (size > 4) <span class='pyx_c_api'>__Pyx_RaiseTooManyValuesError</span>(4); | |
else if (size >= 0) <span class='pyx_c_api'>__Pyx_RaiseNeedMoreValuesError</span>(size); | |
<span class='error_goto'>__PYX_ERR(0, 72, __pyx_L5_error)</span> | |
} | |
#if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS | |
if (likely(<span class='py_c_api'>PyTuple_CheckExact</span>(sequence))) { | |
__pyx_t_7 = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(sequence, 0); | |
__pyx_t_8 = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(sequence, 1); | |
__pyx_t_9 = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(sequence, 2); | |
__pyx_t_10 = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(sequence, 3); | |
} else { | |
__pyx_t_7 = <span class='py_macro_api'>PyList_GET_ITEM</span>(sequence, 0); | |
__pyx_t_8 = <span class='py_macro_api'>PyList_GET_ITEM</span>(sequence, 1); | |
__pyx_t_9 = <span class='py_macro_api'>PyList_GET_ITEM</span>(sequence, 2); | |
__pyx_t_10 = <span class='py_macro_api'>PyList_GET_ITEM</span>(sequence, 3); | |
} | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_7); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_8); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_9); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_10); | |
#else | |
{ | |
Py_ssize_t i; | |
PyObject** temps[4] = {&__pyx_t_7,&__pyx_t_8,&__pyx_t_9,&__pyx_t_10}; | |
for (i=0; i < 4; i++) { | |
PyObject* item = <span class='py_macro_api'>PySequence_ITEM</span>(sequence, i);<span class='error_goto'> if (unlikely(!item)) __PYX_ERR(0, 72, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(item); | |
*(temps[i]) = item; | |
} | |
} | |
#endif | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
} else { | |
Py_ssize_t index = -1; | |
PyObject** temps[4] = {&__pyx_t_7,&__pyx_t_8,&__pyx_t_9,&__pyx_t_10}; | |
__pyx_t_11 = <span class='py_c_api'>PyObject_GetIter</span>(__pyx_t_6);<span class='error_goto'> if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 72, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_11); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
__pyx_t_12 = <span class='pyx_c_api'>__Pyx_PyObject_GetIterNextFunc</span>(__pyx_t_11); | |
for (index=0; index < 4; index++) { | |
PyObject* item = __pyx_t_12(__pyx_t_11); if (unlikely(!item)) goto __pyx_L12_unpacking_failed; | |
<span class='refnanny'>__Pyx_GOTREF</span>(item); | |
*(temps[index]) = item; | |
} | |
if (<span class='pyx_c_api'>__Pyx_IternextUnpackEndCheck</span>(__pyx_t_12(__pyx_t_11), 4) < 0) <span class='error_goto'>__PYX_ERR(0, 72, __pyx_L5_error)</span> | |
__pyx_t_12 = NULL; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_11); __pyx_t_11 = 0; | |
goto __pyx_L13_unpacking_done; | |
__pyx_L12_unpacking_failed:; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_11); __pyx_t_11 = 0; | |
__pyx_t_12 = NULL; | |
if (<span class='pyx_c_api'>__Pyx_IterFinish</span>() == 0) <span class='pyx_c_api'>__Pyx_RaiseNeedMoreValuesError</span>(index); | |
<span class='error_goto'>__PYX_ERR(0, 72, __pyx_L5_error)</span> | |
__pyx_L13_unpacking_done:; | |
} | |
__pyx_t_13 = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(__pyx_t_7); if (unlikely((__pyx_t_13 == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 72, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0; | |
__pyx_t_14 = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(__pyx_t_8); if (unlikely((__pyx_t_14 == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 72, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_8); __pyx_t_8 = 0; | |
__pyx_t_15 = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(__pyx_t_9); if (unlikely((__pyx_t_15 == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 72, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_9); __pyx_t_9 = 0; | |
__pyx_t_16 = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(__pyx_t_10); if (unlikely((__pyx_t_16 == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 72, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_10); __pyx_t_10 = 0; | |
__pyx_v_y_min1 = __pyx_t_13; | |
__pyx_v_x_min1 = __pyx_t_14; | |
__pyx_v_y_max1 = __pyx_t_15; | |
__pyx_v_x_max1 = __pyx_t_16; | |
</pre><pre class="cython line score-0"> <span class="">073</span>: </pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">074</span>: <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">i</span> <span class="o">+</span> <span class="mf">1</span><span class="p">,</span> <span class="n">n_boxes</span><span class="p">):</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_16 = __pyx_v_n_boxes; | |
__pyx_t_15 = __pyx_t_16; | |
for (__pyx_t_14 = (__pyx_v_i + 1); __pyx_t_14 < __pyx_t_15; __pyx_t_14+=1) { | |
__pyx_v_j = __pyx_t_14; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">075</span>: <span class="k">if</span> <span class="n">to_remove</span><span class="p">[</span><span class="n">j</span><span class="p">]:</span></pre> | |
<pre class='cython code score-0 '> if ((__pyx_v_to_remove[__pyx_v_j])) { | |
/* … */ | |
} | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">076</span>: <span class="k">continue</span></pre> | |
<pre class='cython code score-0 '> goto __pyx_L14_continue; | |
</pre><pre class="cython line score-0"> <span class="">077</span>: </pre> | |
<pre class="cython line score-85" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">078</span>: <span class="n">y_min2</span><span class="p">,</span> <span class="n">x_min2</span><span class="p">,</span> <span class="n">y_max2</span><span class="p">,</span> <span class="n">x_max2</span> <span class="o">=</span> <span class="n">boxes</span><span class="p">[</span><span class="n">j</span><span class="p">]</span></pre> | |
<pre class='cython code score-85 '> __pyx_t_6 = <span class='pyx_c_api'>__Pyx_GetItemInt</span>(((PyObject *)__pyx_v_boxes), __pyx_v_j, int, 1, __Pyx_PyInt_From_int, 0, 0, 0);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 78, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
if ((likely(<span class='py_c_api'>PyTuple_CheckExact</span>(__pyx_t_6))) || (<span class='py_c_api'>PyList_CheckExact</span>(__pyx_t_6))) { | |
PyObject* sequence = __pyx_t_6; | |
Py_ssize_t size = <span class='pyx_c_api'>__Pyx_PySequence_SIZE</span>(sequence); | |
if (unlikely(size != 4)) { | |
if (size > 4) <span class='pyx_c_api'>__Pyx_RaiseTooManyValuesError</span>(4); | |
else if (size >= 0) <span class='pyx_c_api'>__Pyx_RaiseNeedMoreValuesError</span>(size); | |
<span class='error_goto'>__PYX_ERR(0, 78, __pyx_L5_error)</span> | |
} | |
#if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS | |
if (likely(<span class='py_c_api'>PyTuple_CheckExact</span>(sequence))) { | |
__pyx_t_10 = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(sequence, 0); | |
__pyx_t_9 = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(sequence, 1); | |
__pyx_t_8 = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(sequence, 2); | |
__pyx_t_7 = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(sequence, 3); | |
} else { | |
__pyx_t_10 = <span class='py_macro_api'>PyList_GET_ITEM</span>(sequence, 0); | |
__pyx_t_9 = <span class='py_macro_api'>PyList_GET_ITEM</span>(sequence, 1); | |
__pyx_t_8 = <span class='py_macro_api'>PyList_GET_ITEM</span>(sequence, 2); | |
__pyx_t_7 = <span class='py_macro_api'>PyList_GET_ITEM</span>(sequence, 3); | |
} | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_10); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_9); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_8); | |
<span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_7); | |
#else | |
{ | |
Py_ssize_t i; | |
PyObject** temps[4] = {&__pyx_t_10,&__pyx_t_9,&__pyx_t_8,&__pyx_t_7}; | |
for (i=0; i < 4; i++) { | |
PyObject* item = <span class='py_macro_api'>PySequence_ITEM</span>(sequence, i);<span class='error_goto'> if (unlikely(!item)) __PYX_ERR(0, 78, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(item); | |
*(temps[i]) = item; | |
} | |
} | |
#endif | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
} else { | |
Py_ssize_t index = -1; | |
PyObject** temps[4] = {&__pyx_t_10,&__pyx_t_9,&__pyx_t_8,&__pyx_t_7}; | |
__pyx_t_11 = <span class='py_c_api'>PyObject_GetIter</span>(__pyx_t_6);<span class='error_goto'> if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 78, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_11); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
__pyx_t_12 = <span class='pyx_c_api'>__Pyx_PyObject_GetIterNextFunc</span>(__pyx_t_11); | |
for (index=0; index < 4; index++) { | |
PyObject* item = __pyx_t_12(__pyx_t_11); if (unlikely(!item)) goto __pyx_L17_unpacking_failed; | |
<span class='refnanny'>__Pyx_GOTREF</span>(item); | |
*(temps[index]) = item; | |
} | |
if (<span class='pyx_c_api'>__Pyx_IternextUnpackEndCheck</span>(__pyx_t_12(__pyx_t_11), 4) < 0) <span class='error_goto'>__PYX_ERR(0, 78, __pyx_L5_error)</span> | |
__pyx_t_12 = NULL; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_11); __pyx_t_11 = 0; | |
goto __pyx_L18_unpacking_done; | |
__pyx_L17_unpacking_failed:; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_11); __pyx_t_11 = 0; | |
__pyx_t_12 = NULL; | |
if (<span class='pyx_c_api'>__Pyx_IterFinish</span>() == 0) <span class='pyx_c_api'>__Pyx_RaiseNeedMoreValuesError</span>(index); | |
<span class='error_goto'>__PYX_ERR(0, 78, __pyx_L5_error)</span> | |
__pyx_L18_unpacking_done:; | |
} | |
__pyx_t_13 = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(__pyx_t_10); if (unlikely((__pyx_t_13 == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 78, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_10); __pyx_t_10 = 0; | |
__pyx_t_17 = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(__pyx_t_9); if (unlikely((__pyx_t_17 == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 78, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_9); __pyx_t_9 = 0; | |
__pyx_t_18 = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(__pyx_t_8); if (unlikely((__pyx_t_18 == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 78, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_8); __pyx_t_8 = 0; | |
__pyx_t_19 = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == (int)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 78, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0; | |
__pyx_v_y_min2 = __pyx_t_13; | |
__pyx_v_x_min2 = __pyx_t_17; | |
__pyx_v_y_max2 = __pyx_t_18; | |
__pyx_v_x_max2 = __pyx_t_19; | |
</pre><pre class="cython line score-0"> <span class="">079</span>: </pre> | |
<pre class="cython line score-0"> <span class="">080</span>: <span class="c"># Calculate intersection</span></pre> | |
<pre class="cython line score-3" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">081</span>: <span class="n">y_min_int</span> <span class="o">=</span> <span class="nb">max</span><span class="p">(</span><span class="n">y_min1</span><span class="p">,</span> <span class="n">y_min2</span><span class="p">)</span></pre> | |
<pre class='cython code score-3 '> __pyx_t_19 = __pyx_v_y_min2; | |
__pyx_t_18 = __pyx_v_y_min1; | |
__pyx_t_2 = (__pyx_t_19 > __pyx_t_18); | |
if (__pyx_t_2) { | |
__pyx_t_17 = __pyx_t_19; | |
} else { | |
__pyx_t_17 = __pyx_t_18; | |
} | |
__pyx_t_6 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_t_17);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 81, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
<span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_y_min_int, __pyx_t_6); | |
__pyx_t_6 = 0; | |
</pre><pre class="cython line score-3" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">082</span>: <span class="n">y_max_int</span> <span class="o">=</span> <span class="nb">min</span><span class="p">(</span><span class="n">y_max1</span><span class="p">,</span> <span class="n">y_max2</span><span class="p">)</span></pre> | |
<pre class='cython code score-3 '> __pyx_t_17 = __pyx_v_y_max2; | |
__pyx_t_19 = __pyx_v_y_max1; | |
__pyx_t_2 = (__pyx_t_17 < __pyx_t_19); | |
if (__pyx_t_2) { | |
__pyx_t_18 = __pyx_t_17; | |
} else { | |
__pyx_t_18 = __pyx_t_19; | |
} | |
__pyx_t_6 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_t_18);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 82, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
<span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_y_max_int, __pyx_t_6); | |
__pyx_t_6 = 0; | |
</pre><pre class="cython line score-3" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">083</span>: <span class="n">x_min_int</span> <span class="o">=</span> <span class="nb">max</span><span class="p">(</span><span class="n">x_min1</span><span class="p">,</span> <span class="n">x_min2</span><span class="p">)</span></pre> | |
<pre class='cython code score-3 '> __pyx_t_18 = __pyx_v_x_min2; | |
__pyx_t_17 = __pyx_v_x_min1; | |
__pyx_t_2 = (__pyx_t_18 > __pyx_t_17); | |
if (__pyx_t_2) { | |
__pyx_t_19 = __pyx_t_18; | |
} else { | |
__pyx_t_19 = __pyx_t_17; | |
} | |
__pyx_t_6 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_t_19);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 83, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
<span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_x_min_int, __pyx_t_6); | |
__pyx_t_6 = 0; | |
</pre><pre class="cython line score-3" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">084</span>: <span class="n">x_max_int</span> <span class="o">=</span> <span class="nb">min</span><span class="p">(</span><span class="n">x_max1</span><span class="p">,</span> <span class="n">x_max2</span><span class="p">)</span></pre> | |
<pre class='cython code score-3 '> __pyx_t_19 = __pyx_v_x_max2; | |
__pyx_t_18 = __pyx_v_x_max1; | |
__pyx_t_2 = (__pyx_t_19 < __pyx_t_18); | |
if (__pyx_t_2) { | |
__pyx_t_17 = __pyx_t_19; | |
} else { | |
__pyx_t_17 = __pyx_t_18; | |
} | |
__pyx_t_6 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_t_17);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 84, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
<span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_x_max_int, __pyx_t_6); | |
__pyx_t_6 = 0; | |
</pre><pre class="cython line score-0"> <span class="">085</span>: </pre> | |
<pre class="cython line score-16" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">086</span>: <span class="k">if</span> <span class="n">y_min_int</span> <span class="o"><</span> <span class="n">y_max_int</span> <span class="ow">and</span> <span class="n">x_min_int</span> <span class="o"><</span> <span class="n">x_max_int</span><span class="p">:</span></pre> | |
<pre class='cython code score-16 '> __pyx_t_6 = <span class='py_c_api'>PyObject_RichCompare</span>(__pyx_v_y_min_int, __pyx_v_y_max_int, Py_LT); <span class='refnanny'>__Pyx_XGOTREF</span>(__pyx_t_6);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 86, __pyx_L5_error)</span> | |
__pyx_t_20 = <span class='pyx_c_api'>__Pyx_PyObject_IsTrue</span>(__pyx_t_6); if (unlikely((__pyx_t_20 < 0))) <span class='error_goto'>__PYX_ERR(0, 86, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
if (__pyx_t_20) { | |
} else { | |
__pyx_t_2 = __pyx_t_20; | |
goto __pyx_L20_bool_binop_done; | |
} | |
__pyx_t_6 = <span class='py_c_api'>PyObject_RichCompare</span>(__pyx_v_x_min_int, __pyx_v_x_max_int, Py_LT); <span class='refnanny'>__Pyx_XGOTREF</span>(__pyx_t_6);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 86, __pyx_L5_error)</span> | |
__pyx_t_20 = <span class='pyx_c_api'>__Pyx_PyObject_IsTrue</span>(__pyx_t_6); if (unlikely((__pyx_t_20 < 0))) <span class='error_goto'>__PYX_ERR(0, 86, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
__pyx_t_2 = __pyx_t_20; | |
__pyx_L20_bool_binop_done:; | |
if (__pyx_t_2) { | |
/* … */ | |
} | |
__pyx_L14_continue:; | |
} | |
__pyx_L15_break:; | |
__pyx_L9_continue:; | |
} | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">087</span>: <span class="n">area1</span> <span class="o">=</span> <span class="p">(</span><span class="n">y_max1</span> <span class="o">-</span> <span class="n">y_min1</span><span class="p">)</span> <span class="o">*</span> <span class="p">(</span><span class="n">x_max1</span> <span class="o">-</span> <span class="n">x_min1</span><span class="p">)</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_area1 = ((__pyx_v_y_max1 - __pyx_v_y_min1) * (__pyx_v_x_max1 - __pyx_v_x_min1)); | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">088</span>: <span class="n">area2</span> <span class="o">=</span> <span class="p">(</span><span class="n">y_max2</span> <span class="o">-</span> <span class="n">y_min2</span><span class="p">)</span> <span class="o">*</span> <span class="p">(</span><span class="n">x_max2</span> <span class="o">-</span> <span class="n">x_min2</span><span class="p">)</span></pre> | |
<pre class='cython code score-0 '> __pyx_v_area2 = ((__pyx_v_y_max2 - __pyx_v_y_min2) * (__pyx_v_x_max2 - __pyx_v_x_min2)); | |
</pre><pre class="cython line score-28" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">089</span>: <span class="n">area_intersection</span> <span class="o">=</span> <span class="p">(</span><span class="n">y_max_int</span> <span class="o">-</span> <span class="n">y_min_int</span><span class="p">)</span> <span class="o">*</span> <span class="p">(</span><span class="n">x_max_int</span> <span class="o">-</span> <span class="n">x_min_int</span><span class="p">)</span></pre> | |
<pre class='cython code score-28 '> __pyx_t_6 = <span class='py_c_api'>PyNumber_Subtract</span>(__pyx_v_y_max_int, __pyx_v_y_min_int);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 89, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
__pyx_t_7 = <span class='py_c_api'>PyNumber_Subtract</span>(__pyx_v_x_max_int, __pyx_v_x_min_int);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 89, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7); | |
__pyx_t_8 = <span class='py_c_api'>PyNumber_Multiply</span>(__pyx_t_6, __pyx_t_7);<span class='error_goto'> if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 89, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_8); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0; | |
__pyx_t_21 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_8); if (unlikely((__pyx_t_21 == (double)-1) && <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 89, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_8); __pyx_t_8 = 0; | |
__pyx_v_area_intersection = __pyx_t_21; | |
</pre><pre class="cython line score-0"> <span class="">090</span>: </pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">091</span>: <span class="k">if</span> <span class="n">area_intersection</span> <span class="o">/</span> <span class="nb">min</span><span class="p">(</span><span class="n">area1</span><span class="p">,</span> <span class="n">area2</span><span class="p">)</span> <span class="o">>=</span> <span class="mf">0.70</span><span class="p">:</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_21 = __pyx_v_area2; | |
__pyx_t_22 = __pyx_v_area1; | |
__pyx_t_2 = (__pyx_t_21 < __pyx_t_22); | |
if (__pyx_t_2) { | |
__pyx_t_23 = __pyx_t_21; | |
} else { | |
__pyx_t_23 = __pyx_t_22; | |
} | |
__pyx_t_2 = ((__pyx_v_area_intersection / __pyx_t_23) >= 0.70); | |
if (__pyx_t_2) { | |
/* … */ | |
} | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">092</span>: <span class="k">if</span> <span class="n">area1</span> <span class="o"><</span> <span class="n">area2</span><span class="p">:</span></pre> | |
<pre class='cython code score-0 '> __pyx_t_2 = (__pyx_v_area1 < __pyx_v_area2); | |
if (__pyx_t_2) { | |
/* … */ | |
} | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">093</span>: <span class="n">to_remove</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="bp">True</span></pre> | |
<pre class='cython code score-0 '> (__pyx_v_to_remove[__pyx_v_i]) = 1; | |
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">094</span>: <span class="k">break</span></pre> | |
<pre class='cython code score-0 '> goto __pyx_L15_break; | |
</pre><pre class="cython line score-0"> <span class="">095</span>: <span class="k">else</span><span class="p">:</span></pre> | |
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">096</span>: <span class="n">to_remove</span><span class="p">[</span><span class="n">j</span><span class="p">]</span> <span class="o">=</span> <span class="bp">True</span></pre> | |
<pre class='cython code score-0 '> /*else*/ { | |
(__pyx_v_to_remove[__pyx_v_j]) = 1; | |
} | |
</pre><pre class="cython line score-0"> <span class="">097</span>: </pre> | |
<pre class="cython line score-41" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">098</span>: <span class="k">return</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="n">i</span> <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n_boxes</span><span class="p">)</span> <span class="k">if</span> <span class="ow">not</span> <span class="n">to_remove</span><span class="p">[</span><span class="n">i</span><span class="p">]],</span> <span class="n">dtype</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">int32</span><span class="p">)</span></pre> | |
<pre class='cython code score-41 '> <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_r); | |
<span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_8, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_8); | |
__pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_8, __pyx_n_s_array);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_8); __pyx_t_8 = 0; | |
{ /* enter inner scope */ | |
__pyx_t_8 = <span class='py_c_api'>PyList_New</span>(0);<span class='error_goto'> if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_8); | |
__pyx_t_3 = __pyx_v_n_boxes; | |
__pyx_t_4 = __pyx_t_3; | |
for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { | |
__pyx_7genexpr__pyx_v_i = __pyx_t_5; | |
__pyx_t_2 = (!(__pyx_v_to_remove[__pyx_7genexpr__pyx_v_i])); | |
if (__pyx_t_2) { | |
__pyx_t_6 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_7genexpr__pyx_v_i);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
if (unlikely(<span class='pyx_c_api'>__Pyx_ListComp_Append</span>(__pyx_t_8, (PyObject*)__pyx_t_6))) <span class='error_goto'>__PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
} | |
} | |
} /* exit inner scope */ | |
__pyx_t_6 = <span class='py_c_api'>PyTuple_New</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_6); | |
<span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_8); | |
if (<span class='pyx_c_api'>__Pyx_PyTuple_SET_ITEM</span>(__pyx_t_6, 0, __pyx_t_8)) <span class='error_goto'>__PYX_ERR(0, 98, __pyx_L5_error)</span>; | |
__pyx_t_8 = 0; | |
__pyx_t_8 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_8); | |
<span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_9, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_9); | |
__pyx_t_10 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_9, __pyx_n_s_int32);<span class='error_goto'> if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_10); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_9); __pyx_t_9 = 0; | |
if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_t_8, __pyx_n_s_dtype, __pyx_t_10) < 0) <span class='error_goto'>__PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_10); __pyx_t_10 = 0; | |
__pyx_t_10 = <span class='pyx_c_api'>__Pyx_PyObject_Call</span>(__pyx_t_7, __pyx_t_6, __pyx_t_8);<span class='error_goto'> if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 98, __pyx_L5_error)</span> | |
<span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_10); | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
<span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_8); __pyx_t_8 = 0; | |
__pyx_r = __pyx_t_10; | |
__pyx_t_10 = 0; | |
goto __pyx_L4_return; | |
} | |
</pre><pre class="cython line score-0"> <span class="">099</span>: </pre> | |
<pre class="cython line score-0"> <span class="">100</span>: <span class="k">finally</span><span class="p">:</span></pre> | |
<pre class="cython line score-26" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">101</span>: <span class="n">PyMem_Free</span><span class="p">(</span><span class="n">to_remove</span><span class="p">)</span></pre> | |
<pre class='cython code score-26 '> /*finally:*/ { | |
__pyx_L5_error:; | |
/*exception exit:*/{ | |
__Pyx_PyThreadState_declare | |
__Pyx_PyThreadState_assign | |
__pyx_t_25 = 0; __pyx_t_26 = 0; __pyx_t_27 = 0; __pyx_t_28 = 0; __pyx_t_29 = 0; __pyx_t_30 = 0; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_10); __pyx_t_10 = 0; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_11); __pyx_t_11 = 0; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_6); __pyx_t_6 = 0; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_7); __pyx_t_7 = 0; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_8); __pyx_t_8 = 0; | |
<span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_9); __pyx_t_9 = 0; | |
if (PY_MAJOR_VERSION >= 3) <span class='pyx_c_api'>__Pyx_ExceptionSwap</span>(&__pyx_t_28, &__pyx_t_29, &__pyx_t_30); | |
if ((PY_MAJOR_VERSION < 3) || unlikely(<span class='pyx_c_api'>__Pyx_GetException</span>(&__pyx_t_25, &__pyx_t_26, &__pyx_t_27) < 0)) <span class='pyx_c_api'>__Pyx_ErrFetch</span>(&__pyx_t_25, &__pyx_t_26, &__pyx_t_27); | |
<span class='refnanny'>__Pyx_XGOTREF</span>(__pyx_t_25); | |
<span class='refnanny'>__Pyx_XGOTREF</span>(__pyx_t_26); | |
<span class='refnanny'>__Pyx_XGOTREF</span>(__pyx_t_27); | |
<span class='refnanny'>__Pyx_XGOTREF</span>(__pyx_t_28); | |
<span class='refnanny'>__Pyx_XGOTREF</span>(__pyx_t_29); | |
<span class='refnanny'>__Pyx_XGOTREF</span>(__pyx_t_30); | |
__pyx_t_3 = __pyx_lineno; __pyx_t_4 = __pyx_clineno; __pyx_t_24 = __pyx_filename; | |
{ | |
<span class='py_c_api'>PyMem_Free</span>(__pyx_v_to_remove); | |
} | |
if (PY_MAJOR_VERSION >= 3) { | |
<span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_t_28); | |
<span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_t_29); | |
<span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_t_30); | |
<span class='pyx_c_api'>__Pyx_ExceptionReset</span>(__pyx_t_28, __pyx_t_29, __pyx_t_30); | |
} | |
<span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_t_25); | |
<span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_t_26); | |
<span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_t_27); | |
<span class='pyx_c_api'>__Pyx_ErrRestore</span>(__pyx_t_25, __pyx_t_26, __pyx_t_27); | |
__pyx_t_25 = 0; __pyx_t_26 = 0; __pyx_t_27 = 0; __pyx_t_28 = 0; __pyx_t_29 = 0; __pyx_t_30 = 0; | |
__pyx_lineno = __pyx_t_3; __pyx_clineno = __pyx_t_4; __pyx_filename = __pyx_t_24; | |
goto __pyx_L1_error; | |
} | |
__pyx_L4_return: { | |
__pyx_t_30 = __pyx_r; | |
__pyx_r = 0; | |
<span class='py_c_api'>PyMem_Free</span>(__pyx_v_to_remove); | |
__pyx_r = __pyx_t_30; | |
__pyx_t_30 = 0; | |
goto __pyx_L0; | |
} | |
} | |
</pre></div></body></html> | |