Raymond Pai-Project-02-Variable-Face

sketch

var r = (200);
var g = (120);
var b = (120);
var mouthx = 50
var mouthy = 20
var eyew = 40
var eyeh = 40
var brow1y1 = 100
var brow1y2 = 100
var brow2y1 = 100
var brow2y2 = 100

function setup() {
    createCanvas(640, 480);
}

function draw() {
    background(240);
    // Draw head
    strokeWeight(5);
    fill(r, g, b, 127);
    ellipse(320, 240, 400, 400);
    //Draw mouth
    fill(0);
    stroke(255, 200, 200);
    rect(320, 300, mouthx, mouthy)
    //Draw eye1
    strokeWeight(20);
    stroke(255);
    fill(0);
    ellipse(420, 200, eyew, eyeh);
    //Draw eye2
    strokeWeight(20);
    stroke(255);
    fill(0);
    ellipse(330, 200, eyew, eyeh);
    //Draw brow1
    strokeWeight(18);
    stroke(0);
    line(270, brow1y1, 350, brow1y2)
    //Draw brow2
    strokeWeight(18);
    stroke(0);
    line(380, brow2y1, 430, brow2y2)
    //ear
    strokeWeight(5);
    fill(r, g, b, 127)

    arc(220, 250, 80, 80, 0, 5 + QUARTER_PI, OPEN);
}
function mousePressed() {
  // Check if mouse is inside the circle
  let d = dist(mouseX, mouseY, 360, 200);
  if (d < 700) {
  //randomize
    r = random(120, 200);
    g = random(100, 120);
    b = random(100, 120);
    mouthx = random(50, 95);
    mouthy = random(30, 105);
    eyew = random (20, 90);
    eyeh = random (20, 145);
    brow1y1 = random (60, 100);
    brow1y2 = random (60, 100);
    brow2y1 = random (60, 100);
    brow2y2 = random (60, 100);
  }
}

Changes in color, mouth, eyes, and eyebrows. It is an expressive fish.

Carly Sacco – Looking Outwards – 02

A generated baroque architecture example of Celestino Soddu.

Celestino Soddu is known for being an architect who uses generative art to create forms and designs for architecture. One of his notable projects from 2011, is using algorithms to replicate and create new geometries that mimic the designs of Baroque  Architecture to imagine new dynamic structures. I think this is a very interesting way to use generative art to take a precedent and recreate the same ideas but re-imagine them with the use of modern technology.

Celestino Soddu using generative methods to create Baroque style architecture.

Soddu used an algorithm matrix based on 21 that generates seemingly perfect architecture, but is rarely repeatable. The algorithm adapts to achieve unpredictable orders. This is very representative of his work due to the fact that Soddu tries to have his generative forms still represent the styles known to baroque. Although he is digitally creating a new design, the product can still be associated to baroque architecture which is his ultimate goal.

Generative art that represents styles of Baroque Architecure.

Aaron Lee-Looking Outwards-02

“theatroacoustic” system. Courtesy LMN Architects

Creator’s name: LMN Architects

Title of the work: Ceiling of a new concert hall at the Voxman School of Music

Year of creation: 2016

Link: https://lmnarchitects.com/project/university-of-iowa-voxman-music-building

Construction sequence. Courtesy LMN Architects

Today, architects use scripting or programming to achieve complex yet fascinating geometry by computers which straightly leads to digital fabrication for mockups. The curves of these new shapes are not only proven to be the new aesthetic but also logical to be built in reality.

LMN Architects in Seattle designed the ceiling of a new concert hall at the Voxman School of Music using generative design and construction. Sophisticated algorithms in scripts were necessary in order to perform seamlessly an acoustic reflector, a distributor of light and air and most importantly aesthetically pleasing. Parameters / variables were first defined and generative algorithm calculated the best degree of curves, number of openings of the 946 unique, folded-aluminum composite modules while none are alike.

The further advantage of designing in scripts is that the design can be easily transcribed to fabrication language. In this case, any changes made to parameters could be produced into physical mock up to simulate acoustic level. Iterations of this process proved that the final product was the best option.

