tv.icntv.grade.film.InctvGrade.java Source code

Java tutorial

Introduction

Here is the source code for tv.icntv.grade.film.InctvGrade.java

Source

/* Copyright 2013 Future TV, Inc.
 *
 *      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.
 */

package tv.icntv.grade.film;

import com.google.common.base.Function;
import com.google.common.base.Joiner;
import com.google.common.base.Splitter;
import com.google.common.collect.Lists;
import com.sun.istack.Nullable;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.util.Tool;
import org.apache.hadoop.util.ToolRunner;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import tv.icntv.grade.film.core.AbstractJob;
import tv.icntv.grade.film.dbcollect.TableConcurrencyJob;
import tv.icntv.grade.film.recommend.TopNJob;
import tv.icntv.grade.film.utils.ReflectionUtils;

import java.util.Date;
import java.util.List;

/**
 * Created with IntelliJ IDEA.
 * User: xiaowu lei
 * Date: 13-12-19
 * Time: ?11:28
 */
public class InctvGrade extends AbstractJob {
    private static Logger logger = LoggerFactory.getLogger("grade-main");
    private static final String cdn_tables = "hbase.cdn.tables";

    private static final String split = ",";

    public InctvGrade(Configuration conf) {
        this.configuration = conf;
    }

    public static void main(String[] args) throws Exception {
        Configuration configuration = HBaseConfiguration.create();
        configuration.addResource("grade.xml");
        int i = ToolRunner.run(configuration, new Grade(configuration), new String[] {});
        System.exit(i);
    }

    @Override
    public int run(String[] strings) throws Exception {

        try {
            ToolRunner.run(configuration, new TableConcurrencyJob(), strings);
        } catch (Exception e) {
        }

        List<String> list = Lists.newArrayList(Splitter.on(",").split(configuration.get(cdn_tables)));
        List<String> results = Lists.transform(list, new Function<String, String>() {
            @Override
            public String apply(@Nullable java.lang.String input) {
                return String.format(configuration.get("hdfs.directory.base.db"), new Date(), input);
            }
        });
        //topN
        try {
            ToolRunner.run(configuration, new TopNJob(),
                    new String[] { Joiner.on(",").join(results),
                            String.format(configuration.get("hdfs.directory.num.middle"), new Date()),
                            String.format(configuration.get("hdfs.directory.num.result"), new Date()) });
        } catch (Exception e) {
            return 1;
        }
        //recommend data generate data
        String baseCfData = String.format(configuration.get("hdfs.directory.base.score"), new Date());
        String output = String.format(configuration.get("icntv.cf.recommend.directory.target"), new Date());
        String temp = String.format(configuration.get("icntv.cf.recommend.directory.temp"), new Date());
        String optional = getParameterForCf(configuration, baseCfData, output, temp);
        try {
            ToolRunner.run(configuration,
                    (Tool) ReflectionUtils.newInstance(configuration.get("recommend.job.className")),
                    new String[] { Joiner.on(",").join(results), baseCfData, optional, output, temp });
        } catch (Exception e) {
            return 1;
        }
        //?
        String middleDirectory = String.format(configuration.get("icntv.correlate.input"), new Date());
        try {
            ToolRunner.run(configuration,
                    (Tool) ReflectionUtils.newInstance(configuration.get("correlate.job.className")),
                    new String[] { Joiner.on(",").join(results), middleDirectory,
                            getParameterForCorrelate(configuration, middleDirectory,
                                    String.format(configuration.get("icntv.correlate.fp.growth.output"),
                                            new Date())),
                            String.format(configuration.get("icntv.correlate.output"), new Date()) });
        } catch (Exception e) {
            return 1;
        }
        return 0; //To change body of implemented methods use File | Settings | File Templates.
    }

    private String getParameterForCf(Configuration configuration, String baseCfData, String output, String temp) {
        StringBuilder sb = new StringBuilder();
        sb.append("--input ").append(baseCfData);
        sb.append(" --output ").append(output);
        sb.append(" --numRecommendations ").append(configuration.get("icntv.cf.recommend.num"));
        sb.append(" --similarityClassname ").append(configuration.get("icntv.cf.recommend.similarityClassname"));
        sb.append(" --tempDir ").append(temp);
        return sb.toString();
    }

    private String getParameterForCorrelate(Configuration configuration, String correlateData, String fpGrowth) {
        StringBuilder sb = new StringBuilder();
        sb.append("minSupport=").append(configuration.get("correlate.minSupport", "3")).append("--")
                .append("maxHeapSize=100").append("--").append("splitterPattern='[\t ]'").append("--")
                .append("input=").append(correlateData).append("--").append("output=").append(fpGrowth);
        return sb.toString();
    }

}