Tecnicas de Agrupacion

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 56

Jess Garca Herrero

TCNICAS DE AGRUPAMIENTO

En esta clase se presentan las tcnicas de agrupamiento, tambin conocidas como clustering,
que buscan grupos de instancias con caractersticas similares mediante el anlisis de
parecido entre sus atributos. Por tanto, a diferencia de las tcnicas anteriores de
clasificacin y prediccin, no se precisa de datos etiquetados con categoras o valores
objetivo, sino que es un anlisis no supervisado para encontrar una estructura en los datos.
Se revisan en primer lugar la tcnicas basadas en distancias, siendo el ms representativo el
mtodo k-medias, que agrupa los datos en k grupos de mnima distancia. Se revisa el
problema de definir distancias cuando el espacio de atributos es heterogneo con tcnicas de
normalizacin y transformacin de atributos nominales.
A continuacin, se presentan las tcnicas jerrquicas de agrupamiento, cuyo objetivo no es
separar en grupos en un mismo nivel, sino hacer una estructura jerrquica conocida como
dendograma. Se detalla el algoritmo COBWEB como tcnica representativa de este problema,
mostrando las heursticas de construccin del rbol jerrquico basadas en una funcin de
utilidad de tipo probabilstico que intenta maximizar el parecido entre instancias dentro de
cada categora y maximizar a su vez la separacin entre categoras
Por ltimo, se presenta el algoritmo EM (Expectation-Maximization) como tcnica que permite
estimar grupos de instancias y parmetros de distribuciones de probabilidad que los describen,
con un criterio de ajustar stas a un conjunto de categoras prefijado.
El tema se completa con una presentacin de las tcnicas semi-supervisadas, que buscan
aunar los clasificadores con las tcnicas de clustering con el objetivo de explotar datos no
etiquetados, habitualmente mucho ms disponibles que los etiquetados que se usan en las
tcncias habituales de clasificacin. Un ejemplo claro de tcnica semi-supervisada es la
combinacin del algoritmo EM con los clasificadores bayesianos.

Agrupamiento
Tcnicas y anlisis de clustering
Jess Garca Herrero
Universidad Carlos III de Madrid

Agrupamiento
Aprendizaje no supervisado. Objetivo: dados ejemplos sin
etiquetar (con clase), determinar un conjunto de grupos (clusters)
en los que se pueden dividir
No hay variable a predecir, sino se pretende descubrir una
estructura en los datos. Ejemplo
grupos de clientes con gustos similares en libros, msica, etc., para
anlisis de mercado

Suele servir de punto de partida para despus hacer un anlisis de


clasificacin sobre los clusters
Tipos de tcnicas:
Aglomerativas y divisoras
Numricas: k -medias, EM
Conceptuales: cluster/2 y cobweb

Agrupamiento

Ejemplos de entrada
1.9
1.85
1.8

Sitio de
acceso: A1
1
1
1
0
1
2

1 cantidad Vivienda:
gastada: A2
A3
0
2
0
1
2
0
2
1
1
1
2
1

Conceptual

Agrupamiento

ltima
compra: A4
Libro
Disco
Libro
Libro
Libro
Libro

altura (m)

1.75
1.7
1.65
1.6
1.55
1.5
45

50

55

60

65
70
peso (Kg)

75

Numrico

80

85

90

Ejemplo de salidas
Conjunto de clases
Clase1: ejemplo4, ejemplo6
Clase2: ejemplo2, ejemplo3, ejemplo5
Clase3: ejemplo1

Jerarqua de clases

Clase 1

Clase 3

Agrupamiento

Clase 2

Clase 4

Clase 5

Clase 6

Ej. Problema a resolver, k=3


5
A2?

4
3
2
1
1

4
A1?

Agrupamiento

Solucin 1
5
A2?

4
3
2
1
1

4
A1?

Agrupamiento

Solucin 2
5
A2?

4
3
2
1
1

4
A1?

Agrupamiento

Agrupamiento con k-medias


Problema a resolver: distribuir los ejemplos en k conjuntos,
minimizando las distancias entre elementos dentro de cada grupo
Algoritmo

Si se tienen que formar k clases, se eligen k ejemplos que


