for(i in 1:nsimu){ aa=data[order(runif(ss)),] A0=aa[c(1:ss0),] A1=aa[-c(1:ss0),] model.1=glm(是否点击 ~ 平台编码+ 竞拍底价 + 是否为全插屏广告 + 手机运营商 + 网络状况 + 设备制造商 + 时段 ,family=binomial(link=logit),data=A0) model.2=glm(是否点击 ~ 平台编码+ 竞拍底价 + 是否为全插屏广告 + 设备制造商 + 时段 ,family=binomial(link=logit),data=A0) model.3=glm(是否点击 ~ 是否为全插屏广告 ,family=binomial(link=logit),data=A0) pred.1=predict(model.1,A1) pred.2=predict(model.2,A1) pred.3=predict(model.3,A1) Y=A1$是否点击 auc.1=roc(Y,pred.1)$auc auc.2=roc(Y,pred.2)$auc auc.3=roc(Y,pred.3)$auc AUC[i,]=c(auc.1,auc.2,auc.3) }

时间: 2024-01-17 08:04:41 浏览: 24
这段代码中,首先通过`order(runif(ss))`来产生一个长度为`ss`的随机序列,然后使用该序列对原始数据`data`进行随机重排,得到一个新的数据集`aa`。接着,将`aa`按照`ss0`的比例分成两个数据集`A0`和`A1`,用`A0`来训练模型,用`A1`来测试模型预测结果。其中,`是否点击`为因变量,`平台编码`、`竞拍底价`、`是否为全插屏广告`、`手机运营商`、`网络状况`、`设备制造商`、`时段`为自变量。接着,使用`glm`函数来建立三个不同的逻辑回归模型,分别为`model.1`、`model.2`、`model.3`。其中,`model.1`包含所有自变量,`model.2`去掉了`手机运营商`和`网络状况`两个变量,`model.3`只包含`是否为全插屏广告`一个变量。使用`predict`函数对`A1`数据集进行预测,得到三个模型的预测结果`pred.1`、`pred.2`、`pred.3`。接着使用`roc`函数计算出三个模型的AUC值,存放在`AUC`矩阵中的第`i`行。这个过程将重复运行`nsimu`次,得到三个模型的AUC值的分布情况。
相关问题

这两个网络的流量矩阵怎么计算,用MATLAB实现:m0=2 m=2 N=20 x1=100rand(1,m0); y1=100rand(1,m0); x2=100rand(1,m0); y2=100rand(1,m0); for i=1:N z11(i)=10 end z1=z11' for i=1:N z22(i)=90 end z2=z22' %for i=1:N %z1(i)=10 %end %for i=1:N %z2(i)=90 %end for i=1:m0 for j=i+1:m0 p1=rand(1,1); p2=rand(1,1); if p1>0.5 a1(i,j)=1; a1(j,i)=0; end if p2>0.5 a2(i,j)=1; a2(j,i)=0; end end end for k=m0+1:N M=size(a1,1);p=zeros(1,M); M1=size(a2,1);p1=zeros(1,M1); x0=100rand(1,1);y0=100rand(1,1); x1(k)=x0;y1(k)=y0; x2(k)=x0;y2(k)=y0; if length(find(a1==1))==0 p(:)=1/M; else for i=1:M p(i)=length(a1(i,:)==1)/length(find(a1==1)); end if length(find(a2==1))==0 p1(:)=1/M1; else for i=1:M1 p1(i)=length(a2(i,:)==1)/length(find(a2==1)); end end end pp=cumsum(p); pp1=cumsum(p1); for i=1:m random_data=rand(1,1); random_data1=rand(1,1); aa=find(pp>=random_data);jj=aa(1); aa1=find(pp1>=random_data1);jj1=aa1(1); a1(k,jj)=1; a1(jj,k)=1; a2(k,jj1)=1; a2(jj1,k)=1; end end

