本文整理匯總了Python中torch.argmin方法的典型用法代碼示例。如果您正苦於以下問題:Python torch.argmin方法的具體用法?Python torch.argmin怎麽用?Python torch.argmin使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類torch
的用法示例。
在下文中一共展示了torch.argmin方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: kmeans
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def kmeans(input, n_clusters=16, tol=1e-6):
"""
TODO: check correctness
"""
indices = torch.Tensor(np.random.choice(input.size(-1), n_clusters))
values = input[:, :, indices]
while True:
dist = func.pairwise_distance(
input.unsqueeze(2).expand(-1, -1, values.size(2), input.size(2)).reshape(
input.size(0), input.size(1), input.size(2) * values.size(2)),
values.unsqueeze(3).expand(-1, -1, values.size(2), input.size(2)).reshape(
input.size(0), input.size(1), input.size(2) * values.size(2))
)
choice_cluster = torch.argmin(dist, dim=1)
old_values = values
values = input[choice_cluster.nonzeros()]
shift = (old_values - values).norm(dim=1)
if shift.max() ** 2 < tol:
break
return values
示例2: forward
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def forward(self, grammian):
"""Planar case solver, when Vi lies on the same plane
Args:
grammian: grammian matrix G[i, j] = [<Vi, Vj>], G is a nxn tensor
Returns:
sol: coefficients c = [c1, ... cn] that solves the min-norm problem
"""
vivj = grammian[self.ii_triu, self.jj_triu]
vivi = grammian[self.ii_triu, self.ii_triu]
vjvj = grammian[self.jj_triu, self.jj_triu]
gamma, cost = self.line_solver_vectorized(vivi, vivj, vjvj)
offset = torch.argmin(cost)
i_min, j_min = self.i_triu[offset], self.j_triu[offset]
sol = torch.zeros(self.n, device=grammian.device)
sol[i_min], sol[j_min] = gamma[offset], 1. - gamma[offset]
return sol
示例3: forward
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def forward(self, XS, YS, XQ, YQ):
'''
@param XS (support x): support_size x ebd_dim
@param YS (support y): support_size
@param XQ (support x): query_size x ebd_dim
@param YQ (support y): query_size
@return acc
@return None (a placeholder for loss)
'''
if self.args.nn_distance == 'l2':
dist = self._compute_l2(XS, XQ)
elif self.args.nn_distance == 'cos':
dist = self._compute_cos(XS, XQ)
else:
raise ValueError("nn_distance can only be l2 or cos.")
# 1-NearestNeighbour
nn_idx = torch.argmin(dist, dim=1)
pred = YS[nn_idx]
acc = torch.mean((pred == YQ).float()).item()
return acc, None
示例4: forward
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def forward(self, coord_volumes_batch, volumes_batch_pred, keypoints_gt, keypoints_binary_validity):
loss = 0.0
n_losses = 0
batch_size = volumes_batch_pred.shape[0]
for batch_i in range(batch_size):
coord_volume = coord_volumes_batch[batch_i]
keypoints_gt_i = keypoints_gt[batch_i]
coord_volume_unsq = coord_volume.unsqueeze(0)
keypoints_gt_i_unsq = keypoints_gt_i.unsqueeze(1).unsqueeze(1).unsqueeze(1)
dists = torch.sqrt(((coord_volume_unsq - keypoints_gt_i_unsq) ** 2).sum(-1))
dists = dists.view(dists.shape[0], -1)
min_indexes = torch.argmin(dists, dim=-1).detach().cpu().numpy()
min_indexes = np.stack(np.unravel_index(min_indexes, volumes_batch_pred.shape[-3:]), axis=1)
for joint_i, index in enumerate(min_indexes):
validity = keypoints_binary_validity[batch_i, joint_i]
loss += validity[0] * (-torch.log(volumes_batch_pred[batch_i, joint_i, index[0], index[1], index[2]] + 1e-6))
n_losses += 1
return loss / n_losses
示例5: assign
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def assign(self, points, distance='euclid', greedy=False):
# points = points.data
centroids = self.centroids
if distance == 'cosine':
# nearest neigbor in the centroids (cosine distance):
points = F.normalize(points, dim=-1)
centroids = F.normalize(centroids, dim=-1)
distances = (torch.sum(points**2, dim=1, keepdim=True) +
torch.sum(centroids**2, dim=1, keepdim=True).t() -
2 * torch.matmul(points, centroids.t())) # T*B, e
print('Distances:', distances[:3])
if not greedy:
logits = - distances
resp = F.gumbel_softmax(logits, tau=self.tau, hard=self.hard)
else:
# Greedy non-differentiable responsabilities:
indices = torch.argmin(distances, dim=-1) # T*B
resp = torch.zeros(points.size(0), self.ne).type_as(points)
resp.scatter_(1, indices.unsqueeze(1), 1)
return resp
示例6: assign
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def assign(self, points, distance='euclid', greedy=False):
points = points.data
centroids = self.centroids
if distance == 'cosine':
# nearest neigbor in the centroids (cosine distance):
points = F.normalize(points, dim=-1)
centroids = F.normalize(centroids, dim=-1)
distances = (torch.sum(points**2, dim=1, keepdim=True) +
torch.sum(centroids**2, dim=1, keepdim=True).t() -
2 * torch.matmul(points, centroids.t())) # T*B, e
if not greedy:
logits = - distances
resp = F.gumbel_softmax(logits, tau=self.tau, hard=self.hard)
# batch_counts = resp.sum(dim=0).view(-1).data
else:
# Greedy non-differentiable responsabilities:
indices = torch.argmin(distances, dim=-1) # T*B
resp = torch.zeros(points.size(0), self.ne).type_as(points)
resp.scatter_(1, indices.unsqueeze(1), 1)
return resp
示例7: calculate_partitions
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def calculate_partitions(partitions_count, cluster_partitions, types):
partition_distribution = torch.ones((partitions_count,
len(torch.unique(types))),
dtype=torch.long)
partition_assignments = torch.zeros(cluster_partitions.shape[0],
dtype=torch.long)
for i in torch.unique(cluster_partitions):
cluster_positions = (cluster_partitions == i).nonzero()
cluster_types = types[cluster_positions]
unique_types_in_cluster, type_count = torch.unique(cluster_types, return_counts=True)
tmp_distribution = partition_distribution.clone()
tmp_distribution[:, unique_types_in_cluster] += type_count
relative_distribution = partition_distribution.double() / tmp_distribution.double()
min_relative_distribution_group = torch.argmin(torch.sum(relative_distribution, dim=1))
partition_distribution[min_relative_distribution_group,
unique_types_in_cluster] += type_count
partition_assignments[cluster_positions] = min_relative_distribution_group
write_out("Loaded data into the following partitions")
write_out("[[ TM SP+TM SP Glob]")
write_out(partition_distribution - torch.ones(partition_distribution.shape,
dtype=torch.long))
return partition_assignments
示例8: _nnef_argminmax_reduce
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def _nnef_argminmax_reduce(input, axes, argmin=False):
# type:(torch.Tensor, List[int], bool)->torch.Tensor
if len(axes) == 1:
return _nnef_generic_reduce(input=input, axes=axes, f=torch.argmin if argmin else torch.argmax)
else:
axes = sorted(axes)
consecutive_axes = list(range(axes[0], axes[0] + len(axes)))
if axes == consecutive_axes:
reshaped = nnef_reshape(input,
shape=(list(input.shape)[:axes[0]]
+ [-1]
+ list(input.shape[axes[0] + len(axes):])))
reduced = _nnef_generic_reduce(input=reshaped, axes=[axes[0]], f=torch.argmin if argmin else torch.argmax)
reshaped = nnef_reshape(reduced, shape=list(dim if axis not in axes else 1
for axis, dim in enumerate(input.shape)))
return reshaped
else:
raise utils.NNEFToolsException(
"{} is only implemented for consecutive axes.".format("argmin_reduce" if argmin else "argmax_reduce"))
示例9: step
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def step(self, i):
"""
There are two standard steps for each iteration: expectation (E) and
minimization (M). The E-step (assignment) is performed with an exhaustive
search and the M-step (centroid computation) is performed with
the exact solution.
Args:
- i: step number
Remarks:
- The E-step heavily uses PyTorch broadcasting to speed up computations
and reduce the memory overhead
"""
# assignments (E-step)
distances = self.compute_distances() # (n_centroids x out_features)
self.assignments = torch.argmin(distances, dim=0) # (out_features)
n_empty_clusters = self.resolve_empty_clusters()
# centroids (M-step)
for k in range(self.n_centroids):
W_k = self.W[:, self.assignments == k] # (in_features x size_of_cluster_k)
self.centroids[k] = W_k.mean(dim=1) # (in_features)
# book-keeping
obj = (self.centroids[self.assignments].t() - self.W).norm(p=2).item()
self.objective.append(obj)
if self.verbose:
logging.info(
f"Iteration: {i},\t"
f"objective: {obj:.6f},\t"
f"resolved empty clusters: {n_empty_clusters}"
)
示例10: resolve_empty_clusters
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def resolve_empty_clusters(self):
"""
If one cluster is empty, the most populated cluster is split into
two clusters by shifting the respective centroids. This is done
iteratively for a fixed number of tentatives.
"""
# empty clusters
counts = Counter(map(lambda x: x.item(), self.assignments))
empty_clusters = set(range(self.n_centroids)) - set(counts.keys())
n_empty_clusters = len(empty_clusters)
tentatives = 0
while len(empty_clusters) > 0:
# given an empty cluster, find most populated cluster and split it into two
k = random.choice(list(empty_clusters))
m = counts.most_common(1)[0][0]
e = torch.randn_like(self.centroids[m]) * self.eps
self.centroids[k] = self.centroids[m].clone()
self.centroids[k] += e
self.centroids[m] -= e
# recompute assignments
distances = self.compute_distances() # (n_centroids x out_features)
self.assignments = torch.argmin(distances, dim=0) # (out_features)
# check for empty clusters
counts = Counter(map(lambda x: x.item(), self.assignments))
empty_clusters = set(range(self.n_centroids)) - set(counts.keys())
# increment tentatives
if tentatives == self.max_tentatives:
logging.info(
f"Could not resolve all empty clusters, {len(empty_clusters)} remaining"
)
raise EmptyClusterResolveError
tentatives += 1
return n_empty_clusters
示例11: assign
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def assign(self):
"""
Assigns each column of W to its closest centroid, thus essentially
performing the E-step in train().
Remarks:
- The function must be called after train() or after loading
centroids using self.load(), otherwise it will return empty tensors
"""
distances = self.compute_distances() # (n_centroids x out_features)
self.assignments = torch.argmin(distances, dim=0) # (out_features)
示例12: append
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def append(self, new_k, new_v):
min_idx = torch.argmin(self.weight_buff).item()
self.keys[min_idx, :] = new_k
self.values[min_idx, :] = new_v
self.weight_buff[min_idx] = torch.mean(self.weight_buff)
示例13: _proj_val
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def _proj_val(x, set):
"""
Compute the projection from x onto the set given.
:param x: Input pytorch tensor.
:param set: Input pytorch vector used to perform the projection.
"""
x = x.repeat((set.size()[0],)+(1,)*len(x.size()))
x = x.permute(*(tuple(range(len(x.size())))[1:] +(0,) ))
x = torch.abs(x-set)
x = torch.argmin(x, dim=len(x.size())-1, keepdim=False)
return set[x]
示例14: least_used_cuda_device
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def least_used_cuda_device() -> Generator:
"""Contextmanager for automatically selecting the cuda device
with the least allocated memory"""
mem_allocs = get_cuda_max_memory_allocations()
least_used_device = torch.argmin(mem_allocs).item()
with torch.cuda.device(least_used_device):
yield
示例15: subgraph_filter
# 需要導入模塊: import torch [as 別名]
# 或者: from torch import argmin [as 別名]
def subgraph_filter(x_atom, x_atom_pos, x_bond, x_bond_dist, x_triplet, x_triplet_angle, args):
D = sqdist(x_atom_pos[:,:,:3], x_atom_pos[:,:,:3])
x_atom, x_atom_pos, x_bond, x_bond_dist, x_triplet, x_triplet_angle = \
x_atom.clone().detach(), x_atom_pos.clone().detach(), x_bond.clone().detach(), x_bond_dist.clone().detach(), x_triplet.clone().detach(), x_triplet_angle.clone().detach()
bsz = x_atom.shape[0]
bonds_mask = torch.ones(bsz, x_bond.shape[1], 1).to(x_atom.device)
for mol_id in range(bsz):
if np.random.uniform(0,1) > args.cutout:
continue
assert not args.use_quad, "Quads are NOT cut out yet"
atom_dists = D[mol_id]
atoms = x_atom[mol_id, :, 0]
n_valid_atoms = (atoms > 0).sum().item()
if n_valid_atoms < 10:
continue
idx_to_drop = np.random.randint(n_valid_atoms-1)
dist_row = atom_dists[idx_to_drop]
neighbor_to_drop = torch.argmin((dist_row[dist_row>0])[:n_valid_atoms-1]).item()
if neighbor_to_drop >= idx_to_drop:
neighbor_to_drop += 1
x_atom[mol_id, idx_to_drop] = 0
x_atom[mol_id, neighbor_to_drop] = 0
x_atom_pos[mol_id, idx_to_drop] = 0
x_atom_pos[mol_id, neighbor_to_drop] = 0
bond_pos_to_drop = (x_bond[mol_id, :, 3] == idx_to_drop) | (x_bond[mol_id, :, 3] == neighbor_to_drop) \
| (x_bond[mol_id, :, 4] == idx_to_drop) | (x_bond[mol_id, :, 4] == neighbor_to_drop)
trip_pos_to_drop = (x_triplet[mol_id, :, 2] == idx_to_drop) | (x_triplet[mol_id, :, 2] == neighbor_to_drop) \
| (x_triplet[mol_id, :, 3] == idx_to_drop) | (x_triplet[mol_id, :, 3] == neighbor_to_drop) \
| (x_triplet[mol_id, :, 4] == idx_to_drop) | (x_triplet[mol_id, :, 4] == neighbor_to_drop)
x_bond[mol_id, bond_pos_to_drop] = 0
x_bond_dist[mol_id, bond_pos_to_drop] = 0
bonds_mask[mol_id, bond_pos_to_drop] = 0
x_triplet[mol_id, trip_pos_to_drop] = 0
x_triplet_angle[mol_id, trip_pos_to_drop] = 0
return x_atom, x_atom_pos, x_bond, x_bond_dist, x_triplet, x_triplet_angle, bonds_mask