actan como semillas
Cada ejemplo se aade a la clase mas similar
Cuando se termina, se calcula el centroide de cada clase,
que pasan a ser las nuevas semillas
Se repite hasta que se llega a un criterio de convergencia
(p.e. Dos iteraciones no cambian las clasicaciones de los
ejemplos)
Es un mtodo de optimizacin local. Depende de la eleccin de la
semilla inicial
Puede iterarse con varias semillas y seleccionar el mejor
Variantes para agrupamiento jerrquico
Agrupamiento

Ejemplo de k-medias. Inicio


5

Semilla 3

A2?

4
3
2

Semilla 2
Semilla 1

1
1

4
A1?

Agrupamiento

Ejemplo de k-medias. Iteracin 1


5

Centroide 3

A2?

4
3
2

Centroide 2

Centroide 1
1

4
A1?

Agrupamiento

Ejemplo de k-medias. Iteracin 2


5

Centroide 3

A2?

4
3
2

Centroide 2

Centroide 1
1

4
A1?

Agrupamiento

Ejemplo de k-medias. Iteracin 3


5

Centroide 3

A2?

4
3
2

Centroide 2

Centroide 1
1

4
A1?

Agrupamiento

Ej2. Problema a resolver, k=2


5
A2?

4
3
2
1
1

4
A1?

Agrupamiento

Ej2. Inicio
5
Semilla 1

A2?

Semilla 2

3
2
1
1

4
A1?

Agrupamiento

Ej2. Situacin estable


5
A2?

4
3
2
1
1

4
A1?

Agrupamiento

Ej2. Inicio
5
Semilla 1

A2?

4
3
2

Semilla 2

1
1

4
A1?

Agrupamiento

Ej2. Situacin estable


5
A2?

4
3
2
1
1

4
A1?

Agrupamiento

Ej2. Inicio
5
Semilla 2

A2?

4
3
2

Semilla 1

1
1

4
A1?

Agrupamiento

Ej2. Situacin estable


5
A2?

4
3
2
1
1

4
A1?

Agrupamiento

Clculo de la distancia
Dados dos ejemplos Xi, Xj, con atributos xil, xjl, l=1,, F
d(Xi , X j )

( x il x jl )

l 1

La similitud puede estimarse con el inverso de la distancia


Problemas:
atributos con diferentes rangos o importancias:
normalizar valores
distancia estadstica (Mahalanobis):

d(X i , X j )

atributos nominales:

F ( x il x jl ) 2
,

2
l
l 1

1, si x il x jl

d( x il , x jl )

0, si x il x jl

Agrupamiento

d(X i , X j )

X i X j t S1X i X j

Clustering conceptual jerrquico


Problema de los enfoques numricos: distancia cuando atributos son no
numricos
En el agrupamiento conceptual una particin de los datos es buena si
cada clase tiene una buena interpretacin conceptual (modelo cognitivo
de jerarquas)
Hay dos tareas (Fisher y Langley, 85 y 86):

agrupamiento: determinacin de subconjuntos tiles de un


conjunto de datos (mtodos numricos)

caracterizacin: determinacin de un concepto por cada


subconjunto descrito extensionalmente (mtodos conceptuales)
COBWEB es un algoritmo incremental de agrupamiento que forma un
rbol aadiendo ejemplos uno por uno

La actualizacin con un nuevo ejemplo puede suponer ubicarlo en


su hoja ms adecuada, o bien una re-estructuracin con la nueva
informacin

Agrupamiento

Ejemplo
Clase 1

e4 ?
Clase 2

e1 , e 2

Clase 3

e3

Varias alternativas de particiones:

P1=[{e1, e2},{e3, e4}]


P2=[{e1, e2, e3,}, {e4}]

Calidad de cada particin?


Creacin de una nueva clase?: [{e1, e2},{e3}, {e4}]
Agrupamiento

Clustering jerrquico
Divisin recursiva: jerarqua conocida

como dendograma
La profundidad es proporcional a la
disimilaridad entre sus hijos

Agrupamiento

Example hierarchical clustering

50 examples of different creatures from the zoo data


Completelinkage

Dendogra
m24

Polar
plot

Creacin del rbol