这段代码的作用是生成两个网络的流量矩阵a1和a2,其中m0是已经存在的节点数,N是总的节点数,x1、y1、x2、y2是节点的坐标,z1和z2是节点的流量需求。下面是计算流量矩阵的代码: ```matlab m0 = 2; m = 2; N = 20; x1 = 100*rand(1,m0); y1 = 100*rand(1,m0); x2 = 100*rand(1,m0); y2 = 100*rand(1,m0); % 初始化节点流量需求 for i = 1:N z11(i) = 10; end z1 = z11'; for i = 1:N z22(i) = 90; end z2 = z22'; % 初始化连接矩阵 a1 = zeros(N,N); a2 = zeros(N,N); % 随机连接已有节点 for i = 1:m0 for j = i+1:m0 p1 = rand(1,1); p2 = rand(1,1); if p1 > 0.5 a1(i,j) = 1; a1(j,i) = 0; end if p2 > 0.5 a2(i,j) = 1; a2(j,i) = 0; end end end % 生成新节点并进行连接 for k = m0+1:N % 计算节点k与已有节点的连接概率 M = size(a1,1); p = zeros(1,M); M1 = size(a2,1); p1 = zeros(1,M1); x0 = 100*rand(1,1); y0 = 100*rand(1,1); x1(k) = x0; y1(k) = y0; x2(k) = x0; y2(k) = y0; if length(find(a1==1)) == 0 p(:) = 1/M; else for i = 1:M p(i) = length(a1(i,:)==1)/length(find(a1==1)); end end if length(find(a2==1)) == 0 p1(:) = 1/M1; else for i = 1:M1 p1(i) = length(a2(i,:)==1)/length(find(a2==1)); end end pp = cumsum(p); pp1 = cumsum(p1); for i = 1:m random_data = rand(1,1); random_data1 = rand(1,1); aa = find(pp>=random_data); jj = aa(1); aa1 = find(pp1>=random_data1); jj1 = aa1(1); a1(k,jj) = 1; a1(jj,k) = 1; a2(k,jj1) = 1; a2(jj1,k) = 1; end end ``` 其中,`a1`和`a2`即为两个网络的流量矩阵。

c语言:求sn=a+aa+aaa

以下是两种C语言求Sn=a+aa+aaa的例子: 1.使用循环计算 ```c #include <stdio.h> int func(int a, int n){ int result = 0; // 结果 int i = 0; // 每次累加的结果为上一次的加数*10再加a int add = a; while (i < n) // 循环n次,也就是n项和 { result += add; add = add * 10 + a; i++; } return result; } int main(){ int a, n; printf("请输入a和n:\n"); scanf("%d%d", &a, &n); printf("结果为:%d\n", func(a, n)); return 0; } ``` 2.使用数学公式计算 ```c #include <stdio.h> #include <math.h> int func(int a, int n){ int result = 0; int i; for (i = 1; i <= n; i++) { result += a * (pow(10, i) - 1) / 9; } return result; } int main(){ int a, n; printf("请输入a和n:\n"); scanf("%d%d", &a, &n); printf("结果为:%d\n", func(a, n)); return 0; } ```

相关推荐

