In this paper, a 3D wake model considering both axial and radial wind speed variations along the incoming wind direction, and the non-flat topography effect on the wind flow, is developed for the layout optimization of a real onshore wind farm. The effectiveness of two methods (i.e., the discretization method that divides the wind scenario into small intervals and the Monte Carlo method which randomly generates the discrete wind speed samples), for evaluating the overall wind farm power production under the wind speed variation of Weibull distribution is investigated for the comparative study. It is found that the Monte Carlo power evaluation method achieves a better outcome than the traditional discretization method, with more total power output and less computational cost. Through the layout optimization with a total of 15 wind turbines installed, the individual wind turbine yields more than 533 kW power out of 536 kW theoretical wake-free power. As the installed wind turbine number increases, the maximum discrepancy of the actual wind turbine power output with respect to the theoretical power increases from 3 kW (with 15 wind turbines) to 6 kW (with 20 wind turbines). Through the comparative study of different wind rotation scenarios, it is found that the maximum discrepancy of individual actual wind turbine power outputs is 8 kW and 13 kW for a rotational angle of [Formula: see text] and [Formula: see text], respectively. Under the scenario of [Formula: see text] wind rotation scenario, the maximum individual power output deficit with 20 installed wind turbines is around 20 kW and the discrepancy of the total power output by comparing to the baseline wind model is maximally 1% proving the robustness of the optimization results with respect to the wind scenario variation.