TensorFlow - ग्रेडिएंट डिसेंट ऑप्टिमाइज़ेशन

डेटा साइंस में ग्रेजुएशन डिसेंट ऑप्टिमाइज़ेशन को एक महत्वपूर्ण अवधारणा माना जाता है।

क्रमिक वंश अनुकूलन के कार्यान्वयन को समझने के लिए नीचे दिए गए चरणों पर विचार करें -

चरण 1

आवश्यक मॉड्यूल और एक्स और वाई चर की घोषणा शामिल करें जिसके माध्यम से हम ढाल वंश अनुकूलन को परिभाषित करने जा रहे हैं।

import tensorflow as tf

x = tf.Variable(2, name = 'x', dtype = tf.float32)
log_x = tf.log(x)
log_x_squared = tf.square(log_x)

optimizer = tf.train.GradientDescentOptimizer(0.5)
train = optimizer.minimize(log_x_squared)

चरण 2

आवश्यक चर को प्रारंभ करें और संबंधित फ़ंक्शन के साथ इसे परिभाषित करने और कॉल करने के लिए ऑप्टिमाइज़र को कॉल करें।

init = tf.initialize_all_variables()

def optimize():
   with tf.Session() as session:
      session.run(init)
      print("starting at", "x:", session.run(x), "log(x)^2:", session.run(log_x_squared))
      
      for step in range(10):
         session.run(train)
         print("step", step, "x:", session.run(x), "log(x)^2:", session.run(log_x_squared))
optimize()

कोड की उपरोक्त रेखा नीचे स्क्रीनशॉट में दिखाए अनुसार आउटपुट उत्पन्न करती है -

हम देख सकते हैं कि आउटपुट में दिखाए गए अनुसार आवश्यक युगों और पुनरावृत्तियों की गणना की जाती है।