图源于电力电子课本65页——电容滤波的单相不可控整流电路。

f<-function(w,d)
{
l<-w/sqrt(w^2+1)*exp(-atan(w)/w)*exp(-d/w)
r<-sin(d)
return(l-r)
}
w<-seq(0.01,60,0.01)
d<-rep(0,length(w))
s<-rep(0,length(w))
for(i in 1:length(w))
{
root<-uniroot(f,c(0,pi/2),w=w[i],tol=0.01)
d[i]<-root$root
s[i]<-pi-d[i]-atan(w[i])
} library(ggplot2)
DataSet1<-data.frame(w,value=d,lab=rep("d",length(w)))
DataSet2<-data.frame(w,value=s,lab=rep("s",length(w)))
DataSet <- rbind(DataSet1,DataSet2) p<-ggplot(data=DataSet,aes(w,value,color=lab))
p+geom_line()+
scale_colour_hue("value",breaks=c("d","s"),labels=c(expression(delta),expression(theta)))+
labs(x=(expression(omega*RC/rad)),y=expression(list(delta,theta)/rad))+
xlim(0,60)+ylim(0,pi)+
scale_x_continuous(expand = c(0,0))+
scale_y_continuous(breaks=round(c(0,pi/6,pi/3,pi/2,2*pi/3,5*pi/6,pi),digits=2),
labels=expression(0,pi/6,pi/3,pi/2,2*pi/3,5*pi/6,pi),expand = c(0, 0))

练习了:

  1. 自定义离散色彩标度;
  2. 修改坐标轴标签;
  3. 修改坐标范围;
  4. 修改显示刻度;
  5. expression数学表达式。

更新补充:图源于电力电子课本143页——单相交流调压电路。

AngleToRadian<-function(alpha)
{
return(alpha*pi/180)
}
RadianToAngle<-function(alpha)
{
return(alpha/pi*180)
}
f<-function(alpha,theta,varphi)
{
var1<-sin(alpha+theta-varphi)
if(varphi==0)
var2<-0
else
var2<-sin(alpha-varphi)*exp(-theta/tan(varphi))
return(var1-var2)
}
alpha<-seq(0,180-2,0.5)
varphi<-seq(0,90,15)
data<-data.frame() for(a in alpha)
{
for(v in varphi)
{
if(v<=a){
t=uniroot(f,c(1e-3,pi+1e-3),alpha=AngleToRadian(a),
varphi=AngleToRadian(v),tol=0.001)
result<-c(a,RadianToAngle(t$root),v)
data<-rbind(data,result)}
}
}
names(data)<-c("alpha","theta","varphi") data$I_VTN<-rep(0,dim(data)[1])
for(i in 1:dim(data)[1])
{
a<-AngleToRadian(data$alpha[i])
t<-AngleToRadian(data$theta[i])
if(data$varphi[i]==90)
v<-AngleToRadian(data$varphi[i]-1)
else
v<-AngleToRadian(data$varphi[i]) data$I_VTN[i]<-1/(2*sqrt(pi))*sqrt(t-sin(t)*cos(2*a+v+t)/cos(v))
}
library(ggplot2)
theme_set(theme_light())
ggplot(data=data,aes(alpha,theta,color=factor(varphi)))+
geom_line()+scale_colour_hue(expression(varphi/(degree)))+
labs(x=(expression(alpha/(degree))),y=expression(theta/(degree)))
ggplot(data=data,aes(alpha,I_VTN,color=factor(varphi)))+geom_line()+
geom_line()+scale_colour_hue(expression(varphi/(degree)))+
labs(x=(expression(alpha/(degree))),y=expression(I[VTN]))

