- Deep Learning Quick Reference
- Mike Bernico
- 380字
- 2021-06-24 18:40:10
Training the Keras model
Now that our network has been built and compiled, all that's left is to train it. Much like in Python's scikit-learn, you can do that by calling .fit() on the model instance, as shown in the following code:
model.fit(x=data["train_X"], y=data["train_y"], batch_size=32, epochs=200, verbose=1, validation_data=(data["val_X"], data["val_y"]))
Let us walk through a few of the important arguments the Keras fit method takes. I will assume that you're familiar with mini-batch gradient descent and training epochs but if you aren't, please check Chapter 1, The Building Blocks of Deep Learning, for an overview. The important arguments in the Keras fit model are as follows:
- batch_size: Keras defaults to a batch size of 32. The batch size is the size of the mini-batch Keras will use. Of course, this means that Keras assumes you want to use mini-batch gradient descent. If, for some reason, you don't want to use mini-batch gradient, you can set batch_size=None.
- epochs: An epoch is just a single pass over the entire training set. In practice, you'll need to monitor your network as it trains to learn when the network has converged, so epochs is a somewhat learnable hyperparameter. Later, we will see that it's possible to save the weights of our model every epoch, or even every epoch that's better than the last. Once we know how to do that, we can choose the epoch we think is best and implement a sort of human-based early stopping.
- validation_data: Here, we are specifying our validation set. At the end of every epoch, Keras will test the model on the validation set and output the results using the loss function and any other metrics you've specified. Alternatively, you can set validation_split to a float value specifying the percentage of the train set you'd like to use for validation. Both options work fine, but I prefer to be very explicit when it comes to dataset splits.
- verbose: This is somewhat self-explanatory; however, it merits a quick mention. verbose=1 outputs a progress bar that shows the status of the current epoch and, at the end of the epoch, Keras will output training and validation loss. verbose can also be set to 2, which outputs loss information every mini-batch, and 0, which makes Keras silent.
推薦閱讀
- 玩轉智能機器人程小奔
- 輕輕松松自動化測試
- 腦動力:C語言函數速查效率手冊
- Seven NoSQL Databases in a Week
- Hadoop 2.x Administration Cookbook
- 機器人智能運動規劃技術
- JSF2和RichFaces4使用指南
- 大學C/C++語言程序設計基礎
- Learning Azure Cosmos DB
- Machine Learning with Apache Spark Quick Start Guide
- Salesforce Advanced Administrator Certification Guide
- 學練一本通:51單片機應用技術
- 機器人制作入門(第4版)
- 天才與算法:人腦與AI的數學思維
- 軟測之魂