Mihika Bansal-Project 02-Variable Face

sketch

/*
Mihika Bansal 
Section E 
mbansal@andrew.cmu.edu
Project-01
*/

var faceWidth=120; 
var faceHeight=150; 
var faceColorR=234; 
var faceColorG=213; 
var faceColorB=200; 
var hairLength=200; 
var neckLength=100; 
var neckWidth= 75; 
var noseY= 220;
var eyeWidth=15; 
var mouthX=20; 
var mouthY=10; 
var earWidth= 15; 
var earHeight= 17; 
var colorR= 230; 
var colorG=211; 
var colorB=152; 

function setup() {
    createCanvas(640, 480);
  }

function draw() {
    background(231, 231, 253); 
  
    //neck
    fill(faceColorR, faceColorG, faceColorB); 
    rectMode(CENTER); 
    rect(width/2, (height / 2 - 50)+(0.5*faceHeight)+0.2*neckLength, neckWidth, neckLength);
    
    //hair 
    fill("black");
    arc(width/2+0.68*(0.5*faceWidth), height/2-20, 100, hairLength, 3*PI/2, PI/2);
    arc(width/2-0.68*(0.5*faceWidth), height/2-20, 100, hairLength, PI/2, 3*PI/2);
    
     //face +ears 
    fill(faceColorR, faceColorG, faceColorB);
    ellipse(width / 2, height / 2 - 50, faceWidth,  faceHeight);
    arc(width/2+(0.5*faceWidth), height/2-0.20*faceHeight, earWidth, earHeight, 3*PI/2, PI/2);
    arc(width/2-(0.5*faceWidth), height/2-0.20*faceHeight, earWidth, earHeight, PI/2, 3*PI/2);
    //hair 
    fill("black");
    arc(width/2, height/2-65, faceWidth*1.3, faceHeight, PI-0.40, QUARTER_PI-0.45 , PIE);
    //nose 
    fill(faceColorR, faceColorG, faceColorB);
    triangle(width/2, noseY, width/2-5, noseY*0.97, width/2+5, noseY*0.97);

    //eyes 
    fill("white"); 
    ellipse(width/2-20, height/2-40, eyeWidth, eyeWidth*0.65);
    ellipse(width/2+20, height/2-40, eyeWidth, eyeWidth*0.65);
    fill("black"); 
    ellipse(width/2-18, height/2-42, eyeWidth*0.45, eyeWidth*0.45);
    ellipse(width/2+22, height/2-42, eyeWidth*0.45, eyeWidth*0.45);

    //mouth
    fill(123, 30, 30); 
    arc(width/2, height/2+faceHeight*0.04, mouthX, mouthY, 0, PI,OPEN);

    //earrings 
    fill(colorR, colorG, colorB); 
    ellipse(width/2+(0.52*faceWidth), height/2-0.18*faceHeight, 5, 5);
    ellipse(width/2-(0.52*faceWidth), height/2-0.18*faceHeight, 5, 5);
    fill(colorR*1.2, colorB*1.2, colorG*1.2);
    rect(width/2+(0.52*faceWidth), height/2+0.04*faceHeight, 5, hairLength*0.2);
    rect(width/2-(0.52*faceWidth), height/2+0.04*faceHeight, 5, hairLength*0.2);
     
}

function mousePressed() {
    faceWidth = random(100, 150);
    faceHeight = random(140, 180);
    eyeWidth = random(10, 25);
    faceColorR= random(150, 250);
    faceColorG= random(102, 245);
    faceColorB= random(55, 236);
    hairLength= random(100, 250);
    neckLength= random(85, 150); 
    neckWidth= random(50, 120);
    noseY=random(215, 230);
    mouthY=random(5,20); 
    mouthX=random(15, 30);
    earWidth=random(10, 25);
    earHeight=random(13, 30);
    colorR=random(0,255); 
    colorG=random(0,255);
    colorB=random(0,255);

}

