<!DOCTYPE html>
<!-- Generated by Cython 0.29.33 -->
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Cython: nj.pyx</title>
    <style type="text/css">
    
body.cython { font-family: courier; font-size: 12; }

.cython.tag  {  }
.cython.line { 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: #408080; 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: #408080; font-style: italic } /* Comment.Hashbang */
.cython .cm { color: #408080; font-style: italic } /* Comment.Multiline */
.cython .cp { color: #BC7A00 } /* Comment.Preproc */
.cython .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */
.cython .c1 { color: #408080; font-style: italic } /* Comment.Single */
.cython .cs { color: #408080; font-style: italic } /* Comment.Special */
.cython .gd { color: #A00000 } /* Generic.Deleted */
.cython .ge { font-style: italic } /* Generic.Emph */
.cython .gr { color: #FF0000 } /* Generic.Error */
.cython .gh { color: #000080; font-weight: bold } /* Generic.Heading */
.cython .gi { color: #00A000 } /* Generic.Inserted */
.cython .go { color: #888888 } /* 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: #7D9029 } /* 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: #999999; font-weight: bold } /* Name.Entity */
.cython .ne { color: #D2413A; font-weight: bold } /* Name.Exception */
.cython .nf { color: #0000FF } /* Name.Function */
.cython .nl { color: #A0A000 } /* 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: #BB6622; font-weight: bold } /* Literal.String.Escape */
.cython .sh { color: #BA2121 } /* Literal.String.Heredoc */
.cython .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */
.cython .sx { color: #008000 } /* Literal.String.Other */
.cython .sr { color: #BB6688 } /* 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 0.29.33</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="nj.c">nj.c</a></p>
<div class="cython"><pre class="cython line score-16" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">001</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-16 '>  __pyx_t_1 = <span class='pyx_c_api'>__Pyx_Import</span>(__pyx_n_s_numpy, 0, 0);<span class='error_goto'> if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_1);
  if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_d, __pyx_n_s_np, __pyx_t_1) &lt; 0) <span class='error_goto'>__PYX_ERR(0, 1, __pyx_L1_error)</span>
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_1); __pyx_t_1 = 0;
/* … */
  __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) &lt; 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">&#xA0;<span class="">002</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-0">&#xA0;<span class="">003</span>: <span class="k">cimport</span> <span class="nn">cython</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">004</span>: <span class="sd">&quot;&quot;&quot;</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">005</span>: <span class="sd">Original code from https://github.com/mattapow/dodonaphy/blob/b0e7e27ce2b46c74c15cc4f964c72be535784b8e/dodonaphy/cython/Cpeeler.pyx</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">006</span>: <span class="sd">&quot;&quot;&quot;</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">007</span>: </pre>
<pre class="cython line score-28" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">008</span>: <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">infty</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">finfo</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">double</span><span class="p">)</span><span class="o">.</span><span class="n">max</span></pre>
<pre class='cython code score-28 '>  <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_1, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_1);
  __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_1, __pyx_n_s_finfo);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_1); __pyx_t_1 = 0;
  <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_1, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_1);
  __pyx_t_3 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_1, __pyx_n_s_double);<span class='error_goto'> if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 8, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_3);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = <span class='pyx_c_api'>__Pyx_PyObject_CallOneArg</span>(__pyx_t_2, __pyx_t_3);<span class='error_goto'> if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_1);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_1, __pyx_n_s_max);<span class='error_goto'> if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 8, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_3);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_4 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_3); if (unlikely((__pyx_t_4 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 8, __pyx_L1_error)</span>
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_6geophy_8tree_dec_2nj_infty = __pyx_t_4;
</pre><pre class="cython line score-28" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">009</span>: <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">eps</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">finfo</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">double</span><span class="p">)</span><span class="o">.</span><span class="n">eps</span></pre>
<pre class='cython code score-28 '>  <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_3, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 9, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_3);
  __pyx_t_1 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_3, __pyx_n_s_finfo);<span class='error_goto'> if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_1);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
  <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_3, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 9, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_3);
  __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_3, __pyx_n_s_double);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = <span class='pyx_c_api'>__Pyx_PyObject_CallOneArg</span>(__pyx_t_1, __pyx_t_2);<span class='error_goto'> if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 9, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_3);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_1); __pyx_t_1 = 0;
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_3, __pyx_n_s_eps);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_4 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_2); if (unlikely((__pyx_t_4 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 9, __pyx_L1_error)</span>
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_6geophy_8tree_dec_2nj_eps = __pyx_t_4;
</pre><pre class="cython line score-0">&#xA0;<span class="">010</span>: </pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">011</span>: <span class="k">cdef</span> <span class="k">class</span> <span class="nf">Node</span><span class="p">:</span></pre>
<pre class='cython code score-0 '>struct __pyx_obj_6geophy_8tree_dec_2nj_Node {
  PyObject_HEAD
  int taxon;
  PyObject *_nj_distances;
  double _nj_xsub;
};

</pre><pre class="cython line score-0">&#xA0;<span class="">012</span>:     <span class="k">cdef</span> <span class="kt">int</span> <span class="nf">taxon</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">013</span>:     <span class="k">cdef</span> <span class="kt">dict</span> <span class="nf">_nj_distances</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">014</span>:     <span class="k">cdef</span> <span class="kt">double</span> <span class="nf">_nj_xsub</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">015</span>: </pre>
<pre class="cython line score-28" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">016</span>:     <span class="k">def</span> <span class="nf">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="nb">int</span> <span class="n">taxon</span><span class="p">):</span></pre>
<pre class='cython code score-28 '>/* Python wrapper */
static int __pyx_pw_6geophy_8tree_dec_2nj_4Node_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_6geophy_8tree_dec_2nj_4Node_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_taxon;
  int __pyx_r;
  <span class='refnanny'>__Pyx_RefNannyDeclarations</span>
  <span class='refnanny'>__Pyx_RefNannySetupContext</span>("__init__ (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&amp;__pyx_n_s_taxon,0};
    PyObject* values[1] = {0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = <span class='py_macro_api'>PyTuple_GET_SIZE</span>(__pyx_args);
      switch (pos_args) {
        case  1: values[0] = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = <span class='py_c_api'>PyDict_Size</span>(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = <span class='pyx_c_api'>__Pyx_PyDict_GetItemStr</span>(__pyx_kwds, __pyx_n_s_taxon)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
      }
      if (unlikely(kw_args &gt; 0)) {
        if (unlikely(<span class='pyx_c_api'>__Pyx_ParseOptionalKeywords</span>(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__init__") &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 16, __pyx_L3_error)</span>
      }
    } else if (<span class='py_macro_api'>PyTuple_GET_SIZE</span>(__pyx_args) != 1) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = <span class='py_macro_api'>PyTuple_GET_ITEM</span>(__pyx_args, 0);
    }
    __pyx_v_taxon = <span class='pyx_c_api'>__Pyx_PyInt_As_int</span>(values[0]); if (unlikely((__pyx_v_taxon == (int)-1) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 16, __pyx_L3_error)</span>
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  <span class='pyx_c_api'>__Pyx_RaiseArgtupleInvalid</span>("__init__", 1, 1, 1, <span class='py_macro_api'>PyTuple_GET_SIZE</span>(__pyx_args)); <span class='error_goto'>__PYX_ERR(0, 16, __pyx_L3_error)</span>
  __pyx_L3_error:;
  <span class='pyx_c_api'>__Pyx_AddTraceback</span>("geophy.tree_dec.nj.Node.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  <span class='refnanny'>__Pyx_RefNannyFinishContext</span>();
  return -1;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6geophy_8tree_dec_2nj_4Node___init__(((struct __pyx_obj_6geophy_8tree_dec_2nj_Node *)__pyx_v_self), __pyx_v_taxon);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  <span class='refnanny'>__Pyx_RefNannyFinishContext</span>();
  return __pyx_r;
}

static int __pyx_pf_6geophy_8tree_dec_2nj_4Node___init__(struct __pyx_obj_6geophy_8tree_dec_2nj_Node *__pyx_v_self, int __pyx_v_taxon) {
  int __pyx_r;
  <span class='refnanny'>__Pyx_RefNannyDeclarations</span>
  <span class='refnanny'>__Pyx_RefNannySetupContext</span>("__init__", 0);
/* … */
  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __pyx_L1_error:;
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_1);
  <span class='pyx_c_api'>__Pyx_AddTraceback</span>("geophy.tree_dec.nj.Node.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  <span class='refnanny'>__Pyx_RefNannyFinishContext</span>();
  return __pyx_r;
}
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">017</span>:         <span class="bp">self</span><span class="o">.</span><span class="n">taxon</span> <span class="o">=</span> <span class="n">taxon</span></pre>
<pre class='cython code score-0 '>  __pyx_v_self-&gt;taxon = __pyx_v_taxon;
</pre><pre class="cython line score-3" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">018</span>:         <span class="bp">self</span><span class="o">.</span><span class="n">_nj_distances</span> <span class="o">=</span> <span class="p">{}</span></pre>
<pre class='cython code score-3 '>  __pyx_t_1 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(0);<span class='error_goto'> if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 18, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_1);
  <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_1);
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_v_self-&gt;_nj_distances);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_v_self-&gt;_nj_distances);
  __pyx_v_self-&gt;_nj_distances = ((PyObject*)__pyx_t_1);
  __pyx_t_1 = 0;
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">019</span>:         <span class="bp">self</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">=</span> <span class="mf">0.0</span></pre>
<pre class='cython code score-0 '>  __pyx_v_self-&gt;_nj_xsub = 0.0;
</pre><pre class="cython line score-0">&#xA0;<span class="">020</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">021</span>: <span class="nd">@cython</span><span class="o">.</span><span class="n">boundscheck</span><span class="p">(</span><span class="bp">False</span><span class="p">)</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">022</span>: <span class="nd">@cython</span><span class="o">.</span><span class="n">wraparound</span><span class="p">(</span><span class="bp">False</span><span class="p">)</span></pre>
<pre class="cython line score-40" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">023</span>: <span class="k">cpdef</span> <span class="nf">nj</span><span class="p">(</span><span class="n">double</span><span class="p">[:,</span> <span class="p">::</span><span class="mf">1</span><span class="p">]</span> <span class="n">pdm</span><span class="p">):</span></pre>
<pre class='cython code score-40 '>static PyObject *__pyx_pw_6geophy_8tree_dec_2nj_1nj(PyObject *__pyx_self, PyObject *__pyx_arg_pdm); /*proto*/
static PyObject *__pyx_f_6geophy_8tree_dec_2nj_nj(__Pyx_memviewslice __pyx_v_pdm, CYTHON_UNUSED int __pyx_skip_dispatch) {
  int __pyx_v_n_pool;
  int __pyx_v_n_taxa;
  int __pyx_v_n_ints;
  int __pyx_v_node_count;
  PyArrayObject *__pyx_v_peel = 0;
  PyArrayObject *__pyx_v_blens = 0;
  PyObject *__pyx_v_node_pool = NULL;
  __pyx_t_5numpy_double_t __pyx_v_dist;
  __pyx_t_5numpy_double_t __pyx_v_v1;
  __pyx_t_5numpy_double_t __pyx_v_v3;
  __pyx_t_5numpy_double_t __pyx_v_v4;
  __pyx_t_5numpy_double_t __pyx_v_qvalue;
  __pyx_t_5numpy_double_t __pyx_v_min_q;
  int __pyx_v_int_i;
  int __pyx_v_parent;
  __pyx_t_5numpy_double_t __pyx_v_delta_f;
  __pyx_t_5numpy_double_t __pyx_v_delta_g;
  __pyx_t_5numpy_double_t __pyx_v_two;
  struct __pyx_obj_6geophy_8tree_dec_2nj_Node *__pyx_v_nd = 0;
  struct __pyx_obj_6geophy_8tree_dec_2nj_Node *__pyx_v_nd1 = 0;
  struct __pyx_obj_6geophy_8tree_dec_2nj_Node *__pyx_v_nd2 = 0;
  struct __pyx_obj_6geophy_8tree_dec_2nj_Node *__pyx_v_node_to_join1 = 0;
  struct __pyx_obj_6geophy_8tree_dec_2nj_Node *__pyx_v_node_to_join2 = 0;
  PyObject *__pyx_v_idx1 = NULL;
  CYTHON_UNUSED PyObject *__pyx_v__ = NULL;
  struct __pyx_obj_6geophy_8tree_dec_2nj_Node *__pyx_v_new_node = NULL;
  int __pyx_7genexpr__pyx_v_taxon;
  __Pyx_LocalBuf_ND __pyx_pybuffernd_blens;
  __Pyx_Buffer __pyx_pybuffer_blens;
  __Pyx_LocalBuf_ND __pyx_pybuffernd_peel;
  __Pyx_Buffer __pyx_pybuffer_peel;
  PyObject *__pyx_r = NULL;
  <span class='refnanny'>__Pyx_RefNannyDeclarations</span>
  <span class='refnanny'>__Pyx_RefNannySetupContext</span>("nj", 0);
  __pyx_pybuffer_peel.pybuffer.buf = NULL;
  __pyx_pybuffer_peel.refcount = 0;
  __pyx_pybuffernd_peel.data = NULL;
  __pyx_pybuffernd_peel.rcbuffer = &amp;__pyx_pybuffer_peel;
  __pyx_pybuffer_blens.pybuffer.buf = NULL;
  __pyx_pybuffer_blens.refcount = 0;
  __pyx_pybuffernd_blens.data = NULL;
  __pyx_pybuffernd_blens.rcbuffer = &amp;__pyx_pybuffer_blens;
/* … */
  /* function exit code */
  __pyx_L1_error:;
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_2);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_3);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_4);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_5);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_7);
  { PyObject *__pyx_type, *__pyx_value, *__pyx_tb;
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    <span class='pyx_c_api'>__Pyx_ErrFetch</span>(&amp;__pyx_type, &amp;__pyx_value, &amp;__pyx_tb);
    <span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&amp;__pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer);
    <span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&amp;__pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer);
  <span class='pyx_c_api'>__Pyx_ErrRestore</span>(__pyx_type, __pyx_value, __pyx_tb);}
  <span class='pyx_c_api'>__Pyx_AddTraceback</span>("geophy.tree_dec.nj.nj", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  goto __pyx_L2;
  __pyx_L0:;
  <span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&amp;__pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer);
  <span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&amp;__pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer);
  __pyx_L2:;
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_peel);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_blens);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_v_node_pool);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_nd);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_nd1);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_nd2);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_node_to_join1);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_node_to_join2);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_v_idx1);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_v__);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>((PyObject *)__pyx_v_new_node);
  <span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_r);
  <span class='refnanny'>__Pyx_RefNannyFinishContext</span>();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_6geophy_8tree_dec_2nj_1nj(PyObject *__pyx_self, PyObject *__pyx_arg_pdm); /*proto*/
