CrossEntropy.h 2.34 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
/* NiuTrans.Tensor - an open-source tensor library
 * Copyright (C) 2017, Natural Language Processing Lab, Northestern University. 
 * All rights reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/*
 * $Created by: Xu Chen (email: hello_master1954@163.com) 2018-09-17
 */

#ifndef __CROSSENTROPY_H__
#define __CROSSENTROPY_H__

#include "../XTensor.h"

namespace nts{ // namespace nts(NiuTrans.Tensor)

enum LOSS_COMPUTE_WAY{
REDUCE_SUM,
REDUCE_MEAN
};

xiaotong committed
34
/* compute the cross entropy loss */
35 36 37 38
void _CrossEntropy(const XTensor * output, const XTensor * gold, 
                   XTensor * loss, const XTensor * weight = NULL, 
                   const XTensor * padding = NULL, int leadingDim = -1);

xiaotong committed
39 40
/* compute the cross entropy loss */
void _CrossEntropyFast(const XTensor * output, const XTensor * gold,
41 42 43
                         XTensor * loss, const XTensor * weight = NULL, 
                         const XTensor * padding = NULL, int leadingDim = -1);

xiaotong committed
44
/* compute the cross entropy loss (return the loss) */
45 46 47 48
DTYPE _CrossEntropy(const XTensor * output, const XTensor * gold,
                    LOSS_COMPUTE_WAY reduceWay, const XTensor * weight = NULL, 
                    const XTensor * padding = NULL, int leadingDim = -1);

xiaotong committed
49 50 51 52
/* compute the cross entropy loss (return the loss) */
DTYPE _CrossEntropyFast(const XTensor * output, const XTensor * gold,
                        LOSS_COMPUTE_WAY reduceWay = REDUCE_MEAN, const XTensor * weight = NULL,
                        const XTensor * padding = NULL, int leadingDim = -1);
53 54 55 56 57 58 59 60

/* backward computation of cross entropy function */
void _CrossEntropyBackward(XTensor * dedy, const XTensor * output, const XTensor * gold, 
                           const XTensor * weight = NULL, XTensor * padding = NULL, 
                           int leadingDim = -1);

} // namespace nts(NiuTrans.Tensor)

xiaotong committed
61
#endif // __CROSSENTROPY_H__