Построение стрелок с началом и концом из двух разных файлов - PullRequest
0 голосов
/ 11 декабря 2018

У меня есть два разных файла .txt с координатами x и y с одинаковым количеством образцов в обоих.

File 1
x y
1 2
5 4
4 6

File 2 
x y
5 6
3 4 
2 3

Я хочу связать каждую из этих точек в файле 1 с соответствующими точками в файле 2. Я знаю, что нарисовать стрелку между двумя точками это

set arrow from (x,y) to (c,d)

Но как это сделать?Я получаю координаты этих точек из двух разных файлов, чтобы нарисовать соединительные линии / стрелки?

Ответы [ 2 ]

0 голосов
/ 11 декабря 2018

Хотя самый быстрый и короткий способ объединения столбцов из разных файлов, вероятно, с помощью внешнего инструмента, я тем не менее суммирую 3 метода gnuplot (т.е. не зависящих от платформы) для объединения столбцов из разных файлов / наборов данных.

  • Метод 1, по-видимому, очень медленный.
  • Метод 2 несколько лучше, но немного сбивает с толку, ок.В 5-6 раз быстрее, чем метод 1
  • Метод 3 работает только с gnuplot> = 5.2, поскольку он использует массивы, прибл.В 20-30 раз быстрее, чем метод 1

Улучшения и комментарии приветствуются.

### merging columns from different files/datasets with gnuplot only
reset session

# creating some dummy data
TimeStart = time(0.0)
N = 5000
set table $Data1
    set samples N
    plot '+' u (rand(0)):(rand(0)) with table
unset table
set table $Data2
    set samples N
    plot '+' u (rand(0)):(rand(0)) with table
unset table
TimeEnd = time(0.0)
print sprintf("Creating data: %.3f sec",TimeEnd-TimeStart)
# end creating dummy data

# Method 1
TimeStart = time(0.0)
stats $Data1 nooutput
RowCount = STATS_records
set print $FinalData1
set table $DataM1_1
do for [i=0:RowCount-1] {
    plot $Data1 u (a=$1,$1):(b=$2,$2) every ::i::i w table
    plot $Data2 u (c=$1,$1):(d=$2,$2) every ::i::i w table
    print sprintf("%g\t%g\t%g\t%g",a,b,c,d)
}
unset table
set print
TimeEnd = time(0.0)
print sprintf("Method 1: %.3f sec",TimeEnd-TimeStart)
# print $FinalData1
# end Method 1


# Method 2
TimeStart = time(0.0)
set table $DataM2_1
    plot for [i=1:2] $Data1 u ($0+i*0.1):i w table
    plot for [i=1:2] $Data2 u ($0+i*0.3):i w table
unset table

set table $DataM2_2
    plot $DataM2_1 u 1:2 smooth frequency
unset table

x1 = y1 = x2 = y2 = NaN
Shift(x) = (x1 = y1, y1 = x2, x2 = y2, y2 = x)
set table $DataM2_3
    plot $DataM2_2 u (Shift($2),x1):(y1):(x2):(y2) with table
unset table

set table $DataM2_4
    plot $DataM2_3 u 1:2:3:4 every 4::3 with table
unset table
set table $FinalData2 # remove empty lines
    plot $DataM2_4 u 1:2:3:4 every ::0 with table
unset table

TimeEnd = time(0.0)
print sprintf("Method 2: %.3f sec",TimeEnd-TimeStart)
# print $FinalData2
# end Method 2


# Method 3
# requires gnuplot >=5.2
# get number of rows, assuming to be identical for $Data1 and $Data2 
TimeStart = time(0.0)
stats $Data1 nooutput
RowCount = STATS_records
array Col1[RowCount]
array Col2[RowCount]
array Col3[RowCount]
array Col4[RowCount]

set table $DataM3_1
    plot $Data1 u (Col1[$0+1]=$1,0):(Col2[$0+1]=$2,0) w table
    plot $Data2 u (Col3[$0+1]=$1,0):(Col4[$0+1]=$2,0) w table
unset table

set print $FinalData3
do for [i=1:RowCount] {
    print sprintf("%g\t%g\t%g\t%g",Col1[i],Col2[i],Col3[i],Col4[i])
}
set print
TimeEnd = time(0.0)
print sprintf("Method 3: %.3f sec",TimeEnd-TimeStart)
# print $FinalData3
# end Method 3

### end of code
0 голосов
/ 11 декабря 2018

Примерно так:

plot "< paste file1.data file2.data" with vectors
...