COBWEB crea incrementalmente un rbol cuyos nodos son
conceptos probabilsticos
La clasificacin consiste en descender por las ramas cuyos nodos
se equiparen mejor, basndose en los valores de varios atributos
al mismo tiempo
Realiza bsqueda en escalada en el espacio de rboles
probabilsticos de clasificacin
Operadores:
Clasificar una instancia en una clase (nodo)
Crear una nueva clase
Combinar dos clases en una
Separar una clase en varias
Promocionar un nodo

En cada nodo se guarda:


Nmero de instancias por debajo
En cada atributo Aj, valor l, nmero de ejemplos con Aj = Vjl

Agrupamiento

Operadores de agrupamiento
Clasificar una instancia:
Se introduce la instancia en cada una de las clases
sucesoras de la actual y se evalan las distintas categoras
Si el mejor es un nodo hoja, se introduce en el. Si no, se
llama recursivamente al algoritmo con l
Crear una clase:
Se comparan las calidades de:
la particin creada por aadir la instancia a la mejor clase
la particin resultante de crear una nueva clase para esa
instancia sola

En caso de ser mejor que este s ola, se crea un nuevo


sucesor de la clase actual
Agrupamiento

Operadores de agrupamiento
Los dos operadores anteriores dependen mucho del orden de los
ejemplos.

Un anlisis completo de reestructuracin no es viable


Se incorporan dos operadores bsicos para compensar:

Combinar dos nodos: Cuando se intenta clasificar una instancia


en un nivel, se intentan mezclar las dos mejores clases y se
evalan las categoras de si estn mejor solas o juntas en una
misma categora

e?
A

B
A

Agrupamiento

Operadores de agrupamiento
Separar dos nodos: Cuando se intenta introducir una instancia
en una clase que tenga sucesores, se estudia si se pueden subir
los sucesores al mismo nivel que la clase

e?

e?
A

Promocionar un nodo: El mismo operador anterior, pero


individualizado para un s olo nodo

e?

e?
B
A
A

Agrupamiento

Heurstica de bsqueda
Define el nivel bsico (aspecto cognitivo)
Ayuda a considerar al mismo tiempo la similitud intra-clase y la disimilitud
inter-clases
Intra-clase (p( Ai = Vijl Ck)): cuanto mas grande, ms ejemplos en la
clase comparten el mismo valor (clases homogneas)
Inter-clases (p( Ck|Ai=Vij )): cuanto mas grande, menos ejemplos de
distintas clases comparten el mismo valor (separacin entre clases)
Calidad de una particin {C1, C2,...,CM}, Ck mutuamente excluyentes, es
un compromiso entre las dos:

p(Ai Vij )p(C k | Ai Vij )p(Ai Vij | Ck )

k 1 i j

donde p(Ai =Vij) prefiere valores ms frecuentes

Agrupamiento

Utilidad de una categora


Como, segn Bayes,
p (Ai=Vij)p(Ck|Ai=Vij) = p(Ck)p(Ai=Vij|Ck )
sustituyendo:
M

2
p(C k ) p(Ai Vij | C k )

k 1

i j

2
i j p(A i Vij | C k )

donde
es el numero esperado de
valores de atributos que se pueden predecir correctamente para
un miembro cualquiera de Ck
La utilidad de una categora Ck es la mejora con respecto a no
tener informacin de la particin:

2
2
p(C k ) p(Ai Vij | C k ) p(Ai Vij )
i j
i j

Agrupamiento

Utilidad de una particin


La utilidad de una particin P={C1, C2, ..., CM} es:

1 M
2
2
CU(P)
p(Ck ) p(Ai Vij | Ck ) p(Ai Vij )
M k 1
i j
i j

Para evitar sobreadecuamiento (un grupo por ejemplo)


Factor 1/M:
Factor de poda (cut-off): mejora en utilidad por una subdivisin
Si el valor Vij de un atributo Ai es independiente de la pertenencia
a la clase Ck:
p(Ai=Vij|Ck ) = p(Ai=Vij )
para ese valor la utilidad de la particin es nula
Si lo anterior es cierto para todos los valores l, el atributo Aj es
irrelevante
Agrupamiento

Utilidad de una particin


Caso extremo: cada instancia en una
categora el numerador toma el valor
mximo:

1 M
2
CU(P) p(C k ) n p(A i Vij )
M k 1
i
j

Numero de atributos

Agrupamiento

Atributos numricos
Los atributos numricos se modelan con una distribucin normal