static char __pyx_doc_6geophy_8tree_dec_2nj_nj[] = " Calculate neighbour joining tree.\n    Credit to Dendropy for python implentation.\n\n    Args:\n        pdm (ndarray): Pairwise distance matrix\n    ";
static PyObject *__pyx_pw_6geophy_8tree_dec_2nj_1nj(PyObject *__pyx_self, PyObject *__pyx_arg_pdm) {
  __Pyx_memviewslice __pyx_v_pdm = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  <span class='refnanny'>__Pyx_RefNannyDeclarations</span>
  <span class='refnanny'>__Pyx_RefNannySetupContext</span>("nj (wrapper)", 0);
  assert(__pyx_arg_pdm); {
    __pyx_v_pdm = <span class='pyx_c_api'>__Pyx_PyObject_to_MemoryviewSlice_d_dc_double</span>(__pyx_arg_pdm, PyBUF_WRITABLE);<span class='error_goto'> if (unlikely(!__pyx_v_pdm.memview)) __PYX_ERR(0, 23, __pyx_L3_error)</span>
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  <span class='pyx_c_api'>__Pyx_AddTraceback</span>("geophy.tree_dec.nj.nj", __pyx_clineno, __pyx_lineno, __pyx_filename);
  <span class='refnanny'>__Pyx_RefNannyFinishContext</span>();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6geophy_8tree_dec_2nj_nj(__pyx_self, __pyx_v_pdm);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  <span class='refnanny'>__Pyx_RefNannyFinishContext</span>();
  return __pyx_r;
}

static PyObject *__pyx_pf_6geophy_8tree_dec_2nj_nj(CYTHON_UNUSED PyObject *__pyx_self, __Pyx_memviewslice __pyx_v_pdm) {
  PyObject *__pyx_r = NULL;
  <span class='refnanny'>__Pyx_RefNannyDeclarations</span>
  <span class='refnanny'>__Pyx_RefNannySetupContext</span>("nj", 0);
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_r);
  if (unlikely(!__pyx_v_pdm.memview)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("pdm"); <span class='error_goto'>__PYX_ERR(0, 23, __pyx_L1_error)</span> }
  __pyx_t_1 = __pyx_f_6geophy_8tree_dec_2nj_nj(__pyx_v_pdm, 0);<span class='error_goto'> if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 23, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_1);
  <span class='pyx_c_api'>__Pyx_AddTraceback</span>("geophy.tree_dec.nj.nj", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&amp;__pyx_v_pdm, 1);
  <span class='refnanny'>__Pyx_XGIVEREF</span>(__pyx_r);
  <span class='refnanny'>__Pyx_RefNannyFinishContext</span>();
  return __pyx_r;
}
</pre><pre class="cython line score-0">&#xA0;<span class="">024</span>:     <span class="sd">&quot;&quot;&quot; Calculate neighbour joining tree.</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">025</span>: <span class="sd">    Credit to Dendropy for python implentation.</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">026</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">027</span>: <span class="sd">    Args:</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">028</span>: <span class="sd">        pdm (ndarray): Pairwise distance matrix</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">029</span>: <span class="sd">    &quot;&quot;&quot;</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">030</span>: </pre>
<pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">031</span>:     <span class="k">cdef</span> <span class="kt">int</span> <span class="nf">n_pool</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdm</span><span class="p">)</span></pre>
<pre class='cython code score-2 '>  __pyx_t_1 = <span class='pyx_c_api'>__Pyx_MemoryView_Len</span>(__pyx_v_pdm); 
  __pyx_v_n_pool = __pyx_t_1;
</pre><pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">032</span>:     <span class="k">cdef</span> <span class="kt">int</span> <span class="nf">n_taxa</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdm</span><span class="p">)</span></pre>
<pre class='cython code score-2 '>  __pyx_t_1 = <span class='pyx_c_api'>__Pyx_MemoryView_Len</span>(__pyx_v_pdm); 
  __pyx_v_n_taxa = __pyx_t_1;