For this project, I worked with the same style of my self portrait to create faces that changed multiple facets. I changed the eye size, skin color, face width and height, neck size and length, hair length, earring size and color, etc, to create unique faces with a distinct style. It was interesting to see faces that were made that I typically would not have made, but still worked visually.

Nadia Susanto – Project 02 – Variable Face

sketch

/*  Nadia Susanto
    Section B
    nsusanto@andrew.cmu.edu
    Project - 02 - Variable Face */

var mouthW = 70
var mouthH = 70
var bodyW = 205
var bodyY = 205
var greenColor = 104
var blueColor = 149
var armXL = 190
var armXR = 430
var armYL = 210
var eyeBW = 25 //black eye part width
var eyeBH = 60
var eyeWW = 20 //white eye part width
var eyeWH = 40

function setup() {
    createCanvas(640, 480);
}

function draw() {
    background(100, 105, 200);
    fill(235, greenColor, blueColor);
    //body
    ellipse(310, 185, bodyW, bodyY);
    //arms
    ellipse(armXL, armYL, 50, 45);
    ellipse(armXR, armYL, 50, 45);
    //cheeks
    fill(235, 104, 149);
    ellipse(250, 175, 25, 15);
    ellipse(370, 175, 25, 15);
    //mouth
    fill(190, 3, 89);
    circle(310, 225, mouthW, mouthH);
    //legs
    fill(221, 3, 89);
    ellipse(235, 295, 40, 70);
    ellipse(385, 295, 40, 70);
    //eyes
    fill("black");
    ellipse(280, 130, eyeBW, eyeBH);
    ellipse(345, 130, eyeBW, eyeBH);
    fill("white")
    ellipse(345, 120, eyeWW, eyeWH);
    ellipse(280, 120, eyeWW, eyeWH);


}

function mousePressed() {
    bodyW = random(200, 270);
    bodyY = random(205, 230);
    greenColor = random(50, 255);
    blueColor = random(0, 255);
    armXL = random(190, 210);
    armXR = random(370, 430);
    armYL = random(140, 210);
    mouthW = random(0, 100);
    mouthH = random(0, 100);

}

This project was definitely a lot of fun to do as my inspiration to do Kirby came from Super Smash Bros. I used adobe illustrator to first sketch out the initial image of what I wanted to do. I animated Kirby to change colors, change how big his suction is, change his body size, and change his arm placements to make it look like he is dancing.

Mihika Bansal-Looking Outwards-02

One of the things that I am passionate about is climate change. So seeing artists that focus on these prevalent issues as the focus of their work is inspiring for me. An artist that I am particularly interested in is Mitchell Whitelaw. He has multiple pieces in which the recent climate crisis is his inspiration.

One piece that I find to be particularly interesting is his climate coasters. These coasters take data from the ANU climate change institute, and will change based on location and time in order to create a new coaster that represents that new data. The app also uses data that ranges from 1991 to 2017, which shows how much it has changed and grown. This project is also an interesting example of data visualization, another field that I am really interested in pursuing.

Mitchell was the primary artist of this work and it was completed in May of 2018.

Link to work: https://gravitron.com.au/climatecoaster/

Climate change coasters created by the ANU School of Art and Design.

Kristine Kim – Looking Outward-02


there exists this placeTarbell, the artist of “Happy Place,” solely uses computer programs and algorithms to generate his own unique graphic designs. I was instantly drawn into his pieces because of the beautiful textures and the rapid movement he captures just with computer coding. The lines and shear layers that breaks the boundaries of the form of a color is really interesting and compelling that makes me want to just stare at it for a long period of time. Looking into the piece and especially the center of the design, it provides an illusion of it spinning and moving.  The color palette also helps the design to portray the smooth and blurry effect this piece provides. For this piece, J.Tarbell used the technique of connected random nodes with preferences to nodes closer. This piece was different then his other works because he claims that he manipulates his works by finely crafting the semantics of each program, but “Happy Place” was open to surprising discoveries. J.Tarbell claims that all code is dead and unnecessary unless it is executed within the computer so he distributes the source of his code in modifiable forms. 

friend network

http://complexification.net/gallery/machines/happyPlace/index.php