1 (a i ) 2
1
f (a i )
exp

2
2
2

Equivalente a suma cuadrtica de probabilidades:

1
2
2
j p(Ai Vij | Ck ) f (a i )da i
2 i

1
1 M
1
1
CU (C1 , C 2 ,..., C M )

p (C k )

M k 1
2 i ik
i

Un grupo con un ejemplo tendra utilidad inifinita:


Agudeza (acuity): mnima varianza en un grupo

Agrupamiento

Algoritmo de agrupamiento
Nodo COBWEB (Instancia,Nodo) {
Actualizar los contadores de Nodo;
Si Nodo es hoja
Entonces IncluirInstancia (Instancia,Nodo);
Devolver Nodo
Si no MejorNodo= MejorClase (Instancia,Nodo);
Si es apropiado crear una nueva clase
Entonces Nuevo-nodo:= CrearNodo (Instancia,Nodo);
Devolver Nuevo-nodo
Si es apropiado combinar dos nodos
Entonces Nuevo-nodo:= CombinarNodos (Instancia,Nodo);
Devolver COBWEB (Instancia,Nuevo-nodo)
Si es apropiado separar dos nodos
Entonces Nuevo-nodo:= SepararNodos (Instancia,Nodo);
Devolver COBWEB (Instancia,Nodo)
Si es apropiado promocionar un nodo
Entonces Nuevo-nodo:= PromocionarNodo (Instancia,Nodo);
Devolver COBWEB (Instancia,Nodo)
Si no, Devolver COBWEB (Instancia,MejorNodo) }

Agrupamiento

Ejemplo COBWEB
Reconocimiento de caracteres (OCR)
Identificar letras a partir de 20 fuentes, con distorsiones aleatorias
Parmetros numricos extrados de las imgenes
x-box y-box w idth high onpix x-bar y-bar x2bar y2bar xybar x2ybar xy2bar x-ege xegvy y-ege yegvx letter
3
11
5
8
3
13
4
5
3
12
1
8
2
6
4
9
A
2
4
4
3
3
9
7
2
6
11
4
7
4
7
5
9
B
4
6
5
4
3
6
7
5
6
11
8
13
2
10
3
9
C
4
10
6
7
2
9
4
3
2
8
1
8
3
7
3
8
A
3
4
5
3
3
8
7
2
6
11
5
7
2
8
4
9
B
5
5
6
8
2
6
7
7
10
8
6
15
1
9
4
9
C
3
5
5
3
2
6
2
2
2
5
2
8
2
6
3
6
A
3
6
4
4
3
11
6
3
6
11
3
7
2
8
4
11
B
4
9
5
6
4
5
8
7
6
9
8
14
2
10
4
10
C
4
10
7
7
2
8
7
3
0
7
0
8
3
7
2
8
A
9
14
7
8
4
9
6
6
6
11
4
9
6
7
7
10
B
3
10
5
7
3
4
9
6
6
6
8
14
1
8
4
10
C
5
9
7
7
5
8
3
1
2
6
2
7
3
5
4
7
A
2
7
3
5
2
6
6
9
7
6
7
7
2
8
8
10
B
8
13
5
8
2
8
6
7
7
12
5
9
2
10
5
9
C

Agrupamiento

Ejemplo (cont)
1. A

2. B

3. C

2. B

1. A

3. C

4. A

1. A

4. A

2. B
5. B

1. A

4. A

2. B

5. B
3. C

Agrupamiento

6. C

3. C

Ejemplo (cont)

2. B
5. B
1. A

4. A

7. A

8.B

9. C

3. C

Agrupamiento

6. C

Ejemplo (cont)

1. A

11. B

4. A

2. B

9. C

12. C

5. B
7. A

10. A

13. A

Agrupamiento

14. B

15. D

8.B

3. C

6. C

Ejemplo: weather data


ID

Outlook

Temp.

Humidity

Windy

Sunny

Hot

High

False

Sunny

Hot

High

True

Overcast

Hot

High

False

Rainy

Mild

High

False

Rainy

Cool

Normal

False

Rainy

Cool

Normal

True

Overcast

Cool

Normal

True

Sunny

Mild

High

False

Sunny

Cool

Normal

False

Rainy

Mild

Normal

False

Sunny

Mild

Normal

True

Overcast

