Browse Source

windows fix (msys2)

windows
cailean 6 months ago
parent
commit
b30a57a188
  1. 5
      .gitignore
  2. 3
      addons.make
  3. BIN
      bin/data/new_tree.bin
  4. BIN
      bin/sv-map.exe
  5. 21
      image-to-mesh.code-workspace
  6. 2
      src/Bullet.cpp
  7. 2
      src/network/Request.cpp
  8. 4
      src/network/Server.cpp
  9. 2
      src/network/Server.h
  10. 78
      src/ofApp.cpp
  11. 4
      src/ofApp.h
  12. 2
      src/onnx/Onnx.h
  13. 2
      src/onnx/Yolo.h
  14. 2
      src/utils/QuadSource.cpp

5
.gitignore

@ -16,6 +16,11 @@
/bin/data/main_dataset /bin/data/main_dataset
/bin/libs/ /bin/libs/
#########
# ignore dlls from copy
#########
/bin/*.dll
######### #########
# general # general
######### #########

3
addons.make

@ -9,4 +9,5 @@ ofxNetwork
ofxTSNE ofxTSNE
ofxTSNE ofxTSNE
ofxPiMapper ofxPiMapper
ofxPiMapper ofxPiMapper
ofxOnnxRuntime

BIN
bin/data/new_tree.bin

Binary file not shown.

BIN
bin/sv-map.exe

Binary file not shown.

21
image-to-mesh.code-workspace

@ -110,7 +110,26 @@
"timer": "cpp", "timer": "cpp",
"buffer": "cpp", "buffer": "cpp",
"socket": "cpp", "socket": "cpp",
"*.glsl": "cpp" "*.glsl": "cpp",
"coroutine": "cpp",
"ios": "cpp",
"locale": "cpp",
"xfacet": "cpp",
"xhash": "cpp",
"xiosbase": "cpp",
"xlocale": "cpp",
"xlocbuf": "cpp",
"xlocinfo": "cpp",
"xlocmes": "cpp",
"xlocmon": "cpp",
"xlocnum": "cpp",
"xloctime": "cpp",
"xmemory": "cpp",
"xstddef": "cpp",
"xstring": "cpp",
"xtr1common": "cpp",
"xtree": "cpp",
"xutility": "cpp"
} }
} }
} }

2
src/Bullet.cpp

@ -185,7 +185,7 @@ void Bullet::draw(){
camera.begin(); camera.begin();
glEnable( GL_DEPTH_TEST ); glEnable( GL_DEPTH_TEST );
ofSetLineWidth(20.f); ofSetLineWidth(1.f);
ofNoFill(); ofNoFill();
ofSetColor(ofColor::yellow); ofSetColor(ofColor::yellow);

2
src/network/Request.cpp

@ -33,7 +33,7 @@ VPResp Request::query(Embedding& in){
past_vp_resp = vp_resp; past_vp_resp = vp_resp;
return vp_resp; return vp_resp;
} catch (exception e) { } catch (_exception e) {
// Some issue happening here when plugging in controllers, or when they initially connect // Some issue happening here when plugging in controllers, or when they initially connect
return past_vp_resp; return past_vp_resp;
} }

4
src/network/Server.cpp

@ -207,7 +207,9 @@ void Server::sendOSCMessage(){
std::string audio_file = folder; std::string audio_file = folder;
// Check if file exists in a given dir // Check if file exists in a given dir
ofFile file("/home/cailean/Desktop/rave/all_wav_files/" + audio_file + ".wav"); ofFile file("C:/Users/caile/Desktop/all_wav_files/all_wav_files/" + audio_file + ".wav");
ofLog() << file.path;
if((audio_file != past_audio_file) && file.exists()){ if((audio_file != past_audio_file) && file.exists()){
me_file.setAddress("/emote/filename"); me_file.setAddress("/emote/filename");

2
src/network/Server.h

@ -75,7 +75,7 @@ class Server{
std::chrono::steady_clock::time_point lastUpdateTime; std::chrono::steady_clock::time_point lastUpdateTime;
const std::chrono::milliseconds updateInterval{1000}; // 1 second interval const std::chrono::milliseconds updateInterval{1000}; // 1 second interval
bool m_RanomdEmbed = true; bool m_RanomdEmbed = false;
int regions[4][4] = { int regions[4][4] = {
{0, 0, 128, 168}, // Top-left {0, 0, 128, 168}, // Top-left

78
src/ofApp.cpp

@ -68,18 +68,18 @@ void ofApp::setup(){
font.load("MaziusDisplay-Bold.otf", 180); font.load("MaziusDisplay-Bold.otf", 180);
ofLog() << font.getLineHeight(); ofLog() << font.getLineHeight();
ORTCHAR_T* modelPath = "/home/cailean/Desktop/openframeworks/of_v0.12.0_linux64gcc6_release/apps/myApps/image-to-mesh/bin/data/models/depth_anything_v2_vits.onnx"; ORTCHAR_T* modelPath = L"C:/Users/caile/of_v20250417_msys2_mingw64_release/apps/myApps/sv-map/bin/data/models/depth_anything_v2_vits.onnx";
ORTCHAR_T* modelPath_Small = "/home/cailean/Desktop/openframeworks/of_v0.12.0_linux64gcc6_release/apps/myApps/image-to-mesh/bin/data/models/depth_anything_v2_vitb.onnx"; ORTCHAR_T* modelPath_Small = L"C:/Users/caile/of_v20250417_msys2_mingw64_release/apps/myApps/sv-map/bin/data/models/depth_anything_v2_vitb.onnx";
ORTCHAR_T* modelPath_Yolo = "/home/cailean/Desktop/openframeworks/of_v0.12.0_linux64gcc6_release/apps/myApps/image-to-mesh/bin/data/models/yolov5s-face.onnx"; ORTCHAR_T* modelPath_Yolo = L"C:/Users/caile/of_v20250417_msys2_mingw64_release/apps/myApps/sv-map/bin/data/models/yolov5s-face.onnx";
ORTCHAR_T* modelPath_Indoor_Dynamic = "/home/cailean/Desktop/openframeworks/of_v0.12.0_linux64gcc6_release/apps/myApps/image-to-mesh/bin/data/models/depth_anything_v2_vitl.onnx"; ORTCHAR_T* modelPath_Indoor_Dynamic = L"C:/Users/caile/of_v20250417_msys2_mingw64_release/apps/myApps/sv-map/bin/data/models/depth_anything_v2_vitl.onnx";
bullet.setup(); bullet.setup();
/* pi mapper setup */ /* pi mapper setup */
mapper.registerFboSource(projection_src); // mapper.registerFboSource(projection_src);
mapper.setup(); // mapper.setup();
projection_src.setFbo(&comp_fbo); // projection_src.setFbo(&comp_fbo);
projection_src.setFbo(&mapper_black); // projection_src.setFbo(&mapper_black);
/* onnx setup */ /* onnx setup */
depth_onnx.Setup(modelPath, false, true); depth_onnx.Setup(modelPath, false, true);
@ -125,7 +125,7 @@ void ofApp::setup(){
portrait_camera.setScale(current_cp.scale); portrait_camera.setScale(current_cp.scale);
updateCurrentCameraMode(); updateCurrentCameraMode();
createNodes("data/json/sv_embeddings.json"); createNodes("json/sv_embeddings.json");
buildMeshes(); buildMeshes();
@ -203,6 +203,16 @@ void ofApp::update(){
mapper.update(); mapper.update();
bullet.update(server->is_active, n, nn_nodes); bullet.update(server->is_active, n, nn_nodes);
if(tsne_update_complete) {
tsne_update_complete = false;
onTSNEUpdateComplete();
}
if(ofGetElapsedTimef() > tsne_start_time + TNSE_DURATION) {
tsne_iter_idx = (tsne_iter_idx + 1) % 3;
updateTSNEPositions(nodes);
}
updateCurrentCameraMode(); updateCurrentCameraMode();
if(bullet.getRandomWalkTime() > 60){ if(bullet.getRandomWalkTime() > 60){
@ -232,11 +242,12 @@ void ofApp::draw(){
esp_comp_fbo.begin(); esp_comp_fbo.begin();
esp_shader.begin(); //esp_shader.begin();
esp_shader.setUniformTexture("tex0", model_esp_out_fbo.getTexture(), 0); //esp_shader.setUniformTexture("tex0", model_esp_out_fbo.getTexture(), 0);
model_esp_out_fbo.draw(0, 0); //model_esp_out_fbo.draw(0, 0);
model_image_esp.draw(0, 0);
esp_comp_fbo.end(); esp_comp_fbo.end();
esp_shader.end(); //esp_shader.end();
portrait_fbo.begin(); portrait_fbo.begin();
@ -275,7 +286,7 @@ void ofApp::draw(){
ofTranslate(0, 0); ofTranslate(0, 0);
comp_fbo.draw(0, 0); comp_fbo.draw(0, 0);
mapper.draw(); //mapper.draw();
if(bullet.print_debug) if(bullet.print_debug)
@ -872,4 +883,41 @@ void ofApp::drawText(){
ofPopStyle(); ofPopStyle();
text_display.end(); text_display.end();
} }
void ofApp::updateTSNEPositions(vector<Node>& _nodes){
if(tsne_updating) {
ofLog() << "TSNE update already in progress";
return;
}
tsne_updating = true;
tsne_update_complete = false; // Reset flag
tsne_thread = std::thread(&ofApp::updateTSNEPositionsThreaded, this, std::ref(_nodes));
tsne_thread.detach();
}
void ofApp::updateTSNEPositionsThreaded(vector<Node>& _nodes){
ofLog() << "Starting TSNE update in thread";
{
std::lock_guard<std::mutex> lock(nodes_mutex);
for(size_t i = 0; i < point_iterations[tsne_iter_idx].size(); i++) {
const auto& vec = point_iterations[tsne_iter_idx][i];
nodes[i].tsne_position = glm::vec3(
((vec[0] * 2) - 1) * tsne_scale,
((vec[1] * 2) - 1) * tsne_scale,
-5.0f
);
}
}
tsne_updating = false;
tsne_update_complete = true; // Set completion flag
ofLog() << "TSNE update complete";
}
void ofApp::onTSNEUpdateComplete() {
// Do whatever you need to do after TSNE update
// This will run on the main thread
bullet.updateTSNEPosition(nodes);
tsne_start_time = ofGetElapsedTimef();
ofLog() << "Handling TSNE update completion on main thread";
}

4
src/ofApp.h

@ -4,7 +4,7 @@
#include "utils/MeshGenerator.h" #include "utils/MeshGenerator.h"
#include "Bullet.h" #include "Bullet.h"
#include "vp/VP.h" #include "vp/VP.h"
#include <onnxruntime_cxx_api.h> #include "ofxOnnxRuntime.h"
#include "onnx/Onnx.h" #include "onnx/Onnx.h"
#include "onnx/Yolo.h" #include "onnx/Yolo.h"
#include "onnx/ModelThread.h" #include "onnx/ModelThread.h"
@ -165,7 +165,7 @@ class ofApp : public ofBaseApp{
Bullet bullet; Bullet bullet;
/* simulation update timer */ /* simulation update timer */
const float TNSE_DURATION = 180.0f; const float TNSE_DURATION = 30.0f;
float tsne_start_time; float tsne_start_time;
int tsne_iter_idx = 0; int tsne_iter_idx = 0;

2
src/onnx/Onnx.h

@ -1,6 +1,6 @@
#pragma once #pragma once
#include <onnxruntime_cxx_api.h> #include "ofxOnnxRuntime.h"
#include <algorithm> // std::generate #include <algorithm> // std::generate
#include <cassert> #include <cassert>
#include <cstddef> #include <cstddef>

2
src/onnx/Yolo.h

@ -3,7 +3,7 @@
#include "ofMain.h" #include "ofMain.h"
#include "ofxOpenCv.h" #include "ofxOpenCv.h"
#include <onnxruntime_cxx_api.h> #include "ofxOnnxRuntime.h"
#include <algorithm> #include <algorithm>
struct Emotef{ struct Emotef{

2
src/utils/QuadSource.cpp

@ -17,5 +17,5 @@ void QuadSource::draw(){
// Fill FBO with our quads // Fill FBO with our quads
ofClear(0); ofClear(0);
//ofBackground(255, 120, 10); //ofBackground(255, 120, 10);
fbo_in->draw(0, 0); // fbo_in->draw(0, 0);
} }
Loading…
Cancel
Save