`
yuyuqian521
  • 浏览: 46923 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

怎样用C#调用R软件:R(D)COM(一)

阅读更多
    R软件是一款功能强大的统计软件,而且是开源项目,所以如果没有银子买SAS这样的系统的时候, R软件是最好的选择。但是不要以为免费的东西就是粗制滥造,R软件绝对不逊色与其它众多的商业统计软件,同Linux一样,拥有众多支持者的R软件一直在成长,不断的有新的软件包加入到R软件的程序库里。到目前为止,R软件的软件包覆盖了统计计算的所有领域,从传统的回归分析到前沿的金融时间序列分析都有。

     C#是Microsoft公司推出的新一代程序编程语言,不仅是纯粹的面向对象,而且在VS 2005的支持下,拥有快速开发应用程序的能力,集成了大量的控件,不论是开发Windows程序,还是开发Web应用,均相当出色。所以,使用C#来开发我们的应用,是明智的选择。

     统计模型在开发应用的过程中,特别是对银行、证卷和保险这些行业,都有着非常广泛的应用。不过,对于这些行业的从业者而言,掌握行业知识、统计知识和计算机能力的人很少。即使拥有这些能力,做这些工作也是相当耗费精力和时间的。所以开发出这些行业有针对性的行业软件就非常的重要。除了能够降低使用门槛,减轻工作负担以外,关键是能够跟即时。快速的对市场和行情做出决策是相当重要的。利用C#做应用程序,R软件做后台的统计分析,这是我们的想法。试想如果自己用代码去实现一个简单的统计回归,检验分析,绝对不是一件容易的事情。

     在C#中怎样调用R软件呢。R软件不只是一种统计工具,它还是一种语言,就语法形式而言跟S语言非常相识。所以类似与数据库一样,在客户端不是就只能调用一些函数,而是可以用数据库提供的SQL语言编写出拥有灵活多变,满足各种需求的功能。R语言也一样,可以在客户端,用S语言编写程序,传送到R软件,R软件计算完成后将结果在传回C# 。既然需要来回传送,必然需要中间的桥梁,就像数据库需要驱动程序一样,在C#中调用R软件,需要安装R(D)COM,R(D)COM是一种DCOM组件,可以注册到Windows的组件服务中,供程序调用。如果用C#开发Web程序,由于ASP.NET是用ASPNET这个用户在执行,而这个用户的权限很低,所以如果要调用R(D)COM的服务的化,需要给ASPNET授予权限。

所有具体的操作,使用方法,可以参考:

http://www.codeproject.com/KB/cs/RtoCSharp.aspx

    下面是一个具体例子:

    
using System;
using System.Configuration;


namespace Common.Regression
{
   /**//// <summary>
   /// IRegression 回归类接口
   /// </summary>
    public interface IRegression
    {
        double[,] Data
        {
            get;
            set;
        }

        RegressionSummary Summary
        {
            get;
        }

        void DoRegression();

        void ReleaseLock();


    }

}


using System;
using STATCONNECTORSRVLib;
using RServerManager;
using System.Threading;

namespace Common.Regression
{
    /**//// <summary>
    /// BaseRegression 回归抽象基类
    /// </summary>
    public abstract class BaseRegression : IRegression
    {
        private static ServerPool mServerPool = null;
        private ServerItem mServerItem = null;
        private IStatConnector mStatConnector = null;

        private static string mKey = "R";
        private static string mClient = "this is client";
        private static int mWaitTime = 50;
        private static int mMaxLoop = 20;
        private static int mMaxServerCount = 5;
        private static int mServerCount = 0;

        static BaseRegression()
        {
            if (mServerPool == null)
            {
                mServerPool = new ServerPool();
            }
        }

        private double[,] mData;
        public double[,] Data
        {
            get
            {
                return mData;
            }
            set
            {
                mData = value;
            }
        }

        private RegressionSummary mSummary;
        public RegressionSummary Summary
        {
            get
            {
                return mSummary;
            }
            set
            {
                mSummary = value;
            }
        }

        /**//// <summary>
        /// 执行回归函数
        /// </summary>
        public abstract void DoRegression();

        /**//// <summary>
        /// 得到执行R代码的连接
       /// </summary>
        /// <returns></returns>
        protected IStatConnector GetStatConnector()
        {
            mServerItem = mServerPool.GetServerExclusive(mKey, Client);
            int count = 0;
            while (mServerItem == null)
            {
                if (mServerCount < mMaxServerCount)
                {
                    //当小于最小服务器数目时,增加连接
                    mStatConnector = new StatConnectorClass();
                    mStatConnector.Init(mKey);
                    mServerPool.Add(mStatConnector, mKey);
                    mServerCount++;
                    mServerItem = mServerPool.GetServerExclusive(mKey, mClient);
                    break;
                }
                if (count < mMaxLoop)
                {
                    Thread.Sleep(mWaitTime);
                    count++;
                    mServerItem = mServerPool.GetServerExclusive(mKey, mClient);
                }
                else
                {
                    return null;
                }
            }

            mStatConnector = mServerItem.Server;
            return mStatConnector;
           
        }

        /**//// <summary>
        /// 释放锁定
        /// </summary>
        public void ReleaseLock()
        {
            if (mServerItem != null)
            {
                mServerItem.ReleaseLock();
            }
        }

        public BaseRegression()
        {           
        }
    }

}


using System;
using System.Data;
using System.Configuration;
using STATCONNECTORSRVLib;

namespace Common.Regression
{
    /**//// <summary>
    /// LogicRegression 利用Logistic模型进行回归
    /// </summary>
    public class LogisticRegression : BaseRegression
    {
        private IStatConnector mStatConnector;
        public LogisticRegression()
        {
            mStatConnector = GetStatConnector();
        }

        public override void DoRegression()
        {
            if (Data == null)
            {
                return;
            }
          
            mStatConnector.SetSymbol("dd", Data);
            mStatConnector.EvaluateNoReturn("Y <- dd[,1]");
            mStatConnector.EvaluateNoReturn("X <- dd[,-1]");

            mStatConnector.EvaluateNoReturn("gr<-glm(Y~X , family=binomial(logit))");
            mStatConnector.EvaluateNoReturn("ss<-summary(gr)");

            Summary = new RegressionSummary(mStatConnector);
            
        }
    }

}

分享到:
评论
1 楼 ryusukekenji 2009-10-04  
我想通过 R(D)COM 和 RExcel 在 Excel 使用 R ,但是一直出现错误信息,请问你是否熟悉 RExcel 呢?

相关推荐

    Java-PHP-C#

    那应该怎么样来检验暑假是否正确呢? 在PHP中加入了正则表达式的支持,让我们可以十分方便的进行数据匹配。 2 什么是正则表达式: 简单的说,正则表达式是一种可以用于模式匹配和替换的强大工具。在几乎所有的...

    C# for CSDN 乱七八糟的看不懂

    C#(WINFORM)学习 一、 C#基础 基础 类型和变量 类型和变量 类型 C# 支持两种类型:“值类型”和“引用类型”。值类型包括简单类型(如 char、int 和 float 等)、枚举类型和结构类型。引用类型包括类 (Class)类 ...

    c#等待提示对话框 防界面假死 更新了

    与前版功能基本相似,修正了部分bug,对界面进行了美化,目前这个美化相信应该够用了,因为时间问题没有增加可自定义界面功能,等有时间再提供吧,压缩文件使用“好压”做的,里面有一个例子,图片资源编辑工具,大家...

    c#调用api控制windows关机示例(可以重启/注销)

    方法一:调用windows自带的shutdown.exe (缺点:会出现倒计时窗口) System.Diagnostics.Process.Start(“shutdown.exe”, “-r -f -t 15”); shutdown参数含义:-r关闭并重启动此计算机;-f 强制运行的应用程序关闭...

    C#坦克大战代码(电脑版本跟手机版本)

    现在毕业了,因为工作中用的是C#,最近很想拿C#把以前写的坦克大战重写下,来熟悉熟悉C#的基本语法。 程序很简单,跟java代码相比没有多大改动 开发环境 vs2008 实现方法如下 1.在form中添加一个panel,在panel的 ...

    c# http post get

    * *使 用:HttpProc.WebClient client = new HttpProc.WebClient(); client.Encoding = System.Text.Encoding.Default;//默认编码方式,根据需要设置其他类型 client.OpenRead("http://www.baidu.com");//普通get...

    asp.net知识库

    Coalesys PanelBar + R.a.d Treeview +Xml 构建的Asp.net 菜单和权限管理模块 突破屏蔽限制,自己的网站使劲弹新IE窗口 对页面SCROLLING的CSS不能生效原因 .Net 中IE使用WinForm控件的使用心得。 动态加载用户控件的...

    【。net 专业】 面试题

    您使用一个SqlDataAdapter对象和一个SqlCommand对象通过调用一个存储过程从数据库中获取产品数据。您将SqlCommand对象的CommandType属性设置为CommandType.StoredProcedure,并将它的CommandText属性设置为...

    C# WinForm快捷键设置技巧

    1、Alt+*(按钮快捷键) 按钮快捷键也为最常用快捷键,其设置也故为简单。...使用Modifiers可设置组合键,键盘数字区按键的Keys枚举以D打头,而小键盘上的数字以NumPad打头。按下Ctrl与Shift组合键的方

    简单C#坦克大战源码(电脑版本跟手机版本)

    现在毕业了,因为工作中用的是C#,最近很想拿C#把以前写的坦克大战重写下,来熟悉熟悉C#的基本语法。 程序很简单,跟java代码相比没有多大改动 实现方法如下 1.在form中添加一个panel,在panel的 Paint方法中得到...

    正则表达式

    例如,假定我们正在检索的模式是一个或多个字母后面跟随一位或多位数字,那么我们可以使用模式 / [a-z] + \ d+/.但是由于假定我们真正关心的是每个匹配 尾部的数字,那么如果我们将模式的数字部分放在括号中 (/ [a-z]...

    asp.net面试题

    该文件称作为“代码隐藏”文件,如果用C#创建,该文件将具有“.ascx.cs”扩展名 B.web窗体也是类 C.项目中所有的Web窗体页的代码隐藏文件都被编译成项目动态链接库(.dll)文件 D.以上都不正确 五、下列ASP.NET语句...

    Unity游戏开发高级教程 第二部分 [MP4] (14.77G)

    128.UIFrame022 K- d6 D$ ^3 N3 f6 q r) d( e 129.UIFrame032 Y3 A, `! T q. ]5 |1 g' E z4 r1 R+ C 130.UIFrame04 131.UIFrame05 132.UIFrame062 R- |& e z; u 133.UIFrame07 134.UIFrame08 135.UIFrame096 k9 R4 `...

    数据库设计工具BDB 最新版 v3.0

    1, 增加E-R图支持 2,增加数据库对象查询功能 3,添加方案右键菜单 4,SQL查询分析功能完善 5,修正了一些bug v3.0浏览: [url]http://www.bainsoft.com/products.html[/url] 贝恩网站: [url]...

Global site tag (gtag.js) - Google Analytics