</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">cdef</span> <span class="kt">int</span> <span class="nf">n_ints</span> <span class="o">=</span> <span class="n">n_taxa</span> <span class="o">-</span> <span class="mf">1</span></pre>
<pre class='cython code score-0 '>  __pyx_v_n_ints = (__pyx_v_n_taxa - 1);
</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="k">cdef</span> <span class="kt">int</span> <span class="nf">node_count</span> <span class="o">=</span> <span class="mf">2</span> <span class="o">*</span> <span class="n">n_taxa</span> <span class="o">-</span> <span class="mf">2</span></pre>
<pre class='cython code score-0 '>  __pyx_v_node_count = ((2 * __pyx_v_n_taxa) - 2);
</pre><pre class="cython line score-0">&#xA0;<span class="">035</span>: </pre>
<pre class="cython line score-38" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">036</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">ndarray</span>[<span class="nf">long</span><span class="p">,</span> <span class="nf">ndim</span><span class="o">=</span><span class="mf">2</span><span class="p">]</span> <span class="n">peel</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">n_ints</span><span class="p">,</span> <span class="mf">3</span><span class="p">),</span> <span class="n">dtype</span><span class="o">=</span><span class="nb">long</span><span class="p">)</span></pre>
<pre class='cython code score-38 '>  <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_2, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 36, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
  __pyx_t_3 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_2, __pyx_n_s_zeros);<span class='error_goto'> if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 36, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_3);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_v_n_ints);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 36, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
  __pyx_t_4 = <span class='py_c_api'>PyTuple_New</span>(2);<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 36, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
  <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_2);
  <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_4, 0, __pyx_t_2);
  <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_int_3);
  <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_int_3);
  <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_4, 1, __pyx_int_3);
  __pyx_t_2 = 0;
  __pyx_t_2 = <span class='py_c_api'>PyTuple_New</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 36, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
  <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_4);
  <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_2, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 36, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
  if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_t_4, __pyx_n_s_dtype, ((PyObject *)(&amp;PyLong_Type))) &lt; 0) <span class='error_goto'>__PYX_ERR(0, 36, __pyx_L1_error)</span>
  __pyx_t_5 = <span class='pyx_c_api'>__Pyx_PyObject_Call</span>(__pyx_t_3, __pyx_t_2, __pyx_t_4);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 36, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_4); __pyx_t_4 = 0;
  if (!(likely(((__pyx_t_5) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_5, __pyx_ptype_5numpy_ndarray))))) <span class='error_goto'>__PYX_ERR(0, 36, __pyx_L1_error)</span>
  __pyx_t_6 = ((PyArrayObject *)__pyx_t_5);
  {
    __Pyx_BufFmt_StackElem __pyx_stack[1];
    if (unlikely(<span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&amp;__pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer, (PyObject*)__pyx_t_6, &amp;__Pyx_TypeInfo_long, PyBUF_FORMAT| PyBUF_STRIDES| PyBUF_WRITABLE, 2, 0, __pyx_stack) == -1)) {
      __pyx_v_peel = ((PyArrayObject *)Py_None); <span class='pyx_macro_api'>__Pyx_INCREF</span>(Py_None); __pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer.buf = NULL;
      <span class='error_goto'>__PYX_ERR(0, 36, __pyx_L1_error)</span>
    } else {__pyx_pybuffernd_peel.diminfo[0].strides = __pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer.strides[0]; __pyx_pybuffernd_peel.diminfo[0].shape = __pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer.shape[0]; __pyx_pybuffernd_peel.diminfo[1].strides = __pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer.strides[1]; __pyx_pybuffernd_peel.diminfo[1].shape = __pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer.shape[1];
    }
  }
  __pyx_t_6 = 0;
  __pyx_v_peel = ((PyArrayObject *)__pyx_t_5);
  __pyx_t_5 = 0;
</pre><pre class="cython line score-36" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">037</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">ndarray</span>[<span class="kt">np</span>.<span class="nf">double_t</span><span class="p">,</span> <span class="nf">ndim</span><span class="o">=</span><span class="mf">1</span><span class="p">]</span> <span class="n">blens</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">node_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">double</span><span class="p">)</span></pre>
<pre class='cython code score-36 '>  <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_5, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
  __pyx_t_4 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_5, __pyx_n_s_zeros);<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_v_node_count);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
  __pyx_t_2 = <span class='py_c_api'>PyTuple_New</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
  <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_5);
  <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_2, 0, __pyx_t_5);
  __pyx_t_5 = 0;
  __pyx_t_5 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
  <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_3, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_3);
  __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_3, __pyx_n_s_double);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
  if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_t_5, __pyx_n_s_dtype, __pyx_t_7) &lt; 0) <span class='error_goto'>__PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyObject_Call</span>(__pyx_t_4, __pyx_t_2, __pyx_t_5);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 37, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_4); __pyx_t_4 = 0;
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
  if (!(likely(((__pyx_t_7) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_7, __pyx_ptype_5numpy_ndarray))))) <span class='error_goto'>__PYX_ERR(0, 37, __pyx_L1_error)</span>
  __pyx_t_8 = ((PyArrayObject *)__pyx_t_7);
  {
    __Pyx_BufFmt_StackElem __pyx_stack[1];
    if (unlikely(<span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&amp;__pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer, (PyObject*)__pyx_t_8, &amp;__Pyx_TypeInfo_nn___pyx_t_5numpy_double_t, PyBUF_FORMAT| PyBUF_STRIDES| PyBUF_WRITABLE, 1, 0, __pyx_stack) == -1)) {
      __pyx_v_blens = ((PyArrayObject *)Py_None); <span class='pyx_macro_api'>__Pyx_INCREF</span>(Py_None); __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.buf = NULL;
      <span class='error_goto'>__PYX_ERR(0, 37, __pyx_L1_error)</span>
    } else {__pyx_pybuffernd_blens.diminfo[0].strides = __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.strides[0]; __pyx_pybuffernd_blens.diminfo[0].shape = __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.shape[0];
    }
  }
  __pyx_t_8 = 0;
  __pyx_v_blens = ((PyArrayObject *)__pyx_t_7);
  __pyx_t_7 = 0;
</pre><pre class="cython line score-0">&#xA0;<span class="">038</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">039</span>:     <span class="c"># initialise node pool</span></pre>
<pre class="cython line score-21" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">040</span>:     <span class="n">node_pool</span> <span class="o">=</span> <span class="p">[</span><span class="n">Node</span><span class="p">(</span><span class="n">taxon</span><span class="o">=</span><span class="n">taxon</span><span class="p">)</span> <span class="k">for</span> <span class="n">taxon</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n_pool</span><span class="p">)]</span></pre>
<pre class='cython code score-21 '>  { /* enter inner scope */
    __pyx_t_7 = <span class='py_c_api'>PyList_New</span>(0);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 40, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
    __pyx_t_9 = __pyx_v_n_pool;
    __pyx_t_10 = __pyx_t_9;
    for (__pyx_t_11 = 0; __pyx_t_11 &lt; __pyx_t_10; __pyx_t_11+=1) {
      __pyx_7genexpr__pyx_v_taxon = __pyx_t_11;
      __pyx_t_5 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(1);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 40, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
      __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_7genexpr__pyx_v_taxon);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 40, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
      if (<span class='py_c_api'>PyDict_SetItem</span>(__pyx_t_5, __pyx_n_s_taxon, __pyx_t_2) &lt; 0) <span class='error_goto'>__PYX_ERR(0, 40, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyObject_Call</span>(((PyObject *)__pyx_ptype_6geophy_8tree_dec_2nj_Node), __pyx_empty_tuple, __pyx_t_5);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 40, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(<span class='pyx_c_api'>__Pyx_ListComp_Append</span>(__pyx_t_7, (PyObject*)__pyx_t_2))) <span class='error_goto'>__PYX_ERR(0, 40, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
    }
  } /* exit inner scope */
  __pyx_v_node_pool = ((PyObject*)__pyx_t_7);
  __pyx_t_7 = 0;
</pre><pre class="cython line score-0">&#xA0;<span class="">041</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">042</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">dist</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">043</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">v1</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">044</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">v3</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">045</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">v4</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">046</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">qvalue</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">047</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">min_q</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">048</span>:     <span class="k">cdef</span> <span class="kt">int</span> <span class="nf">int_i</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">049</span>:     <span class="k">cdef</span> <span class="kt">int</span> <span class="nf">parent</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">050</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">delta_f</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">051</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">delta_g</span></pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">052</span>:     <span class="k">cdef</span> <span class="kt">np</span>.<span class="kt">double_t</span> <span class="nf">two</span> <span class="o">=</span> <span class="mf">2.</span></pre>
<pre class='cython code score-0 '>  __pyx_v_two = 2.;
</pre><pre class="cython line score-0">&#xA0;<span class="">053</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">054</span>:     <span class="c"># More hints to use Node</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">055</span>:     <span class="k">cdef</span> <span class="kt">Node</span> <span class="nf">nd</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">056</span>:     <span class="k">cdef</span> <span class="kt">Node</span> <span class="nf">nd1</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">057</span>:     <span class="k">cdef</span> <span class="kt">Node</span> <span class="nf">nd2</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">058</span>:     <span class="k">cdef</span> <span class="kt">Node</span> <span class="nf">node_to_join1</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">059</span>:     <span class="k">cdef</span> <span class="kt">Node</span> <span class="nf">node_to_join2</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">060</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">061</span>:     <span class="c"># cache calculations</span></pre>
<pre class="cython line score-9" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">062</span>:     <span class="k">for</span> <span class="n">nd1</span> <span class="ow">in</span> <span class="n">node_pool</span><span class="p">:</span></pre>
<pre class='cython code score-9 '>  __pyx_t_7 = __pyx_v_node_pool; <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_7); __pyx_t_12 = 0;
  for (;;) {
    if (__pyx_t_12 &gt;= <span class='py_macro_api'>PyList_GET_SIZE</span>(__pyx_t_7)) break;
    #if CYTHON_ASSUME_SAFE_MACROS &amp;&amp; !CYTHON_AVOID_BORROWED_REFS
    __pyx_t_2 = <span class='py_macro_api'>PyList_GET_ITEM</span>(__pyx_t_7, __pyx_t_12); <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_2); __pyx_t_12++; if (unlikely(0 &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 62, __pyx_L1_error)</span>
    #else
    __pyx_t_2 = <span class='py_macro_api'>PySequence_ITEM</span>(__pyx_t_7, __pyx_t_12); __pyx_t_12++;<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 62, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
    #endif
    if (!(likely(((__pyx_t_2) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_2, __pyx_ptype_6geophy_8tree_dec_2nj_Node))))) <span class='error_goto'>__PYX_ERR(0, 62, __pyx_L1_error)</span>
    <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_nd1, ((struct __pyx_obj_6geophy_8tree_dec_2nj_Node *)__pyx_t_2));
    __pyx_t_2 = 0;
