File: fourleg.pl

package info (click to toggle)
dmrgpp 6.06-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 113,900 kB
  • sloc: cpp: 80,986; perl: 14,772; ansic: 2,923; makefile: 83; sh: 17
file content (115 lines) | stat: -rw-r--r-- 2,602 bytes parent folder | download
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
#!/usr/bin/perl

use strict;
use warnings;
use utf8;

use OmegaUtils;

my ($file, $l, $whatLeg) = @ARGV;
defined($whatLeg) or die "USAGE: $0 filename l whatLeg\n";

my $upperLeg = 0;
if ($whatLeg eq "upper") {
	$upperLeg = 1;
} elsif ($whatLeg eq "lower") {
	$upperLeg = 0;
} else {
	die "USAGE: $0 filename l upper | lower\n";
}

my @array = loadValues($file);
ft(\@array, $l, $upperLeg);

sub ft
{
	my ($a, $l, $upperLeg) = @_;
	my ($isPeriodic, $zeroAtCenter, $nonNegativeOnly) = (1, 0, 0);
	my $omegas = scalar(@$a);
	my $centralSite = $l;
	my $geometry = {"name" => "ladder", "leg" => 2, "subname" => ""};
	my $hptr = {isPeriodic => $isPeriodic, centralSite => $centralSite};
	my $outSpectrum = "out.spectrum";

	open(FOUTSPECTRUM, ">", "$outSpectrum") or die "$0: Cannot write to $outSpectrum : $!\n";

	for (my $index = 0; $index < $omegas; ++$index) {
		my $ptr = $a->[$index];
		(scalar(@$ptr) == 2) or die "$0: ptr.size should be 2\n";
		my $omega = $ptr->[0];
		print FOUTSPECTRUM "$omega ";
		my $ptr2 = $ptr->[1];
		my @v;
		my $sites = scalar(@$ptr2);
		my $counter = 0;
		for (my $i = 0; $i < $sites; ++$i) {
			my $y = $i % 4;
			if ($upperLeg) {
				next if ($y > 1);
			} else {
				next if ($y < 2);
			}

			$v[$counter++] = $ptr2->[$i];
		}

		die "$0: Counter error\n" if ($counter != 2*$l);

		my @f;
		OmegaUtils::fourierLadder(\@f, \@v, 2, $hptr);
		my @array;
		OmegaUtils::writeFourier(\@array, \@f, $geometry);
		printSpectrum(\@array);
	}

	close(FOUTSPECTRUM);
	OmegaUtils::printGnuplot($outSpectrum, $geometry, $isPeriodic, $zeroAtCenter, $nonNegativeOnly);
}

sub printSpectrum
{
	my ($array) = @_;

	my $n = scalar(@$array);
	for (my $j = 0; $j < $n; ++$j) {
		my $array2 = $array->[$j];
		my @array2 = @$array2;
		print FOUTSPECTRUM "$array2[1] $array2[2] ";
	}

	print FOUTSPECTRUM "\n";
}

sub loadValues
{
	my ($file) = @_;
	open(FILE, "<", $file) or die "$0: Cannot open $file : $!\n";
	my @array;
	my $index = 0;
	while (<FILE>) {
		my @temp = split;
		my $n = scalar(@temp);
		die "$0: Expected two values, got $n\n" unless ($n == 2);
		my $omega = $temp[0];
		my $sites = $temp[1];
		my @values;
		for (my $i = 0; $i < $sites; ++$i) {
			$_ = <FILE>;
			chomp;
			my @temp = split;
			my $x = scalar(@temp);
			die "$0: Expected three values, got $x\n" unless ($x == 3);
			die "$0: Expected $i as first number, got $temp[0]\n" unless ($i == $temp[0]);
			my @temp2 = ($temp[1], $temp[2]);
			$values[$i] = \@temp2;
		}

		my @tmp = ($omega, \@values);
		$array[$index++] = \@tmp;
	}

	close(FILE);
	print STDERR "$0: Found $index omegas\n";
	return @array;
}