Maison >développement back-end >Tutoriel Python >Déduplication de tableau de points Python numpy

Déduplication de tableau de points Python numpy

不言
不言original
2018-04-18 11:04:132011parcourir

Ce qui suit est un exemple de déduplication de tableau de points numpy Python. Il a une bonne valeur de référence et j'espère qu'il sera utile à tout le monde. Venez jeter un œil ensemble

Pas d'autres bêtises, il suffit de vous rendre sur le code, avec des commentaires détaillés

# coding = utf-8
import numpy as np
from IPython import embed
# xy 输入,可支持浮点数操作 速度很快哦
# return xy 去重后结果
def duplicate_removal(xy):
  if xy.shape[0] < 2:
    return xy
  _tmp = (xy*4000).astype(&#39;i4&#39;)          # 转换成 i4 处理
  _tmp = _tmp[:,0] + _tmp[:,1]*1j         # 转换成复数处理 
  keep = np.unique(_tmp, return_index=True)[1]  # 去重 得到索引                  
  return xy[keep]                 # 得到数据并返回  
# _tmp[:,0] 切片操作,因为时二维数组,_tmp[a:b, c:d]为通用表达式,
# 表示取第一维的索引 a 到索引 b,和第二维的索引 c 到索引 d
# 当取所有时可以直接省略,但要加&#39;:&#39;冒号 、当 a == b 时可只写 a ,同时不用&#39;:&#39;冒号
if __name__ == &#39;__main__&#39;:
  if 1: # test
    xy = np.array([[1.0, 1.0, 1.0], [2.0, 2.0, 2.0], [3.0, 0.0, 0.0], [1.0, 1.0, 1.00]])
    print(xy)
    new_xy = duplicate_removal(xy)
    print(new_xy)
  embed()

Recommandations associées :

Trouver la valeur maximale du tableau numpy et sa méthode d'indexation

Implémentation du tableau ndarray dans numpy Renvoie les méthodes d'index qui répondent à des conditions spécifiques


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Article précédent:Axes et dimensions en numpyArticle suivant:Axes et dimensions en numpy