如何在 perl 中将天数(1 到 365.25)与弧度相关联?

Per*_*eri 5 perl radians sine-wave

我的天数从 1 到 180 天,从 $epoch='2020-05-11' 开始减少和增加日期。整个周期 = 365.25 天,最后将添加幅度、频率和相位以创建正弦波。这不是附加的完整代码,但我需要每天将其转换为弧度或相关联?如何解决这个问题,我通过互联网搜索只是从度数转换为弧度。

数据输入来自 bat 文件,更容易进行更改:

C:\Strawberry\perl\bin\perl.exe D:\perl\ex4444.pl Peri_GPS ZAT1_GPS 2020-05-11 180
pause
Run Code Online (Sandbox Code Playgroud)

和代码本身:

#!/usr/bin/perl
use Math::Random::OO::Normal;
use Time::Local;
use Time::Localtime;
use POSIX qw(strftime);

my $filename = 'D:\perl\program.txt';
    open (FH, '>', $filename) 
        or die $!;
        
my ($station1, $station2, $epoch, $count_day) = @ARGV; 

$day_a2 = -1;
$day_a1 = $day_a2 - $count_day;
$day_a3 = 1;
$day_a4 = $day_a3 + $count_day;

my ($year, $month, $day) = split('-', $epoch);

$epoch = timelocal(0, 0, 0, $day, $month-1, $year-1900);
$day_sec = 60*60*24;
$interval=$count_day*$day_sec;
$epoch1=$epoch-86400;
$epoch2=$epoch1-$interval;
$epoch3=$epoch+86400;
$epoch4=$epoch3+$interval;

@x1=(); @x2=();

for ($d = $day_a1; $d <= $day_a2; $d++){
    $epoch2 += $day_sec;
    push (@x1, $d);
    printf FH scalar(strftime " %Y %m %d %H %M", localtime($epoch2));
    printf FH " %14.4f  \n";
    close $FH;
}
for ($d = $day_a3; $d <= $day_a4; $d++){
    $epoch3 += $day_sec;
    push (@x2, $d);
    print FH scalar(strftime " %Y %m %d %H %M", localtime($epoch3));
    printf FH " %14.4f  \n";
    close $FH; 
}
Run Code Online (Sandbox Code Playgroud)

ike*_*ami 10

你有一个范围,你想找到这个范围的一小部分。这是简单的乘法。

use POSIX       qw( strftime );
use Time::Local qw( timelocal );

my $date = '2020-05-11';
my $num_steps = 11;

my ($y, $m, $d) = split(/-/, $date);
my $epoch = timelocal(0, 0, 0, $d, $m-1, $y-1900);

my $range = 365.25 * 24 * 60 * 60 / 2;

for my $step (-$num_steps..$num_steps) {
   my $fraction = $step / $num_steps;
   my $new_epoch = $epoch + $range * $fraction;
   say strftime("%F %T", localtime($new_epoch));
}
Run Code Online (Sandbox Code Playgroud)

对于我的时区,输出

2019-11-10 08:00:00
2019-11-28 14:18:00
2019-12-16 20:36:00
2020-01-04 02:54:00
2020-01-22 09:12:00
2020-02-09 15:30:00
2020-02-27 21:48:00
2020-03-17 05:06:00
2020-04-04 11:24:00
2020-04-22 17:42:00
2020-05-11 00:00:00
2020-05-29 06:18:00
2020-06-16 12:36:00
2020-07-04 18:54:00
2020-07-23 01:12:00
2020-08-10 07:30:00
2020-08-28 13:48:00
2020-09-15 20:06:00
2020-10-04 02:24:00
2020-10-22 08:42:00
2020-11-09 14:00:00
Run Code Online (Sandbox Code Playgroud)

注意$fraction从 -1 到 +1 是如何变化的?好吧,sin(x) 也是如此!

假设我们在程序中添加以下内容:

use constant PI => 3.14159265359;

$fraction = sin( $fraction * PI );
Run Code Online (Sandbox Code Playgroud)

内置函数sin将弧度作为输入,因此人们会期望日期遵循以下分布:

sin(x) 从 -pi 到 +pi

该程序现在输出以下内容:

use constant PI => 3.14159265359;

$fraction = sin( $fraction * PI );
Run Code Online (Sandbox Code Playgroud)