/* … */
  }
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">063</span>:         <span class="n">nd1</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">=</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="mf">0.0</span></pre>
<pre class='cython code score-0 '>    __pyx_v_nd1-&gt;_nj_xsub = ((__pyx_t_5numpy_double_t)0.0);
</pre><pre class="cython line score-9" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">064</span>:         <span class="k">for</span> <span class="n">nd2</span> <span class="ow">in</span> <span class="n">node_pool</span><span class="p">:</span></pre>
<pre class='cython code score-9 '>    __pyx_t_2 = __pyx_v_node_pool; <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_2); __pyx_t_13 = 0;
    for (;;) {
      if (__pyx_t_13 &gt;= <span class='py_macro_api'>PyList_GET_SIZE</span>(__pyx_t_2)) break;
      #if CYTHON_ASSUME_SAFE_MACROS &amp;&amp; !CYTHON_AVOID_BORROWED_REFS
      __pyx_t_5 = <span class='py_macro_api'>PyList_GET_ITEM</span>(__pyx_t_2, __pyx_t_13); <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_5); __pyx_t_13++; if (unlikely(0 &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 64, __pyx_L1_error)</span>
      #else
      __pyx_t_5 = <span class='py_macro_api'>PySequence_ITEM</span>(__pyx_t_2, __pyx_t_13); __pyx_t_13++;<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 64, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
      #endif
      if (!(likely(((__pyx_t_5) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_5, __pyx_ptype_6geophy_8tree_dec_2nj_Node))))) <span class='error_goto'>__PYX_ERR(0, 64, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_nd2, ((struct __pyx_obj_6geophy_8tree_dec_2nj_Node *)__pyx_t_5));
      __pyx_t_5 = 0;
/* … */
      __pyx_L7_continue:;
    }
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
</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">if</span> <span class="n">nd1</span> <span class="ow">is</span> <span class="n">nd2</span><span class="p">:</span></pre>
<pre class='cython code score-0 '>      __pyx_t_14 = (__pyx_v_nd1 == __pyx_v_nd2);
      __pyx_t_15 = (__pyx_t_14 != 0);
      if (__pyx_t_15) {
/* … */
      }
</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="k">continue</span></pre>
<pre class='cython code score-0 '>        goto __pyx_L7_continue;
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">067</span>:             <span class="n">dist</span> <span class="o">=</span> <span class="n">pdm</span><span class="p">[</span><span class="n">nd1</span><span class="o">.</span><span class="n">taxon</span><span class="p">,</span> <span class="n">nd2</span><span class="o">.</span><span class="n">taxon</span><span class="p">]</span></pre>
<pre class='cython code score-0 '>      __pyx_t_16 = __pyx_v_nd1-&gt;taxon;
      __pyx_t_17 = __pyx_v_nd2-&gt;taxon;
      __pyx_v_dist = (*((double *) ( /* dim=1 */ ((char *) (((double *) ( /* dim=0 */ (__pyx_v_pdm.data + __pyx_t_16 * __pyx_v_pdm.strides[0]) )) + __pyx_t_17)) )));
</pre><pre class="cython line score-16" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">068</span>:             <span class="n">nd1</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">nd2</span><span class="p">]</span> <span class="o">=</span> <span class="n">dist</span></pre>
<pre class='cython code score-16 '>      __pyx_t_5 = <span class='py_c_api'>PyFloat_FromDouble</span>(__pyx_v_dist);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 68, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
      if (unlikely(__pyx_v_nd1-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 68, __pyx_L1_error)</span>
      }
      if (unlikely(<span class='py_c_api'>PyDict_SetItem</span>(__pyx_v_nd1-&gt;_nj_distances, ((PyObject *)__pyx_v_nd2), __pyx_t_5) &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 68, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
</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="n">nd1</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">+=</span> <span class="n">dist</span></pre>
<pre class='cython code score-0 '>      __pyx_v_nd1-&gt;_nj_xsub = (__pyx_v_nd1-&gt;_nj_xsub + __pyx_v_dist);
</pre><pre class="cython line score-0">&#xA0;<span class="">070</span>: </pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">071</span>:     <span class="k">while</span> <span class="n">n_pool</span> <span class="o">&gt;</span> <span class="mf">1</span><span class="p">:</span></pre>
<pre class='cython code score-0 '>  while (1) {
    __pyx_t_15 = ((__pyx_v_n_pool &gt; 1) != 0);
    if (!__pyx_t_15) break;
</pre><pre class="cython line score-0">&#xA0;<span class="">072</span>:         <span class="c"># calculate argmin of Q-matrix</span></pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">073</span>:         <span class="n">min_q</span> <span class="o">=</span> <span class="n">infty</span></pre>
<pre class='cython code score-0 '>    __pyx_v_min_q = __pyx_v_6geophy_8tree_dec_2nj_infty;
</pre><pre class="cython line score-1" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">074</span>:         <span class="n">n_pool</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">node_pool</span><span class="p">)</span></pre>
<pre class='cython code score-1 '>    __pyx_t_12 = <span class='py_macro_api'>PyList_GET_SIZE</span>(__pyx_v_node_pool);<span class='error_goto'> if (unlikely(__pyx_t_12 == ((Py_ssize_t)-1))) __PYX_ERR(0, 74, __pyx_L1_error)</span>
    __pyx_v_n_pool = __pyx_t_12;
</pre><pre class="cython line score-19" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">075</span>:         <span class="k">for</span> <span class="n">idx1</span><span class="p">,</span> <span class="n">nd1</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">node_pool</span><span class="p">[:</span><span class="o">-</span><span class="mf">1</span><span class="p">]):</span></pre>
<pre class='cython code score-19 '>    <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_int_0);
    __pyx_t_7 = __pyx_int_0;
    __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyList_GetSlice</span>(__pyx_v_node_pool, 0, -1L);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 75, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
    __pyx_t_5 = __pyx_t_2; <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_5); __pyx_t_12 = 0;
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
    for (;;) {
      if (__pyx_t_12 &gt;= <span class='py_macro_api'>PyList_GET_SIZE</span>(__pyx_t_5)) break;
      #if CYTHON_ASSUME_SAFE_MACROS &amp;&amp; !CYTHON_AVOID_BORROWED_REFS
      __pyx_t_2 = <span class='py_macro_api'>PyList_GET_ITEM</span>(__pyx_t_5, __pyx_t_12); <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_2); __pyx_t_12++; if (unlikely(0 &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 75, __pyx_L1_error)</span>
      #else
      __pyx_t_2 = <span class='py_macro_api'>PySequence_ITEM</span>(__pyx_t_5, __pyx_t_12); __pyx_t_12++;<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 75, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
      #endif
      if (!(likely(((__pyx_t_2) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_2, __pyx_ptype_6geophy_8tree_dec_2nj_Node))))) <span class='error_goto'>__PYX_ERR(0, 75, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_nd1, ((struct __pyx_obj_6geophy_8tree_dec_2nj_Node *)__pyx_t_2));
      __pyx_t_2 = 0;
      <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_7);
      <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_idx1, __pyx_t_7);
      __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyInt_AddObjC</span>(__pyx_t_7, __pyx_int_1, 1, 0, 0);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 75, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7);
      __pyx_t_7 = __pyx_t_2;
      __pyx_t_2 = 0;
/* … */
    }
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
</pre><pre class="cython line score-29" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">076</span>:             <span class="k">for</span> <span class="n">_</span><span class="p">,</span> <span class="n">nd2</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">node_pool</span><span class="p">[</span><span class="n">idx1</span> <span class="o">+</span> <span class="mf">1</span> <span class="p">:]):</span></pre>
<pre class='cython code score-29 '>      <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_int_0);
      __pyx_t_2 = __pyx_int_0;
      __pyx_t_4 = <span class='pyx_c_api'>__Pyx_PyInt_AddObjC</span>(__pyx_v_idx1, __pyx_int_1, 1, 0, 0);<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 76, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
      __pyx_t_15 = (__pyx_t_4 == Py_None);
      if (__pyx_t_15) {
        __pyx_t_13 = 0;
      } else {
        __pyx_t_18 = <span class='pyx_c_api'>__Pyx_PyIndex_AsSsize_t</span>(__pyx_t_4); if (unlikely((__pyx_t_18 == (Py_ssize_t)-1) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 76, __pyx_L1_error)</span>
        __pyx_t_13 = __pyx_t_18;
      }
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_4); __pyx_t_4 = 0;
      __pyx_t_4 = <span class='pyx_c_api'>__Pyx_PyList_GetSlice</span>(__pyx_v_node_pool, __pyx_t_13, PY_SSIZE_T_MAX);<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 76, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
      __pyx_t_3 = __pyx_t_4; <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_3); __pyx_t_13 = 0;
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_4); __pyx_t_4 = 0;
      for (;;) {
        if (__pyx_t_13 &gt;= <span class='py_macro_api'>PyList_GET_SIZE</span>(__pyx_t_3)) break;
        #if CYTHON_ASSUME_SAFE_MACROS &amp;&amp; !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_4 = <span class='py_macro_api'>PyList_GET_ITEM</span>(__pyx_t_3, __pyx_t_13); <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_4); __pyx_t_13++; if (unlikely(0 &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 76, __pyx_L1_error)</span>
        #else
        __pyx_t_4 = <span class='py_macro_api'>PySequence_ITEM</span>(__pyx_t_3, __pyx_t_13); __pyx_t_13++;<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 76, __pyx_L1_error)</span>
        <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
        #endif
        if (!(likely(((__pyx_t_4) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_4, __pyx_ptype_6geophy_8tree_dec_2nj_Node))))) <span class='error_goto'>__PYX_ERR(0, 76, __pyx_L1_error)</span>
        <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_nd2, ((struct __pyx_obj_6geophy_8tree_dec_2nj_Node *)__pyx_t_4));
        __pyx_t_4 = 0;
        <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_2);
        <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v__, __pyx_t_2);
        __pyx_t_4 = <span class='pyx_c_api'>__Pyx_PyInt_AddObjC</span>(__pyx_t_2, __pyx_int_1, 1, 0, 0);<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 76, __pyx_L1_error)</span>
        <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
        <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2);
        __pyx_t_2 = __pyx_t_4;
        __pyx_t_4 = 0;