DD=xlsread('residual.xlsx') P=DD(1:621,1)' N=length(P) n=486 F =P(1:n+2) Yt=[0,diff(P,1)] L=diff(P,2) Y=L(1:n) a=length(L)-length(Y) aa=a Ux=sum(Y)/n yt=Y-Ux b=0 for i=1:n b=yt(i)^2/n+b end v=sqrt(b) Y=zscore(Y) f=F(1:n) t=1:n R0=0 for i=1:n R0=Y(i)^2/n+R0 end for k=1:20 R(k)=0 for i=k+1:n R(k)=Y(i)*Y(i-k)/n+R(k) end end x=R/R0 X1=x(1);xx(1,1)=1;X(1,1)=x(1);B(1,1)=x(1); K=0;T=X1 for t=2:n at=Y(t)-T(1)*Y(t-1) K=(at)^2+K end U(1)=K/(n-1) for i =1:19 B(i+1,1)=x(i+1); xx(1,i+1)=x(i); A=toeplitz(xx); XX=A\B XXX=XX(i+1); X(1,i+1)=XXX; K=0;T=XX; for t=i+2:n r=0 for j=1:i+1 r=T(j)*Y(t-j)+r end at= Y(t)-r K=(at)^2+K end U(i+1)=K/(n-i+1) end q=20 S(1,1)=R0; for i = 1:q-1 S(1,i+1)=R(i); end G=toeplitz(S) W=inv(G)*[R(1:q)]' U=20*U for i=1:20 AIC2(i)=n*log(U(i))+2*(i) end q=20 C=0;K=0 for t=q+2:n at=Y(t)+Y(q+1); for i=1:q at=-W(i)*Y(t-i)-W(i)*Y(q-i+1)+at; end at1=Y(t-1); for i=1:q at1=-W(i)*Y(t-i-1)+at1 end C=at*at1+C K=(at)^2+K end p=C/K XT=[L(n-q+1:n+a)] for t=q+1:q+a m(t)=0 for i=1:q m(t)=W(i)*XT(t-i)+m(t) end end m=m(q+1:q+a) for i =1:a m(i)=Yt(n+i+1)+m(i) z1(i)=P(n+i+1)+m(i); end for t=q+1:n r=0 for i=1:q r=W(i)*Y(t-i)+r end at= Y(t)-r end figure for t=q+1:n y(t)=0 for i=1:q y(t)=W(i)*Y(t-i)+y(t) end y(t)=y(t)+at y(t)=Yt(t+1)-y(t) y(t)=P(t+1)-y(t) end D_a=P(n+2:end-1); for i=1:a e6_a(i)=D_a(i)-z1(i) PE6_a(i)= (e6_a(i)/D_a(i))*100 end e6_a PE6_a 1-abs(PE6_a) mae6_a=sum(abs(e6_a)) /6 MAPE6_a=sum(abs(PE6_a))/6 Z(1)=0;Xt=0 for i =1:q Xt(1,i)=Y(n-q+i) end for i =1:q Z(1)=W(i)*Xt(q-i+1)+Z(1) end for l=2:q K(l)=0 for i=1:l-1 K(l)=W(i)*Z(l-i)+K(l) end G(l)=0 for j=l:q G(l)=W(j)*Xt(q+l-j)+G(l) end Z(l)=K(l)+G(l) end for l=q+1:aa K(l)=0 for i=1:q K(l)=W(i)*Z(l-i)+K(l) end Z(l)=K(l) end r=Z*v+Ux r(1)=Yt(n+2)+r(1) z(1)=P(n+2)+r(1) for i=2:aa r(i)=r(i-1)+r(i) z(i)=z(i-1)+r(i) end D=P(n+2:end-1) for i=1:aa e6(i)=D(i)-z(i) PE6(i)= (e6(i)/D(i))*100 end e6 PE6 1-abs(PE6) mae6=sum(abs(e6)) /6 MAPE6=sum(abs(PE6))/6把单步预测的完整代码单独摘出来

最新推荐

recommend-type

node-v0.8.10-sunos-x64.tar.gz

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

【课程设计】实现的金融风控贷款违约预测python源码.zip

【课程设计】实现的金融风控贷款违约预测python源码.zip
recommend-type

node-v0.10.27-x86.msi

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

课设毕设基于SSM的高校二手交易平台-LW+PPT+源码可运行.zip

课设毕设基于SSM的高校二手交易平台--LW+PPT+源码可运行
recommend-type

c++,冒险游戏,可供学习

冒险游戏,可供学习
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

SPDK_NVMF_DISCOVERY_NQN是什么 有什么作用

SPDK_NVMF_DISCOVERY_NQN 是 SPDK (Storage Performance Development Kit) 中用于查询 NVMf (Non-Volatile Memory express over Fabrics) 存储设备名称的协议。NVMf 是一种基于网络的存储协议,可用于连接远程非易失性内存存储器。 SPDK_NVMF_DISCOVERY_NQN 的作用是让存储应用程序能够通过 SPDK 查询 NVMf 存储设备的名称,以便能够访问这些存储设备。通过查询 NVMf 存储设备名称,存储应用程序可以获取必要的信息,例如存储设备的IP地址、端口号、名称等,以便能
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。