-
Notifications
You must be signed in to change notification settings - Fork 0
/
Ejercicio2CP.go
109 lines (95 loc) · 3.02 KB
/
Ejercicio2CP.go
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
package main
import (
"fmt"
"image"
"image/color"
"image/jpeg"
"log"
"os"
"path/filepath"
"strings"
"sync"
"time"
)
func check(err error) {
if err != nil {
panic(err)
}
}
func main() {
//Valores pequeños para la imagen 1 -> Tigre
//Valores grandes para la imagen 2 -> Catedral
var determinante float64 = 0.75
imgPath := "Imagenes/catedral.jpg"
f, err := os.Open(imgPath)
check(err)
defer f.Close()
img, _, err := image.Decode(f)
imgPath2 := "Imagenes/tigre.jpg"
f2, err2 := os.Open(imgPath2)
check(err2)
defer f2.Close()
img2, _, err2 := image.Decode(f2)
size2 := img2.Bounds().Size()
rect2 := image.Rect(0, 0, size2.X, size2.Y)
wImg2 := image.NewRGBA(rect2)
wg := new(sync.WaitGroup)
start := time.Now()
// Primer bucle determinado por el tamaño X de la imagen 2
for x := 0; x < size2.X; x++ {
wg.Add(1)
x := x
go func() {
// Segundo bucle determinado por el tamaño Y de la imagen 2
for y := 0; y < size2.Y; y++ {
pixel := img.At(x, y)
originalColor := color.RGBAModel.Convert(pixel).(color.RGBA)
// Obteniendo valores de los pixeles de la figura 2
red_1 := float64(originalColor.R)
green_1 := float64(originalColor.G)
blue_1 := float64(originalColor.B)
pixel2 := img2.At(x, y)
originalColor2 := color.RGBAModel.Convert(pixel2).(color.RGBA)
// Obteniendo valores de los pixeles de la figura 2
red_2 := float64(originalColor2.R)
green_2 := float64(originalColor2.G)
blue_2 := float64(originalColor2.B)
// Aplicando formula
red_definitivo := uint8((red_1 * determinante) + ((1 - determinante) * red_2))
green_definitivo := uint8((green_1 * determinante) + ((1 - determinante) * green_2))
blue_definitivo := uint8((blue_1 * determinante) + ((1 - determinante) * blue_2))
if red_definitivo > 255 || green_definitivo > 255 || blue_definitivo > 255 {
red_definitivo = 255
green_definitivo = 255
blue_definitivo = 255
}
if red_definitivo < 0 || green_definitivo < 0 || blue_definitivo < 0 {
red_definitivo = 0
green_definitivo = 0
blue_definitivo = 0
}
pixel_definitivo := color.RGBA{
R: red_definitivo, G: green_definitivo, B: blue_definitivo,
}
wImg2.Set(x, y, pixel_definitivo)
}
defer wg.Done()
}()
}
wg.Wait()
//Tiempo de Ejecucion
fin := time.Since(start)
log.Printf("Ejercicio 2 con Concurrencia: Tiempo de ejecucion %s", fin)
//Obteniendo extension y nombre para la imagen 1
ext_fig1 := filepath.Ext(imgPath)
nombre_fig1 := strings.TrimSuffix(filepath.Base(imgPath), ext_fig1)
//Obteniendo extension y nombre para la imagen 2
ext_fig2 := filepath.Ext(imgPath2)
nombre_fig2 := strings.TrimSuffix(filepath.Base(imgPath2), ext_fig2)
newImagePath2 := fmt.Sprintf("%s/%s_%s_blending_CP%s", filepath.Dir(imgPath2), nombre_fig2, nombre_fig1, ext_fig2)
fg2, err2 := os.Create(newImagePath2)
defer fg2.Close()
check(err2)
err2 = jpeg.Encode(fg2, wImg2, nil)
check(err2)
}