/* … */
      }
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
</pre><pre class="cython line score-18" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">077</span>:                 <span class="n">v1</span> <span class="o">=</span> <span class="p">(</span><span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="p">(</span><span class="n">n_pool</span><span class="p">)</span> <span class="o">-</span> <span class="n">two</span><span class="p">)</span> <span class="o">*</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="p">(</span><span class="n">nd1</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">nd2</span><span class="p">])</span></pre>
<pre class='cython code score-18 '>        if (unlikely(__pyx_v_nd1-&gt;_nj_distances == Py_None)) {
          <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
          <span class='error_goto'>__PYX_ERR(0, 77, __pyx_L1_error)</span>
        }
        __pyx_t_4 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_nd1-&gt;_nj_distances, ((PyObject *)__pyx_v_nd2));<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 77, __pyx_L1_error)</span>
        <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
        __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_4); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 77, __pyx_L1_error)</span>
        <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_4); __pyx_t_4 = 0;
        __pyx_v_v1 = ((((__pyx_t_5numpy_double_t)__pyx_v_n_pool) - __pyx_v_two) * ((__pyx_t_5numpy_double_t)__pyx_t_19));
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">078</span>:                 <span class="n">qvalue</span> <span class="o">=</span> <span class="n">v1</span> <span class="o">-</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="n">nd1</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">-</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="n">nd2</span><span class="o">.</span><span class="n">_nj_xsub</span></pre>
<pre class='cython code score-0 '>        __pyx_v_qvalue = ((__pyx_v_v1 - ((__pyx_t_5numpy_double_t)__pyx_v_nd1-&gt;_nj_xsub)) - ((__pyx_t_5numpy_double_t)__pyx_v_nd2-&gt;_nj_xsub));
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">079</span>:                 <span class="k">if</span> <span class="n">qvalue</span> <span class="o">&lt;</span> <span class="n">min_q</span><span class="p">:</span></pre>
<pre class='cython code score-0 '>        __pyx_t_15 = ((__pyx_v_qvalue &lt; __pyx_v_min_q) != 0);
        if (__pyx_t_15) {
/* … */
        }
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">080</span>:                     <span class="n">min_q</span> <span class="o">=</span> <span class="n">qvalue</span></pre>
<pre class='cython code score-0 '>          __pyx_v_min_q = __pyx_v_qvalue;
</pre><pre class="cython line score-0">&#xA0;<span class="">081</span>:                     <span class="c">#nodes_to_join = (nd1, nd2)</span></pre>
<pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">082</span>:                     <span class="n">node_to_join1</span> <span class="o">=</span> <span class="n">nd1</span></pre>
<pre class='cython code score-2 '>          <span class='pyx_macro_api'>__Pyx_INCREF</span>(((PyObject *)__pyx_v_nd1));
          <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_node_to_join1, __pyx_v_nd1);
</pre><pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">083</span>:                     <span class="n">node_to_join2</span> <span class="o">=</span> <span class="n">nd2</span></pre>
<pre class='cython code score-2 '>          <span class='pyx_macro_api'>__Pyx_INCREF</span>(((PyObject *)__pyx_v_nd2));
          <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_node_to_join2, __pyx_v_nd2);
</pre><pre class="cython line score-0">&#xA0;<span class="">084</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">085</span>:         <span class="c"># create the new node</span></pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">086</span>:         <span class="n">int_i</span> <span class="o">=</span> <span class="n">n_taxa</span> <span class="o">-</span> <span class="n">n_pool</span></pre>
<pre class='cython code score-0 '>    __pyx_v_int_i = (__pyx_v_n_taxa - __pyx_v_n_pool);
</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">parent</span> <span class="o">=</span> <span class="n">int_i</span> <span class="o">+</span> <span class="n">n_taxa</span></pre>
<pre class='cython code score-0 '>    __pyx_v_parent = (__pyx_v_int_i + __pyx_v_n_taxa);
</pre><pre class="cython line score-6" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">088</span>:         <span class="n">new_node</span> <span class="o">=</span> <span class="n">Node</span><span class="p">(</span><span class="n">parent</span><span class="p">)</span></pre>
<pre class='cython code score-6 '>    __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyInt_From_int</span>(__pyx_v_parent);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 88, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
    __pyx_t_5 = <span class='pyx_c_api'>__Pyx_PyObject_CallOneArg</span>(((PyObject *)__pyx_ptype_6geophy_8tree_dec_2nj_Node), __pyx_t_7);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 88, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
    <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_new_node, ((struct __pyx_obj_6geophy_8tree_dec_2nj_Node *)__pyx_t_5));
    __pyx_t_5 = 0;
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">089</span>:         <span class="n">peel</span><span class="p">[</span><span class="n">int_i</span><span class="p">,</span> <span class="mf">2</span><span class="p">]</span> <span class="o">=</span> <span class="n">parent</span></pre>
<pre class='cython code score-0 '>    __pyx_t_17 = __pyx_v_int_i;
    __pyx_t_16 = 2;
    *__Pyx_BufPtrStrided2d(long *, __pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer.buf, __pyx_t_17, __pyx_pybuffernd_peel.diminfo[0].strides, __pyx_t_16, __pyx_pybuffernd_peel.diminfo[1].strides) = __pyx_v_parent;
</pre><pre class="cython line score-0">&#xA0;<span class="">090</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">091</span>:         <span class="c"># attach it to the tree</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">092</span>:         <span class="c">#peel[int_i, 0] = nodes_to_join[0].taxon</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">093</span>:         <span class="c">#peel[int_i, 1] = nodes_to_join[1].taxon</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">094</span>:         <span class="c">#node_pool.remove(nodes_to_join[0])</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">095</span>:         <span class="c">#node_pool.remove(nodes_to_join[1])</span></pre>
<pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">096</span>:         <span class="n">peel</span><span class="p">[</span><span class="n">int_i</span><span class="p">,</span> <span class="mf">0</span><span class="p">]</span> <span class="o">=</span> <span class="n">node_to_join1</span><span class="o">.</span><span class="n">taxon</span></pre>
<pre class='cython code score-2 '>    if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 96, __pyx_L1_error)</span> }
    __pyx_t_9 = __pyx_v_node_to_join1-&gt;taxon;
    __pyx_t_16 = __pyx_v_int_i;
    __pyx_t_17 = 0;
    *__Pyx_BufPtrStrided2d(long *, __pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer.buf, __pyx_t_16, __pyx_pybuffernd_peel.diminfo[0].strides, __pyx_t_17, __pyx_pybuffernd_peel.diminfo[1].strides) = __pyx_t_9;
</pre><pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">097</span>:         <span class="n">peel</span><span class="p">[</span><span class="n">int_i</span><span class="p">,</span> <span class="mf">1</span><span class="p">]</span> <span class="o">=</span> <span class="n">node_to_join2</span><span class="o">.</span><span class="n">taxon</span></pre>
<pre class='cython code score-2 '>    if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 97, __pyx_L1_error)</span> }
    __pyx_t_9 = __pyx_v_node_to_join2-&gt;taxon;
    __pyx_t_17 = __pyx_v_int_i;
    __pyx_t_16 = 1;
    *__Pyx_BufPtrStrided2d(long *, __pyx_pybuffernd_peel.rcbuffer-&gt;pybuffer.buf, __pyx_t_17, __pyx_pybuffernd_peel.diminfo[0].strides, __pyx_t_16, __pyx_pybuffernd_peel.diminfo[1].strides) = __pyx_t_9;
</pre><pre class="cython line score-3" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">098</span>:         <span class="n">node_pool</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">node_to_join1</span><span class="p">)</span></pre>
<pre class='cython code score-3 '>    if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 98, __pyx_L1_error)</span> }
    __pyx_t_5 = __Pyx_CallUnboundCMethod1(&amp;__pyx_umethod_PyList_Type_remove, __pyx_v_node_pool, ((PyObject *)__pyx_v_node_to_join1));<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 98, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
</pre><pre class="cython line score-3" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">099</span>:         <span class="n">node_pool</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">node_to_join2</span><span class="p">)</span></pre>
<pre class='cython code score-3 '>    if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 99, __pyx_L1_error)</span> }
    __pyx_t_5 = __Pyx_CallUnboundCMethod1(&amp;__pyx_umethod_PyList_Type_remove, __pyx_v_node_pool, ((PyObject *)__pyx_v_node_to_join2));<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 99, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
