training updates
This commit is contained in:
		
							parent
							
								
									c7f5b6cc21
								
							
						
					
					
						commit
						4120ac3aa6
					
				
							
								
								
									
										6
									
								
								train.py
								
								
								
								
							
							
						
						
									
										6
									
								
								train.py
								
								
								
								
							|  | @ -209,7 +209,7 @@ def train(): | |||
| 
 | ||||
|     # Start training | ||||
|     nb = len(dataloader)  # number of batches | ||||
|     n_burn = max(3 * nb, 300)  # burn-in iterations, max(3 epochs, 300 iterations) | ||||
|     n_burn = max(3 * nb, 500)  # burn-in iterations, max(3 epochs, 300 iterations) | ||||
|     maps = np.zeros(nc)  # mAP per class | ||||
|     # torch.autograd.set_detect_anomaly(True) | ||||
|     results = (0, 0, 0, 0, 0, 0, 0)  # 'P', 'R', 'mAP', 'F1', 'val GIoU', 'val Objectness', 'val Classification' | ||||
|  | @ -234,8 +234,8 @@ def train(): | |||
|             targets = targets.to(device) | ||||
| 
 | ||||
|             # Burn-in | ||||
|             if ni <= n_burn: | ||||
|                 model.gr = np.interp(ni, [0, n_burn], [0.0, 1.0])  # giou loss ratio (obj_loss = 1.0 or giou) | ||||
|             if ni <= n_burn * 2: | ||||
|                 model.gr = np.interp(ni, [0, n_burn * 2], [0.0, 1.0])  # giou loss ratio (obj_loss = 1.0 or giou) | ||||
|                 if ni == n_burn:  # burnin complete | ||||
|                     print_model_biases(model) | ||||
| 
 | ||||
|  |  | |||
|  | @ -149,7 +149,7 @@ class ModelEMA: | |||
|         self.ema = deepcopy(model) | ||||
|         self.ema.eval() | ||||
|         self.updates = 0  # number of EMA updates | ||||
|         self.decay = lambda x: decay * (1 - math.exp(-x / 1000))  # decay exponential ramp (to help early epochs) | ||||
|         self.decay = lambda x: decay * (1 - math.exp(-x / 2000))  # decay exponential ramp (to help early epochs) | ||||
|         self.device = device  # perform ema on different device from model if set | ||||
|         if device: | ||||
|             self.ema.to(device=device) | ||||
|  |  | |||
|  | @ -688,11 +688,11 @@ def coco_single_class_labels(path='../coco/labels/train2014/', label_class=43): | |||
|             shutil.copyfile(src=img_file, dst='new/images/' + Path(file).name.replace('txt', 'jpg'))  # copy images | ||||
| 
 | ||||
| 
 | ||||
| def kmean_anchors(path='../coco/train2017.txt', n=9, img_size=(608, 608)): | ||||
| def kmean_anchors(path='../coco/train2017.txt', n=12, img_size=(320, 1024)): | ||||
|     # from utils.utils import *; _ = kmean_anchors() | ||||
|     # Produces a list of target kmeans suitable for use in *.cfg files | ||||
|     # Creaters kmeans anchors for use in *.cfg files | ||||
|     from utils.datasets import LoadImagesAndLabels | ||||
|     thr = 0.20  # IoU threshold | ||||
|     thr = 0.225  # IoU threshold | ||||
| 
 | ||||
|     def print_results(k): | ||||
|         k = k[np.argsort(k.prod(1))]  # sort small to large | ||||
|  | @ -709,7 +709,7 @@ def kmean_anchors(path='../coco/train2017.txt', n=9, img_size=(608, 608)): | |||
|     def fitness(k):  # mutation fitness | ||||
|         iou = wh_iou(wh, torch.Tensor(k))  # iou | ||||
|         max_iou = iou.max(1)[0] | ||||
|         return max_iou.mean()  # product | ||||
|         return (max_iou * (max_iou > thr).float()).mean()  # product | ||||
| 
 | ||||
|     # Get label wh | ||||
|     wh = [] | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue