-
Notifications
You must be signed in to change notification settings - Fork 42
/
PlotFuncs_ScalarVector.py
495 lines (388 loc) · 41 KB
/
PlotFuncs_ScalarVector.py
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
#================================PlotFuncs_ScalarVector.py==================================#
# Created by Ciaran O'Hare 2022
# Description:
# This file has some extra classes for dealing with the scalar and vector plots
# only
#==============================================================================#
from PlotFuncs import *
def NaturalnessCorner(ax,scale,Lambda_min_TeV,dim,edgecolor='gold',facecolor='gold',
lw=3,path_effects=line_background(4,'k'),
nlevels=100,alpha=0.1,Lambda_max_TeV=1e20,
mass_label=5e-13,
text_label=r'Natural $d_e$ ($\Lambda = 10$ TeV)',
text_shift=[1,1],zorder=-100,
Shading=True,fs=25):
m_vals = array([1e-30,1e30])
d_natural = lambda m,Lambda : m/(scale*Lambda**dim)
ax.plot(m_vals,d_natural(m_vals,Lambda_min_TeV*1e12),'-',lw=lw,color=edgecolor,path_effects=path_effects,zorder=zorder)
if Shading:
Lambda_vals = logspace(log10(Lambda_min_TeV),log10(Lambda_max_TeV),nlevels)
for Lambda in Lambda_vals:
ax.fill_between(m_vals,d_natural(m_vals,Lambda*1e12),y2=1e-100,color=facecolor,alpha=alpha,zorder=zorder,lw=0)
trans_angle = plt.gca().transData.transform_angles(array((45.0,)),array([[0, 0]]))[0]
ax.text(mass_label*text_shift[0],0.1*d_natural(mass_label,Lambda_min_TeV*1e12)*text_shift[1],text_label,fontsize=fs,color=edgecolor,rotation=trans_angle,path_effects=line_background(1,'k'),clip_on=True,zorder=zorder)
return
def FuzzyDM(ax,edgecolor='#205e8a',facecolor='#205e8a',text_col='#205e8a',
lw=3,path_effects=line_background(0,'k'),
nlevels=100,alpha=0.05,m_max=2e-20,m_min=1e-24,
g_label=5e-13,fs=23,
text_label=r'{\bf Structure formation}',
text_shift=[1,1],zorder=-100,rotation=90,
ymax=1e30,ymin=1e-30):
g_vals = array([ymin,ymax])
m_vals = logspace(log10(m_min),log10(m_max),nlevels)
for m in m_vals:
ax.fill_between(array([1e-30,m]),array([ymax,ymax]),y2=ymin,color=facecolor,alpha=alpha,zorder=zorder,lw=0)
ax.text(m_max*text_shift[0]*0.5,g_label*text_shift[1],text_label,fontsize=fs,color=text_col,rotation=rotation,path_effects=line_background(1,'k'),clip_on=True,zorder=zorder)
return
class ScalarPhoton():
def MICROSCOPE(ax,text_label=r'{\bf MICROSCOPE}',text_pos=[1e-16,0.34e-3],col='#84878c',text_col='k',fs=15,zorder=-1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/MICROSCOPE.txt")
FilledLimit(ax,dat,text_label,y2=1e20,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def EotWashEP(ax,text_label=r'{\bf E\"ot-Wash (EP)}',text_pos=[1.4e-24,1.8e-3],col='gray',text_col='k',fs=20,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/EotWashEP.txt")
FilledLimit(ax,dat,text_label,y2=1e20,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def FifthForce(ax,text_label=r'{\bf Fifth force (ISL)}',text_pos=[0.5e-21,0.6e2],rotation=-25,col='darkgray',text_col='k',fs=20,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/FifthForce.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def GlobularClusters(ax,text_label=r'{\bf Globular clusters}',text_pos=[2e-24,3.3e9],col=[0.0, 0.66, 0.42],text_col='w',fs=27,zorder=1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/GlobularClusters.txt")
FilledLimit(ax,dat,text_label,y2=1e20,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def AURIGA(ax,text_label=r'{\bf AURIGA}',text_pos=[0.18e-11,0.1e-6],rotation=90,col='darkred',text_col='darkred',fs=17,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=0):
dat = loadtxt("limit_data/ScalarPhoton/AURIGA.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def DyDy(ax,text_label=r'{\bf Dy/Dy}',text_pos=[0.4e-22,0.3e-6],rotation=28,col='#a11a4e',text_col='w',fs=19,zorder=0.02,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/DyDy.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def DyQuartz(ax,text_label=r'{\bf Dy/Quartz}',text_pos=[0.1e-15,3e-1],rotation=28,col='#c11a4e',text_col='w',fs=20,zorder=0.10,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/DyQuartz.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def YbSr(ax,text_label=r'{\bf Yb$^+$/Sr}',text_pos=[2e-20,1.5e-6],rotation=23,col='#a11b33',text_col='w',fs=15,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=1,path_effects=line_background(1.5,'k')):
dat = loadtxt("limit_data/ScalarPhoton/YbSr.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=path_effects)
return
def RbCs(ax,text_label=r'\center{{\bf SYRTE \newline Rb/Cs}}',text_pos=[0.25e-23,4e-7],rotation=-30,col='#c7345d',text_col='w',fs=17,zorder=0.01,text_on=True,Projection=False,edgealpha=1,lw=1):
dat = loadtxt("limit_data/ScalarPhoton/RbCs.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1,'k'))
return
def BACON(ax,text_label=r'{\bf BACON}',text_pos=[0.1e-21,0.075e-7],rotation=26,col='#59042d',text_col='#59042d',fs=18,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=1):
dat = loadtxt("limit_data/ScalarPhoton/BACON.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def PTB(ax,text_label=r'{\bf PTB}',text_pos=[0.3e-20,1.2e-8],rotation=23,col='#d11b33',text_col='#d11b33',fs=19,zorder=-0.01,text_on=True,Projection=False,edgealpha=1,lw=1):
dat = loadtxt("limit_data/ScalarPhoton/PTB.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def SrSi(ax,text_label=r'{\bf Sr/Si}',text_pos=[0.3e-17,0.4e-3],rotation=13,col='#730f3a',text_col='w',fs=14,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=1):
dat = loadtxt("limit_data/ScalarPhoton/SrSi.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def HQuartzSapphire(ax,text_label=r'\center{\bf H/Quartz/Sapphire}',text_pos=[0.7e-18,1e4],rotation=0,col='#a81313',text_col='w',fs=20,zorder=0.11,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/HQuartzSapphire.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def I2(ax,text_label=r'{\bf I}$_2$',text_pos=[0.5e-12,1e6],rotation=0,col='#b52452',text_col='w',fs=25,zorder=0.13,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/I2.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def DAMNED(ax,text_label=r'{\bf DAMNED}',text_pos=[0.85e-10,0.7e4],rotation=90,col='#b5243f',text_col='w',fs=13,zorder=0.11,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/DAMNED.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def GEO600(ax,text_label=r'{\bf GEO600}',text_pos=[4e-13,1e2],rotation=0,col='#b5260d',text_col='w',fs=20,zorder=0.11,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/GEO600.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def LIGO(ax,text_label=r'{\bf LIGO}',text_pos=[0.73e-13,0.05e3],rotation=90,col='#c3151d',text_col='w',fs=19,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/LIGO.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def Holometer(ax,text_label=r'{\bf Holometer}',text_pos=[1.85e-10,0.15e9],rotation=0,col='#b53724',text_col='w',fs=15,zorder=0.17,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/Holometer.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1,'k'))
return
def DynamicDecoupling(ax,text_label=r'\center{\bf Dynamic \newline decoupling}',text_pos=[0.8e-13,0.15e9],rotation=-26,col='crimson',text_col='w',fs=10,zorder=0.14,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/DynamicDecoupling.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1,'k'))
return
def CsCav(ax,text_label=r'{\bf Cs/Cav}',text_pos=[3e-8,0.2e7],rotation=55,col='red',text_col='w',fs=18,zorder=0.109,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/CsCav.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
# Projected
def AEDGE(ax,text_label=r'{\bf AEDGE}',text_pos=[1e-16,0.1e-11],rotation=50,col='#eb4034',text_col='#eb4034',fs=20,zorder=-1.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/Projections/AEDGE.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def AION(ax,text_label=r'{\bf AION}',text_pos=[1e-14,6e-7],rotation=51,col='#eb4034',text_col='#eb4034',fs=18,zorder=-1.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/Projections/AION-km.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def MAGIS(ax,text_label=r'{\bf MAGIS}',text_pos=[4e-16,2e-7],rotation=35,col='#eb4034',text_col='#eb4034',fs=17,zorder=-1.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/Projections/MAGIS-km.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def NuclearClock(ax,text_label=r'{\bf Nuclear clock}',text_pos=[2e-19,2e-12],rotation=30,col='darkred',text_col='darkred',fs=20,zorder=-1.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/Projections/NuclearClock.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def DUAL(ax,text_label=r'{\bf DUAL}',text_pos=[0.5e-11,1e-6],rotation=0,col='#a10649',text_col='#a10649',fs=15,zorder=0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/Projections/DUAL.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def FOCOS(ax,text_label=r'{\bf FOCOS}',text_pos=[9e-17,3e-5],rotation=0,col='gray',text_col='gray',fs=17,zorder=-1.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/Projections/FOCOS.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def Resonators(ax,text_label=r'{\bf Resonators}',ms=7,alpha=0.75,text_pos=[0.1e-9,0.9e-4],rotation=23,rotation2=90,col='#690c43',text_col='#690c43',fs=25,fs2=13,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarPhoton/Projections/Resonator-Sapphire.txt")
plt.plot(dat[:-15,0],dat[:-15,1],'--',color=col,zorder=zorder,alpha=alpha,lw=lw)
dat = loadtxt("limit_data/ScalarPhoton/Projections/Resonator-Pillar.txt")
plt.plot(dat[:,0],dat[:,1],'--',color=col,zorder=zorder,alpha=alpha,lw=lw)
dat = loadtxt("limit_data/ScalarPhoton/Projections/Resonator-Quartz.txt")
plt.plot(dat[:,0],dat[:,1],'--',color=col,zorder=zorder,alpha=alpha,lw=lw)
dat = loadtxt("limit_data/ScalarPhoton/Projections/Resonator-Helium.txt")
plt.plot(dat[:,0],dat[:,1],'--',color=col,zorder=zorder,alpha=alpha,lw=lw)
ax.text(1.8e-11,3e-2,'Helium',rotation=rotation2,fontsize=fs2,color=text_col,alpha=alpha)
ax.text(1.3e-10,3e-2,'Sapphire',rotation=rotation2,fontsize=fs2,color=text_col,alpha=alpha)
ax.text(4e-9,0.7e-1,'Pillar',rotation=rotation2,fontsize=fs2,color=text_col,alpha=alpha)
ax.text(4.5e-7,0.8e2,'Quartz BAW',rotation=rotation2,fontsize=fs2,color=text_col,alpha=alpha)
plt.text(text_pos[0],text_pos[1],text_label,rotation=rotation,color=text_col,fontsize=fs,alpha=alpha)
return
class ScalarElectron():
def MICROSCOPE(ax,text_label=r'{\bf MICROSCOPE}',text_pos=[2e-24,6e-3],col='#84878c',text_col='k',fs=20,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/MICROSCOPE.txt")
FilledLimit(ax,dat,text_label,y2=1e20,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def EotWashEP(ax,text_label=r'{\bf E\"ot-Wash (EP)}',text_pos=[2e-24,0.8e-1],col='gray',text_col='k',fs=20,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/EotWashEP.txt")
FilledLimit(ax,dat,text_label,y2=1e20,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def FifthForce(ax,text_label=r'{\bf Fifth force (ISL)}',text_pos=[0.5e-21,4e2],rotation=-26,col='darkgray',text_col='k',fs=20,zorder=0.101,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/FifthForce.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def RedGiants(ax,text_label=r'{\bf Red giants}',text_pos=[2e-24,7e7],col=[0.0, 0.66, 0.42],text_col='w',fs=30,zorder=2,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/RedGiants.txt")
FilledLimit(ax,dat,text_label,y2=1e20,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def WhiteDwarfs(ax,text_label=r'{\bf White Dwarfs}',text_pos=[2e-24,4.2e7],col=[0.0, 0.66, 0.42],text_col='w',fs=30,zorder=2,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/WhiteDwarfs.txt")
FilledLimit(ax,dat,text_label,y2=1e20,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def HSi(ax,text_label=r'{\bf H/Si}',text_pos=[1e-20,2e-4],rotation=23,col='#730f3a',text_col='w',fs=20,zorder=-0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/HSi.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def AURIGA(ax,text_label=r'{\bf AURIGA}',text_pos=[0.8e-11,0.01e-2],rotation=-90,col='darkred',text_col='darkred',fs=17,zorder=0.01,text_on=True,Projection=False,edgealpha=1,lw=0):
dat = loadtxt("limit_data/ScalarElectron/AURIGA.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def I2(ax,text_label=r'{\bf I}$_2$',text_pos=[0.33e-12,2.0e6],rotation=20,col='#b52452',text_col='w',fs=19,zorder=0.11,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/I2.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def GEO600(ax,text_label=r'{\bf GEO600}',text_pos=[4e-13,2e2],rotation=0,col='#b5260d',text_col='w',fs=20,zorder=0.109,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/GEO600.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def HQuartzSapphire(ax,text_label=r'\center{{\bf H/Quartz/Sapphire}}',text_pos=[0.8e-18,1e4],rotation=0,col='#a81313',text_col='w',fs=20,zorder=0.11,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/HQuartzSapphire.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def DAMNED(ax,text_label=r'{\bf DAMNED}',text_pos=[4.6e-11,1.55e4],rotation=90,col='#b5243f',text_col='w',fs=12,zorder=0.12,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/DAMNED.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def CsCav(ax,text_label=r'{\bf Cs/Cav}',text_pos=[2.9e-9,0.07e7],rotation=20,col='red',text_col='w',fs=16,zorder=0.11,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/CsCav.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def Cavities(ax,text_label=r'{\bf Cavities}',text_pos=[0.5e-16,1.9e1],rotation=0,col='#ab333b',text_col='w',fs=18,zorder=0.109,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Cavities.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def Holometer(ax,text_label=r'{\bf Holometer}',text_pos=[1.3e-9,3e4],rotation=0,col='#b53724',text_col='#b53724',fs=15,zorder=0.15,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Holometer.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def RbQuartz(ax,text_label=r'{\bf Rb/Quartz}',text_pos=[2e-14,6e3],rotation=25,col='#c11a4e',text_col='w',fs=15,zorder=0.10999,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/RbQuartz.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def YbCs(ax,text_label=r'{\bf Yb/Cs}',text_pos=[1.8e-22,1.3e-5],rotation=0,col='#a11b33',text_col='w',fs=16,zorder=-1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/YbCs.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def LIGO(ax,text_label=r'{\bf LIGO}',text_pos=[0.73e-13,0.02e3],rotation=90,col='#c3151d',text_col='w',fs=19,zorder=0.101,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/LIGO.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def NANOGrav(ax,text_label=r'{\bf NANOGrav}',text_pos=[0.15e-23,5.0e-6],rotation=0,col='#6b012a',text_col='w',fs=16,zorder=-10,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/NANOGrav.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1,'k'))
return
# Projections
def AEDGE(ax,text_label=r'{\bf AEDGE}',text_pos=[1e-16,0.1e-11],rotation=51,col='#eb4034',text_col='#eb4034',fs=20,zorder=0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Projections/AEDGE.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def AION(ax,text_label=r'{\bf AION-km}',text_pos=[1e-14,0.1e-5],rotation=52,col='#eb4034',text_col='#eb4034',fs=20,zorder=0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Projections/AION-km.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def MAGIS(ax,text_label=r'{\bf MAGIS-km}',text_pos=[3e-16,0.2e-6],rotation=36,col='#eb4034',text_col='#eb4034',fs=20,zorder=0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Projections/MAGIS-km.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def DUAL(ax,text_label=r'{\bf DUAL}',text_pos=[3e-11,0.1e-4],rotation=0,col='#eb4034',text_col='#eb4034',fs=15,zorder=0,text_on=True,Projection=False,edgealpha=1,lw=1):
dat = loadtxt("limit_data/ScalarElectron/Projections/DUAL.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def Resonators(ax,text_label=r'{\bf Resonators}',ms=7,alpha=0.75,text_pos=[0.1e-9,0.9e-4],rotation=23,rotation2=90,col='#690c43',text_col='#690c43',fs=25,fs2=13,zorder=0.2,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Projections/Resonator-Sapphire.txt")
plt.plot(dat[:-10000,0],dat[:-10000,1],'--',color=col,zorder=zorder,alpha=alpha,lw=lw)
dat = loadtxt("limit_data/ScalarElectron/Projections/Resonator-Pillar.txt")
plt.plot(dat[:,0],dat[:,1],'--',color=col,zorder=zorder,alpha=alpha,lw=lw)
dat = loadtxt("limit_data/ScalarElectron/Projections/Resonator-Quartz.txt")
plt.plot(dat[:,0],dat[:,1],'--',color=col,zorder=zorder,alpha=alpha,lw=lw)
#dat = loadtxt("limit_data/ScalarElectron/Projections/Resonator-Helium.txt")
#plt.plot(dat[:,0],dat[:,1],'--',color=col,zorder=zorder,alpha=alpha,lw=lw)
#ax.text(1.8e-11,2.5e-1,'Helium',rotation=rotation2,fontsize=fs2,color=text_col,alpha=alpha)
ax.text(1.2e-10,1e-2,'Sapphire',rotation=rotation2,fontsize=fs2,color=text_col,alpha=alpha)
ax.text(4e-9,0.5e-1,'Pillar',rotation=rotation2,fontsize=fs2,color=text_col,alpha=alpha)
ax.text(4.5e-7,0.8e3,'Quartz BAW',rotation=rotation2,fontsize=fs2,color=text_col,alpha=alpha)
plt.text(text_pos[0],text_pos[1],text_label,rotation=rotation,color=text_col,fontsize=fs,alpha=alpha)
return
def OpticalMW(ax,text_label=r'{\bf Optical-MW clock}',text_pos=[3e-22,7e-8],rotation=29,col='#703e41',text_col='#703e41',fs=20,zorder=0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Projections/OpticalMW.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def SrOH(ax,text_label=r'{\bf SrOH}',text_pos=[3e-22,20e-10],rotation=30,col='#703e41',text_col='#703e41',fs=20,zorder=0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Projections/SrOH.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def CavityCavity(ax,text_label=r'{\bf Cavity}',text_pos=[5e-13,2e-4],rotation=25,col='#703e41',text_col='#703e41',fs=13,zorder=0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/ScalarElectron/Projections/CavityCavity.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def IPTA(ax,text_label=r'{\bf IPTA}',text_pos=[5e-24,2e-7],rotation=0,col='#274f70',text_col='#274f70',fs=20,zorder=-1,text_on=True,Projection=False,edgealpha=1,lw=2):
dat = loadtxt("limit_data/ScalarElectron/IPTA.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def HELIOS(ax,text_label=r'{\bf HELIOS}',text_pos=[3e-11,0.6e0],rotation=90,col='#4f061d',text_col='#4f061d',fs=15,zorder=0.1011,text_on=True,Projection=False,edgealpha=1,lw=2):
dat = loadtxt("limit_data/ScalarElectron/Projections/HELIOS.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
class VectorBL():
def MICROSCOPE(ax,text_label=r'{\bf MICROSCOPE}',text_pos=[1.5e-22,2.7e-25],col='#84878c',text_col='k',fs=17,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/MICROSCOPE.txt")
FilledLimit(ax,dat,text_label,y2=1e20,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def EotWashEP(ax,text_label=r'{\bf E\"ot-Wash (EP)}',rotation=15,text_pos=[0.1e-8,0.5e-21],col='gray',text_col='k',fs=18,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/EotWashEP.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def InverseSquareLaw(ax,text_label=r'{\bf ISL}',rotation=60,text_pos=[9.9e-4,5.5e-19],col='darkgray',text_col='k',fs=18,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/InverseSquareLaw.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def Casimir(ax,text_label=r'{\bf Casimir}',rotation=60,text_pos=[3e-2,0.7e-14],col='silver',text_col='k',fs=18,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/Casimir.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def DMStability(ax,text_label=r'{\bf DM decays}',text_pos=[1e1,5e-16],rotation=-24,col='royalblue',text_col='w',fs=20,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/DMStability.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def Sun(ax,text_label=r'{\bf Sun}',text_pos=[0.1e2,0.8e-11],rotation=0,col='forestgreen',text_col='w',fs=24,zorder=0.2,text_on=True,Projection=False,edgealpha=1,lw=1.2):
dat = loadtxt("limit_data/VectorB-L/Sun.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def HorizontalBranch(ax,text_label=r'{\bf Horizontal branch}',text_pos=[0.7e-6,1e-10],rotation=0,col='seagreen',text_col='w',fs=19,zorder=0.19,text_on=True,Projection=False,edgealpha=1,lw=1.2):
dat = loadtxt("limit_data/VectorB-L/HorizontalBranch.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def RedGiant(ax,text_label=r'{\bf Red giants}',text_pos=[1e-4,2.2e-11],rotation=0,col=[0.0, 0.66, 0.42],text_col='w',fs=19,zorder=0.18,text_on=True,Projection=False,edgealpha=1,lw=1.2):
dat = loadtxt("limit_data/VectorB-L/RedGiant.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def EotWashDM(ax,text_label=r'{\bf E\"ot-Wash (DM)}',text_pos=[0.08e-17,0.5e-23],rotation=90,col='darkred',text_col='w',fs=20,zorder=0.2,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/EotWashDM.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def KAGRA(ax,text_label=r'{\bf KAGRA}',text_pos=[0.3e-12,9.5e-19],rotation=90,col='#8c193c',text_col='w',fs=20,zorder=0.5,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/KAGRA.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def LIGO(ax,text_label='',text_pos=[1e-13,3e-20],rotation=90,col='crimson',text_col='w',fs=17,zorder=0.21,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/LIGO-O1.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def LIGOVirgo(ax,text_pos=[0.1e-12,2e-21],fs=18,rotation=0,text_label=r'\begin{center} {\bf LIGO/\linebreak VIRGO} \end{center}',col='crimson',text_col='w',zorder=0.2,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/LIGOVirgo.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def LISAPathfinder(ax,text_label=r'{\bf LISA Pathfinder}',text_pos=[3e-17,0.3e-15],rotation=70,col='#6b0a24',text_col='w',fs=17,zorder=0.21,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/LISAPathfinder.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def LISAPathfinderRelativeAcceleration(ax,text_label=r'{\bf LISA Pathfinder} (rel. acceleration)',text_pos=[1.4e-15,0.19e-21],rotation=90,col='#6b0a24',text_col='w',fs=17,zorder=0.1,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/LISAPathfinder-RelativeAcceleration.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def PPTA(ax,text_label=r'{\bf PPTA}',text_pos=[2e-22,1e-21],rotation=90,col='#692820',text_col='w',fs=19,zorder=0.21,text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/PPTA.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw,path_effects=line_background(1.5,'k'))
return
def MAGIS(ax,text_label=r'{\bf MAGIS-100} (upgrade)',text_pos=[0.02e-20,0.75e-28],rotation=0,col='#a10649',text_col='#a10649',fs=16,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=1.5):
#dat = loadtxt("limit_data/VectorB-L/Projections/MAGIS100-Initial.txt")
#UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
dat = loadtxt("limit_data/VectorB-L/Projections/MAGIS100-Upgrade.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
#plt.text(0.04e-19,0.6e-26,'Initial',color=text_col,fontsize=fs*0.75,ha='center')
#plt.text(0.04e-19,2.3e-28,'Upgrade',color=text_col,fontsize=fs*0.75,ha='center')
return
def STE_QUEST(ax,text_label=r'{\bf STE-QUEST}',text_pos=[1.5e-22,0.9e-26],rotation=0,col='#752b29',text_col='#752b29',fs=13,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=2):
dat = loadtxt("limit_data/VectorB-L/Projections/STE-QUEST.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def OptomechanicalMembranes(ax,text_label=r'{\bf \noindent Optomechanical \newline \indent membranes}',text_pos=[0.3e-11,0.4e-25],rotation=55,col='#961c06',text_col='#961c06',fs=15,zorder=0.25,text_on=True,Projection=False,edgealpha=1,lw=1.2):
dat = loadtxt("limit_data/VectorB-L/Projections/OptomechanicalMembranes.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def LISA(ax,text_label=r'{\bf LISA}',text_pos=[1.3e-17,1.5e-27],rotation=0,col='darkred',text_col='darkred',fs=15,zorder=0.25,text_on=True,Projection=False,edgealpha=1,lw=2):
dat = loadtxt("limit_data/VectorB-L/Projections/LISA.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def Asteroids(ax,text_label=r'{\bf Asteroids}',text_pos=[4.2e-20,0.35e-26],rotation=0,col='red',text_col='red',fs=14,zorder=0.25,text_on=True,Projection=False,edgealpha=1,lw=2):
dat = loadtxt("limit_data/VectorB-L/Projections/Asteroids.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def SKA(ax,text_label=r'{\bf SKA}',text_pos=[3e-22,5e-26],rotation=60,col='green',text_col='green',fs=15,zorder=-1,text_on=True,Projection=False,edgealpha=1,lw=2):
dat = loadtxt("limit_data/VectorB-L/Projections/SKA.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def TorsionBalance(ax,text_label=r'\begin{center}{\bf Torsion\linebreak \vspace{-3em} balance}\end{center}',text_pos=[0.5e-15,3e-29],rotation=63,col='gray',text_col='gray',fs=15,zorder=0.0,text_on=True,Projection=False,edgealpha=1,lw=2):
dat = loadtxt("limit_data/VectorB-L/Projections/TorsionBalance.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def HELIOS(ax,text_label=r'{\bf HELIOS}',text_pos=[2.3e-11,0.6e-21],rotation=90,col='#4f061d',text_col='#4f061d',fs=14,zorder=0.1011,text_on=True,Projection=False,edgealpha=1,lw=2):
dat = loadtxt("limit_data/VectorB-L/Projections/HELIOS.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,linestyle='--',edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return
def POLONAISE(ax,text_label=r'{\bf POLONAISE}',text_pos=[3e-13,7e-13],rotation=-90,col='pink',text_col='pink',fs=13,zorder=1.0,edgecolor='pink',text_on=True,Projection=False,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/POLONAISE.txt")
FilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,col=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,edgecolor=edgecolor,lw=lw,path_effects=line_background(1.5,'k'))
return
def POLONAISE_Projection(ax,text_label=r'{\bf POLONAISE}',text_pos=[0.4e-13,0.7e-27],rotation=39,col='r',text_col='r',fs=13,zorder=-1,text_on=True,edgealpha=1,lw=1.5):
dat = loadtxt("limit_data/VectorB-L/Projections/POLONAISE.txt")
UnfilledLimit(ax,dat,text_label,y2=1e20,rotation=rotation,text_pos=text_pos,text_col=text_col,edgecolor=col,fs=fs,zorder=zorder,text_on=text_on,edgealpha=edgealpha,lw=lw)
return