</pre><pre class="cython line score-0">&#xA0;<span class="">100</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">101</span>:         <span class="c"># calculate the distances for the new node</span></pre>
<pre class="cython line score-9" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">102</span>:         <span class="k">for</span> <span class="n">nd</span> <span class="ow">in</span> <span class="n">node_pool</span><span class="p">:</span></pre>
<pre class='cython code score-9 '>    __pyx_t_5 = __pyx_v_node_pool; <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_5); __pyx_t_12 = 0;
    for (;;) {
      if (__pyx_t_12 &gt;= <span class='py_macro_api'>PyList_GET_SIZE</span>(__pyx_t_5)) break;
      #if CYTHON_ASSUME_SAFE_MACROS &amp;&amp; !CYTHON_AVOID_BORROWED_REFS
      __pyx_t_7 = <span class='py_macro_api'>PyList_GET_ITEM</span>(__pyx_t_5, __pyx_t_12); <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_7); __pyx_t_12++; if (unlikely(0 &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 102, __pyx_L1_error)</span>
      #else
      __pyx_t_7 = <span class='py_macro_api'>PySequence_ITEM</span>(__pyx_t_5, __pyx_t_12); __pyx_t_12++;<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 102, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      #endif
      if (!(likely(((__pyx_t_7) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_7, __pyx_ptype_6geophy_8tree_dec_2nj_Node))))) <span class='error_goto'>__PYX_ERR(0, 102, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_XDECREF_SET</span>(__pyx_v_nd, ((struct __pyx_obj_6geophy_8tree_dec_2nj_Node *)__pyx_t_7));
      __pyx_t_7 = 0;
/* … */
    }
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
</pre><pre class="cython line score-0">&#xA0;<span class="">103</span>:             <span class="c"># actual node-to-node distances</span></pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">104</span>:             <span class="n">v1</span> <span class="o">=</span> <span class="mf">0.0</span></pre>
<pre class='cython code score-0 '>      __pyx_v_v1 = 0.0;
</pre><pre class="cython line score-0">&#xA0;<span class="">105</span>:             <span class="c">#for node_to_join in nodes_to_join:</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">106</span>:             <span class="c">#    v1 += &lt;np.double_t&gt;nd._nj_distances[node_to_join]</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">107</span>:             <span class="c">#v3 = nodes_to_join[0]._nj_distances[nodes_to_join[1]]</span></pre>
<pre class="cython line score-20" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">108</span>:             <span class="n">v1</span> <span class="o">+=</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="n">nd</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">node_to_join1</span><span class="p">]</span></pre>
<pre class='cython code score-20 '>      if (unlikely(__pyx_v_nd-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 108, __pyx_L1_error)</span>
      }
      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 108, __pyx_L1_error)</span> }
      __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_nd-&gt;_nj_distances, ((PyObject *)__pyx_v_node_to_join1));<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 108, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 108, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_v_v1 = (__pyx_v_v1 + ((__pyx_t_5numpy_double_t)__pyx_t_19));
</pre><pre class="cython line score-20" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">109</span>:             <span class="n">v1</span> <span class="o">+=</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="n">nd</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">node_to_join2</span><span class="p">]</span></pre>
<pre class='cython code score-20 '>      if (unlikely(__pyx_v_nd-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 109, __pyx_L1_error)</span>
      }
      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 109, __pyx_L1_error)</span> }
      __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_nd-&gt;_nj_distances, ((PyObject *)__pyx_v_node_to_join2));<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 109, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 109, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_v_v1 = (__pyx_v_v1 + ((__pyx_t_5numpy_double_t)__pyx_t_19));
</pre><pre class="cython line score-22" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">110</span>:             <span class="n">v3</span> <span class="o">=</span> <span class="n">node_to_join1</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">node_to_join2</span><span class="p">]</span></pre>
<pre class='cython code score-22 '>      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 110, __pyx_L1_error)</span> }
      if (unlikely(__pyx_v_node_to_join1-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 110, __pyx_L1_error)</span>
      }
      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 110, __pyx_L1_error)</span> }
      __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_node_to_join1-&gt;_nj_distances, ((PyObject *)__pyx_v_node_to_join2));<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 110, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 110, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_v_v3 = __pyx_t_19;
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">111</span>:             <span class="n">dist</span> <span class="o">=</span> <span class="mf">0.5</span> <span class="o">*</span> <span class="p">(</span><span class="n">v1</span> <span class="o">-</span> <span class="n">v3</span><span class="p">)</span></pre>
<pre class='cython code score-0 '>      __pyx_v_dist = (0.5 * (__pyx_v_v1 - __pyx_v_v3));
</pre><pre class="cython line score-16" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">112</span>:             <span class="n">new_node</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">nd</span><span class="p">]</span> <span class="o">=</span> <span class="n">dist</span></pre>
<pre class='cython code score-16 '>      __pyx_t_7 = <span class='py_c_api'>PyFloat_FromDouble</span>(__pyx_v_dist);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 112, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      if (unlikely(__pyx_v_new_node-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 112, __pyx_L1_error)</span>
      }
      if (unlikely(<span class='py_c_api'>PyDict_SetItem</span>(__pyx_v_new_node-&gt;_nj_distances, ((PyObject *)__pyx_v_nd), __pyx_t_7) &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 112, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
</pre><pre class="cython line score-16" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">113</span>:             <span class="n">nd</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">new_node</span><span class="p">]</span> <span class="o">=</span> <span class="n">dist</span></pre>
<pre class='cython code score-16 '>      __pyx_t_7 = <span class='py_c_api'>PyFloat_FromDouble</span>(__pyx_v_dist);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 113, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      if (unlikely(__pyx_v_nd-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 113, __pyx_L1_error)</span>
      }
      if (unlikely(<span class='py_c_api'>PyDict_SetItem</span>(__pyx_v_nd-&gt;_nj_distances, ((PyObject *)__pyx_v_new_node), __pyx_t_7) &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 113, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
</pre><pre class="cython line score-0">&#xA0;<span class="">114</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">115</span>:             <span class="c"># Adjust/recalculate the values needed for the Q-matrix calculation</span></pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">116</span>:             <span class="n">new_node</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">+=</span> <span class="n">dist</span></pre>
<pre class='cython code score-0 '>      __pyx_v_new_node-&gt;_nj_xsub = (__pyx_v_new_node-&gt;_nj_xsub + __pyx_v_dist);
</pre><pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">117</span>:             <span class="n">nd</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">+=</span> <span class="n">dist</span></pre>
<pre class='cython code score-0 '>      __pyx_v_nd-&gt;_nj_xsub = (__pyx_v_nd-&gt;_nj_xsub + __pyx_v_dist);
</pre><pre class="cython line score-0">&#xA0;<span class="">118</span>:             <span class="c">#for node_to_join in nodes_to_join:</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">119</span>:             <span class="c">#    nd._nj_xsub -= &lt;np.double_t&gt;node_to_join._nj_distances[nd]</span></pre>
<pre class="cython line score-20" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">120</span>:             <span class="n">nd</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">-=</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="n">node_to_join1</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">nd</span><span class="p">]</span></pre>
<pre class='cython code score-20 '>      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 120, __pyx_L1_error)</span> }
      if (unlikely(__pyx_v_node_to_join1-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 120, __pyx_L1_error)</span>
      }
      __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_node_to_join1-&gt;_nj_distances, ((PyObject *)__pyx_v_nd));<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 120, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 120, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_v_nd-&gt;_nj_xsub = (__pyx_v_nd-&gt;_nj_xsub - ((__pyx_t_5numpy_double_t)__pyx_t_19));
</pre><pre class="cython line score-20" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">121</span>:             <span class="n">nd</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">-=</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="n">node_to_join2</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">nd</span><span class="p">]</span></pre>
<pre class='cython code score-20 '>      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 121, __pyx_L1_error)</span> }
      if (unlikely(__pyx_v_node_to_join2-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 121, __pyx_L1_error)</span>
      }
      __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_node_to_join2-&gt;_nj_distances, ((PyObject *)__pyx_v_nd));<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 121, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 121, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_v_nd-&gt;_nj_xsub = (__pyx_v_nd-&gt;_nj_xsub - ((__pyx_t_5numpy_double_t)__pyx_t_19));
</pre><pre class="cython line score-0">&#xA0;<span class="">122</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">123</span>:         <span class="c"># calculate the branch lengths</span></pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">124</span>:         <span class="k">if</span> <span class="n">n_pool</span> <span class="o">&gt;</span> <span class="mf">2</span><span class="p">:</span></pre>
<pre class='cython code score-0 '>    __pyx_t_15 = ((__pyx_v_n_pool &gt; 2) != 0);
    if (__pyx_t_15) {
/* … */
      goto __pyx_L19;
    }
</pre><pre class="cython line score-0">&#xA0;<span class="">125</span>:             <span class="c">#v1 = 0.5 * nodes_to_join[0]._nj_distances[nodes_to_join[1]]</span></pre>
<pre class="cython line score-28" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">126</span>:             <span class="n">v1</span> <span class="o">=</span> <span class="mf">0.5</span> <span class="o">*</span> <span class="n">node_to_join1</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">node_to_join2</span><span class="p">]</span></pre>
<pre class='cython code score-28 '>      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 126, __pyx_L1_error)</span> }
      if (unlikely(__pyx_v_node_to_join1-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 126, __pyx_L1_error)</span>
      }
      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 126, __pyx_L1_error)</span> }
      __pyx_t_5 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_node_to_join1-&gt;_nj_distances, ((PyObject *)__pyx_v_node_to_join2));<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 126, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
      __pyx_t_7 = <span class='py_c_api'>PyNumber_Multiply</span>(__pyx_float_0_5, __pyx_t_5);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 126, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
      __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 126, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_v_v1 = __pyx_t_19;
