[
    [
        [
            "layers.Conv2d(64, 128, 3, activation='relu')",
            "layers.Conv2D(128, 3)",
            "nn.Conv2d(64, 128, 3)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.",
            "Conv2d(64, 128, 3, activation='relu')"
        ],
        [
            "layers.Conv2d(input_shape=[3, 2], output_shape=[3, 2], kernel_size=3, stride=2)",
            "layers.Conv2D(dim_out, 3, 2)",
            "nn.Conv2d(dim_in, dim_out, 3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.",
            "Conv2d(input_shape=[3, 2], output_shape=[3, 2], kernel_size=3, stride=2)"
        ],
        [
            "layers.ReLU()",
            "layers.ReLU()",
            "nn.ReLU()",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.",
            "ReLU()"
        ],
        [
            "layers.Dropout(0.1)",
            "layers.Dropout(0.1)",
            "nn.Dropout(0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.",
            "Dropout(0.1)"
        ],
        [
            "layers.Linear(dim_in, dim_out)",
            "layers.Dense(dim_out)",
            "nn.Linear(dim_in, dim_out)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.",
            "Linear(dim_in, dim_out)"
        ],
        [
            "x = self.activation(self.fc(x))",
            "x = tf.nn.relu(self.fc(x))",
            "x = F.relu(self.fc(x))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\n",
            "x = self.activation(self.fc(x))"
        ],
        [
            "layers.Embedding(vocab_size, embed_dim)",
            "layers.Embedding(vocab_size, embed_dim)",
            "nn.Embedding(vocab_size, embed_dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.",
            "Embedding(vocab_size, embed_dim)"
        ],
        [
            "self.embed_tokens = nn.Embedding(max_len, dim_emb)",
            "max_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)",
            "max_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)",
            "# Translate PyTorch to Keras\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\n",
            "self.embed_tokens = nn.Embedding(max_len, dim_emb)"
        ],
        [
            "layers.MaxPooling2d(2, 2)",
            "layers.MaxPooling2D(2, 2)",
            "nn.MaxPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.",
            "MaxPooling2d(2, 2)"
        ],
        [
            "self.bn1 = layers.BatchNormalization(axis=0)\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2d(3, 3, padding='valid')\nself.pool1 = layers.MaxPool2d(3, 2)",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNormalization(axis=0)\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2d(3, 3, padding='valid')\nself.pool1 = layers.MaxPool2d(3, 2)"
        ],
        [
            "layers.BatchNorm2D(num_channels, name='bn1')\nlayers.ReLU(name='act1')\nlayers.Conv2D(num_channels, num_channels, 3, activation='relu')\nlayers.AvgPool2D(2, 2, name='pool1')",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)",
            "self.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\n",
            "layers.BatchNorm2D(num_channels, name='bn1')\nlayers.ReLU(name='act1')\nlayers.Conv2D(num_channels, num_channels, 3, activation='relu')\nlayers.AvgPool2D(2, 2, name='pool1')"
        ],
        [
            "layers.LayerNormalization(dim)",
            "layers.LayerNormalization()",
            "nn.LayerNorm(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.",
            "LayerNormalization(dim)"
        ],
        [
            "layers.LeakyReLU(alpha=args.leaky)",
            "layers.LeakyReLU(args.leaky)",
            "nn.LeakyReLU(args.leaky)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.",
            "LeakyReLU(alpha=args.leaky)"
        ],
        [
            "layers.LSTM(512, 512, dropout=0.1)",
            "layers.LSTM(512, dropout=0.1)",
            "nn.LSTM(512, 512, dropout=0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.",
            "LSTM(512, 512, dropout=0.1)"
        ],
        [
            "tf.cat(states, dim=-1)",
            "tf.concat(states, axis=-1)",
            "torch.cat(states, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.",
            "cat(states, dim=-1)"
        ],
        [
            "tf.nn.log_softmax(logits, axis=-1)",
            "tf.nn.log_softmax(logits, axis=-1)",
            "F.log_softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "log_softmax(logits, axis=-1)"
        ],
        [
            "tf.nn.softmax(logits, axis=-1)",
            "tf.nn.softmax(logits, axis=-1)",
            "F.softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "softmax(logits, axis=-1)"
        ],
        [
            "tf.reshape(x, [batch_size, -1])",
            "tf.reshape(x, [batch_size, -1])",
            "torch.reshape(x, [batch_size, -1])",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.",
            "reshape(x, [batch_size, -1])"
        ],
        [
            "layers.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "layers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "nn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.",
            "MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)"
        ],
        [
            "self.attn = layers.MultiheadAttention(d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNorm(d_model)\n\ndef forward(self, x):\n \"\"\"\n\nX is a (batch_size, input_length, input_dim) Tensor\n\nComputes the forward pass of the network.\n\n\"\"\"\n\nx = F.relu(self.fc(x))\nx = tf.nn.relu(self.fc(x))\n",
            "self.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)",
            "self.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\n",
            "self.attn = layers.MultiheadAttention(d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNorm(d_model)\n\ndef forward(self, x):\n \"\"\"\n\nX is a (batch_size, input_length, input_dim) Tensor\n\nComputes the forward pass of the network.\n\n\"\"\"\n\nx = F.relu(self.fc(x))\nx = tf.nn.relu(self.fc(x))\n"
        ],
        [
            "self.rnn = (layers.LSTM(d_model, d_model) if rnn_type == 'LSTM' else layers.GRU(d_model, d_model))",
            "self.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))",
            "self.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\n",
            "self.rnn = (layers.LSTM(d_model, d_model) if rnn_type == 'LSTM' else layers.GRU(d_model, d_model))"
        ],
        [
            "x = self.classifier(x)\nreturn x",
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)",
            "x = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\n",
            "x = self.classifier(x)\nreturn x"
        ],
        [
            "z = layers. concatenate ([x, y], axis=1)",
            "z = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)",
            "z = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\n",
            "z = layers. concatenate ([x, y], axis=1)"
        ],
        [
            "x = layers.Input(shape=(None,))",
            "x = self.layer1(x)",
            "x = self.layer1(x)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\n",
            "x = layers.Input(shape=(None,))"
        ],
        [
            "\ny = tf.nn.relu(tf.nn.tanh(tf.nn.flatten(x)))\nx = x + dropout(y, keep_prob)",
            "y = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "y = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\n",
            "\ny = tf.nn.relu(tf.nn.tanh(tf.nn.flatten(x)))\nx = x + dropout(y, keep_prob)"
        ],
        [
            "self.bn1 = layers.BatchNormalization(args.dim)\nself.act1 = activation()\nself.conv1 = layers.Conv3x3(args.dim)\nself.pool1 = layers.MaxPool2d(3, 2)\n\nWe will use the translation layer provided by PyTorch to translate PyTorch networks to Keras.\n\nThe first layer in a PyTorch network is usually the input layer. In Keras, this would be the layer that takes",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNormalization(args.dim)\nself.act1 = activation()\nself.conv1 = layers.Conv3x3(args.dim)\nself.pool1 = layers.MaxPool2d(3, 2)\n\nWe will use the translation layer provided by PyTorch to translate PyTorch networks to Keras.\n\nThe first layer in a PyTorch network is usually the input layer. In Keras, this would be the layer that takes"
        ],
        [
            "self.layer_1 = layers.Conv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\n",
            "self.layer_1 = layers.Conv2D(planes, kernel=3, stride=1, dilation=2)"
        ],
        [
            "layers.MaxPooling2D(kernel_size=3, stride=2)",
            "layers.MaxPooling2D(pool_size=3, strides=2)",
            "nn.MaxPool2d(kernel_size=3, stride=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.",
            "MaxPooling2D(kernel_size=3, stride=2)"
        ],
        [
            "self.fc = layers.Linear(dim, activation='relu')",
            "self.fc = CustomLinear(dim)",
            "self.fc = CustomLinear(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\n",
            "self.fc = layers.Linear(dim, activation='relu')"
        ],
        [
            "layers.Conv2D(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)",
            "layers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)",
            "nn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.",
            "Conv2D(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)"
        ]
    ],
    [
        [
            "layers.Conv2d(64, 128, 3)",
            "layers.Conv2D(128, 3)",
            "nn.Conv2d(64, 128, 3)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.",
            "Conv2d(64, 128, 3)"
        ],
        [
            "layers.Conv2d(dim_in, dim_out, 3, 2)",
            "layers.Conv2D(dim_out, 3, 2)",
            "nn.Conv2d(dim_in, dim_out, 3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.",
            "Conv2d(dim_in, dim_out, 3, 2)"
        ],
        [
            "layers.ReLU()",
            "layers.ReLU()",
            "nn.ReLU()",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.",
            "ReLU()"
        ],
        [
            "layers.Dropout(0.1)",
            "layers.Dropout(0.1)",
            "nn.Dropout(0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.",
            "Dropout(0.1)"
        ],
        [
            "layers.Linear(dim_in, dim_out)",
            "layers.Dense(dim_out)",
            "nn.Linear(dim_in, dim_out)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.",
            "Linear(dim_in, dim_out)"
        ],
        [
            "x = tf.nn.relu(self.fc(x))",
            "x = tf.nn.relu(self.fc(x))",
            "x = F.relu(self.fc(x))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\n",
            "x = tf.nn.relu(self.fc(x))"
        ],
        [
            "layers.Embedding(vocab_size, embed_dim)",
            "layers.Embedding(vocab_size, embed_dim)",
            "nn.Embedding(vocab_size, embed_dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.",
            "Embedding(vocab_size, embed_dim)"
        ],
        [
            "max_len = 512\nself.embed_tokens = embedding_dim(n_words)",
            "max_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)",
            "max_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\n",
            "max_len = 512\nself.embed_tokens = embedding_dim(n_words)"
        ],
        [
            "layers.MaxPooling2D(2, 2)",
            "layers.MaxPooling2D(2, 2)",
            "nn.MaxPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.",
            "MaxPooling2D(2, 2)"
        ],
        [
            "self.bn1 = tf.contrib.layers.batch_normalization(\n\ndim,\n\nname='bn1')\nself.act1 = tf.nn.leaky_relu(alpha=0.2)\nself.conv1 = tf.nn.conv2d(\n\ninput_shape=(dim,),\n\nkernel_size=(3,),\n\nstride=(1, 1),\n\npadding='SAME')\nself.pool1 = tf.nn.max_ pool(\n\ninput_shape=(3,),\n\nkernel_size=(2,),\n\npadding='SAME')",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = tf.contrib.layers.batch_normalization(\n\ndim,\n\nname='bn1')\nself.act1 = tf.nn.leaky_relu(alpha=0.2)\nself.conv1 = tf.nn.conv2d(\n\ninput_shape=(dim,),\n\nkernel_size=(3,),\n\nstride=(1, 1),\n\npadding='SAME')\nself.pool1 = tf.nn.max_ pool(\n\ninput_shape=(3,),\n\nkernel_size=(2,),\n\npadding='SAME')"
        ],
        [
            "self.bn1 = layers.BatchNorm2d(num_channels)\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2d(num_channels, num_channels, 3)\nself.pool1 = layers.AvgPool2d(2, 2)",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)",
            "self.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNorm2d(num_channels)\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2d(num_channels, num_channels, 3)\nself.pool1 = layers.AvgPool2d(2, 2)"
        ],
        [
            "layers.L2Normalization(dim)",
            "layers.LayerNormalization()",
            "nn.LayerNorm(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.",
            "L2Normalization(dim)"
        ],
        [
            "layers.LeakyReLU()",
            "layers.LeakyReLU(args.leaky)",
            "nn.LeakyReLU(args.leaky)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.",
            "LeakyReLU()"
        ],
        [
            "layers.LSTM(512, 512, dropout=0.1)",
            "layers.LSTM(512, dropout=0.1)",
            "nn.LSTM(512, 512, dropout=0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.",
            "LSTM(512, 512, dropout=0.1)"
        ],
        [
            "tf.nn.cat(states, axis=-1)",
            "tf.concat(states, axis=-1)",
            "torch.cat(states, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.",
            "nn.cat(states, axis=-1)"
        ],
        [
            "tf.nn.log_softmax(logits, dim=-1)",
            "tf.nn.log_softmax(logits, axis=-1)",
            "F.log_softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "log_softmax(logits, dim=-1)"
        ],
        [
            "tf.nn.softmax(logits, axis=-1)",
            "tf.nn.softmax(logits, axis=-1)",
            "F.softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "softmax(logits, axis=-1)"
        ],
        [
            "tf.reshape(x, [-1, batch_size])",
            "tf.reshape(x, [batch_size, -1])",
            "torch.reshape(x, [batch_size, -1])",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.",
            "reshape(x, [-1, batch_size])"
        ],
        [
            "layers.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "layers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "nn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.",
            "MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)"
        ],
        [
            "self.attn = layers.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNorm(args.d_model)\n\ndef forward(self, X, Y):\n # Keras\nlogits = tf.matmul(X, self.embed_tokens)\n + self.bn1\n + self.act1\n + self.conv1\n + self.pool1\nlogits = tf.nn.log_softmax(log",
            "self.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)",
            "self.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\n",
            "self.attn = layers.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNorm(args.d_model)\n\ndef forward(self, X, Y):\n # Keras\nlogits = tf.matmul(X, self.embed_tokens)\n + self.bn1\n + self.act1\n + self.conv1\n + self.pool1\nlogits = tf.nn.log_softmax(log"
        ],
        [
            "self.rnn = (layers.LSTM(d_model, d_model) if rnn_type == 'LSTM' else layers.GRU(d_model, d_model))",
            "self.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))",
            "self.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\n",
            "self.rnn = (layers.LSTM(d_model, d_model) if rnn_type == 'LSTM' else layers.GRU(d_model, d_model))"
        ],
        [
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, dim=-1)",
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)",
            "x = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\n",
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, dim=-1)"
        ],
        [
            "z = layers.Sequential([layers.Conv2D(32, kernel_size=(3, 3), activation='relu'), layers.MaxPooling2D(2, 2), layers.Conv2D(64, kernel_size=(3, 3), activation='relu'), layers.MaxPooling2D(2, 2), layers.Flatten",
            "z = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)",
            "z = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\n",
            "z = layers.Sequential([layers.Conv2D(32, kernel_size=(3, 3), activation='relu'), layers.MaxPooling2D(2, 2), layers.Conv2D(64, kernel_size=(3, 3), activation='relu'), layers.MaxPooling2D(2, 2), layers.Flatten"
        ],
        [
            "x = self.layer1(x)",
            "x = self.layer1(x)",
            "x = self.layer1(x)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\n",
            "x = self.layer1(x)"
        ],
        [
            "x = keras.layers.fc(x, densely_connected_units, activation='relu')\n\nx = x + self.dropout(x, 0.5)",
            "y = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "y = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\n",
            "x = keras.layers.fc(x, densely_connected_units, activation='relu')\n\nx = x + self.dropout(x, 0.5)"
        ],
        [
            "self.bn1 = layers.BatchNorm(dim)\nself.act1 = activation()\nself.conv1 = layers.Conv(filters=128, kernel_size=5, strides=2, padding='SAME')\nself.pool1 = layers.MaxPool(3, 2)",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNorm(dim)\nself.act1 = activation()\nself.conv1 = layers.Conv(filters=128, kernel_size=5, strides=2, padding='SAME')\nself.pool1 = layers.MaxPool(3, 2)"
        ],
        [
            "self.layer_1 = layers.Conv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\n",
            "self.layer_1 = layers.Conv2D(planes, kernel=3, stride=1, dilation=2)"
        ],
        [
            "layers.MaxPooling2D(kernel_size=3, stride=2)",
            "layers.MaxPooling2D(pool_size=3, strides=2)",
            "nn.MaxPool2d(kernel_size=3, stride=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.",
            "MaxPooling2D(kernel_size=3, stride=2)"
        ],
        [
            "self.fc = layers.Linear(dim, activation='relu')",
            "self.fc = CustomLinear(dim)",
            "self.fc = CustomLinear(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\n",
            "self.fc = layers.Linear(dim, activation='relu')"
        ],
        [
            "layers.Conv2d(in_channels=128, out_channels=512, kernel_size=5, bias=False)",
            "layers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)",
            "nn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.",
            "Conv2d(in_channels=128, out_channels=512, kernel_size=5, bias=False)"
        ]
    ],
    [
        [
            "layers.Conv2d(64, 128, 3)",
            "layers.Conv2D(128, 3)",
            "nn.Conv2d(64, 128, 3)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.",
            "Conv2d(64, 128, 3)"
        ],
        [
            "layers.Conv2D(in_dim, out_dim, 3, 2)",
            "layers.Conv2D(dim_out, 3, 2)",
            "nn.Conv2d(dim_in, dim_out, 3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.",
            "Conv2D(in_dim, out_dim, 3, 2)"
        ],
        [
            "layers.ReLU()",
            "layers.ReLU()",
            "nn.ReLU()",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.",
            "ReLU()"
        ],
        [
            "layers.dropout(0.1)",
            "layers.Dropout(0.1)",
            "nn.Dropout(0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.",
            "dropout(0.1)"
        ],
        [
            "layers.Linear(dim_in, dim_out)",
            "layers.Dense(dim_out)",
            "nn.Linear(dim_in, dim_out)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.",
            "Linear(dim_in, dim_out)"
        ],
        [
            "x = layers. activation (x)",
            "x = tf.nn.relu(self.fc(x))",
            "x = F.relu(self.fc(x))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\n",
            "x = layers. activation (x)"
        ],
        [
            "layers.Embedding(vocab_size, embed_dim)",
            "layers.Embedding(vocab_size, embed_dim)",
            "nn.Embedding(vocab_size, embed_dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.",
            "Embedding(vocab_size, embed_dim)"
        ],
        [
            "embedding_dim = 512\nself.embed_tokens = layers.Embedding(n_words, embedding_dim)",
            "max_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)",
            "max_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\n",
            "embedding_dim = 512\nself.embed_tokens = layers.Embedding(n_words, embedding_dim)"
        ],
        [
            "layers.MaxPool2d(2, 2)",
            "layers.MaxPooling2D(2, 2)",
            "nn.MaxPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.",
            "MaxPool2d(2, 2)"
        ],
        [
            "self.bn1 = layers.BatchNormalization(dim)\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2d(dim, dim, 3)\nself.pool1 = layers.MaxPool2d(3, 2)\n\ndef forward(self, x):\nwith torch.no_grad():\ny = self.attn(x)\nx = x + self.drop(y)\ny = self.drop1(x)\nx = self.norm1(x)\nreturn self.rnn(x)",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNormalization(dim)\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2d(dim, dim, 3)\nself.pool1 = layers.MaxPool2d(3, 2)\n\ndef forward(self, x):\nwith torch.no_grad():\ny = self.attn(x)\nx = x + self.drop(y)\ny = self.drop1(x)\nx = self.norm1(x)\nreturn self.rnn(x)"
        ],
        [
            "self.bn1 = layers.BatchNorm(num_channels)\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2d(num_channels, num_channels, 3)\nself.pool1 = layers.AvgPool2d(2, 2)",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)",
            "self.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNorm(num_channels)\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2d(num_channels, num_channels, 3)\nself.pool1 = layers.AvgPool2d(2, 2)"
        ],
        [
            "layers.LayerNorm(dim)",
            "layers.LayerNormalization()",
            "nn.LayerNorm(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.",
            "LayerNorm(dim)"
        ],
        [
            "layers.LeakyReLU(args.leaky)",
            "layers.LeakyReLU(args.leaky)",
            "nn.LeakyReLU(args.leaky)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.",
            "LeakyReLU(args.leaky)"
        ],
        [
            "layers.LSTM(512, 512, dropout=0.1)",
            "layers.LSTM(512, dropout=0.1)",
            "nn.LSTM(512, 512, dropout=0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.",
            "LSTM(512, 512, dropout=0.1)"
        ],
        [
            "tf.cat(states, -1)",
            "tf.concat(states, axis=-1)",
            "torch.cat(states, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.",
            "cat(states, -1)"
        ],
        [
            "tf.nn.softmax(logits, dim=0)",
            "tf.nn.log_softmax(logits, axis=-1)",
            "F.log_softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "softmax(logits, dim=0)"
        ],
        [
            "tf.nn.softmax(logits, dim=-1)",
            "tf.nn.softmax(logits, axis=-1)",
            "F.softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "softmax(logits, dim=-1)"
        ],
        [
            "tf.reshape(x, [batch_size, -1])",
            "tf.reshape(x, [batch_size, -1])",
            "torch.reshape(x, [batch_size, -1])",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.",
            "reshape(x, [batch_size, -1])"
        ],
        [
            "layers.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=dropout)",
            "layers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "nn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.",
            "MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=dropout)"
        ],
        [
            "self.attn = layers.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNorm(args.d_model)",
            "self.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)",
            "self.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)",
            "# Translate PyTorch to Keras\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\n",
            "self.attn = layers.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNorm(args.d_model)"
        ],
        [
            "self.rnn = (layers.LSTM(d_model, d_model) if rnn_type == 'LSTM' else layers.GRU(d_model, d_model))",
            "self.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))",
            "self.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\n",
            "self.rnn = (layers.LSTM(d_model, d_model) if rnn_type == 'LSTM' else layers.GRU(d_model, d_model))"
        ],
        [
            "model.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])\n\nx = self.classifier(x)\nreturn model.evaluate(x, epoch",
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)",
            "x = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\n",
            "model.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])\n\nx = self.classifier(x)\nreturn model.evaluate(x, epoch"
        ],
        [
            "sequences = layers.InputSequence([x, y])\n\n       # PyTorch  self.layer_2 = nn.ReLU()     # Keras  layers.ReLU()",
            "z = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)",
            "z = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\n",
            "sequences = layers.InputSequence([x, y])\n\n       # PyTorch  self.layer_2 = nn.ReLU()     # Keras  layers.ReLU()"
        ],
        [
            "x = layers.Input(shape=(bsz,))",
            "x = self.layer1(x)",
            "x = self.layer1(x)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\n",
            "x = layers.Input(shape=(bsz,))"
        ],
        [
            "y = F.relu(self.ffn1(x))\nx = x + layers.Dropout(y)",
            "y = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "y = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\n",
            "y = F.relu(self.ffn1(x))\nx = x + layers.Dropout(y)"
        ],
        [
            "\ndef conv3x3(dim):\n\nreturn layers.Conv2D(filters=64, strides=1, kernel_size=3, use_bias=False)\n\ndef activation():\n\nreturn layers.ReLU()",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "\ndef conv3x3(dim):\n\nreturn layers.Conv2D(filters=64, strides=1, kernel_size=3, use_bias=False)\n\ndef activation():\n\nreturn layers.ReLU()"
        ],
        [
            "self.layer_1 = layers.Conv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\n",
            "self.layer_1 = layers.Conv2D(planes, kernel=3, stride=1, dilation=2)"
        ],
        [
            "layers.MaxPooling2D(kernel_size=3, stride=2)",
            "layers.MaxPooling2D(pool_size=3, strides=2)",
            "nn.MaxPool2d(kernel_size=3, stride=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.",
            "MaxPooling2D(kernel_size=3, stride=2)"
        ],
        [
            "self.fc = layers.Linear(dim)",
            "self.fc = CustomLinear(dim)",
            "self.fc = CustomLinear(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\n",
            "self.fc = layers.Linear(dim)"
        ],
        [
            "layers.Conv2D(128, 512, 2, 5, bias=False)",
            "layers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)",
            "nn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.",
            "Conv2D(128, 512, 2, 5, bias=False)"
        ]
    ],
    [
        [
            "layers.Conv2d(64, 128, 3)",
            "layers.Conv2D(128, 3)",
            "nn.Conv2d(64, 128, 3)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.",
            "Conv2d(64, 128, 3)"
        ],
        [
            "layers.Conv2d(dim_in, dim_out, 3, 2)",
            "layers.Conv2D(dim_out, 3, 2)",
            "nn.Conv2d(dim_in, dim_out, 3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.",
            "Conv2d(dim_in, dim_out, 3, 2)"
        ],
        [
            "layers.ReLU()",
            "layers.ReLU()",
            "nn.ReLU()",
            "# Translate PyTorch to Keras\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.",
            "ReLU()"
        ],
        [
            "layers.Dropout(0.1)",
            "layers.Dropout(0.1)",
            "nn.Dropout(0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.",
            "Dropout(0.1)"
        ],
        [
            "layers.Linear(dim_in,dim_out)",
            "layers.Dense(dim_out)",
            "nn.Linear(dim_in, dim_out)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.",
            "Linear(dim_in,dim_out)"
        ],
        [
            "x = activation(self.fc(x))",
            "x = tf.nn.relu(self.fc(x))",
            "x = F.relu(self.fc(x))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\n",
            "x = activation(self.fc(x))"
        ],
        [
            "layers.Embedding(vocab_size, embed_dim)",
            "layers.Embedding(vocab_size, embed_dim)",
            "nn.Embedding(vocab_size, embed_dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.",
            "Embedding(vocab_size, embed_dim)"
        ],
        [
            "embed_tokens = layers.Embedding(n_words, 128)",
            "max_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)",
            "max_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)",
            "# Translate PyTorch to Keras\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\n",
            "embed_tokens = layers.Embedding(n_words, 128)"
        ],
        [
            "layers.MaxPooling2D(2, 2)",
            "layers.MaxPooling2D(2, 2)",
            "nn.MaxPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.",
            "MaxPooling2D(2, 2)"
        ],
        [
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2d(dim, dim, 3)\nself.pool1 = layers.MaxPool2d(3, 2)\n\nself.bn2 = nn.BatchNorm2d(dim)\nself.act2 = nn.LeakyReLU(0.2)\nself.conv2 = nn.Conv2d(dim, dim, 3)\nself.pool2 = nn.MaxPool2d(3, 2)\nself.fc1",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2d(dim, dim, 3)\nself.pool1 = layers.MaxPool2d(3, 2)\n\nself.bn2 = nn.BatchNorm2d(dim)\nself.act2 = nn.LeakyReLU(0.2)\nself.conv2 = nn.Conv2d(dim, dim, 3)\nself.pool2 = nn.MaxPool2d(3, 2)\nself.fc1"
        ],
        [
            "layers.BatchNorm(num_channels)\nlayers.ReLU()\nlayers.Conv2D(num_channels, num_channels, 3)\nlayers.Pooling2D(pool_size=2, strides=2)",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)",
            "self.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\n",
            "layers.BatchNorm(num_channels)\nlayers.ReLU()\nlayers.Conv2D(num_channels, num_channels, 3)\nlayers.Pooling2D(pool_size=2, strides=2)"
        ],
        [
            "layers.LayerNorm(axis)",
            "layers.LayerNormalization()",
            "nn.LayerNorm(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.",
            "LayerNorm(axis)"
        ],
        [
            "layers.LeakyReLU()",
            "layers.LeakyReLU(args.leaky)",
            "nn.LeakyReLU(args.leaky)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.",
            "LeakyReLU()"
        ],
        [
            "layers.LSTM(512, 512, dropout=0.1)",
            "layers.LSTM(512, dropout=0.1)",
            "nn.LSTM(512, 512, dropout=0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.",
            "LSTM(512, 512, dropout=0.1)"
        ],
        [
            "tf.concat(states, axis=-1)",
            "tf.concat(states, axis=-1)",
            "torch.cat(states, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.",
            "concat(states, axis=-1)"
        ],
        [
            "tf.nn.softmax(logits, dim=-1)",
            "tf.nn.log_softmax(logits, axis=-1)",
            "F.log_softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "softmax(logits, dim=-1)"
        ],
        [
            "tf.nn.softmax(logits, axis=-1)",
            "tf.nn.softmax(logits, axis=-1)",
            "F.softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "softmax(logits, axis=-1)"
        ],
        [
            "tf.reshape(x, [batch_size, -1])",
            "tf.reshape(x, [batch_size, -1])",
            "torch.reshape(x, [batch_size, -1])",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.",
            "reshape(x, [batch_size, -1])"
        ],
        [
            "layers.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=dropout)",
            "layers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "nn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.",
            "MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=dropout)"
        ],
        [
            "self.attn = layers.MultiHeadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNorm(args.d_model)",
            "self.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)",
            "self.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\n",
            "self.attn = layers.MultiHeadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNorm(args.d_model)"
        ],
        [
            "self.rnn = (layers.LSTM(d_model, d_model) if rnn_type == 'LSTM' else layers.GRU(d_model, d_model))",
            "self.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))",
            "self.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\n",
            "self.rnn = (layers.LSTM(d_model, d_model) if rnn_type == 'LSTM' else layers.GRU(d_model, d_model))"
        ],
        [
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)",
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)",
            "x = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\n",
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)"
        ],
        [
            "x = tensor.reshape(x, [-1, bsz])     y = tensor.reshape(y, [-1, bsz])",
            "z = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)",
            "z = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\n",
            "x = tensor.reshape(x, [-1, bsz])     y = tensor.reshape(y, [-1, bsz])"
        ],
        [
            "x = self.bn1(x) + \\",
            "x = self.layer1(x)",
            "x = self.layer1(x)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\n",
            "x = self.bn1(x) + \\"
        ],
        [
            "y = tf.nn.relu(tf.nn.dropout(tf.nn.flatten(self.ffn1(x))), keep_prob=0.5)\nx = tf.add(x, tf.dropout(x, keep_prob=0.",
            "y = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "y = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\n",
            "y = tf.nn.relu(tf.nn.dropout(tf.nn.flatten(self.ffn1(x))), keep_prob=0.5)\nx = tf.add(x, tf.dropout(x, keep_prob=0."
        ],
        [
            "self.bn1 = layers.BatchNormalization(dim)\nself.act1 = activation()\nself.conv1 = layers.Conv3x3(dim)\nself.pool1 = layers.MaxPooling2d(3, 2)",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNormalization(dim)\nself.act1 = activation()\nself.conv1 = layers.Conv3x3(dim)\nself.pool1 = layers.MaxPooling2d(3, 2)"
        ],
        [
            "self.layer_1 = conv2d(x, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\n",
            "self.layer_1 = conv2d(x, kernel=3, stride=1, dilation=2)"
        ],
        [
            "layers.MaxPool2d(kernel_size=3, stride=2)",
            "layers.MaxPooling2D(pool_size=3, strides=2)",
            "nn.MaxPool2d(kernel_size=3, stride=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.",
            "MaxPool2d(kernel_size=3, stride=2)"
        ],
        [
            "self.fc = layers.Dense(dim)",
            "self.fc = CustomLinear(dim)",
            "self.fc = CustomLinear(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\n",
            "self.fc = layers.Dense(dim)"
        ],
        [
            "layers.Conv2D(in_channels=128, out_channels=512, strides=2, kernel_size=5, bias=False)",
            "layers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)",
            "nn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.",
            "Conv2D(in_channels=128, out_channels=512, strides=2, kernel_size=5, bias=False)"
        ]
    ],
    [
        [
            "layers.Conv2D(64, 128, 3)",
            "layers.Conv2D(128, 3)",
            "nn.Conv2d(64, 128, 3)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.",
            "Conv2D(64, 128, 3)"
        ],
        [
            "layers.Conv2d(dim_in, dim_out, 3, 2)",
            "layers.Conv2D(dim_out, 3, 2)",
            "nn.Conv2d(dim_in, dim_out, 3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.",
            "Conv2d(dim_in, dim_out, 3, 2)"
        ],
        [
            "layers.LeakyReLU()",
            "layers.ReLU()",
            "nn.ReLU()",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.",
            "LeakyReLU()"
        ],
        [
            "layers.Dropout(0.1)",
            "layers.Dropout(0.1)",
            "nn.Dropout(0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.",
            "Dropout(0.1)"
        ],
        [
            "layers.Linear(dim_in, dim_out)",
            "layers.Dense(dim_out)",
            "nn.Linear(dim_in, dim_out)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.",
            "Linear(dim_in, dim_out)"
        ],
        [
            "x = tf.nn.relu(self.fc(x))",
            "x = tf.nn.relu(self.fc(x))",
            "x = F.relu(self.fc(x))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\n",
            "x = tf.nn.relu(self.fc(x))"
        ],
        [
            "layers.Embedding(vocab_size, embed_dim)",
            "layers.Embedding(vocab_size, embed_dim)",
            "nn.Embedding(vocab_size, embed_dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nnn.Conv2d(dim_in, dim_out, 3, 2)\n# Keras\nlayers.Conv2D(dim_out, 3, 2)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.",
            "Embedding(vocab_size, embed_dim)"
        ],
        [
            "max_len = 512\nself.embed_tokens = layers.Embedding(n_words, max_len)",
            "max_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)",
            "max_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\n",
            "max_len = 512\nself.embed_tokens = layers.Embedding(n_words, max_len)"
        ],
        [
            "layers.MaxPooling2D(pool_size, stride)",
            "layers.MaxPooling2D(2, 2)",
            "nn.MaxPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.",
            "MaxPooling2D(pool_size, stride)"
        ],
        [
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2d(dim, dim, 3)\nself.pool1 = layers.MaxPool2d(3, 2)\n\nself.bn2 = nn.BatchNorm2d(dim)\nself.act2 = nn.LeakyReLU(0.2)\nself.conv2 = nn.Conv2d(dim, dim, 3)\nself.pool2 = nn.MaxPool2d(3, 2)\nself.fc =",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2D(dim, 3)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = nn.LeakyReLU(0.2)\nself.conv1 = nn.Conv2d(dim, dim, 3)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.LeakyReLU(0.2)\nself.conv1 = layers.Conv2d(dim, dim, 3)\nself.pool1 = layers.MaxPool2d(3, 2)\n\nself.bn2 = nn.BatchNorm2d(dim)\nself.act2 = nn.LeakyReLU(0.2)\nself.conv2 = nn.Conv2d(dim, dim, 3)\nself.pool2 = nn.MaxPool2d(3, 2)\nself.fc ="
        ],
        [
            "self.bn1 = layers.BatchNormalization(axis=0)\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2d(num_channels, num_channels, 3)\nself.pool1 = layers.AvgPooling2d(2, 2)\n\nself.fc2 = CustomLinear(dim)\nself.bn2 = nn.BatchNorm2d(num_channels)\nself.act2 = nn.ReLU()\nself.conv2 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool2 = nn.",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)",
            "self.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNormalization(axis=0)\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2d(num_channels, num_channels, 3)\nself.pool1 = layers.AvgPooling2d(2, 2)\n\nself.fc2 = CustomLinear(dim)\nself.bn2 = nn.BatchNorm2d(num_channels)\nself.act2 = nn.ReLU()\nself.conv2 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool2 = nn."
        ],
        [
            "layers.L2(dim)",
            "layers.LayerNormalization()",
            "nn.LayerNorm(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.",
            "L2(dim)"
        ],
        [
            "layers.LeakyReLU(args.leaky)",
            "layers.LeakyReLU(args.leaky)",
            "nn.LeakyReLU(args.leaky)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.",
            "LeakyReLU(args.leaky)"
        ],
        [
            "layers.LSTM(512, 512, dropout=0.1)",
            "layers.LSTM(512, dropout=0.1)",
            "nn.LSTM(512, 512, dropout=0.1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.",
            "LSTM(512, 512, dropout=0.1)"
        ],
        [
            "tf.concat(states, axis=-1)",
            "tf.concat(states, axis=-1)",
            "torch.cat(states, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.",
            "concat(states, axis=-1)"
        ],
        [
            "tf.nn.softmax(logits, dim=-1)",
            "tf.nn.log_softmax(logits, axis=-1)",
            "F.log_softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "softmax(logits, dim=-1)"
        ],
        [
            "tf.nn.softmax(logits, axis=-1)",
            "tf.nn.softmax(logits, axis=-1)",
            "F.softmax(logits, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.",
            "softmax(logits, axis=-1)"
        ],
        [
            "tf.reshape(x, [batch_size, -1])",
            "tf.reshape(x, [batch_size, -1])",
            "torch.reshape(x, [batch_size, -1])",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.",
            "reshape(x, [batch_size, -1])"
        ],
        [
            "layers.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "layers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "nn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)",
            "# Translate PyTorch to Keras\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.",
            "MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)"
        ],
        [
            "attn = tf.nn.multi_head_attention(d_model, n_heads, dropout=attn_dropout)\ndrop1 = tf.nn.dropout(d_model, rate=dropout)\nnorm1 = tf.nn.layer_norm(d_model, activity_regularization=rate)",
            "self.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)",
            "self.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\n",
            "attn = tf.nn.multi_head_attention(d_model, n_heads, dropout=attn_dropout)\ndrop1 = tf.nn.dropout(d_model, rate=dropout)\nnorm1 = tf.nn.layer_norm(d_model, activity_regularization=rate)"
        ],
        [
            "self.rnn = layers.LSTM() if rnn_type == 'LSTM' else layers.GRU()",
            "self.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))",
            "self.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\nz = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(num_channels)\nself.act1 = nn.ReLU()\nself.conv1 = nn.Conv2d(num_channels, num_channels, 3)\nself.pool1 = nn.AvgPool2d(2, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = layers.ReLU()\nself.conv1 = layers.Conv2D(num_channels, 3)\nself.pool1 = layers.AveragePooling2D(2, 2)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nnn.Dropout(0.1)\n# Keras\nlayers.Dropout(0.1)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\n",
            "self.rnn = layers.LSTM() if rnn_type == 'LSTM' else layers.GRU()"
        ],
        [
            "x = self.classifier(x)\nreturn tf.nn.softmax(x, dim=-1)",
            "x = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)",
            "x = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\nself.fc = CustomLinear(dim)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\n",
            "x = self.classifier(x)\nreturn tf.nn.softmax(x, dim=-1)"
        ],
        [
            "z = tf.nn.dense(x, activation='softmax', Nepal=False)",
            "z = tf.concat([tf.reshape(x, [bsz, -1]), tf.reshape(y, [bsz, -1])], axis=1)",
            "z = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nmax_len = 512\nself.embed_tokens = nn.Embedding(n_words, dim_emb)\n# Keras\nmax_len = 512\nself.embed_tokens = layers.Embedding(n_words, dim_emb, input_length=max_len)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nz = torch.cat([torch.reshape(x, [bsz, -1]), torch.reshape(y, [bsz, -1])], dim=1)\n# Keras\n",
            "z = tf.nn.dense(x, activation='softmax', Nepal=False)"
        ],
        [
            "x = tf.nn.Layer1(x)",
            "x = self.layer1(x)",
            "x = self.layer1(x)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nx = F.relu(self.fc(x))\n# Keras\nx = tf.nn.relu(self.fc(x))\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)\n\n# PyTorch\nx = self.classifier(x)\nreturn F.log_softmax(x, dim=-1)\n# Keras\nx = self.classifier(x)\nreturn tf.nn.log_softmax(x, axis=-1)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\n",
            "x = tf.nn.Layer1(x)"
        ],
        [
            "\ndef forward(x, weight, bias):\n y = self.relu(tf.matmul(x, weight) + bias)\n return tf.dropout(y, 0.5)",
            "y = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "y = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\n",
            "\ndef forward(x, weight, bias):\n y = self.relu(tf.matmul(x, weight) + bias)\n return tf.dropout(y, 0.5)"
        ],
        [
            "self.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = layers.Convolution(\nkernel_size=(3, 3),\nstrides=(1, 1),\npadding='same'\n)\nself.pool1 = layers.MaxPooling2d(kernel_size=(3, 2), strides=(2, 2))",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)",
            "self.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LayerNorm(dim)\n# Keras\nlayers.LayerNormalization()\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\ny = self.ffn2(F.relu(self.ffn1(x)))\nx = x + self.drop(y)\n# Keras\ny = self.ffn2(tf.nn.relu(self.ffn1(x)))\nx = x + self.drop(y)\n\n# PyTorch\nnn.LeakyReLU(args.leaky)\n# Keras\nlayers.LeakyReLU(args.leaky)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\n",
            "self.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = layers.Convolution(\nkernel_size=(3, 3),\nstrides=(1, 1),\npadding='same'\n)\nself.pool1 = layers.MaxPooling2d(kernel_size=(3, 2), strides=(2, 2))"
        ],
        [
            "self.layer_1 = layers.Conv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "self.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nnn.Conv2d(64, 128, 3)\n# Keras\nlayers.Conv2D(128, 3)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nself.rnn = (nn.LSTM(d_model, d_model) if rnn_type == 'LSTM' else nn.GRU(d_model, d_model))\n# Keras\nself.rnn = (layers.LSTM(d_model) if rnn_type == 'LSTM' else layers.GRU(d_model))\n\n# PyTorch\ntorch.reshape(x, [batch_size, -1])\n# Keras\ntf.reshape(x, [batch_size, -1])\n\n# PyTorch\nself.layer_1 = BasicConv2D(planes, kernel=3, stride=1, dilation=2)\n# Keras\n",
            "self.layer_1 = layers.Conv2D(planes, kernel=3, stride=1, dilation=2)"
        ],
        [
            "layers.MaxPooling2d(kernel_size=3, stride=2)",
            "layers.MaxPooling2D(pool_size=3, strides=2)",
            "nn.MaxPool2d(kernel_size=3, stride=2)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\nnn.MultiheadAttention(embed_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n# Keras\nlayers.MultiHeadAttention(key_dim=model_dim, num_heads=num_heads, dropout=attn_dropout)\n\n# PyTorch\nx = self.layer1(x)\n# Keras\nx = self.layer1(x)\n\n# PyTorch\nnn.Linear(dim_in, dim_out)\n# Keras\nlayers.Dense(dim_out)\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.",
            "MaxPooling2d(kernel_size=3, stride=2)"
        ],
        [
            "self.fc = layers.Linear(dim)",
            "self.fc = CustomLinear(dim)",
            "self.fc = CustomLinear(dim)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nself.attn = nn.MultiheadAttention(args.d_model, args.n_heads, dropout=args.att_dropout)\nself.drop1 = nn.Dropout(args.dropout)\nself.norm1 = nn.LayerNorm(args.d_model)\n# Keras\nself.attn = layers.MultiHeadAttention(args.n_heads, args.d_model, dropout=args.att_dropout)\nself.drop1 = layers.Dropout(args.dropout)\nself.norm1 = layers.LayerNormalization(args.d_model)\n\n# PyTorch\ntorch.cat(states, dim=-1)\n# Keras\ntf.concat(states, axis=-1)\n\n# PyTorch\nself.bn1 = nn.BatchNorm2d(dim)\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = nn.MaxPool2d(3, 2)\n# Keras\nself.bn1 = layers.BatchNormalization()\nself.act1 = activation()\nself.conv1 = conv3x3(dim)\nself.pool1 = layers.MaxPooling2D(3, 2)\n\n# PyTorch\nnn.Embedding(vocab_size, embed_dim)\n# Keras\nlayers.Embedding(vocab_size, embed_dim)\n\n# PyTorch\nF.log_softmax(logits, dim=-1)\n# Keras\ntf.nn.log_softmax(logits, axis=-1)\n\n# PyTorch\nself.fc = CustomLinear(dim)\n# Keras\n",
            "self.fc = layers.Linear(dim)"
        ],
        [
            "layers.Conv2d(in_channels=128, out_channels=512, strides=2, kernel_size=5, activation='relu')",
            "layers.Conv2D(filters=512, strides=2, kernel_size=5, use_bias=False)",
            "nn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)",
            "# Translate PyTorch to Keras\n\n# PyTorch\nnn.LSTM(512, 512, dropout=0.1)\n# Keras\nlayers.LSTM(512, dropout=0.1)\n\n# PyTorch\nnn.MaxPool2d(2, 2)\n# Keras\nlayers.MaxPooling2D(2, 2)\n\n# PyTorch\nnn.ReLU()\n# Keras\nlayers.ReLU()\n\n# PyTorch\nF.softmax(logits, dim=-1)\n# Keras\ntf.nn.softmax(logits, axis=-1)\n\n# PyTorch\nnn.MaxPool2d(kernel_size=3, stride=2)\n# Keras\nlayers.MaxPooling2D(pool_size=3, strides=2)\n\n# PyTorch\nnn.Conv2d(in_channels=128, out_channels=512, stride=2, kernel_size=5, bias=False)\n# Keras\nlayers.",
            "Conv2d(in_channels=128, out_channels=512, strides=2, kernel_size=5, activation='relu')"
        ]
    ]
]