PyTorch - कन्वर्सेशन में फ़ीचर एक्सट्रैक्शन

संवैधानिक तंत्रिका नेटवर्क में एक प्राथमिक विशेषता शामिल होती है, extraction। निम्नलिखित चरणों का उपयोग दृढ़ तंत्रिका नेटवर्क की सुविधा निष्कर्षण को लागू करने के लिए किया जाता है।

चरण 1

"PyTorch" के साथ फीचर निष्कर्षण मॉडल बनाने के लिए संबंधित मॉडल आयात करें।

import torch
import torch.nn as nn
from torchvision import models

चरण 2

फ़ीचर एक्सट्रैक्टर की एक क्लास बनाएं, जिसे ज़रूरत पड़ने पर बुलाया जा सके।

class Feature_extractor(nn.module):
   def forward(self, input):
      self.feature = input.clone()
      return input
new_net = nn.Sequential().cuda() # the new network
target_layers = [conv_1, conv_2, conv_4] # layers you want to extract`
i = 1
for layer in list(cnn):
   if isinstance(layer,nn.Conv2d):
      name = "conv_"+str(i)
      art_net.add_module(name,layer)
      if name in target_layers:
         new_net.add_module("extractor_"+str(i),Feature_extractor())
      i+=1
   if isinstance(layer,nn.ReLU):
      name = "relu_"+str(i)
      new_net.add_module(name,layer)
   if isinstance(layer,nn.MaxPool2d):
      name = "pool_"+str(i)
      new_net.add_module(name,layer)
new_net.forward(your_image)
print (new_net.extractor_3.feature)