</pre><pre class="cython line score-0">&#xA0;<span class="">127</span>:             <span class="n">v4</span> <span class="o">=</span> <span class="p">(</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">128</span>:                 <span class="mf">1.0</span></pre>
<pre class="cython line score-5" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">129</span>:                 <span class="o">/</span> <span class="p">(</span><span class="n">two</span> <span class="o">*</span> <span class="p">(</span><span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="n">n_pool</span> <span class="o">-</span> <span class="n">two</span><span class="p">))</span></pre>
<pre class='cython code score-5 '>      __pyx_t_19 = (__pyx_v_two * (((__pyx_t_5numpy_double_t)__pyx_v_n_pool) - __pyx_v_two));
      if (unlikely(__pyx_t_19 == 0)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_ZeroDivisionError, "float division");
        <span class='error_goto'>__PYX_ERR(0, 129, __pyx_L1_error)</span>
      }
</pre><pre class="cython line score-0">&#xA0;<span class="">130</span>:                 <span class="c">#* (nodes_to_join[0]._nj_xsub - nodes_to_join[1]._nj_xsub)</span></pre>
<pre class="cython line score-4" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">131</span>:                 <span class="o">*</span> <span class="p">(</span><span class="n">node_to_join1</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">-</span> <span class="n">node_to_join2</span><span class="o">.</span><span class="n">_nj_xsub</span><span class="p">)</span></pre>
<pre class='cython code score-4 '>      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 131, __pyx_L1_error)</span> }
      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 131, __pyx_L1_error)</span> }
      __pyx_v_v4 = ((((__pyx_t_5numpy_double_t)1.0) / __pyx_t_19) * (__pyx_v_node_to_join1-&gt;_nj_xsub - __pyx_v_node_to_join2-&gt;_nj_xsub));
</pre><pre class="cython line score-0">&#xA0;<span class="">132</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="">133</span>:             <span class="n">delta_f</span> <span class="o">=</span> <span class="n">v1</span> <span class="o">+</span> <span class="n">v4</span></pre>
<pre class='cython code score-0 '>      __pyx_v_delta_f = (__pyx_v_v1 + __pyx_v_v4);
</pre><pre class="cython line score-0">&#xA0;<span class="">134</span>:             <span class="c">#delta_g = &lt;np.double_t&gt;nodes_to_join[0]._nj_distances[nodes_to_join[1]] - delta_f</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">135</span>:             <span class="c">#blens[nodes_to_join[0].taxon] = delta_f</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">136</span>:             <span class="c">#blens[nodes_to_join[1].taxon] = delta_g</span></pre>
<pre class="cython line score-22" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">137</span>:             <span class="n">delta_g</span> <span class="o">=</span> <span class="o">&lt;</span><span class="n">np</span><span class="o">.</span><span class="n">double_t</span><span class="o">&gt;</span><span class="n">node_to_join1</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">node_to_join2</span><span class="p">]</span> <span class="o">-</span> <span class="n">delta_f</span></pre>
<pre class='cython code score-22 '>      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 137, __pyx_L1_error)</span> }
      if (unlikely(__pyx_v_node_to_join1-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 137, __pyx_L1_error)</span>
      }
      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 137, __pyx_L1_error)</span> }
      __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_node_to_join1-&gt;_nj_distances, ((PyObject *)__pyx_v_node_to_join2));<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 137, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 137, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_v_delta_g = (((__pyx_t_5numpy_double_t)__pyx_t_19) - __pyx_v_delta_f);
</pre><pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">138</span>:             <span class="n">blens</span><span class="p">[</span><span class="n">node_to_join1</span><span class="o">.</span><span class="n">taxon</span><span class="p">]</span> <span class="o">=</span> <span class="n">delta_f</span></pre>
<pre class='cython code score-2 '>      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 138, __pyx_L1_error)</span> }
      __pyx_t_16 = __pyx_v_node_to_join1-&gt;taxon;
      *__Pyx_BufPtrStrided1d(__pyx_t_5numpy_double_t *, __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.buf, __pyx_t_16, __pyx_pybuffernd_blens.diminfo[0].strides) = __pyx_v_delta_f;
</pre><pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">139</span>:             <span class="n">blens</span><span class="p">[</span><span class="n">node_to_join2</span><span class="o">.</span><span class="n">taxon</span><span class="p">]</span> <span class="o">=</span> <span class="n">delta_g</span></pre>
<pre class='cython code score-2 '>      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 139, __pyx_L1_error)</span> }
      __pyx_t_16 = __pyx_v_node_to_join2-&gt;taxon;
      *__Pyx_BufPtrStrided1d(__pyx_t_5numpy_double_t *, __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.buf, __pyx_t_16, __pyx_pybuffernd_blens.diminfo[0].strides) = __pyx_v_delta_g;
</pre><pre class="cython line score-0">&#xA0;<span class="">140</span>:         <span class="k">else</span><span class="p">:</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">141</span>:             <span class="c">#dist = nodes_to_join[0]._nj_distances[nodes_to_join[1]]</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">142</span>:             <span class="c">#blens[nodes_to_join[0].taxon] = dist / two</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">143</span>:             <span class="c">#blens[nodes_to_join[1].taxon] = dist / two</span></pre>
<pre class="cython line score-22" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">144</span>:             <span class="n">dist</span> <span class="o">=</span> <span class="n">node_to_join1</span><span class="o">.</span><span class="n">_nj_distances</span><span class="p">[</span><span class="n">node_to_join2</span><span class="p">]</span></pre>
<pre class='cython code score-22 '>    /*else*/ {
      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 144, __pyx_L1_error)</span> }
      if (unlikely(__pyx_v_node_to_join1-&gt;_nj_distances == Py_None)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_TypeError, "'NoneType' object is not subscriptable");
        <span class='error_goto'>__PYX_ERR(0, 144, __pyx_L1_error)</span>
      }
      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 144, __pyx_L1_error)</span> }
      __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_GetItem</span>(__pyx_v_node_to_join1-&gt;_nj_distances, ((PyObject *)__pyx_v_node_to_join2));<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 144, __pyx_L1_error)</span>
      <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
      __pyx_t_19 = __pyx_<span class='py_c_api'>PyFloat_AsDouble</span>(__pyx_t_7); if (unlikely((__pyx_t_19 == ((npy_double)-1)) &amp;&amp; <span class='py_c_api'>PyErr_Occurred</span>())) <span class='error_goto'>__PYX_ERR(0, 144, __pyx_L1_error)</span>
      <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_v_dist = __pyx_t_19;
</pre><pre class="cython line score-7" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">145</span>:             <span class="n">blens</span><span class="p">[</span><span class="n">node_to_join1</span><span class="o">.</span><span class="n">taxon</span><span class="p">]</span> <span class="o">=</span> <span class="n">dist</span> <span class="o">/</span> <span class="n">two</span></pre>
<pre class='cython code score-7 '>      if (unlikely(__pyx_v_two == 0)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_ZeroDivisionError, "float division");
        <span class='error_goto'>__PYX_ERR(0, 145, __pyx_L1_error)</span>
      }
      if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 145, __pyx_L1_error)</span> }
      __pyx_t_16 = __pyx_v_node_to_join1-&gt;taxon;
      *__Pyx_BufPtrStrided1d(__pyx_t_5numpy_double_t *, __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.buf, __pyx_t_16, __pyx_pybuffernd_blens.diminfo[0].strides) = (__pyx_v_dist / __pyx_v_two);
</pre><pre class="cython line score-7" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">146</span>:             <span class="n">blens</span><span class="p">[</span><span class="n">node_to_join2</span><span class="o">.</span><span class="n">taxon</span><span class="p">]</span> <span class="o">=</span> <span class="n">dist</span> <span class="o">/</span> <span class="n">two</span></pre>
<pre class='cython code score-7 '>      if (unlikely(__pyx_v_two == 0)) {
        <span class='py_c_api'>PyErr_SetString</span>(PyExc_ZeroDivisionError, "float division");
        <span class='error_goto'>__PYX_ERR(0, 146, __pyx_L1_error)</span>
      }
      if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 146, __pyx_L1_error)</span> }
      __pyx_t_16 = __pyx_v_node_to_join2-&gt;taxon;
      *__Pyx_BufPtrStrided1d(__pyx_t_5numpy_double_t *, __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.buf, __pyx_t_16, __pyx_pybuffernd_blens.diminfo[0].strides) = (__pyx_v_dist / __pyx_v_two);
    }
    __pyx_L19:;
</pre><pre class="cython line score-0">&#xA0;<span class="">147</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">148</span>:         <span class="c"># clean up</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">149</span>:         <span class="c">#for node_to_join in nodes_to_join:</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">150</span>:         <span class="c">#    node_to_join._nj_distances = {}</span></pre>
<pre class="cython line score-0">&#xA0;<span class="">151</span>:         <span class="c">#    node_to_join._nj_xsub = 0.0</span></pre>
<pre class="cython line score-5" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">152</span>:         <span class="n">node_to_join1</span><span class="o">.</span><span class="n">_nj_distances</span> <span class="o">=</span> <span class="p">{}</span></pre>
<pre class='cython code score-5 '>    __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(0);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 152, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
    if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 152, __pyx_L1_error)</span> }
    <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_7);
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_v_node_to_join1-&gt;_nj_distances);
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_v_node_to_join1-&gt;_nj_distances);
    __pyx_v_node_to_join1-&gt;_nj_distances = ((PyObject*)__pyx_t_7);
    __pyx_t_7 = 0;
</pre><pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">153</span>:         <span class="n">node_to_join1</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">=</span> <span class="mf">0.0</span></pre>
<pre class='cython code score-2 '>    if (unlikely(!__pyx_v_node_to_join1)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join1"); <span class='error_goto'>__PYX_ERR(0, 153, __pyx_L1_error)</span> }
    __pyx_v_node_to_join1-&gt;_nj_xsub = 0.0;
</pre><pre class="cython line score-5" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">154</span>:         <span class="n">node_to_join2</span><span class="o">.</span><span class="n">_nj_distances</span> <span class="o">=</span> <span class="p">{}</span></pre>
<pre class='cython code score-5 '>    __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyDict_NewPresized</span>(0);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 154, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
    if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 154, __pyx_L1_error)</span> }
    <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_7);
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_v_node_to_join2-&gt;_nj_distances);
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_v_node_to_join2-&gt;_nj_distances);
    __pyx_v_node_to_join2-&gt;_nj_distances = ((PyObject*)__pyx_t_7);
    __pyx_t_7 = 0;
