Notes
- Check the Selected Computational Thinking Analysis Papers for how you should or not prepare your analysis about the project.
- p5js website
- p5JS cheatsheet
- Presentations page
- RandomSeed IG link
- RandomSeed Webpage selected projects
Topics
WebSockets + WebRTC + Arduino (Physical Computing)
Creative Code Syllabus at Devin University
ML5 Related
Neural Network Model Training
Golan Levin Example Codes
AI & ML
-
ML Guitar Effect Control Modify the guitar effect pedal parameters via ML5 faceAPI ml5 Interface
ML5 Face Api - Mask Create a mask illustration. Make it detect by the library. ml5 tutorial -
ML5 Hand Pose Detection Hand and finger tip detection. tutorial
-
Flappy Bird NUI Playing Flappy Birds via body gestures. ml5 game
-
Elemental Powers AR Displays abstracted imagery of earth elements like water, wind, fire, soil⊠ml5 Interface game
-
Body Painting Creating generative art via yoga gestures. ml5 generativeart
-
Posenet Xylophone Blocks produce notes when left or right hand occupies the same space on the screen. ml5 Interface music
-
Volume up/down Volume up or down a signal according to the userâs ankle movement.
-
Head Tracking Piano Switch the notes via angle of the nose, and play the notes by opening mouth. ml5 Interface music
-
Body Pose Music Play and switch the notes according to the userâs body control points. ml5 Interface music
-
âïž Space Oddity - Performance w/ Posenet This performance uses the Posenet library in ml5.js to project the face of David Bowie as an image which follows my face during the performance. The lips moved based on the volume of my singing by using the Amplitude() object in the p5.Sound library. The other visuals in the sketch are also made in p5.js.. ml5 Interface audiovisual
-
Teachable Machine - Sound Sound classifier to play snake game with different spoken words. tutorial ml5
-
Teachable Machine - Pose YMCA song with body gestures. The tutorial might be outdated. Check the following tutorial tutorial ml5 game
-
Teachable Machine - ImageHow to train model based on different images. tutorial
-
Painting with Body Creates symmetrical drawing via hand gestures.
-
Hand Pose - Emoji Display an emoji according to prerecorded poses. ml5 Interface
-
Guitar Chord Extractor Displays chords according to user hand pose. ml5 music
-
ML5 Machine Learning In JS The complete playlist of Daniel Schifman.
week 1
- đ Keep your eyes open. Choose a thing. Letâs say your favorite cup at your home, or a specific bird that you hear everyday, or your pet, or a tree at the campus. Review the example tutorial. On the last page of the tutorial, you will see that whenever you run the code, it generates different facial expressions.
- As we did in the previous semester, break it apart using CT principles. Redraw it using p5JS.
- Make it parametric. So whenever you run the app, determine its properties randomly.
- â« Upload the sketch to your openProcessing account.
- âSubmit the p5js link.
- đ Read Delusions of Dialogue: Control and Choice in Interactive Art
- đș Watch the videos on the last presentation page.
- đ Read Delusions of Dialogue: Control and Choice in Interactive Art
- đș Watch the videos in the presentation. Read about arrays
Selected Assignments A
Alara Yılmaz, Aylin BursalıoÄlu, Cansu Ăzbek, Deniz Sönmez, Duru Seyhan, Gizem ĂobanoÄlu â, Ä°dil Akan, Ä°ris Eryılmaz, Lana Jamal, Naz Ä°pek, Zaman Khan
Selected Assignments B
Abeerah Malik, Aleyna Kabaklar, Azra SadıkoÄlu, Bahar Kızılkaya, Boray ĂnlĂŒ, Duru Seyhan, Duygu Aksöz, Ä°rem Apaydın, Kerem Alp, Kerme YaĆlıçimen, Zeynep Erol
week 2
2025-2026
- Finalize the project that you started in class time. You have two options. Choose 1 or 2. It is optional to submit both of them.
- The challenge is whenever we run the code, the formalistic features of your Object (Class) change randomly.
- Upload a screenshot of your choice. Review the keyPressed() function in Example to implement into your code.
2024-2025
- Convert the week 01 assignment to a class. Reference1, Reference2
- Create instances of your class by initializing it using different parameters.
- Create at least 10 different objects in different features.
- Position all of the objects in the same sketch. Do not create different sketches of each instance.
- â« Upload the sketch to your openProcessing account.
- âSubmit the openprocessing link.
- âSubmit the sketch source code as zip file as well.
Selected Assignments A
Selected Assignments B
Abeerah Malik, Azra SadıkoÄlu, Boray ĂnlĂŒ, Duru Seyhan, Duygu Aksöz, Kerem YaĆlıçimen, Zeynep Erol
week 3
2025-2026
- Utilize Arrays to dynamically control multiple objects.
- Distribute objects on the canvas.
- Animate them up/down, left/right
- Creative Coding Fest
2024-2025
- Write a mini game story.
- Design the storyboard. Keep the document size at 800 x 800 pixel and resolution to 72 DPI.
- Design Intro Scene: A background, Clearly explain instructions to play the game shortly. A button to start the game.
- Design Game Scene: A background, the hero, and enemies.
- Design Final Scene: A background, the result of the game. SUCCESS or FAIL or CONGRATS depending on your scenario.
- Export UI elements as PNG files.
- đș Check the videos Former Student Games.
week 4
2025-2026
Showcase of games on itch.io web platform, links
Making a software visual guide, link
Feedback for the games
Assignment
Dear all,
Let me clarify one thing. Those who do not attend classes submit irrelevant assignments. It does not mean that if your code is running, you will get high grades. This is a friendly reminder for you. Please read the LMS submissions carefully or ask your friends in the class before submission. For this game project, I wonât decrease anyoneâs grade. But for the upcoming projects, if I receive irrelevant assignments, do not shock when you see your grades đ€·ââïž. Youâre warned!
For the next week, I want all of you to finalize your games. Each game must have 3 different scenes, as discussed in the lecture time. You will be graded according to your game interface design (40 points) and game mechanics (40 points).Â
- Submit the link to your project. (10 points)
- Submit a zip version of your project. (10 points)
- Submit screen-capture video of your game play. Keep it under 2 minutes. Convert the screen capture to mp4 video format. Handbrake Software tutorial (10 points)
For more information about the game format, visit the link.
2024-2025
- đ Implement all of the scenes that you design for your game in P5Js.
- You can use the codes in my game and implement to yours. Fork my [game template] to adapt your game scenes. For those who have different game mechanics than my game, do your best. I want to see the implemented design in P5Js. Please ask to me or your friends in class whenever you need help or get stuck!!! I can provide you tutorials and reference code snippets.
- â« Upload the sketch to your openProcessing account.
- âSubmit the openprocessing link.
- âSubmit the sketch source code as zip file as well.
week 5
This form, which will be available starting Monday, March 3, consists of two open-ended questions where students can share what they find positive about the courses and the areas they believe could be improved for a better learning experience. The form will remain accessible via SIS throughout the upcoming week.
2025-2026
PLEASE READ CAREFULLY!
You have 3 options. Choose one below.
- Art: Create an interactive AR sketch where the fiducial marker displays a unique piece of digital art or animation.
- Education: Design an AR-based educational tool that uses fiducial marker to teach a concept (e.g., design, astronomy, biology, geography, or math).
- Interactive Poster: Create a poster about a topic of your choice. You can use a material that you did before in your other typography or basic design courses. Attach the marker to the corner of your poster. Whenever, the user points the camera on to the poster display some more information or animation related to the printed design.
You can use a single or multiple markers if you want. Refer to the example sketch In this sketch you need to print the first 6 markers (0wFrame.png, 1wFrame.png, 2wFrame.png, 3wFrame.png, 4wFrame.png, 5wFrame.png) from the following link.
General Submission Guidelines for All Assignments:
- Code Submission:Â Submit the p5.js source code and any additional assets (images, sounds, etc.) used in the project.
- Zipped Project Folder:Â Compress the entire project folder.
- Proof of Concept Video:Â Record a video using a mobile phone to demonstrate the AR application in action. The video should clearly show the fiducial markers being detected and the AR content responding accordingly.
Sign up for a free account on the GitHub web page due to the upcoming class.
Augmented Reality
- Your games must be finished and finalized.Â
- I donât want to hear any apologies or last day help requests.
- Upload your whole sketch folder.
- Submit the link of your game.
week 6
2025-2026
Watch the following videos in order.
- Introduction to Machine Learning
- Pose Detection
- Hand Pose Detection with ml5.js
- Face Mesh with ml5.js
- ml5.js 1.0 and Guest Conductor Patt Vira
Assignment 06
Option 1: Choose one of your algorithmic art assignments code from the last semester or create a new algorithmic art sketch. When we run the app, the user can change the properties of your art work by using his/her hand gestures. Use the code Hand Pose Detection with ml5.js as reference. Watch related videos and review the code examples on the page to get inspiration.
Options 2: Create three different masks in Photoshop or Illustrator. Upload the masks to your project. Use the code Face Mesh with ml5.js as reference. Whenever we run the app, make the app chooses randomly one of the masks and display on the userâs face.
Assignment 1: ML
- You can use face, hand, or body position to move your character. Refer to the example code that I wrote in class time.
- Upload the link of your sketch
- Upload The codes as well in zip format.
Assignment 2: Mask
- You can choose whatever image you want.
- You can create illustration using simple shapes.
- We will write the code in class time.Â
- Upload the image you choose.Â
- References : Computational Mask Repo, Generative Masks, Ref3
week 7
2025-2026
You may choose one of the following:
Option 1: Interactive Art Installation
Objective: Create an interactive digital art piece that responds to real-world objects.
Instructions:
- Collect and Train: Gather at least 10 distinct objects.
- Develop with p5.js:
Integrate the trained model into a p5.js sketch.
Design visual elements that change based on the detected object. For example, displaying different animations or colors corresponding to each object.
Option 2: Educational Game
Objective: Develop a simple game that teaches users about the objects recognized by the classifier.
Instructions:
- Collect and Train: Select 10 educational items (e.g., fruits, geometric shapes, tools). Train a model using Teachable Machine to identify each item.
- Game Development: Create a p5.js game where users present objects to the camera. Provide feedback or facts about the object upon correct identification.
Option 3: Assistive Tool
Objective: Build a tool that aids individuals with visual impairments by audibly identifying objects.
Instructions:
- Collect and Train: Assemble 10 everyday objects. Train an image classifier using Teachable Machine to recognize these items.
- Develop with p5.js: Integrate the model into a p5.js sketch.
Implement functionality to speak the name of the detected object using the p5.js sound library.
2024-2025
Please READđą
No Late SubmissionsâââIf you donât understand ask me, or your friend, or to an AI chatbot. Â
- Use Decomposition, Flow, Translation, and Algorithm Design steps for your mask generation. I want to see how you implement your ideas. Upload text, diagram or any kind of material that you include your programming activity. Create a pdf for your design process as I show you in the presentation. You donât need to include material for the Algorithm Desin section since your codes on openProcessing is the last step actually. (40 points) Tutorial
- Write down the mask code. (20 points)
- Apply ML5 library to enable head tracking on camera. (20 points)Â
- Head Tracking Code:Â ML5 Face Tracking Example
- Head Tracking With Mask Implementation Code:Â Face Tracking with Mask Example
- Skim the attached document (Form+Code Book, Repetetion pg. 42-65)
- Choose an image that includes repetition in the artwork from the follwing link.
- âSubmit the openprocessing link.
- âSubmit the sketch source code as zip file as well.
week 8
2025 - 2026
Personal Portfolio Inspiration
The only web design inspiration sites you need:
Build, Share, and Explore Developer Portfolios â Portfolio creation guides
http://curated.design â My personal fav
http://land-book.com â Large selection
http://landing.gallery â All niches
http://saaslandingpage.com â SaaS
http://admiretheweb.com â Unique
http://supahero.io
Would add http://mobbin.com to this!
unicorn.studio â No-code WebGL Tool
Some other list of inspirational projects to check.
Built At Lightspeed - 4000+ Themes, Templates & UI KitsThe worldâs largest marketplace of themes, templates and UI kits for the modern stack.
Hand pose Examples
p5.js Web Editor | Hand Pose Thumbs Up or Down
Pose Net
Object Detection and Speech Synthesis
Teachable Machine
2024 - 2025
- Finalize the code and submit the source code and openprocessing link.
- Choose the most appropriate options for the artworks included in each survey. You can choose multiple choices.
week 9
Holiday
week 10
week 11
Project Proposal Submission
- Game Showcases
- Side Scrolling Dog Game Use space to jump. Hold shift to speed up. Collect bones. Runaway from obstacles. Pixelart game.
- Platformer Game
- Line Physics Game
- One Million Particles
- Online Events
API Calls
Check the following page (List of Free Rest APIs) to access more API-related content resources in the free version.
Machine Learning
1: Introduction (9/5)
2: Transfer Learning (9/12)
3: Pre-trained models 1: Body (9/19)
4: Pre-trained models 2: Face and Hand (9/26)
- Facemesh Generates facemeshâŠ
- Lip Drawing Extract shapes from another shape.
- Finger Tracking Generates particles attached on index finger
- Finger tracking 2 Generate custom shape using index finger and finger tip.
- NUI with fingers Scale up/down the loaded image real-time
5:Â Training a Neural Network 1Â (10/3)
6:Â Training a Neural Network 2Â (10/10)
7: ml5.js project presentations (10/17)
8: Introduction to Transformers.js (10/24)
9: Language Models (10/31)
10: Image Generation Models (11/7)
11: Final Project Proposals + Fine-Tuning (11/14)
12: Final Project Proposals + TBD (11/21)
13: Final Project Play Testing (12/05)
14: Final Project Presentations (12/12)
Final Project Instructions
âïž If you think that your project is ready, fill out the submission form also. Click the link to download Project Template
đ§ You are free to propose any project idea as long as it includes programming.Â
If you need a topic or theme, you can utilize one of the following concepts;
- A project including machine learning ideas using â ml5 libraryÂ
- A project including interactive platform games. Check previous studentsâ works â 1, 3, 4, 5, 6, 7, 8
- Interactive educational applications and games. Check previous studentsâ works â 1
- Puzzle games â 1
- Sound interactive games and applications â 1, 2
- Interactive applications about a specific theme â Travel Guide, Cancel Culture
- Interactive illustration stories â 1
- Audiovisual VJ apps â ASCII-art, Drum Performance Visualizer, Op-art, The Story of Nothing
- Skeuomorphic conceptual applications â 1
- Generative Art (Recursion, Fractals) â 1
- Generative Art (Image Processing) â 1
- Generative Art (Abstracted formalism) â Fish, Generative Logo
- A project including Algorithmic Art Praxis. Choose multiple categories from the cheat sheet that I distributed to you in class and create series of artworks according to a theme and print them to fine papers. Check the existing artworks to get inspired â link. You can view specific category items using ALAP website.