তবুও অন্য বিকল্পটি হ'ল einsum
উভয় অ্যারেতে ফাংশনটি নাম্পায় ব্যবহার করা:
In [1]: import numpy as np
In [2]: a = np.arange(1200.0).reshape((-1,3))
In [3]: %timeit [np.linalg.norm(x) for x in a]
100 loops, best of 3: 3.86 ms per loop
In [4]: %timeit np.sqrt((a*a).sum(axis=1))
100000 loops, best of 3: 15.6 µs per loop
In [5]: %timeit np.sqrt(np.einsum('ij,ij->i',a,a))
100000 loops, best of 3: 8.71 µs per loop
বা ভেক্টর:
In [5]: a = np.arange(100000)
In [6]: %timeit np.sqrt(a.dot(a))
10000 loops, best of 3: 80.8 µs per loop
In [7]: %timeit np.sqrt(np.einsum('i,i', a, a))
10000 loops, best of 3: 60.6 µs per loop
তবে এটি বলার সাথে কিছু ওভারহেড যুক্ত বলে মনে হচ্ছে যা এটি ছোট ইনপুটগুলির সাহায্যে ধীর করে দিতে পারে:
In [2]: a = np.arange(100)
In [3]: %timeit np.sqrt(a.dot(a))
100000 loops, best of 3: 3.73 µs per loop
In [4]: %timeit np.sqrt(np.einsum('i,i', a, a))
100000 loops, best of 3: 4.68 µs per loop
linalg.norm
নীচে উল্লিখিত হিসাবে ব্যবহার করি । তবে আপনার ল্যাম্বদা জিনিসটির চেয়ে কিছুটা সহজ, কোনও আমদানির প্রয়োজন নেই, কেবলsum(x*x)**0.5