create_grids() to YOLOLayer method
This commit is contained in:
		
							parent
							
								
									91f563c2a2
								
							
						
					
					
						commit
						93055a9d58
					
				
							
								
								
									
										11
									
								
								models.py
								
								
								
								
							
							
						
						
									
										11
									
								
								models.py
								
								
								
								
							|  | @ -134,8 +134,9 @@ class YOLOLayer(nn.Module): | |||
|         self.ng = torch.Tensor(ng).to(device) | ||||
| 
 | ||||
|         # build xy offsets | ||||
|         yv, xv = torch.meshgrid([torch.arange(self.ny), torch.arange(self.nx)]) | ||||
|         self.grid_xy = torch.stack((xv, yv), 2).to(device).view((1, 1, self.ny, self.nx, 2)) | ||||
|         if not self.training: | ||||
|             yv, xv = torch.meshgrid([torch.arange(self.ny, device=device), torch.arange(self.nx, device=device)]) | ||||
|             self.grid = torch.stack((xv, yv), 2).view((1, 1, self.ny, self.nx, 2)) | ||||
| 
 | ||||
|         if self.anchor_vec.device != device: | ||||
|             self.anchor_vec = self.anchor_vec.to(device) | ||||
|  | @ -179,11 +180,11 @@ class YOLOLayer(nn.Module): | |||
|             # Avoid broadcasting for ANE operations | ||||
|             m = self.na * self.nx * self.ny | ||||
|             ng = 1 / self.ng.repeat((m, 1)) | ||||
|             grid_xy = self.grid_xy.repeat((1, self.na, 1, 1, 1)).view(m, 2) | ||||
|             grid = self.grid.repeat((1, self.na, 1, 1, 1)).view(m, 2) | ||||
|             anchor_wh = self.anchor_wh.repeat((1, 1, self.nx, self.ny, 1)).view(m, 2) * ng | ||||
| 
 | ||||
|             p = p.view(m, self.no) | ||||
|             xy = torch.sigmoid(p[:, 0:2]) + grid_xy  # x, y | ||||
|             xy = torch.sigmoid(p[:, 0:2]) + grid  # x, y | ||||
|             wh = torch.exp(p[:, 2:4]) * anchor_wh  # width, height | ||||
|             p_cls = torch.sigmoid(p[:, 4:5]) if self.nc == 1 else \ | ||||
|                 torch.sigmoid(p[:, 5:self.no]) * torch.sigmoid(p[:, 4:5])  # conf | ||||
|  | @ -191,7 +192,7 @@ class YOLOLayer(nn.Module): | |||
| 
 | ||||
|         else:  # inference | ||||
|             io = p.clone()  # inference output | ||||
|             io[..., :2] = torch.sigmoid(io[..., :2]) + self.grid_xy  # xy | ||||
|             io[..., :2] = torch.sigmoid(io[..., :2]) + self.grid  # xy | ||||
|             io[..., 2:4] = torch.exp(io[..., 2:4]) * self.anchor_wh  # wh yolo method | ||||
|             io[..., :4] *= self.stride | ||||
|             torch.sigmoid_(io[..., 4:]) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue