summaryrefslogtreecommitdiffstats
path: root/src/host/rita_pll/rita_pll.pl
blob: 7de1aec4421d9b4bae107bc8e5af534e4cc101ce (plain)
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
#!/usr/bin/perl

sub pll_rx($$$$$) {
	my ($a, $b, $p, $r, $l) = @_;

	return (($b*$p+$a)/($r*$l))*26;
}

sub pll_rx_low_band($$) {
	my ($a, $b) = @_;
	my $p = 64; my $r = 65; my $l = 4;
	return pll_rx($a, $b, $p, $r, $l);
}

sub pll_rx_high_band($$) {
	my ($a, $b) = @_;
	my $p = 64; my $r = 65; my $l = 2;
	return pll_rx($a, $b, $p, $r, $l);
}

sub pll_tx_gsm850_1($$) {
	my ($a, $b) = @_;
	my $p = 64; my $r = 55; my $l = 4; my $m = 26;

	my $left = ((1/$l) - (1/$m));
	my $right = (($b*$p+$a)/$r);

	return $left * $right * 26;
}

sub pll_tx_gsm850_2($$) {
	my ($a, $b) = @_;
	my $p = 64; my $r = 30; my $l = 4; my $m = 52;

	my $left = ((1/$l) - (1/$m));
	my $right = (($b*$p+$a)/$r);

	return $left * $right * 26;
}

sub pll_tx_gsm900($$) {
	my ($a, $b) = @_;
	my $p = 64; my $r = 35; my $l = 4; my $m = 52;

	my $left = ((1/$l) + (1/$m));
	my $right = (($b*$p+$a)/$r);

	return $left * $right * 26;
}

sub pll_tx_high($$) {
	my ($a, $b) = @_;
	my $p = 64; my $r = 70; my $l = 2; my $m = 26;

	my $left = ((1/$l) + (1/$m));
	my $right = (($b*$p+$a)/$r);

	return $left * $right * 26;
}

sub hr() {
	printf("======================================================================\n");
}

printf("PLL Rx Low Band:\n");
for (my $b = 135; $b <= 150; $b++) {
	for (my $a = 0; $a <= 62; $a++) {
		printf("Fout=%4.2f (A=%03u, B=%03u)\n", pll_rx_low_band($a, $b), $a, $b);
	}
}

hr();
printf("PLL Rx High Band:\n");
for (my $b = 141; $b <= 155; $b++) {
	for (my $a = 0; $a <= 62; $a++) {
		printf("Fout=%4.2f (A=%03u, B=%03u)\n", pll_rx_high_band($a, $b), $a, $b);
	}
}

hr();
printf("PLL Tx GSM850_1\n");
for (my $b = 128; $b <= 130; $b++) {
	for (my $a = 0; $a <= 62; $a++) {
		printf("Fout=%4.2f (A=%03u, B=%03u)\n", pll_tx_gsm850_1($a, $b), $a, $b);
	}
}

hr();
printf("PLL Tx GSM850_2\n");
for (my $b = 65; $b <= 66; $b++) {
	for (my $a = 0; $a <= 63; $a++) {
		printf("Fout=%4.2f (A=%03u, B=%03u)\n", pll_tx_gsm850_2($a, $b), $a, $b);
	}
}

hr();
printf("PLL Tx GSM900\n");
for (my $b = 68; $b <= 71; $b++) {
	for (my $a = 0; $a <= 63; $a++) {
		printf("Fout=%4.2f (A=%03u, B=%03u)\n", pll_tx_gsm900($a, $b), $a, $b);
	}
}

hr();
printf("PLL Tx GSM1800/1900\n");
for (my $b = 133; $b <= 149; $b++) {
	for (my $a = 0; $a <= 63; $a++) {
		printf("Fout=%4.2f (A=%03u, B=%03u)\n", pll_tx_high($a, $b), $a, $b);
	}
}