tensorflow 2 kerasネットワークを構築する2つの方法


tensorflow 2 kerasネットワークを構築する2つの方法

  • 1. Sequential六歩法
  • 2. Model継承
  • 1.Sequential六歩法

    import    #import  
    train test   # 
    model=tf.keras.models.Sequential  #  
    model.compile # , 
    model.fit       #  
    model.summary   #  

    たとえば、アヤメのデータセットのトレーニング:
    import tensorflow as tf
    from sklearn import datasets
    import numpy as np
    
    x_train = datasets.load_iris().data
    y_train = datasets.load_iris().target
    
    np.random.seed(116)
    np.random.shuffle(x_train)
    np.random.seed(116)
    np.random.shuffle(y_train)
    tf.random.set_seed(116)
    
    model = tf.keras.models.Sequential([
        tf.keras.layers.Dense(3, activation='softmax', kernel_regularizer=tf.keras.regularizers.l2())
    ])
    
    model.compile(optimizer=tf.keras.optimizers.SGD(lr=0.1),
                  loss=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=False),
                  metrics=['sparse_categorical_accuracy'])
    
    model.fit(x_train, y_train, batch_size=32, epochs=500, validation_split=0.2, validation_freq=20)
    
    model.summary()
    

    2.Model継承


    Sequentialモジュールではなく、Modelメソッドを使って、自分でネットワーク構造を書きます.やはり上の簡単な例です.
    import tensorflow as tf
    from tensorflow.keras.layers import Dense
    from tensorflow.keras import Model
    from sklearn import datasets
    import numpy as np
    
    x_train = datasets.load_iris().data
    y_train = datasets.load_iris().target
    
    np.random.seed(116)
    np.random.shuffle(x_train)
    np.random.seed(116)
    np.random.shuffle(y_train)
    tf.random.set_seed(116)
    
    class IrisModel(Model):
        def __init__(self):
            super(IrisModel, self).__init__()
            self.d1 = Dense(3, activation='softmax', kernel_regularizer=tf.keras.regularizers.l2())
    
        def call(self, x):
            y = self.d1(x)
            return y
    
    model = IrisModel()
    
    model.compile(optimizer=tf.keras.optimizers.SGD(lr=0.1),
                  loss=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=False),
                  metrics=['sparse_categorical_accuracy'])
    
    model.fit(x_train, y_train, batch_size=32, epochs=500, validation_split=0.2, validation_freq=20)
    model.summary()