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
번호 분류 제목 글쓴이 날짜 추천
43099 일반 커미션 가격이라는게 솔직히 일방적으로 정하는건가 4 SenKaZe 2018-08-21 4
43098 일반 정말 차근차근 발전되고 있네 4 루미아 2018-08-21 0
43097 일반 1050 ti 쓰는친구들있니 8 꿀뚤 2018-08-21 0
43096 일반 커미션 가격이야기 대놓고 못하는거 이런 이유는 없음? 5 엘에르엘 2018-08-21 0
43095 일반 라이더 나올때가 된 것 같은데 2 엘에르엘 2018-08-21 0
43094 일반 커미션은 내가 부르는대로 가격임 5 CHJ. 2018-08-21 2
43093 일반 시간은없고 예쁜건 갖고싶고 1 하벤하이드 2018-08-21 0
43092 일반 난 대체 무엇을 위해 피시방에.... 1 어흑마이갓 2018-08-21 0
43091 일반 프리랜서라는건 기무대띠 2018-08-21 0
43089 일반 퍼블릭월드에 아바타 올린거 대리업로드로 팔아달라면 얼마가 적당한거 같음? 8 ㅇㅇ 211.36 2018-08-21 0
43088 일반 오백원짜리...천원짜리... SenKaZe 2018-08-21 2
43086 일반 시간 아끼려고 커미션 하는것도 있음 3 Luche 2018-08-21 1
43083 일반 프리 '랜서' 러닝머신러닝 2018-08-21 1
43082 일반 천원짜리 커미션 2 Luche 2018-08-21 0
43079 일반 나도 커미션 받고싶은데 내꺼 만지는시간너무 길다 ㅇㅇ 211.36 2018-08-21 0
43078 일반 150만원짜리 트레이싱 3 러프멜 2018-08-21 0
43077 일반 그러니까 츠이타 커뮤라는게 이런거지 2 초보자아 2018-08-21 0
43076 일반 이제는 전설이된 150만원짜리 커미션 6 ㅇㅇ 58.232 2018-08-21 0
43075 일반 이정도면 vr끼고도 ㄱㅊ겠지? 9 SenKaZe 2018-08-21 0
43073 일반 정리해준다 5 어흑마이갓 2018-08-21 0
43072 일반 커미션이라는건 .. 자기만 만족하면 되는거다 ... 8 카디아. 2018-08-21 1
43070 일반 그와중에 뚜따 뚜따 하는거 나만 귀엽냐 1 초보자아 2018-08-21 0
43069 일반 애초에 프리랜서 일이 얼마라고 매기기 애매함 1 ㅇㅇ 220.93 2018-08-21 0
43068 일반 풀바디 아바타랑 아닌 아바타랑 무슨 차이임? 2 ㅇㅇ 183.101 2018-08-21 0
43067 일반 VRChat 데스크톱 유저의 올바른 플레이법 애플치즈 2018-08-21 0
43066 일반 가격 논쟁 이제 그만하셈 4 기무대띠 2018-08-21 0
43065 일반 아니 가족놀이 하는데 면접을 본다고???? 2 초보자아 2018-08-21 0
43063 일반 아 그래서 조회 어떻게 해 2 ㅇㅇ 180.231 2018-08-21 0
43062 일반 커미션 가격 알려주는게 별거냐 80 ㅇㅇ 211.246 2018-08-21 0
43061 일반 이런 풀바디 아바타 만들어 줄수 있는사람? 3 기무대띠 2018-08-21 0
43060 일반 시급으로 줄수도 있잖어 11 러프멜 2018-08-21 2
43059 일반 커미션 가격은 공개해야 한다.... 6 ㅇㅅㅇ 221.153 2018-08-21 2
43058 일반 패드립이 존나당연한 세상 10 dd 175.223 2018-08-21 1
43057 일반 허리트래커 너무튄다 3 사요 2018-08-21 0
43056 일반 다음 업뎃에 아바타 복사핵 대책 생긴다던데 2 Luche 2018-08-21 0
43055 일반 내가 하는 방송 보여주면서 vrc 같이 하는거 가능한가요? 3 열심히는합니다 2018-08-21 0
43054 일반 커미션받을때 걍 깍아주지마 16 꼬마키` 2018-08-21 5
43053 일반 vr컨트롤러 만들기 가능한부분? 7 공돌이빌런 121.164 2018-08-21 0
43051 일반 유니티 업로드 질문이긴 한데... 2134214 121.168 2018-08-21 0
43050 일반 바리안 린 모델파일 있는데 커미션 해줄수 있는사람 있냐 3 기무대띠 2018-08-21 0
념글 삭제글 갤러리 랭킹