Mild

High

True

Overcast

Hot

Normal

False

Rainy

Mild

High

True

39

Clustering weather data


ID

Outlook

Temp.

Humidity

Windy

Sunny

Hot

High

False

Sunny

Hot

High

True

Overcast

Hot

High

False

Rainy

Mild

High

False

Rainy

Cool

Normal

False

Rainy

Cool

Normal

True

Overcast

Cool

Normal

True

Sunny

Mild

High

False

Sunny

Cool

Normal

False

Rainy

Mild

Normal

False

Sunny

Mild

Normal

True

Overcast

Mild

High

True

Overcast

Hot

Normal

False

Rainy

Mild

High

True

40

5
Merge best host
and runner-up

3
Consider splitting the best host if
merging doesnt help

Final hierarchy

41

Example: the iris data (subset)

42

Clustering with cutoff

43

Agrupamiento probabilstico (EM)


El agrupamiento con categoras presenta algunos problemas

Dependencia del orden


Tendencia al sobreajuste

Esta aproximacin evita las divisiones prematuras, asignando


parmetros a un modelo de mezcla de distribuciones
Mezcla de k distribuciones de probabilidad, representando los k
clusters.
118; 240;
18; 26;
p1=0.6
p2=0.4
0.06

0.05

p(a)

0.04

0.03

0.02

0.01

10

20

30
a

40

50

60

Se determina la probabilidad de que cada instancia proceda de


cada grupo
Agrupamiento

Algoritmo EM
Se determina el nmero de grupos a ajustar: k
En cada grupo, parmetros de las distribuciones de cada atributo
pi, i , i i=1...k
Ej.: 2 grupos (A, B) y un atributo: 5 parmetros

En cada iteracin hay dos etapas:


Expectation: se calculan las probabilidades de cada ejemplo en
cada uno de los grupos
1 (x A )2
f ( x | A)p A
1
Pr(A | x )
;
f ( x | A)
exp

2
f (x)
2 A
2
A

Maximization: se calculan los parmetros de las distribuciones


que maximicen la verosimilitud de las distribuciones
w i Pr(A | x i );
w1x1 ...w n x n
w1 ( x1 A ) ...w n ( x n A ) 2
2
A
; A
;
w1 ...w n
w1 ...w n

Agrupamiento

Algoritmo EM
Condicin de parada:

se estima la verosimilitud sobre todo el conjunto de instancias:


n

f ( x i | A)p A f ( x i | B)p B

i 1

se para cuando la mejora en sucesivas iteraciones est debajo de e

Extensin:

Ejemplos con varios atributos y clases


Puede asumirse independencia (Naive Bayes) o estimar
covarianzas (problema de sobreajuste)
Atributos nominales:
Se determinan las probabilidades condicionales para cada
valor

No asegura mnimo global: varias iteraciones


Se pueden estimar el nmero de grupos automticamente,
mediante validacin cruzada
Agrupamiento

Ejemplo
300 datos procedentes de dos distribuciones (no conocidas)

pA=0.8; A=18; A=8; pB=0.2; B=50; B=6;

Inicializacin:

pA=pB=0.5; A=B=10.0;A,B en dos ejemplos al azar


0.045
0.04
0.035
0.03
0.025
0.02
0.015
0.01
0.005
0
-20

Agrupamiento

-10

10

20

30

40

50

60

70

Ejemplo
0.045

0.045

Iteracin 2
pA = 0.57; mA =30.68;
sA =15.0299
pB = 0.42; mB =14.61
sB = 7.23

0.04
0.035
0.03
0.025
0.02

0.035
0.03
0.025
0.02

0.015

0.015

0.01

0.01

0.005

0.005

0
-20

-10

10

20

30

40

50

60

70

0.045

0
-20

-10

10

20

30

40

50

60

70

0.045

Iteracin 15
pA = 0.33; mA =39.0;
sA =14.7
pB = 0.67; mB =16.37
sB = 6.75

0.04
0.035
0.03
0.025
0.02

0.035
0.03
0.025
0.02
0.015

0.01

0.01

0.005

0.005

-10

10

20

Agrupamiento

30

40

50

60

70

Iteracin 30
pA = 0.2; mA =49.2;
sA =7.1
pB = 0.8; mB =17.54
sB = 7.54

0.04