</pre><pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">155</span>:         <span class="n">node_to_join2</span><span class="o">.</span><span class="n">_nj_xsub</span> <span class="o">=</span> <span class="mf">0.0</span></pre>
<pre class='cython code score-2 '>    if (unlikely(!__pyx_v_node_to_join2)) { <span class='pyx_c_api'>__Pyx_RaiseUnboundLocalError</span>("node_to_join2"); <span class='error_goto'>__PYX_ERR(0, 155, __pyx_L1_error)</span> }
    __pyx_v_node_to_join2-&gt;_nj_xsub = 0.0;
</pre><pre class="cython line score-0">&#xA0;<span class="">156</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">157</span>:         <span class="c"># add the new node to the pool of nodes</span></pre>
<pre class="cython line score-2" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">158</span>:         <span class="n">node_pool</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">new_node</span><span class="p">)</span></pre>
<pre class='cython code score-2 '>    __pyx_t_20 = <span class='pyx_c_api'>__Pyx_PyList_Append</span>(__pyx_v_node_pool, ((PyObject *)__pyx_v_new_node));<span class='error_goto'> if (unlikely(__pyx_t_20 == ((int)-1))) __PYX_ERR(0, 158, __pyx_L1_error)</span>
</pre><pre class="cython line score-0">&#xA0;<span class="">159</span>: </pre>
<pre class="cython line score-0">&#xA0;<span class="">160</span>:         <span class="c"># adjust count</span></pre>
<pre class="cython line score-0" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">161</span>:         <span class="n">n_pool</span> <span class="o">-=</span> <span class="mf">1</span></pre>
<pre class='cython code score-0 '>    __pyx_v_n_pool = (__pyx_v_n_pool - 1);
  }
</pre><pre class="cython line score-69" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">162</span>:     <span class="n">blens</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">maximum</span><span class="p">(</span><span class="n">blens</span><span class="p">,</span> <span class="n">eps</span><span class="p">)</span></pre>
<pre class='cython code score-69 '>  <span class='pyx_c_api'>__Pyx_GetModuleGlobalName</span>(__pyx_t_5, __pyx_n_s_np);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 162, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
  __pyx_t_2 = <span class='pyx_c_api'>__Pyx_PyObject_GetAttrStr</span>(__pyx_t_5, __pyx_n_s_maximum);<span class='error_goto'> if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 162, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_2);
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = <span class='py_c_api'>PyFloat_FromDouble</span>(__pyx_v_6geophy_8tree_dec_2nj_eps);<span class='error_goto'> if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 162, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_5);
  __pyx_t_3 = NULL;
  __pyx_t_9 = 0;
  if (CYTHON_UNPACK_METHODS &amp;&amp; unlikely(<span class='py_c_api'>PyMethod_Check</span>(__pyx_t_2))) {
    __pyx_t_3 = <span class='py_macro_api'>PyMethod_GET_SELF</span>(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = <span class='py_macro_api'>PyMethod_GET_FUNCTION</span>(__pyx_t_2);
      <span class='pyx_macro_api'>__Pyx_INCREF</span>(__pyx_t_3);
      <span class='pyx_macro_api'>__Pyx_INCREF</span>(function);
      <span class='pyx_macro_api'>__Pyx_DECREF_SET</span>(__pyx_t_2, function);
      __pyx_t_9 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (<span class='py_c_api'>PyFunction_Check</span>(__pyx_t_2)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, ((PyObject *)__pyx_v_blens), __pyx_t_5};
    __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyFunction_FastCall</span>(__pyx_t_2, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 162, __pyx_L1_error)</span>
    <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (<span class='pyx_c_api'>__Pyx_PyFastCFunction_Check</span>(__pyx_t_2)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, ((PyObject *)__pyx_v_blens), __pyx_t_5};
    __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyCFunction_FastCall</span>(__pyx_t_2, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 162, __pyx_L1_error)</span>
    <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_t_3); __pyx_t_3 = 0;
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_5); __pyx_t_5 = 0;
  } else
  #endif
  {
    __pyx_t_4 = <span class='py_c_api'>PyTuple_New</span>(2+__pyx_t_9);<span class='error_goto'> if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 162, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_4);
    if (__pyx_t_3) {
      <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_3); <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_4, 0, __pyx_t_3); __pyx_t_3 = NULL;
    }
    <span class='pyx_macro_api'>__Pyx_INCREF</span>(((PyObject *)__pyx_v_blens));
    <span class='refnanny'>__Pyx_GIVEREF</span>(((PyObject *)__pyx_v_blens));
    <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_4, 0+__pyx_t_9, ((PyObject *)__pyx_v_blens));
    <span class='refnanny'>__Pyx_GIVEREF</span>(__pyx_t_5);
    <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_4, 1+__pyx_t_9, __pyx_t_5);
    __pyx_t_5 = 0;
    __pyx_t_7 = <span class='pyx_c_api'>__Pyx_PyObject_Call</span>(__pyx_t_2, __pyx_t_4, NULL);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 162, __pyx_L1_error)</span>
    <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
    <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_4); __pyx_t_4 = 0;
  }
  <span class='pyx_macro_api'>__Pyx_DECREF</span>(__pyx_t_2); __pyx_t_2 = 0;
  if (!(likely(((__pyx_t_7) == Py_None) || likely(<span class='pyx_c_api'>__Pyx_TypeTest</span>(__pyx_t_7, __pyx_ptype_5numpy_ndarray))))) <span class='error_goto'>__PYX_ERR(0, 162, __pyx_L1_error)</span>
  __pyx_t_8 = ((PyArrayObject *)__pyx_t_7);
  {
    __Pyx_BufFmt_StackElem __pyx_stack[1];
    <span class='pyx_c_api'>__Pyx_SafeReleaseBuffer</span>(&amp;__pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer);
    __pyx_t_9 = <span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&amp;__pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer, (PyObject*)__pyx_t_8, &amp;__Pyx_TypeInfo_nn___pyx_t_5numpy_double_t, PyBUF_FORMAT| PyBUF_STRIDES| PyBUF_WRITABLE, 1, 0, __pyx_stack);
    if (unlikely(__pyx_t_9 &lt; 0)) {
      <span class='py_c_api'>PyErr_Fetch</span>(&amp;__pyx_t_21, &amp;__pyx_t_22, &amp;__pyx_t_23);
      if (unlikely(<span class='pyx_c_api'>__Pyx_GetBufferAndValidate</span>(&amp;__pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer, (PyObject*)__pyx_v_blens, &amp;__Pyx_TypeInfo_nn___pyx_t_5numpy_double_t, PyBUF_FORMAT| PyBUF_STRIDES| PyBUF_WRITABLE, 1, 0, __pyx_stack) == -1)) {
        Py_XDECREF(__pyx_t_21); Py_XDECREF(__pyx_t_22); Py_XDECREF(__pyx_t_23);
        <span class='pyx_c_api'>__Pyx_RaiseBufferFallbackError</span>();
      } else {
        <span class='py_c_api'>PyErr_Restore</span>(__pyx_t_21, __pyx_t_22, __pyx_t_23);
      }
      __pyx_t_21 = __pyx_t_22 = __pyx_t_23 = 0;
    }
    __pyx_pybuffernd_blens.diminfo[0].strides = __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.strides[0]; __pyx_pybuffernd_blens.diminfo[0].shape = __pyx_pybuffernd_blens.rcbuffer-&gt;pybuffer.shape[0];
    if (unlikely(__pyx_t_9 &lt; 0)) <span class='error_goto'>__PYX_ERR(0, 162, __pyx_L1_error)</span>
  }
  __pyx_t_8 = 0;
  <span class='pyx_macro_api'>__Pyx_DECREF_SET</span>(__pyx_v_blens, ((PyArrayObject *)__pyx_t_7));
  __pyx_t_7 = 0;
</pre><pre class="cython line score-10" onclick="(function(s){s.display=s.display==='block'?'none':'block'})(this.nextElementSibling.style)">+<span class="">163</span>:     <span class="k">return</span> <span class="n">peel</span><span class="p">,</span> <span class="n">blens</span></pre>
<pre class='cython code score-10 '>  <span class='pyx_macro_api'>__Pyx_XDECREF</span>(__pyx_r);
  __pyx_t_7 = <span class='py_c_api'>PyTuple_New</span>(2);<span class='error_goto'> if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 163, __pyx_L1_error)</span>
  <span class='refnanny'>__Pyx_GOTREF</span>(__pyx_t_7);
  <span class='pyx_macro_api'>__Pyx_INCREF</span>(((PyObject *)__pyx_v_peel));
  <span class='refnanny'>__Pyx_GIVEREF</span>(((PyObject *)__pyx_v_peel));
  <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_7, 0, ((PyObject *)__pyx_v_peel));
  <span class='pyx_macro_api'>__Pyx_INCREF</span>(((PyObject *)__pyx_v_blens));
  <span class='refnanny'>__Pyx_GIVEREF</span>(((PyObject *)__pyx_v_blens));
  <span class='py_macro_api'>PyTuple_SET_ITEM</span>(__pyx_t_7, 1, ((PyObject *)__pyx_v_blens));
  __pyx_r = __pyx_t_7;
  __pyx_t_7 = 0;
  goto __pyx_L0;
</pre></div></body></html>