Minjae Jeong-LO-02

While searching through the list of generative artists, I went through the works by Tom Beddard and found his work “Tree Net” the most fascinating.

http://sub.blue/treenet

One thing that I really like about this art is that it reminded me of our cells when we enlarge them enough to look with our bare eyes. When we think of generative art as reproducing the patterns we find in nature, I think this project is a very inspiring work that it shows such details. I do not still understand how difficult creating art with coding, but I my goal from this class is to learn how to reproduce what I want as close as possible.

Chelsea Fan-Looking-Outward-02

LIA is an Austrian artist who combines drawing and painting with digital images and algorithms. She uses code to translate a concept into a “machine” that produces performances, software installations, sculptures, projections, and other multimedia productions live.

I admire that LIA mixes the traditional “art” of painting and drawing with a new and innovative style through code. Her artwork has a sense of fluidity and continuation in its movement. I really like that her software art is abstract and isn’t meant to resemble or picture a tangible object. It is really inspiring to see a form of art that you normally wouldn’t see in a museum or anywhere out on the streets. My favorite part is that there’s no tangible “finishing” point in her artwork. It is not as if she has draw a cat and is finished, but rather when she herself feels satisfied with the machine’s interpretation of her code.

The only critique I have is that there is a lot of inconsistency in the appreciation of abstract artwork. The beauty and worth in abstract artwork is difficult to measure compared to representational artwork.

03_2017_01_06_16_25_35

An Untitled Experiment by LIA from January 8, 2017

2017_08_12_21_45_27

 

Another Untitled Experiment by LIA from June 5, 2018

Videos of LIA artwork can be found at this link: https://vimeo.com/liasomething/videos

Bo Yang-Project-02-Variable Face

sketch

/*
    Bo Yang
    Section A
    byang2@andrew.cmu.edu
    Project-02-Variable-Face
*/

    var eyeSize = 25;
    var faceWidth = 120;
    var faceHeight = 180;
    var mouth = 55;
    let color = "#86592d";
    let colors = ["#33cccc", "#ccccff", "#cc6600", "##993333"];


function setup() {
    createCanvas(640, 480);
}
 
function draw() {
    var eyeL = width / 2 - faceWidth * 0.25;
    var eyeR = width / 2 + faceWidth * 0.25;
    background(color);
 

    //face
    noStroke();
    fill("#006622");
    ellipse(width / 2, height / 2, faceWidth, faceHeight);
    ellipse(width / 2, height * 0.6, faceWidth * 1.5, faceHeight);

    //black eyes
    fill("black");
    ellipse(eyeL, height / 3, eyeSize / 3, eyeSize / 3);
    ellipse(eyeR,height / 3, eyeSize / 3, eyeSize /3);

    //eyes
    ellipse(eyeL, height / 3, eyeSize, eyeSize);
    ellipse(eyeR, height / 3, eyeSize, eyeSize);

    //pupil
    fill(255);
    ellipse(eyeL, height / 3, eyeSize / 2, eyeSize / 2);
    ellipse(eyeR, height / 3, eyeSize / 2, eyeSize / 2);

    //cheeks
    fill("#ff99bb");
    ellipse(eyeL - 8, (height / 3) + 40, eyeSize * 1.2, eyeSize * 1.2);
    ellipse(eyeR + 8, (height / 3) + 40, eyeSize * 1.2, eyeSize * 1.2);

    //mouth
    fill("#ff4d4d"); 
    arc(width / 2, height * 0.6, mouth, mouth, TWO_PI, PI);

    
}
 
function mousePressed() {
    
    faceWidth = random(30, 120);
    faceHeight = random(100, 200);
    eyeSize = random(15, 35);
    mouth = random(25, 60);
    color = random(colors);
    eyeL = random(width / 2, width / 2 - faceWidth * 0.25);
}

In this program, I draw a frog in the different background color. The frog’s body shape and eyes size will change when you click it. Before I draw it, I just noticed the face shape is more like a frog’s body shape. It use variables on the face, eyes, mouth and background.