0.015

0
-20

Iteracin 5
pA = 0.45; mA =33.42;
sA =16.38
pB = 0.55; mB =16.05
sB = 6.1

0.04

0
-20

-10

10

20

30

40

50

60

70

Ejemplo
Agrupamiento con diferentes rangos y varianzas en los atributos:
c1=[0;-10];c2=[0;10];c3=[-5;0];c4=[5;0]; 100 muestras de cada distribucin
x1=x2=10; y1=y2=1;
15
x3=x4=1; y3=y4=3;
10

y
0

-5

-10

-15
-30

Agrupamiento

-20

-10

10

20

30

Salida k-medias (k=4)


c1=[0;-10];c2=[0;10];c3=[-5;0];c4=[5;0]; 100 muestras de cada distribucin
x1=x2=10; y1=y2=1;
x3=x4=1; y3=y4=3;
kMeans
======
0
184 ( 46%)
Cluster centroids:
1
60 ( 15%)
Cluster 0
2 105 ( 26%)
0.29598152173913045 0.43623478260869575 4
3
51 ( 13%)
Cluster 1
6.1586733333333346 -10.12866 1
Cluster 2
-0.4669076190476191 9.952375238095238 2
Cluster 3
-7.0927921568627434 -9.091737254901963 1Clustered Instances

Agrupamiento

Salida EM
c1=[0;-10];c2=[0;10];c3=[-5;0];c4=[5;0]; 100 muestras de cada distribucin
x1=x2=10; y1=y2=1;
x3=x4=1; y3=y4=3;
Number of clusters selected by cross validation: 4
Cluster: 0 Prior probability: 0.2487
Attribute: X
Normal Distribution. Mean = 4.9001 StdDev = 1.0596
Attribute: Y
Normal Distribution. Mean = 0.7223 StdDev = 3.0122

Cluster: 2 Prior probability: 0.2514


Attribute: X
Normal Distribution. Mean = -0.2195 StdDev = 10.195
Attribute: Y
Normal Distribution. Mean = 10.1292 StdDev = 0.9554
Cluster: 3 Prior probability: 0.2494

Cluster: 1 Prior probability: 0.2505


Attribute: X
Normal Distribution. Mean = 0.6498 StdDev = 8.4748
Attribute: Y
Normal Distribution. Mean = -10.0672 StdDev = 0.9735

Agrupamiento

Attribute: X
Normal Distribution. Mean = -5.1877 StdDev = 0.9635
Attribute: Y
Normal Distribution. Mean = -0.2764 StdDev = 3.1796

Nmero de clusters, k?
Valor k que minimiza distancia a los centros de
clusters con validacin cruzada
Utilizacin de penzliacin en la distancia a los
datos de entranamiento (criterio MDL)
Aplicar k-medias recursivamente con k = 2 y usar
criterio de parada (eg. based on MDL)
Semillas de subclusters en la direccin de mayor
varianza en el cluster (un sigma en cada direccin desde
el centro del cluster padre)
Agrupamiento

Aprendizaje semisupervisado
Semisupervised learning: utilizar datos etiquetados
y no etiquetados
Objetivo: mejorar la clasificacin

Razn: datos no etiquetados son ms disponibles y


baratos
Web mining: classifying web pages
Text mining: identifying names in text
Video mining: classifying people in the news

Aprovechar amplia disponibilidad de ejemplos no


etiquetados
Agrupamiento

Clustering y clasificacin
Idea: nave Bayes sobre ejemplos etiquetados y
despus EM
1. Constuir modelo nave Bayes con datos etiquetados
2. Etiquetar datos no etiquetados con probabilidaes
(expectation step)
3. Entrenar nuevo modelo nave Bayes con todos los
datos (maximization step)
4. Repetir 2 y 3 hasta convergencia

Como EM fijando los cluster a las clases y


comnzando con probabilidades de etiquetados
Agrupamiento

Clustering y clasificacin
Aplicado con xito en textos
Ciertas frases son indicativas de clases
Algunas frases ocrren solo en textos no
etiquetados, otras en los dos

EM puede generalizar tomando la


ocurrencia de ambos tipos
Variancin: reducir el peso de datos no
etiquetados
Variacin: permitir ms de un cluster por clase
Agrupamiento

También podría gustarte

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy