VRChat 마이너 갤러리 저장소

제 목
일반 일본인이 테스트한 다이나믹 본이 성능에 미치는 영향 보고
글쓴이
하벤하이드
추천
10
댓글
9
원본 글 주소
https://gall.dcinside.com/vr/39377
  • 2018-08-09 10:47:52
							

http://www.doll-profile.com/blog/131


[VRChat] DynamicBone이 성능에 미치는 영향 조사보고

DynamicBone에 대해 처리가 무거운, 아니 그렇게 무겁지 않은, Gravity가 무거운, 아니 사실 무겁지 않은 등등, 다양한 정보가 착종하고 자신 궁금했기 때문에 조사해 보았습니다.

참고로 나 자신은 평소에는 HTML을 쓰고있는 인간에서 Unity이나 게임 제작은 완전히 아마추어입니다. 가능한 의미있는 검증을하려고했지만 본직의 사람이 보면 엉뚱한 일을하고있을 가능성도 있기 때문에, 만약 이상한 곳 있으면 쭉쭉 돌진 해 주셨으면하고 생각합니다.

8/4 추기

DistantDisable는 VRChat에서 자동으로 활성화되는 것을 확인했습니다. (강제로 DistantDisable에 체크가 들어가 Distance to Object에 10의 값이 들어간 상태가 .Distance to Object 5 등 작은 값을 설정 한 경우에도 10 값으로 강제됩니다)

그래서 2018 / 08 / 04 현재 사용자가 DistantDisable와 Distant to Object의 설정을 만지작 거려도 의미가 없습니다.

결론

자세한 상당히 길기 때문에 먼저 결론을.

  • Gravity를 설정하여도 부하는 변하지 않는다
  • UpdateRate을 내려도 대부분 가볍게한다
  • DistantDisable 가볍게하는 효과가 크므로 결정 하자고 (그 때는 DistanceToObject을 가능한 한 낮게 해 주었으면)

검증 방법

  • Unity의 Profiler에서 확인
  • 장면에 20 장만 여기 모델을 배치하고 DynamicBone을 설정 (무당은 CandyRockStar을 춤추게하는)
  • 검증 단말기의 CPU는 i5 8400

Unity에서 검증 한 이유는 렌더링의 문제가 아니기 때문에 VR 환경 인 필요는 없다고 판단했기 때문입니다. 만일을 위해 일부 VRChat에서 결과가 같은지 확인 했습니다만, Unity에서의 검증 및 결과는 바뀌지 않았다.

검증 패턴은 다음과 같습니다.

  • DynamicBone 없음
  • DynamicBone 있습니다
  • DynamicBone 있습니다 (Gravity 값을 입력)
  • DynamicBone 있습니다 (위 외에도 DynamicBoneCollider을 배치)
  • DynamicBone 있습니다 (위 외에도 UpdateRate을 30)
  • DynamicBone 있습니다 (위 외에도 DistantDisable를 사용)

DynamicBone 없음

no_dynamic_bone

위 2.1ms가 Rendering (렌더링) 아래 0.9ms가 Others (카테고리 분류가 어려운 것)에 소비되는 시간입니다.

DynamicBone 처리에 소비되는 시간은 파란색 Scripts (스크립트)로 표시됩니다. 지금은 DynamicBone을 설정하지 않기 때문에 거의 표시되지 않아요.

DynamicBone 있습니다

dynamic_bone

  • 트윈 테일
  • 소매

에 대한 기본 설정 DynamicBone을 설정 한 상태입니다. DynamicBone의 처리 시간은 1.5ms되어 있습니다.

1.5ms 보니 짧게 느껴 있지만 90FPS를 지향 경우 1 프레임의 처리 시간은 11ms입니다. 사용할 수있는 처리 시간의 10 % 이상을 DynamicBone 만 사용 버리고 있기 때문에 결코 가벼운 처리라고는 할 수있는 것 같습니다.

DynamicBone 있습니다 (Gravity 값을 입력)

dynamic_bone_with_gravity

DynamicBone 모든 Gravity : Y로 "-0.02"을 설정 한 상태의 물건입니다. 처리 시간은 변함없이 1.5ms이므로 Gravity 특히 무거운 처리가 아닌 것 같습니다.

실제로 DynamicBone 소스를 확인 했습니다만, Gravity의 유무로 처리가 무거워지는 같은 곳도 눈에 띄지 않았기 때문에이 결과는 타당한 것으로 생각합니다.

DynamicBone 있습니다 (위 외에도 DynamicBoneCollider을 배치)

dynamic_bone_with_gravity_and_collider

몸에 2 개, 소매에 영향을 Collider를 설정 한 것입니다. 처리 시간은 0.3ms 증가 1.8ms입니다.

단 2 곳의 Collider에서 처리 시간이 이만큼 늘어난 때문에 Collider 투성이의 아바타는 매우 위험하게 될까 ...

DynamicBone 있습니다 (위 외에도 UpdateRate을 30)

dynamic_bone_with_gravity_and_collider_rate_30

여기에서 DynamicBone의 처리를 가볍게하기위한 설정의 검증입니다.

UpdateRate는 1 초에 몇 번 DynamicBone를 업데이트하거나 설정합니다. 기본이 60이므로 절반 설정해 보았습니다.

결과는 1.7ms와 0.1ms 밖에 짧아지고 있지 않습니다. 과연 궁금해 조사한 곳, UpdateRate가 작은 경우에 처리를 생략하는 처리 "SkipUpdateParticles"가 있는데, 그것은 상당히 무거운 처리가되어있었습니다.

Collider 투성이의 DynamicBone라면 나름대로 유용한 설정은있다라고 생각 합니다만, 그렇지 않으면 UpdateRate 처리 부하에 관해서는 그다지 영향을주지 않으므로주의하십시오.

DynamicBone 있습니다 (위 외에도 DistantDisable를 사용)

dynamic_bone_with_gravity_and_collider_distance_5

이곳은 DistantDisable를 활성화 한 다음 DistanceToObject 5를 설정 한 패턴입니다. (앞 3 장만 DynamicBone이 움직이고 있습니다)

이곳은 처리 부하가 0.6ms까지 떨어지고있어 UpdateRate와 달리 활성화하고 있어요.


DynamicBone를 사용할 때는 DistantDisable을 활성화하고 DistanceToObject를 가능한 한 작게 해주면 주위에 친화적 인 것으로 생각합니다.

(모두의 추기대로 VRChat에서 강제 설정이 활성화됩니다)

이상

성능에 관해서는 체감하기 쉽기 때문에 상당히 분위기에서 이야기 경향인데, 실제로 조사해 보면 의외의 결과가되기도하네요.

현재 운영하고있는 월드는 성능에 상당한 어려움을 겪고있다 (20 명 초과 근처에서 CPU 부하가 위험하다 ...) 때문에, 이런 부하 조사 기사가 증가하면 좋다고 생각 썼습니다.

선전

img_feature_dancehall01

Silent Club 이라는 월드를 만들었습니다. 음성 채팅 강제 음소거 월드입니다. 공용으로 지정하지 않고 기본적으로 일주일에 한 번 개점합니다.

제작은 나와 실린더 씨 의 두 사람. 싹둑 분담은 실린더 씨가 외형 부분 (Blender에서 모델링, 라이팅 등) 및 특수 효과의 아이디어, 제가 기술적 인 부분 (효과와 특수 효과의 구현 등)와 WEB 사이트 제작됩니다. 제작 착수에서 최근의 정식 오픈까지 대략 2 개월 정도였습니다.

(나 포함) 대화를 싫어하는 사람도 그렇지 않은 사람도 함께 즐길 수있는 장소가 있으면 좋겠다라고 생각하고 만들었 기 때문에 가자. "VRChat 시작했지만 대화가 ..."라는 사람을 발견했을 때에는 꼭 추천 해 주실 수 있으면이라고 생각합니다.



크롬 번역기 돌린거라 말이 좀 이상할수도있음 원문보고싶으면 댓글링크 ㄱ


하벤하이드 http://www.doll-profile.com/blog/131 2018.08.09 10:47:58
하벤하이드 다이나믹본을 가진 물체를 볼때 일정거리 떨어지면 다이나믹본을 끄는 옵션이 있는데 이게 vrchat내부에서는 자동으로 거리 10으로 강제 적용되어있음 2018.08.09 10:49:43
Lydie 3줄요약은? 2018.08.09 10:52:12
하벤하이드 본문에 결론있음 3줄임 2018.08.09 10:52:40
하벤하이드 내 결론은 컬라이더가 많을수록 프레임 드랍이 커진다 2018.08.09 10:53:51
하벤하이드 제일 유의미한 옵션이 거리에 따른 다이나믹본 해제 옵션인데 저게 vrchat에서 이미 강제로 10으로잡혀있으니 컬라이더를 줄이는게 제일 유의미 2018.08.09 10:54:10
하벤하이드 나는 컴 하이스펙이고 내 아바타는 내가 쓸떄 이상없음 최적화 ㅈ까 컬라이더 떢칠해야 이쁨 이런사람이 한월드에 20명있으면 누구라도 렉쩔듯 2018.08.09 10:55:31
늑대소녀 성능 많이 타는구나 역시 2018.08.09 10:56:06
zetyx 캐릭터 몰려있는 곳에서 멀리 떨어지면 프레임이 나아지던데 다이나믹 본때문이었군 2018.08.09 11:35:12
번호 분류 제목 글쓴이 날짜 추천
39985 일반 공지에있는 표정넣는거 봐도 모르겠다 ㅇㅇ 112.151 2018-08-11 0
39984 일반 너네는 춤출 때, 체조할 때 조심해라 1 델피늄 2018-08-11 0
39983 일반 버스안에서 자다가 일어나보나 종점이네요 초보자아 2018-08-11 0
39982 일반 '그'방 New에 있던데 1 ㅇㅇ 221.164 2018-08-11 0
39981 일반 근데 진짜이건 잘찍은듯 3 구다코구다오 2018-08-11 0
39980 일반 핵쟁이 랑같이 다니는애들은 뭣맛으로 걔네들이랑 같이 노가리까는거냐 2 합체로보 2018-08-11 0
39979 일반 허브 바꼇네? tntnt 2018-08-11 0
39977 일반 혹시 VR클럽에서 디제잉 해볼사람 있음? 8 Luche 2018-08-11 0
39976 일반 놀로Vr이 기어VR 양손 헤드 트래킹되게해주는 기계야 설화눈꽃 2018-08-11 0
39974 일반 VR살때 질문인데.. 1 크리스 2018-08-11 0
39973 일반 VRC 입문하고 싶은데 질문좀 10 젤나타맙소사 2018-08-11 0
39972 일반 랫저댄방 vrc개발자온듯? 7 가사이_유노 2018-08-11 2
39971 일반 유니티에 애니메이션 하나더 만들순없나? 2 ㅁㄴㅇㄹ 125.142 2018-08-11 0
39970 일반 파티클 질문인데 6 sd2 121.168 2018-08-11 0
39969 일반 이 사진 너무 귀엽게 나온듯 검은연 2018-08-11 0
39968 일반 [VRChat 강좌#11] GPU 파티클 적용하기 (데스크탑 모드) 5 5upporter 2018-08-11 20
39967 일반 아니 만들고 싶은건 안만들고 1 Luche 2018-08-11 1
39966 일반 핵쟁이들이 자기 밴당한거 굳이 말해주는거 좋지 않냐. 3 MANKALO 2018-08-11 0
39965 일반 트래커는 내구성 ㅆㅆㅌㅊ아님? 2 댕타 2018-08-11 0
39964 일반 오늘따라 왜이렇게 ㅇㅇ 124.57 2018-08-11 0
39963 일반 슈샘? ㅁㄴㅇㄹ 125.142 2018-08-11 0
39962 일반 안녕 VR챗 핵쟁이 래빗이야~~ 9 ㅇㅇ 121.200 2018-08-11 2
39961 일반 커메 말하게 할수없나..(입구조 ㅂㄷ) 1 래ㅑㅕ2 121.168 2018-08-11 0
39959 일반 거긴 오줌누는 곳이야! 핣으면 안대! 기무대띠 2018-08-11 0
39957 일반 110V 를 220V로 바꾸려는데 도움좀 3 설화눈꽃 2018-08-11 0
39956 일반 으아아아 왜죠 2 저댄조아 2018-08-11 0
39955 일반 아바타 적용했는데 1 q1 2018-08-11 0
39954 일반 사람들이 같이 딴겜 할 사람들 구하니깐 거의다 접네 3 ㅇㅇ 211.36 2018-08-11 0
39953 일반 오늘의 VRC (움짤많음 용량큼) 3 ㅇㅇ 211.246 2018-08-11 2
39952 일반 중고나라 경험자 갑은 나인거 같은데 7 NAME_HORANG 2018-08-11 0
39951 일반 파티클리미터 다들 수치 얼마 쓰냐 3 라그네아 2018-08-11 0
39950 일반 무브봉 적용 실패 후기 10 쿨통 2018-08-11 1
39949 일반 1080ti쓰면 저댄방 20명버틸수있음? 7 울테 2018-08-11 0
39948 일반 저스트댄스 pc 결제 안하고 계속하는법 ㄷㅂㅈㄷㅈㅂ 114.200 2018-08-11 0
39947 일반 나도 풀트래킹 질문좀 7 Gloryman 2018-08-11 0
39946 일반 난 뭐 만드는것도 아니고 친구만드는것도 아닌데 VR챗 왜하지 9 ㅇㅇ 220.93 2018-08-11 0
39945 일반 풀트래킹 문제는 대부분 아바타문제지 1 Luche 2018-08-11 0
39944 일반 풀트래킹 위치 설정하고싶은데 질문을 정리해서 이 글에 씀 13 앵뽀뽀 2018-08-11 0
39943 일반 H방글좀 올려줘 넘궁금해 ㅇㅇ 121.139 2018-08-11 0
39942 일반 갤에 H방글 없는거 처음본다 _감자 2018-08-11 0
념글 삭제글 갤러리 랭킹