PyTorch - कन्वर्सेशन का परिचय

रूपांतरण से सीएनएन मॉडल के निर्माण के बारे में सभी बातें हैं। नेटवर्क आर्किटेक्चर में निम्नलिखित चरणों का संयोजन होगा -

  • Conv2d
  • MaxPool2d
  • रेक्टिफाइड लीनियर यूनिट
  • View
  • रैखिक परत

मॉडल को प्रशिक्षित करना

मॉडल का प्रशिक्षण एक ही प्रक्रिया है जैसे छवि वर्गीकरण समस्याएं। निम्नलिखित कोड स्निपेट प्रदान किए गए डेटासेट पर एक प्रशिक्षण मॉडल की प्रक्रिया को पूरा करता है -

def fit(epoch,model,data_loader,phase 
= 'training',volatile = False):
   if phase == 'training':
      model.train()
   if phase == 'training':
      model.train()
   if phase == 'validation':
      model.eval()
   volatile=True
   running_loss = 0.0
   running_correct = 0
   for batch_idx , (data,target) in enumerate(data_loader):
      if is_cuda:
         data,target = data.cuda(),target.cuda()
         data , target = Variable(data,volatile),Variable(target)
      if phase == 'training':
         optimizer.zero_grad()
         output = model(data)
         loss = F.nll_loss(output,target)
         running_loss + = 
         F.nll_loss(output,target,size_average = 
         False).data[0]
         preds = output.data.max(dim = 1,keepdim = True)[1]
         running_correct + = 
         preds.eq(target.data.view_as(preds)).cpu().sum()
         if phase == 'training':
            loss.backward()
            optimizer.step()
   loss = running_loss/len(data_loader.dataset)
   accuracy = 100. * running_correct/len(data_loader.dataset)
   print(f'{phase} loss is {loss:{5}.{2}} and {phase} accuracy is {running_correct}/{len(data_loader.dataset)}{accuracy:{return loss,accuracy}})

विधि में प्रशिक्षण और सत्यापन के लिए अलग-अलग तर्क शामिल हैं। विभिन्न तरीकों का उपयोग करने के दो प्राथमिक कारण हैं -

  • ट्रेन मोड में, ड्रॉपआउट मानों का प्रतिशत निकालता है, जो सत्यापन या परीक्षण चरण में नहीं होना चाहिए।

  • प्रशिक्षण मोड के लिए, हम ग्रेडिएंट्स की गणना करते हैं और मॉडल के मापदंडों के मान को बदलते हैं, लेकिन परीक्षण या सत्यापन चरणों के दौरान वापस प्रसार की आवश्यकता नहीं होती है।