ggplot2练习的更多相关文章

  1. 跟我一起ggplot2(1)

    ggplot2 R的作图工具包,可以使用非常简单的语句实现非常复杂漂亮的效果. qplot 加载qplot library(ggplot2) # 测试数据集,ggplot2内置的钻石数据 qplot( ...

  2. R语言:ggplot2精细化绘图——以实用商业化图表绘图为例

    本文版权归http://www.cnblogs.com/weibaar 本文旨在介绍R语言中ggplot2包的一些精细化操作,主要适用于对R画图有一定了解,需要更精细化作图的人,尤其是那些刚从exce ...

  3. ggplot2 多图排版

    和R自带的绘图系统不同,ggplot2不能直接通过par(mfrow) 或者 layout()来排版多张图片.终于发现,其实可以通过一个『gridExtra』包来搞定: require(gridExt ...

  4. ggplot2 上篇

    title: "ggplot2 上篇" author: "li_volleyball" date: "2016年4月16日" output: ...

  5. ggplot2包--R可视化

    1.ggplot2发展历程 ggplot2是Hadley在爱荷华州立大学博士期间的作品,也是他博士论文的主题之一,实际上ggplot2还有个前身ggplot,但后来废弃了,某种程度上这也是Hadley ...

  6. ggplot2.multiplot:将多个图形使用GGPLOT2在同一页上

    一页多图 介绍 ggplot2.multiplot是一个易于使用的功能,将多个图形在同一页面上使用R统计软件和GGPLOT2绘图方法.这个功能是从easyGgplot2包. 安装并加载easyGgpl ...

  7. ggplot2 legend图例的修改

    ggplot2中的legend包括四个部分: legend.tittle, legend.text, legend.key, legend.backgroud.针对每一部分有四种处理方式: eleme ...

  8. Plotting means and error bars (ggplot2)

    library(ggplot2) ############################################# # summarySE ######################### ...

  9. ggplot2 学习笔记 (持续更新.....)

    1. 目前有四种主题 theme_gray(), theme_bw() , theme_minimal(),theme_classic() 2. X轴设置刻度 scale_x_continuous(l ...

  10. ggplot2 demo

    title <- rep("A Really Rather Long Text Label", 25)value <- runif(25, 1,10)spacing & ...

随机推荐

  1. FPGA 浮点定点数的处理

    大纲: 1浮点数的格式指定 2浮点数的运算(加法) 3浮点数加减法器的实现(难于乘除法器的实现)  1. 在FPGA的设计中,浮点数的概念不同于C语言中的定义,这里的浮点数指的是小数点位置会发生变化的 ...

  2. OpenCV Laplace 算子

    #include "opencv2/imgproc/imgproc.hpp" #include "opencv2/highgui/highgui.hpp" #i ...

  3. pandas向表格中循环写入数据

    pandas向表格中循环写入多行数据 import pandas as pd def list_topic(total_num, str1): """ 生成多个主题 :p ...

  4. 隐私标签(Privacy.Tag):轻轻一贴,愉快拍照!

    用相机去捕捉精彩瞬间,用照片来记录生活足迹,并实时地与朋友们分享当下的心情,似乎已成为我们忙碌生活中最有趣的调味剂.但随着移动设备照相功能的日益完善,以及各大社交平台的不断兴起,很多时候,你是否也会有 ...

  5. python反转链表和成对反转

    https://www.cnblogs.com/tianqizhi/p/9673894.html https://blog.csdn.net/weixin_34168700/article/detai ...

  6. idea如何使用git

    1.安装好git(我下载的2.23.0版本百度网盘分享)  提取码  7ie1 2.配置git环境变量  Path   路径是你安装的git 目录下的bin目录   安装好后窗口命令输入git 可以测 ...

  7. 网易与Google合作,于GDC开幕首日发布开源UI自动化测试方案

    [TechWeb报道]美西时间3月19日,在GDC开幕第一天的Google开发者专场,Google发布了一款由网易研发的UI自动化测试方案:Airtest Project. Google方面评价,这可 ...

  8. 蚂蚁金服招聘-无线测试开发(20k-36k/月)

    蚂蚁金服-支付宝国际事业部-高级测试开发工程师/测试专家 工作年限:三年以上学历要求:本科期望层级:P6/P7工作地点:上海,杭州,深圳等为什么选择加入我们? 我们的岗位有何不同?1.国际化远景:随着 ...

  9. java.lang.SecurityException: class "javax.servlet.AsyncContext"'s signer information does not match signer information of other classes in the same package

    最近在写个Http协议的压测挡板时,遇到以下错误. 2018-03-08 10:34:07.808:INFO:oejs.Server:jetty-8.1.9.v20130131 2018-03-08 ...

  10. ODI学习资料

    ODI12.2.1.4入门指南:https://docs.oracle.com/en/middleware/fusion-middleware/data-integrator/12.2.1.4/ind ...